X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=build.sh;h=bce3bbd50b35ece1583fbe77767d97a4e9fa4b7c;hb=refs%2Fheads%2Faccepted%2Ftizen_7.0_unified;hp=1c7871007b501354c5cf7aa6d12e5ab123f0aec0;hpb=9d214a6d7bbf569dad8e5ac25e502a42f77a2282;p=platform%2Fcore%2Fcsapi%2Ftizenfx.git diff --git a/build.sh b/build.sh index 1c78710..bce3bbd 100755 --- a/build.sh +++ b/build.sh @@ -1,75 +1,245 @@ -#!/bin/bash +#!/bin/bash -e -SCRIPT_FILE=$(readlink -f $0) -SCRIPT_DIR=$(dirname $SCRIPT_FILE) +SCRIPT_DIR=$(dirname $(readlink -f $0)) +CONFIGURATION=Release +SLN_NAME=_Build +SLN_FILE=$SCRIPT_DIR/$SLN_NAME.sln OUTDIR=$SCRIPT_DIR/Artifacts -RETRY_CMD="$SCRIPT_DIR/tools/retry.sh" -TIMEOUT_CMD="$SCRIPT_DIR/tools/timeout.sh" -DOTNET_CMD="$RETRY_CMD $TIMEOUT_CMD 600 dotnet" +PROFILES=(mobile tv wearable) +TARGET_ASSEMBLY_DIR=/usr/share/dotnet.tizen/framework +TARGET_PRELOAD_DIR=/usr/share/dotnet.tizen/preload -RUN_BUILD="$DOTNET_CMD msbuild $SCRIPT_DIR/build/build.proj /nologo" +source $SCRIPT_DIR/packaging/version.txt +VERSION_PREFIX=$(expr $NUGET_VERSION : '\([0-9]\+\.[0-9]\+\.[0-9]\+\)') usage() { - echo "Usage: %0 [command] [args]" + echo "Usage: $0 [command] [args]" echo "Commands:" echo " build [module] Build a specific module" echo " full Build all modules in src/ directory" + echo " design Build NUI Design module" + echo " xamlbuild Build NUI XamlBuild module" echo " dummy Generate dummy assemblies of all modules" echo " pack [version] Make a NuGet package with build artifacts" + echo " install [target] Install assemblies to the target device" echo " clean Clean all artifacts" } -cmd_build() { +prepare_solution() { + target=$1; [ -z "$target" ] && target="full" + + dotnet new sln -n $SLN_NAME -o $SCRIPT_DIR --force + if [ "$target" == "public" -o "$target" == "full" ]; then + dotnet sln $SLN_FILE add $SCRIPT_DIR/src/*/*.csproj + fi + if [ "$target" == "internal" -o "$target" == "full" ]; then + dotnet sln $SLN_FILE add $SCRIPT_DIR/internals/src/*/*.csproj + fi + if [ "$target" == "design" ]; then + dotnet sln $SLN_FILE add $SCRIPT_DIR/src/*/*.Design.csproj + else + dotnet sln $SLN_FILE remove $SCRIPT_DIR/src/*/*.Design.csproj + fi + if [ "$target" == "xamlbuild" ]; then + dotnet sln $SLN_FILE add $SCRIPT_DIR/src/*/*.XamlBuild.csproj + else + dotnet sln $SLN_FILE remove $SCRIPT_DIR/src/*/*.XamlBuild.csproj + fi +} + +cleanup_solution() { + rm -f $SLN_FILE +} + +remove_intermediates() { + find $1 -type d \ + \( -name obj -o -name bin \) -print0 | xargs -0 -I {} rm -fr "{}" +} + +clean() { + remove_intermediates $SCRIPT_DIR/build/ + remove_intermediates $SCRIPT_DIR/src/ + remove_intermediates $SCRIPT_DIR/internals/src/ + rm -fr $OUTDIR + rm -f msbuild.log + cleanup_solution +} + +restore() { + if [ -d /nuget ]; then + dotnet restore -s /nuget $@ + else + dotnet restore $@ + fi +} + +build() { + dotnet build --no-restore -c $CONFIGURATION /fl $@ +} + +copy_artifacts() { + mkdir -p $2 + for proj in $(ls -d1 $1/*/); do + if [ -d $proj/bin/$CONFIGURATION ]; then + cp -fr $proj/bin/$CONFIGURATION/*/* $2 + fi + done +} + +build_artifacts() { + copy_artifacts $SCRIPT_DIR/src $OUTDIR/bin/public + copy_artifacts $SCRIPT_DIR/internals/src $OUTDIR/bin/internal + + # move preload + mkdir -p $OUTDIR/preload + mv $OUTDIR/bin/public/*.preload $OUTDIR/preload 2>/dev/null || : + mv $OUTDIR/bin/internal/*.preload $OUTDIR/preload 2>/dev/null || : + + # merge filelist + for profile in ${PROFILES[@]}; do + list=$(cat $OUTDIR/bin/public/*.$profile.filelist \ + $OUTDIR/bin/internal/*.$profile.filelist \ + | sort | uniq) + rm -f $OUTDIR/$profile.filelist + for item in $list; do + if [[ "$item" == *.preload ]]; then + echo $TARGET_PRELOAD_DIR/$item >> $OUTDIR/$profile.filelist + else + echo $TARGET_ASSEMBLY_DIR/$item >> $OUTDIR/$profile.filelist + fi + done + done +} + +cmd_module_build() { if [ -z "$1" ]; then echo "No module specified." exit 1 fi - if [ -d /nuget ]; then - NUGET_SOURCE_OPT="/p:RestoreSources=/nuget" - fi - $RUN_BUILD /t:restore /p:Project=$1 $NUGET_SOURCE_OPT - $RUN_BUILD /t:build /p:Project=$1 + module=$1; shift; + sources=(src internals/src) + for src in $sources; do + project=$SCRIPT_DIR/$src/$module/$module.csproj + echo $project + if [ -f "$project" ]; then + restore $project + build $project $@ + fi + done } cmd_full_build() { - if [ -d /nuget ]; then - NUGET_SOURCE_OPT="/p:RestoreSources=/nuget" - fi - $RUN_BUILD /t:clean - $RUN_BUILD /t:restore $NUGET_SOURCE_OPT - $RUN_BUILD /t:build + clean + prepare_solution full + restore $SLN_FILE $@ + build $SLN_FILE $@ + cleanup_solution + build_artifacts + cmd_dummy_build +} + +cmd_design_build() { + prepare_solution design + restore $SLN_FILE + build $SLN_FILE $@ + projects=$(dirname $(ls -1 $SCRIPT_DIR/src/*/*.Design.csproj)) + for proj in $projects; do + if [ -d $proj/bin/$CONFIGURATION ]; then + cp -f $proj/bin/$CONFIGURATION/*/*.Design.dll $SCRIPT_DIR/pkg/Tizen.NET.API*/design/ + fi + done + cleanup_solution +} + +cmd_xamlbuild_build() { + prepare_solution xamlbuild + restore $SLN_FILE + build $SLN_FILE $@ + projects=$(dirname $(ls -1 $SCRIPT_DIR/src/*/*.XamlBuild.csproj)) + for proj in $projects; do + if [ -d $proj/bin/$CONFIGURATION ]; then + cp -f $proj/bin/$CONFIGURATION/*/*.XamlBuild.dll $SCRIPT_DIR/pkg/Tizen.NET.API*/xamlbuild/ + fi + done + cleanup_solution } cmd_dummy_build() { - if [ -d /nuget ]; then - NUGET_SOURCE_OPT="/p:RestoreSources=/nuget" + if [ ! -d $OUTDIR/bin/public/ref ]; then + echo "No assemblies to read. Build TizenFX first." + exit 1 fi - $RUN_BUILD /t:dummy $NUGET_SOURCE_OPT - $RUN_BUILD /t:afterdummy + mkdir -p $OUTDIR/bin/dummy + dotnet $SCRIPT_DIR/tools/bin/APITool.dll \ + dummy $OUTDIR/bin/public/ref $OUTDIR/bin/dummy } cmd_pack() { VERSION=$1 if [ -z "$VERSION" ]; then - TIMESTAMP=$(date +"%s") - VERSION="5.0.0-local-$TIMESTAMP" + pushd $SCRIPT_DIR > /dev/null + VERSION=$VERSION_PREFIX.$((10000+$(git rev-list --count HEAD))) + popd > /dev/null fi - $RUN_BUILD /t:pack /p:Version=$VERSION + restore $SCRIPT_DIR/build/pack.csproj + nuspecs=$(find $SCRIPT_DIR/pkg/ -name "*.nuspec") + for nuspec in $nuspecs; do + dotnet pack --no-restore --no-build --nologo -o $OUTDIR \ + $SCRIPT_DIR/build/pack.csproj \ + /p:Version=$VERSION \ + /p:NuspecFile=$(readlink -f $nuspec) + done } -cmd_clean() { - $RUN_BUILD /t:clean +cmd_install() { + DEVICE_ID=$1 + + RUNTIME_ASSEMBLIES="$OUTDIR/bin/public/*.dll $OUTDIR/bin/internal/*.dll" + + device_cnt=$(sdb devices | grep -v "List" | wc -l) + + if [ $device_cnt -eq 0 ]; then + echo "No connected devices" + exit 1 + fi + + if [ $device_cnt -gt 1 ] && [ -z "$DEVICE_ID" ]; then + echo "Multiple devices are connected. Specify the device. (ex: ./build.sh install [device-id])" + sdb devices + exit 1 + fi + + SDB_OPTIONS="" + if [ -n "$DEVICE_ID" ]; then + SDB_OPTIONS="-s $DEVICE_ID" + fi + + sdb $SDB_OPTIONS root on + sdb $SDB_OPTIONS shell mount -o remount,rw / + sdb $SDB_OPTIONS push $RUNTIME_ASSEMBLIES $TARGET_ASSEMBLY_DIR + + nifile_cnt=$(sdb $SDB_OPTIONS shell find $TARGET_ASSEMBLY_DIR -name '*.ni.dll' | wc -l) + if [ $nifile_cnt -gt 0 ]; then + sdb $SDB_OPTIONS shell "rm -f $TARGET_ASSEMBLY_DIR/*.ni.dll" + sdb $SDB_OPTIONS shell dotnettool --ni-system + sdb $SDB_OPTIONS shell dotnettool --ni-regen-all-app + fi + + sdb $SDB_OPTIONS shell chsmack -a '_' $TARGET_ASSEMBLY_DIR/* } -cmd=$1; shift; +cmd=$1; [ $# -gt 0 ] && shift; case "$cmd" in - build|--build|-b) cmd_build $@ ;; + build|--build|-b) cmd_module_build $@ ;; full |--full |-f) cmd_full_build $@ ;; + design|--design) cmd_design_build $@ ;; + xamlbuild|--xamlbuild) cmd_xamlbuild_build $@ ;; dummy|--dummy|-d) cmd_dummy_build $@ ;; pack |--pack |-p) cmd_pack $@ ;; - clean|--clean|-c) cmd_clean $@ ;; + install |--install |-i) cmd_install $@ ;; + clean|--clean|-c) clean ;; *) usage ;; esac