-
Notifications
You must be signed in to change notification settings - Fork 24
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added wasi-sdk flow #307
Added wasi-sdk flow #307
Changes from 31 commits
ad1ca5e
426b8ff
2525da0
a0cb465
17beb4d
3f2da6c
f38f521
915bc84
90c071d
b1ed769
d5fd0ef
a4b8734
a536b93
bf0e0aa
a443d2c
3f15161
2b441a6
a8e96b4
32e532b
f244f8b
4ab7653
d717f61
2955160
24885c9
1f7ff41
a7d2c77
40a1e89
605ef11
1163a29
1b926d9
ea55666
17e2613
30a53d9
3036bc2
ca26058
e435609
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,16 @@ | ||
if [[ "$__TargetOS" == Browser ]]; then | ||
EMSDK_PATH=$PWD/artifacts/emsdk | ||
rm -rf $EMSDK_PATH | ||
git clone https://github.com/emscripten-core/emsdk.git $EMSDK_PATH | ||
EMSCRIPTEN_VERSION="`cat ./.devcontainer/emscripten-version.txt 2>&1`" | ||
cd $EMSDK_PATH && ./emsdk install $EMSCRIPTEN_VERSION | ||
cd $EMSDK_PATH && ./emsdk activate $EMSCRIPTEN_VERSION | ||
# ready to build, e.g.: | ||
# ./build.sh /p:TargetOS=Browser /p:TargetArchitecture=wasm /p:IcuTracing=true | ||
# ./build.sh /p:TargetOS=Browser /p:TargetArchitecture=wasm /p:IcuTracing=true | ||
elif [[ "$__TargetOS" == Wasi ]]; then | ||
WASI_SDK_PATH=$PWD/artifacts/wasi-sdk | ||
rm -rf $WASI_SDK_PATH | ||
git clone https://github.com/WebAssembly/wasi-sdk.git $WASI_SDK_PATH | ||
# ready to build, e.g.: | ||
# ./build.sh /p:TargetOS=Wasi /p:TargetArchitecture=wasm /p:IcuTracing=true | ||
fi |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,7 @@ | ||
<Project> | ||
<Target Name="Build" Condition="'$(PackOnly)' != 'true'" DependsOnTargets="PatchEmscripten;CopyEmscriptenVersion"> | ||
<Import Project="$(RepositoryEngineeringDir)Versions.props" /> | ||
|
||
<Target Name="Build" Condition="'$(PackOnly)' != 'true'" DependsOnTargets="PatchEmscripten;CopyEmscriptenVersion;PatchWasiSdk"> | ||
<Error Condition="'$(TargetOS)' == ''" Text="TargetOS needs to be specified!" /> | ||
<Error Condition="'$(TargetArchitecture)' == ''" Text="TargetArchitecture needs to be specified!" /> | ||
|
||
|
@@ -10,7 +12,7 @@ | |
<Copy SourceFiles="$(MSBuildThisFileDirectory)\..\icu-filters\curr-root.txt" | ||
DestinationFiles="$(MSBuildThisFileDirectory)\..\icu\icu4c\source\data\curr\root.txt"/> | ||
<Exec WorkingDirectory="$(MSBuildThisFileDirectory)" | ||
Command="make -f icu.mk all TARGET_OS=$(TargetOS.ToLower()) TARGET_ARCHITECTURE=$(TargetArchitecture) ICU_TRACING=$(IcuTracing) $(_ExtraParams) SHELL=/bin/bash" | ||
Command="make -f icu.mk all TARGET_OS=$(TargetOS.ToLower()) TARGET_ARCHITECTURE=$(TargetArchitecture) ICU_TRACING=$(IcuTracing) WASI_SDK_PATH=$(RepoRoot)artifacts/wasi-sdk $(_ExtraParams) SHELL=/bin/bash" | ||
IgnoreStandardErrorWarningFormat="true" /> | ||
</Target> | ||
<Target Name="Restore" /> | ||
|
@@ -37,4 +39,18 @@ | |
Lines="@(_ItemsFromEmscriptenVersionFile->Replace('"', ''))" | ||
Overwrite="true" /> | ||
</Target> | ||
<Target Name="PatchWasiSdk" Condition="'$(TargetOS)' == 'Wasi'"> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please rename to There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Updated, now it will download wasi sdk only when needed. |
||
<PropertyGroup> | ||
<_WasiLocalPath>$(RepoRoot)\artifacts</_WasiLocalPath> | ||
<_WasiSdkUrl Condition="$([MSBuild]::IsOSPlatform('Linux'))">https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-$(WasiSdkVersion)/wasi-sdk-$(WasiSdkVersion).0-linux.tar.gz</_WasiSdkUrl> | ||
<_WasiSdkUrl Condition="$([MSBuild]::IsOSPlatform('OSX'))">https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-$(WasiSdkVersion)/wasi-sdk-$(WasiSdkVersion).0-macos.tar.gz</_WasiSdkUrl> | ||
</PropertyGroup> | ||
|
||
<Error Condition="'$(_WasiSdkUrl)' == ''" Text="_WasiSdkUrl is not set!" /> | ||
|
||
<Exec Command="rm -rf wasi-sdk-*/ wasi-sdk/ && curl -L -o- $(_WasiSdkUrl) --fail -S | tar -xvz && mv wasi-sdk-$(WasiSdkVersion).*/ wasi-sdk/" | ||
WorkingDirectory="$(_WasiLocalPath)" | ||
IgnoreStandardErrorWarningFormat="true" /> | ||
|
||
</Target> | ||
</Project> |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
# TODO: add other host platform/arch combinations | ||
UNAME_S := $(shell uname -s) | ||
UNAME_M := $(shell uname -m) | ||
UNAME_R := $(shell uname -r) | ||
|
||
ifeq ($(UNAME_S),Linux) | ||
HOST_PLATFORM=x86_64-pc-linux-gnu | ||
endif | ||
ifeq ($(UNAME_S),Darwin) | ||
ifeq ($(UNAME_M),arm64) | ||
HOST_PLATFORM=arm64-apple-darwin$(UNAME_R) | ||
endif | ||
ifeq ($(UNAME_M),x86_64) | ||
HOST_PLATFORM=x86_64-apple-darwin$(UNAME_R) | ||
endif | ||
endif | ||
ifeq ($(WASM_ENABLE_THREADS),true) | ||
pavelsavara marked this conversation as resolved.
Show resolved
Hide resolved
|
||
THREADS_FLAG="-pthread" | ||
endif | ||
|
||
CONFIGURE_COMPILER_FLAGS += \ | ||
CFLAGS="-Oz -fno-exceptions -Wno-sign-compare $(THREADS_FLAG) $(ICU_DEFINES)" \ | ||
CXXFLAGS="-Oz -fno-exceptions -Wno-sign-compare $(THREADS_FLAG) $(ICU_DEFINES)" \ | ||
CC="$(WASI_SDK_PATH)/bin/clang --sysroot=$(WASI_SDK_PATH)/share/wasi-sysroot" \ | ||
CXX="$(WASI_SDK_PATH)/bin/clang++ --sysroot=$(WASI_SDK_PATH)/share/wasi-sysroot" \ | ||
--host=$(HOST_PLATFORM) --build=wasm32 | ||
|
||
check-env: | ||
: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For a future PR: This
Publish Packages
job should run for PRs too, and generate the packages, but skip the publishing part itself. This would ensure that the PR doesn't break packaging.