diff --git a/.appveyor.yml b/.appveyor.yml deleted file mode 100644 index db8de0236f..0000000000 --- a/.appveyor.yml +++ /dev/null @@ -1,198 +0,0 @@ -environment: - matrix: - # Main VM variants - - FLAVOR: squeak.cog.spur - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: squeak.cog.spur - ARCH: win64x64 - CYG_ROOT: C:\cygwin64 - MINGW_ARCH: x86_64 - - FLAVOR: pharo.cog.spur - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: pharo.cog.spur - ARCH: win64x64 - CYG_ROOT: C:\cygwin64 - MINGW_ARCH: x86_64 - - # Main minheadless VM variants. - - FLAVOR: squeak.cog.spur.minheadless - ARCH: win32x86 - CPU_ARCH: x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - BUILD_WITH_CMAKE: yes - # - FLAVOR: squeak.cog.spur - # ARCH: win64x64 - # CPU_ARCH: x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - # BUILD_WITH_CMAKE: yes - - FLAVOR: pharo.cog.spur.minheadless - ARCH: win32x86 - CPU_ARCH: x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - BUILD_WITH_CMAKE: yes - # - FLAVOR: pharo.cog.spur - # ARCH: win64x64 - # CPU_ARCH: x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - # BUILD_WITH_CMAKE: yes - - # Minheadless VM variants with SDL2 based support for traditional display. - # - FLAVOR: squeak.cog.spur+sdl2 - # ARCH: win32x86 - # CPU_ARCH: x86 - # CYG_ROOT: C:\cygwin - # MINGW_ARCH: i686 - # BUILD_WITH_CMAKE: yes - # - FLAVOR: squeak.cog.spur+sdl2 - # ARCH: win64x64 - # CPU_ARCH: x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - # BUILD_WITH_CMAKE: yes - # - FLAVOR: pharo.cog.spur+sdl2 - # ARCH: win32x86 - # CPU_ARCH: x86 - # CYG_ROOT: C:\cygwin - # MINGW_ARCH: i686 - # BUILD_WITH_CMAKE: yes - # - FLAVOR: pharo.cog.spur+sdl2 - # ARCH: win64x64 - # CPU_ARCH: x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - # BUILD_WITH_CMAKE: yes - - # Other VM variants - - FLAVOR: squeak.sista.spur - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: squeak.cog.spur.lowcode - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: squeak.cog.v3 - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: squeak.stack.spur - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: squeak.stack.v3 - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: pharo.sista.spur - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - - FLAVOR: pharo.cog.spur.lowcode - ARCH: win32x86 - CYG_ROOT: C:\cygwin - MINGW_ARCH: i686 - # - FLAVOR: newspeak.cog.spur - # ARCH: win32x86 - # CYG_ROOT: C:\cygwin - # MINGW_ARCH: i686 - # - FLAVOR: newspeak.stack.spur - # ARCH: win32x86 - # CYG_ROOT: C:\cygwin - # MINGW_ARCH: i686 - # - FLAVOR: pharo.sista.spur - # ARCH: win64x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - # - FLAVOR: newspeak.cog.spur - # ARCH: win64x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - - FLAVOR: squeak.stack.spur - ARCH: win64x64 - CYG_ROOT: C:\cygwin64 - MINGW_ARCH: x86_64 - # - FLAVOR: pharo.stack.spur - # ARCH: win64x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - # - FLAVOR: newspeak.stack.spur - # ARCH: win64x64 - # CYG_ROOT: C:\cygwin64 - # MINGW_ARCH: x86_64 - - -matrix: - fast_finish: true - allow_failures: - - FLAVOR: squeak.cog.spur.minheadless - - FLAVOR: pharo.cog.spur.minheadless - - FLAVOR: squeak.sista.spur - - FLAVOR: pharo.sista.spur - - FLAVOR: squeak.cog.spur.lowcode - - FLAVOR: pharo.cog.spur.lowcode - -notifications: - - provider: Email - to: - - vm-dev@lists.squeakfoundation.org - on_build_success: false - -platform: - - x86 - -clone_depth: 5 - -cache: - - .thirdparty-cache - -install: - # Search for [appveyor skip], [skip appveyor], [skip ci] or [ci skip] and exit if found in full commit message - - ps: $commit=$env:APPVEYOR_REPO_COMMIT_MESSAGE + $env:APPVEYOR_REPO_COMMIT_MESSAGE_EXTENDED - - ps: If ($commit.Contains("[skip appveyor]") -Or $commit.Contains("[appveyor skip]")) { Exit-AppVeyorBuild } - - ps: $commit=$env:APPVEYOR_REPO_COMMIT_MESSAGE + $env:APPVEYOR_REPO_COMMIT_MESSAGE_EXTENDED - - ps: If ($commit.Contains("[skip ci]") -Or $commit.Contains("[ci skip]")) { Exit-AppVeyorBuild } - - 'curl -fsSL --retry 4 -m 600 -o "setup-x86.exe" "http://cygwin.com/setup-x86.exe" ' - - 'curl -fsSL --retry 4 -m 600 -o "setup-x86_64.exe" "http://cygwin.com/setup-x86_64.exe" ' - - 'call scripts/installCygwin.bat %MINGW_ARCH% "%CYG_ROOT%"' - -# Cygwin build script -# -# NOTES: -# -# The stdin/stdout file descriptor appears not to be valid for the Appveyor -# build which causes failures as certain functions attempt to redirect -# default file handles. Ensure a dummy file descriptor is opened with 'exec'. -build_script: - - '%CYG_ROOT%\bin\bash -lc "cd $APPVEYOR_BUILD_FOLDER; exec 0> $GITHUB_ENV + echo "ASSET_NAME=${{ steps.build-vm.outputs.ASSET_NAME }}" >> $GITHUB_ENV + echo "PRODUCTS_PATH=${{ steps.build-vm.outputs.PRODUCTS_PATH }}" >> $GITHUB_ENV + echo "APP_NAME=${{ steps.build-vm.outputs.APP_NAME }}" >> $GITHUB_ENV + + - name: Sign VM (not implemented) + if: false + run: ./deploy/sign-vm.sh + + - name: Pack VM + run: ./deploy/pack-vm.sh + + - name: Store artifact w/ revision + uses: actions/upload-artifact@v2 + with: + name: ${{ env.ASSET_NAME }}_${{ env.ASSET_REVISION }} + path: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + + - name: Update artifact in latest-release + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'push' && endsWith( github.ref , 'Cog' ) + with: + prerelease: true + allowUpdates: true + replacesArtifacts: true + artifacts: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ matrix.mode == 'debug' && 'latest-debug-build' || matrix.mode == 'assert' && 'latest-assert-build' || 'latest-build' }} + body: ${{ github.event.head_commit.message }} diff --git a/.github/workflows/extra.yml b/.github/workflows/extra.yml new file mode 100644 index 0000000000..bddaa3af1e --- /dev/null +++ b/.github/workflows/extra.yml @@ -0,0 +1,105 @@ +name: Extra Monthly Builds + +on: + schedule: + - cron: '0 0 1 * *' # Build on the 1st of every month at midnight + workflow_dispatch: + inputs: + should-deploy: + description: 'Deploy on success' + required: true + default: "true" # No boolean support at the moment + + +jobs: + build: + strategy: + fail-fast: false # let them finish bc. different platforms + matrix: + arch: + - { name: win64x64, os: windows-latest } + - { name: win32x86, os: windows-latest } + - { name: linux64x64, os: ubuntu-latest } + - { name: linux32x86, os: ubuntu-latest } + - { name: macos64x64, os: macos-latest } + # - { name: macos32x86, os: macos-latest } + + flavor: + # Only newsqueak.* builds are fully prepared for all platforms + - newspeak.cog.spur + - newspeak.stack.spur + + include: + - arch: { name: win32x86, os: windows-latest } + flavor: squeak.cog.v3 + - arch: { name: win32x86, os: windows-latest } + flavor: squeak.stack.v3 + - arch: { name: win32x86, os: windows-latest } + flavor: squeak.cog.spur.lowcode + # - arch: { name: win32x86, os: windows-latest } + # flavor: pharo.cog.spur.lowcode + + - arch: { name: linux32x86, os: ubuntu-latest } + flavor: squeak.cog.v3 + - arch: { name: linux32x86, os: ubuntu-latest } + flavor: squeak.stack.v3 + - arch: { name: linux32x86, os: ubuntu-latest } + flavor: pharo.cog.spur.lowcode + - arch: { name: linux32x86, os: ubuntu-latest } + flavor: pharo.stack.spur.lowcode + + # - arch: { name: macos64x64, os: macos-latest } + # flavor: pharo.cog.spur.lowcode # impl. decl. getThisSessionID + - arch: { name: macos64x64, os: macos-latest } + flavor: pharo.stack.spur.lowcode + + runs-on: ${{ matrix.arch.os }} + name: ${{ matrix.flavor }} for ${{ matrix.arch.name }} + env: + ARCH: ${{ matrix.arch.name }} + FLAVOR: ${{ matrix.flavor }} + MODE: fast # no assert or debug here + HEARTBEAT: threaded # linux only; no itimer here + MSYS_SYS: ${{ matrix.arch.name == 'win64x64' && 'mingw64' || 'mingw32' }} + MSYS_ENV: ${{ matrix.arch.name == 'win64x64' && 'x86_64' || 'i686' }} + steps: + - name: Checkout files + uses: actions/checkout@v2 + # with: + # ref: ${{ github.event_name == 'workflow_dispatch' && github.event.inputs.ref || 'refs/heads/Cog'}} + + - name: Restore build cache + uses: actions/cache@v2 + with: + path: .thirdparty-cache + key: ${{ startsWith(matrix.arch.name, 'win') && 'thirdparty-cache-win' || startsWith(matrix.arch.name, 'linux') && 'thirdparty-cache-linux' || 'thirdparty-cache-macos' }} + + - name: Prepare environment + if: startsWith(matrix.arch.name, 'linux') + run: ./scripts/ci/actions_prepare_linux_x86.sh + + - name: Build VM + shell: bash + run: ./scripts/ci/actions_build.sh + + - name: Pack VM + shell: bash + run: ./deploy/pack-vm.sh + + - name: Store artifact w/ revision + uses: actions/upload-artifact@v2 + with: + name: ${{ env.ASSET_NAME }}_${{ env.ASSET_REVISION }} + path: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + + - name: Update artifact in latest-build + uses: ncipollo/release-action@v1.8.6 + if: github.event.inputs.should-deploy == 'true' && endsWith( github.ref , 'Cog' ) + with: + prerelease: true + allowUpdates: true + replacesArtifacts: true + artifacts: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ matrix.mode == 'debug' && 'latest-debug-build' || matrix.mode == 'assert' && 'latest-assert-build' || 'latest-build' }} + body: ${{ github.event.head_commit.message }} diff --git a/.github/workflows/linux-arm.yml b/.github/workflows/linux-arm.yml new file mode 100644 index 0000000000..0a008eabf7 --- /dev/null +++ b/.github/workflows/linux-arm.yml @@ -0,0 +1,142 @@ +name: Build for Linux (ARM) + +on: + push: # All branches, but appropriate paths only. + paths: + # This workflow spec and its support scripts + - '.github/workflows/linux-arm.yml' + - 'scripts/ci/*linux_arm.sh' + - 'scripts/ci/*build.sh' + - 'deploy/**' + # Relevant sources for this platform + - 'build.linux*/**' # Makefile-based build scripts + - '*src/**' # Generated VMMaker sources (incl. plugins) + - 'platforms/Cross/**' + - 'platforms/unix/**' + # Skip changes in documentation artifacts + - '!**.md' + - '!**HowToBuild' + pull_request: + branches: + - Cog + paths-ignore: + - '**.md' + - '**HowToBuild' + workflow_dispatch: + inputs: + tag: + description: "Build new release candidate for tag" + required: true + default: YYYYMMDDHHMM + +jobs: + build: + strategy: + fail-fast: false # let them finish bc. mixed platforms + matrix: + arch: + - linux32ARMv6 + # - linux32ARMv7 # Newspeak only, see "extra-arm" workflow + - linux64ARMv8 + flavor: + - squeak.cog.spur + - squeak.stack.spur + mode: + - fast + - debug + - assert + + runs-on: ubuntu-latest + name: ${{ matrix.flavor }} for ${{ matrix.arch }}${{ matrix.mode == 'debug' && ' (DEBUG)' || matrix.mode == 'assert' && ' (ASSERT)' || '' }} + env: + ARCH: ${{ matrix.arch }} + ARCH_ARM: ${{ matrix.arch == 'linux32ARMv6' && 'armv6' || matrix.arch == 'linux32ARMv7' && 'armv7' || 'aarch64' }} + FLAVOR: ${{ matrix.flavor }} + MODE: ${{ matrix.mode }} + HEARTBEAT: threaded # itimer not supported + steps: + - name: Checkout files + if: github.event_name != 'workflow_dispatch' + uses: actions/checkout@v2 + + - name: Checkout files for new release candidate + if: github.event_name == 'workflow_dispatch' + uses: actions/checkout@v2 + with: + ref: refs/tags/${{ github.event.inputs.tag }} + + # TODO: Can we use the same thirdparty cache for armv6, armv7, and aarch64? Are pre-compiled binaries compatible or organized differently? + - name: Restore build cache + uses: actions/cache@v2 + with: + path: .thirdparty-cache + key: thirdparty-cache-linux-${{ env.ARCH_ARM }} + + # https://github.com/marketplace/actions/run-on-architecture + - name: Build VM + uses: uraimo/run-on-arch-action@v2.1.1 + id: build-vm + with: + arch: ${{ env.ARCH_ARM }} + distro: buster + + #TODO: Somehow use ./scripts/ci/actions_prepare_linux_arm.sh + #SEE: https://github.com/uraimo/run-on-arch-action/issues/54 + install: | + apt update -y + apt install -yq --no-install-suggests --no-install-recommends build-essential git devscripts uuid-dev libcairo2-dev libpango1.0-dev libgl1-mesa-dev libgl1-mesa-glx libssl-dev libevdev-dev m4 libpulse-dev libasound2-dev libfreetype6-dev libx11-dev libxrender-dev libtool automake autoconf libltdl-dev + + env: | # Copy the entire environment for the docker container + ARCH: ${{ env.ARCH }} + ARCH_ARM: ${{ env.ARCH_ARM }} + FLAVOR: ${{ env.FLAVOR }} + MODE: ${{ env.MODE }} + HEARTBEAT: ${{ env.HEARTBEAT }} + + run: ./scripts/ci/actions_build.sh + + - name: Post Build VM + #TODO: https://github.com/uraimo/run-on-arch-action/issues/52 + run: | + sudo chown -R runner ${{ steps.build-vm.outputs.PRODUCTS_PATH }} + echo "ASSET_REVISION=${{ steps.build-vm.outputs.ASSET_REVISION }}" >> $GITHUB_ENV + echo "ASSET_NAME=${{ steps.build-vm.outputs.ASSET_NAME }}" >> $GITHUB_ENV + echo "PRODUCTS_PATH=${{ steps.build-vm.outputs.PRODUCTS_PATH }}" >> $GITHUB_ENV + echo "APP_NAME=${{ steps.build-vm.outputs.APP_NAME }}" >> $GITHUB_ENV + + - name: Sign VM (not implemented) + if: false + run: ./deploy/sign-vm.sh + + - name: Pack VM + run: ./deploy/pack-vm.sh + + - name: Store artifact w/ revision + uses: actions/upload-artifact@v2 + with: + name: ${{ env.ASSET_NAME }}_${{ env.ASSET_REVISION }} + path: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + + - name: Update artifact in latest-release + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'push' && endsWith( github.ref , 'Cog' ) + with: + prerelease: true + allowUpdates: true + replacesArtifacts: true + artifacts: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ matrix.mode == 'debug' && 'latest-debug-build' || matrix.mode == 'assert' && 'latest-assert-build' || 'latest-build' }} + body: ${{ github.event.head_commit.message }} + + - name: Deploy artifact as new release candidate + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'workflow_dispatch' + with: + prerelease: true # release candidate + allowUpdates: true + replacesArtifacts: true + artifacts: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ github.event.inputs.tag }} + body: ${{ github.event.head_commit.message }} diff --git a/.github/workflows/linux.yml b/.github/workflows/linux.yml new file mode 100644 index 0000000000..3b76ec2f4b --- /dev/null +++ b/.github/workflows/linux.yml @@ -0,0 +1,137 @@ +name: Build for Linux (x86) + +on: + push: # All branches, but appropriate paths only. + paths: + # This workflow spec and its support scripts + - '.github/workflows/linux.yml' + - 'scripts/ci/*linux_x86.sh' + - 'scripts/ci/*build.sh' + - 'deploy/**' + # Relevant sources for this platform + - 'build.linux*/**' # Makefile-based build scripts + - '*src/**' # Generated VMMaker sources (incl. plugins) + - 'platforms/Cross/**' + - 'platforms/unix/**' + # Skip changes in documentation artifacts + - '!**.md' + - '!**HowToBuild' + pull_request: + branches: + - Cog + paths-ignore: + - '**.md' + - '**HowToBuild' + workflow_dispatch: + inputs: + tag: + description: "Build new release candidate for tag" + required: true + default: YYYYMMDDHHMM + +jobs: + build: + strategy: + fail-fast: true + matrix: + arch: + - linux64x64 + - linux32x86 + flavor: + - squeak.cog.spur + - pharo.cog.spur + # - pharo.stack.spur # build not prepared + heartbeat: + - threaded + - itimer + mode: + - fast + - debug + - assert + include: + # sista build not fully prepared for linux64x64, so only choose selected configurations for linux32x86 + - arch: linux32x86 + flavor: squeak.sista.spur + heartbeat: threaded + mode: fast + - arch: linux32x86 + flavor: pharo.sista.spur + heartbeat: threaded + mode: fast + # squeak.stack.spur builds are not prepared for itimer + - arch: linux64x64 + flavor: squeak.stack.spur + heartbeat: threaded + mode: fast + - arch: linux32x86 + flavor: squeak.stack.spur + heartbeat: threaded + mode: fast + + runs-on: ubuntu-latest + name: ${{ matrix.flavor }}${{ matrix.heartbeat == 'itimer' && ' (itimer)' || '' }} for ${{ matrix.arch }}${{ matrix.mode == 'debug' && ' (DEBUG)' || matrix.mode == 'assert' && ' (ASSERT)' || '' }} + env: + ARCH: ${{ matrix.arch }} + FLAVOR: ${{ matrix.flavor }} + MODE: ${{ matrix.mode }} + steps: + - name: Checkout files + if: github.event_name != 'workflow_dispatch' + uses: actions/checkout@v2 + + - name: Checkout files for new release candidate + if: github.event_name == 'workflow_dispatch' + uses: actions/checkout@v2 + with: + ref: refs/tags/${{ github.event.inputs.tag }} + + - name: Restore build cache + uses: actions/cache@v2 + with: + path: .thirdparty-cache + key: thirdparty-cache-linux + + - name: Prepare environment + run: ./scripts/ci/actions_prepare_linux_x86.sh + + - name: Build VM + run: ./scripts/ci/actions_build.sh + env: + HEARTBEAT: ${{ matrix.heartbeat }} + + - name: Sign VM (not implemented) + if: false + run: ./deploy/sign-vm.sh + + - name: Pack VM + run: ./deploy/pack-vm.sh + + - name: Store artifact w/ revision + uses: actions/upload-artifact@v2 + with: + name: ${{ env.ASSET_NAME }}_${{ env.ASSET_REVISION }} + path: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + + - name: Update artifact in latest-build + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'push' && endsWith( github.ref , 'Cog' ) + with: + prerelease: true + allowUpdates: true + replacesArtifacts: true + artifacts: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ matrix.mode == 'debug' && 'latest-debug-build' || matrix.mode == 'assert' && 'latest-assert-build' || 'latest-build' }} + body: ${{ github.event.head_commit.message }} + + - name: Deploy artifact as new release candidate + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'workflow_dispatch' + with: + prerelease: true # release candidate + allowUpdates: true + replacesArtifacts: true + artifacts: ${{ env.PRODUCTS_PATH }}/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ github.event.inputs.tag }} + body: ${{ github.event.head_commit.message }} diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml new file mode 100644 index 0000000000..da41310de7 --- /dev/null +++ b/.github/workflows/macos.yml @@ -0,0 +1,122 @@ +name: Build for macOS + +on: + push: # All branches, but appropriate paths only. + paths: + # This workflow spec and its support scripts + - '.github/workflows/macos.yml' + - 'scripts/ci/*build.sh' + - 'deploy/**' + # Relevant sources for this platform + - 'build.macos*/**' # Makefile-based build scripts + - '*src/**' # Generated VMMaker sources (incl. plugins) + - 'platforms/Cross/**' + - 'platforms/iOS/**' # Note that 'platforms/Mac OS' is deprecated + # Skip changes in documentation artifacts + - '!**.md' + - '!**HowToBuild' + pull_request: + branches: + - Cog + paths-ignore: + - '**.md' + - '**HowToBuild' + workflow_dispatch: + inputs: + tag: + description: "Build new release candidate for tag" + required: true + default: YYYYMMDDHHMM + +jobs: + build: + strategy: + fail-fast: true + matrix: + arch: + - macos64x64 + # - macos32x86 # Might be deprecated in general + flavor: + - squeak.cog.spur + # - squeak.sista.spur # -Werror bc. decl. missing + - squeak.stack.spur + - pharo.cog.spur + # - pharo.sista.spur # -Werror bc. decl. missing + - pharo.stack.spur + mode: + - fast + - debug + - assert + + runs-on: macos-latest + name: ${{ matrix.flavor }} for ${{ matrix.arch }}${{ matrix.mode == 'debug' && ' (DEBUG)' || matrix.mode == 'assert' && ' (ASSERT)' || '' }} + env: + ARCH: ${{ matrix.arch }} + FLAVOR: ${{ matrix.flavor }} + MODE: ${{ matrix.mode }} + steps: + - name: Checkout files + if: github.event_name != 'workflow_dispatch' + uses: actions/checkout@v2 + + - name: Checkout files for new release candidate + if: github.event_name == 'workflow_dispatch' + uses: actions/checkout@v2 + with: + ref: refs/tags/${{ github.event.inputs.tag }} + + - name: Restore build cache + uses: actions/cache@v2 + with: + path: .thirdparty-cache + key: thirdparty-cache-macos + + - name: Build VM + run: ./scripts/ci/actions_build.sh + + - name: Sign VM + continue-on-error: true # Save unsigned build artifacts + run: ./deploy/sign-vm.sh + env: + SQUEAK_SIGN_PASSWORD: ${{ secrets.SQUEAK_SIGN_PASSWORD }} + SQUEAK_CERT_PASSWORD: ${{ secrets.SQUEAK_CERT_PASSWORD }} + SQUEAK_SIGN_IDENTITY: ${{ secrets.SQUEAK_SIGN_IDENTITY }} + PHARO_SIGN_PASSWORD: ${{ secrets.PHARO_SIGN_PASSWORD }} + PHARO_CERT_PASSWORD: ${{ secrets.PHARO_CERT_PASSWORD }} + PHARO_SIGN_IDENTITY: ${{ secrets.PHARO_SIGN_IDENTITY }} + NEWSPEAK_SIGN_PASSWORD: ${{ secrets.NEWSPEAK_SIGN_PASSWORD }} + NEWSPEAK_CERT_PASSWORD: ${{ secrets.NEWSPEAK_CERT_PASSWORD }} + NEWSPEAK_SIGN_IDENTITY: ${{ secrets.NEWSPEAK_SIGN_IDENTITY }} + + - name: Pack VM + run: ./deploy/pack-vm.sh + + - name: Store artifact w/ revision + uses: actions/upload-artifact@v2 + with: + name: ${{ env.ASSET_NAME }}_${{ env.ASSET_REVISION }} + path: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + + - name: Update artifact in latest-build + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'push' && endsWith( github.ref , 'Cog' ) + with: + prerelease: true + allowUpdates: true + replacesArtifacts: true + artifacts: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ matrix.mode == 'debug' && 'latest-debug-build' || matrix.mode == 'assert' && 'latest-assert-build' || 'latest-build' }} + body: ${{ github.event.head_commit.message }} + + - name: Deploy artifact as new release candidate + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'workflow_dispatch' + with: + prerelease: true # release candidate + allowUpdates: true + replacesArtifacts: true + artifacts: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ github.event.inputs.tag }} + body: ${{ github.event.head_commit.message }} diff --git a/.github/workflows/win.yml b/.github/workflows/win.yml new file mode 100644 index 0000000000..f8eee3144b --- /dev/null +++ b/.github/workflows/win.yml @@ -0,0 +1,129 @@ +name: Build for Windows + +on: + push: # All branches, but appropriate paths only. + paths: + # This workflow spec and its support scripts + - '.github/workflows/win.yml' + - 'scripts/ci/*msys.sh' + - 'scripts/ci/*build.sh' + - 'deploy/**' + # Relevant sources for this platform + - 'build.win*/**' # Makefile-based build scripts + - '*src/**' # Generated VMMaker sources (incl. plugins) + - 'platforms/Cross/**' + - 'platforms/win32/**' + # Skip changes in documentation artifacts + - '!**.md' + - '!**HowToBuild' + pull_request: + branches: + - Cog + paths-ignore: + - '**.md' + - '**HowToBuild' + workflow_dispatch: + inputs: + tag: + description: "Build new release candidate for tag" + required: true + default: YYYYMMDDHHMM + + +jobs: + build: + strategy: + fail-fast: true + matrix: + arch: + - win64x64 + - win32x86 + flavor: + - squeak.cog.spur + - squeak.stack.spur + # - pharo.cog.spur # third-party not yet working + # - pharo.stack.spur # third-party not yet working + mode: + - fast + - debug + - assert + include: + # sista build not fully prepared for win64x64, so only your selected configurations for win32x86 + - arch: win32x86 + flavor: squeak.sista.spur + mode: fast + # - arch: win32x86 + # flavor: pharo.sista.spur + # mode: fast + + runs-on: windows-latest + name: ${{ matrix.flavor }} for ${{ matrix.arch }}${{ matrix.mode == 'debug' && ' (DEBUG)' || matrix.mode == 'assert' && ' (ASSERT)' || '' }} + env: + ARCH: ${{ matrix.arch }} + FLAVOR: ${{ matrix.flavor }} + MODE: ${{ matrix.mode }} + steps: + - name: Checkout files + if: github.event_name != 'workflow_dispatch' + uses: actions/checkout@v2 + + - name: Checkout files for new release candidate + if: github.event_name == 'workflow_dispatch' + uses: actions/checkout@v2 + with: + ref: refs/tags/${{ github.event.inputs.tag }} + + - name: Restore build cache + uses: actions/cache@v2 + with: + path: .thirdparty-cache + key: thirdparty-cache-win + + # - name: Setup tmate debugging session + # uses: mxschmitt/action-tmate@v3 + + - name: Build VM + shell: bash + run: ./scripts/ci/actions_build.sh + # run: C:\msys64\usr\bin\bash -lc "cd $(pwd); exec ./scripts/ci/actions_build.sh" + env: + MSYS_SYS: ${{ matrix.arch == 'win64x64' && 'mingw64' || 'mingw32' }} + MSYS_ENV: ${{ matrix.arch == 'win64x64' && 'x86_64' || 'i686' }} + + - name: Sign VM (not implemented) + if: false + run: ./deploy/sign-vm.sh + + - name: Pack VM + shell: bash + run: ./deploy/pack-vm.sh + + - name: Store artifact w/ revision + uses: actions/upload-artifact@v2 + with: + name: ${{ env.ASSET_NAME }}_${{ env.ASSET_REVISION }} + path: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + + - name: Update artifact in latest-build + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'push' && endsWith(github.ref, 'Cog') + with: + prerelease: true + allowUpdates: true + replacesArtifacts: true + artifacts: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ matrix.mode == 'debug' && 'latest-debug-build' || matrix.mode == 'assert' && 'latest-assert-build' || 'latest-build' }} + body: ${{ github.event.head_commit.message }} + + - name: Deploy artifact as new release candidate + uses: ncipollo/release-action@v1.8.6 + if: github.event_name == 'workflow_dispatch' + with: + prerelease: true # release candidate + allowUpdates: true + replacesArtifacts: true + artifacts: products/${{ env.ASSET_NAME }}.${{ env.ASSET_EXTENSION }} + token: ${{ secrets.GITHUB_TOKEN }} + tag: ${{ github.event.inputs.tag }} + body: ${{ github.event.head_commit.message }} diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index 721ae997b8..0000000000 --- a/.travis.yml +++ /dev/null @@ -1,225 +0,0 @@ -language: c - -sudo: required - -addons: - apt: - update: true - -cache: - directories: - - armchroot - - .thirdparty-cache - -notifications: - slack: - secure: gyekIJqPdx7SxqpugvtpY5mZSg54oFkFJ+DKBPILtjyI/sDhcSwT9GwY/zoHoYkoHrPLepDxyPgkAC8JCcTiAcxOazq5zlVva6SoQRjlDnC64oCYvOj/2giuYkXLXnwvj8mIINEgXzEvLdalpHwazsY0fzKNFM1mdrkPolmf2CvaNbKCGkiagsjrxJHEEB4tLcUP4ArqVE6wb+20HXoMKlHccgCFvN67bYJrTXDnuhEgKMooQRFv0yVoimckdRn1amvIgljavPwv2yHX+V1roneyi90e4ri9AT2sROeRprGnaib9Z8p+/mgWIUnTLL7pjbNHhtvZptsj3xjanWy1Bt/4MMewTWN4REE/KKxLp79CQvGNR+Ki7mF2UpgYUtxHYpFNIGNF9VomwnfWAuYdGDAYAGY3S1W12RPo37CC7RP/lPM96L6ypW41FoQKlnhzm+StJV+mlI5C1jQBU2WKoVhaKXJpraX2mUJXyN8ilYDo7PrJe0SRLH6J2WwPM5Z/RdscBDEGAR4RhZnn++1IE7e1gZPJB4NZH/3wLBwDhz8S4kB/GB32/rz3ZaftCf2+XjAZXzF3SroUCZ/MWZPGrwchEkU/3z1Tm8FTbELxZk1rSYpdLwVnXYooo5vggqjgAZvmlTerJuufl5lOkXT44PynZAvE+I+MrD04DpKuH0w= - -aliases: - - &mac-build - os: osx - osx_image: xcode8.3 - -notifications: - email: - - vm-dev@lists.squeakfoundation.org - -jobs: - fast_finish: true - include: - - stage: "Main Squeak and Pharo builds" - env: ARCH="linux32x86" FLAVOR="squeak.cog.spur" - - env: ARCH="macos32x86" FLAVOR="squeak.cog.spur" - <<: *mac-build - - env: ARCH="linux64x64" FLAVOR="squeak.cog.spur" - - env: ARCH="macos64x64" FLAVOR="squeak.cog.spur" - <<: *mac-build - - env: ARCH="linux32x86" FLAVOR="pharo.cog.spur" HEARTBEAT="threaded" - # - env: ARCH="macos32x86" FLAVOR="pharo.cog.spur" - # <<: *mac-build - - env: ARCH="linux64x64" FLAVOR="pharo.cog.spur" HEARTBEAT="threaded" - # - env: ARCH="macos64x64" FLAVOR="pharo.cog.spur" - # <<: *mac-build - - - stage: "Minheadless CMake builds" - env: ARCH="linux32x86" FLAVOR="squeak.cog.spur" CPU_ARCH="x86" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos32x86" FLAVOR="squeak.cog.spur" CPU_ARCH="x86" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - env: ARCH="linux64x64" FLAVOR="squeak.cog.spur" CPU_ARCH="x64" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos64x64" FLAVOR="squeak.cog.spur" CPU_ARCH="x64" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - env: ARCH="linux32x86" FLAVOR="pharo.cog.spur" CPU_ARCH="x86" HEARTBEAT="threaded" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos32x86" FLAVOR="pharo.cog.spur" CPU_ARCH="x86" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - env: ARCH="linux64x64" FLAVOR="pharo.cog.spur" CPU_ARCH="x64" HEARTBEAT="threaded" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos64x64" FLAVOR="pharo.cog.spur" CPU_ARCH="x64" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - # Minheadless CMake builds with SDL2 traditional display - - env: ARCH="linux32x86" FLAVOR="squeak.cog.spur+sdl2" CPU_ARCH="x86" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos32x86" FLAVOR="squeak.cog.spur+sdl2" CPU_ARCH="x86" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - env: ARCH="linux64x64" FLAVOR="squeak.cog.spur+sdl2" CPU_ARCH="x64" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos64x64" FLAVOR="squeak.cog.spur+sdl2" CPU_ARCH="x64" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - env: ARCH="linux32x86" FLAVOR="pharo.cog.spur+sdl2" CPU_ARCH="x86" HEARTBEAT="threaded" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos32x86" FLAVOR="pharo.cog.spur+sdl2" CPU_ARCH="x86" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - env: ARCH="linux64x64" FLAVOR="pharo.cog.spur+sdl2" CPU_ARCH="x64" HEARTBEAT="threaded" BUILD_WITH_CMAKE="yes" - - env: ARCH="macos64x64" FLAVOR="pharo.cog.spur+sdl2" CPU_ARCH="x64" BUILD_WITH_CMAKE="yes" - <<: *mac-build - - - stage: "Other Linux builds" - # env: ARCH="linux64x64" FLAVOR="newspeak.cog.spur" - - env: ARCH="linux64x64" FLAVOR="pharo.cog.spur" HEARTBEAT="itimer" - # - env: ARCH="linux64x64" FLAVOR="pharo.sista.spur" HEARTBEAT="threaded" - # - env: ARCH="linux32x86" FLAVOR="newspeak.cog.spur" - - env: ARCH="linux32x86" FLAVOR="squeak.cog.v3" - - env: ARCH="linux32x86" FLAVOR="squeak.sista.spur" - - env: ARCH="linux32x86" FLAVOR="pharo.cog.spur" HEARTBEAT="itimer" - - env: ARCH="linux32x86" FLAVOR="pharo.sista.spur" HEARTBEAT="threaded" - compiler: clang - - env: ARCH="linux32x86" FLAVOR="pharo.sista.spur" HEARTBEAT="itimer" - compiler: clang - - - stage: "Other Mac builds" - # env: ARCH="macos64x64" FLAVOR="newspeak.cog.spur" - # <<: *mac-build - # - env: ARCH="macos64x64" FLAVOR="pharo.sista.spur" - # <<: *mac-build - env: ARCH="macos64x64" FLAVOR="pharo.cog.spur.lowcode" - <<: *mac-build - # - env: ARCH="macos32x86" FLAVOR="newspeak.cog.spur" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="pharo.sista.spur" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="pharo.cog.spur.lowcode" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="squeak.cog.v3" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="squeak.sista.spur" - <<: *mac-build - - - stage: "Stack builds" - env: ARCH="linux64x64" FLAVOR="squeak.stack.spur" - # - env: ARCH="linux64x64" FLAVOR="newspeak.stack.spur" - # - env: ARCH="linux32x86" FLAVOR="newspeak.stack.spur" - - env: ARCH="linux32x86" FLAVOR="squeak.stack.spur" - - env: ARCH="linux32x86" FLAVOR="squeak.stack.v3" - - env: ARCH="macos64x64" FLAVOR="pharo.stack.spur" - <<: *mac-build - - env: ARCH="macos64x64" FLAVOR="pharo.stack.spur.lowcode" - <<: *mac-build - - env: ARCH="macos64x64" FLAVOR="squeak.stack.spur" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="newspeak.stack.spur" - <<: *mac-build - # - env: ARCH="macos64x64" FLAVOR="newspeak.stack.spur" - # <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="pharo.stack.spur" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="pharo.stack.spur.lowcode" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="squeak.stack.spur" - <<: *mac-build - - env: ARCH="macos32x86" FLAVOR="squeak.stack.v3" - <<: *mac-build - - - stage: "linux32ARMv6 builds" - # env: ARCH="linux32ARMv6" FLAVOR="newspeak.cog.spur" CHROOT="schroot -p -c rpi - # -- bash -c " - # dist: trusty - # group: edge - # - env: ARCH="linux32ARMv6" FLAVOR="newspeak.stack.spur" CHROOT="schroot -p -c rpi - # -- bash -c " - # dist: trusty - # group: edge - env: ARCH="linux32ARMv6" FLAVOR="squeak.cog.spur" CHROOT="schroot -p -c rpi -- - bash -c " - dist: trusty - group: edge - - env: ARCH="linux32ARMv6" FLAVOR="pharo.cog.spur" CHROOT="schroot -p -c rpi -- - bash -c " - dist: trusty - group: edge - - env: ARCH="linux32ARMv6" FLAVOR="squeak.stack.spur" CHROOT="schroot -p -c rpi - -- bash -c " - dist: trusty - group: edge - - env: ARCH="linux32ARMv6" FLAVOR="squeak.stack.v3" CHROOT="schroot -p -c rpi -- - bash -c " - dist: trusty - group: edge - allow_failures: - - env: FLAVOR="squeak.sista.spur" - - env: FLAVOR="pharo.sista.spur" - - env: FLAVOR="squeak.cog.spur.lowcode" - - env: FLAVOR="pharo.cog.spur.lowcode" - - env: ARCH="linux64x64" FLAVOR="newspeak.cog.spur" - - env: ARCH="linux32x86" FLAVOR="newspeak.cog.spur" - - env: ARCH="macos64x64" FLAVOR="newspeak.cog.spur" - - env: ARCH="macos32x86" FLAVOR="newspeak.cog.spur" - - env: ARCH="linux64x64" FLAVOR="newspeak.stack.spur" - - env: ARCH="linux32x86" FLAVOR="newspeak.stack.spur" - - env: ARCH="macos64x64" FLAVOR="newspeak.stack.spur" - - env: ARCH="macos32x86" FLAVOR="newspeak.stack.spur" - - env: ARCH="linux32ARMv6" FLAVOR="newspeak.cog.spur" - - env: ARCH="linux32ARMv6" FLAVOR="newspeak.stack.spur" - - env: ARCH="linux64x64" FLAVOR="pharo.cog.spur" HEARTBEAT="threaded" - - env: ARCH="linux32x86" FLAVOR="pharo.cog.spur" HEARTBEAT="threaded" - - env: ARCH="linux64x64" FLAVOR="pharo.cog.spur" HEARTBEAT="itimer" - - env: ARCH="linux32x86" FLAVOR="pharo.cog.spur" HEARTBEAT="itimer" - - env: ARCH="macos64x64" FLAVOR="pharo.cog.spur" - - env: ARCH="macos32x86" FLAVOR="pharo.cog.spur" - - env: ARCH="macos64x64" FLAVOR="pharo.cog.spur.lowcode" - - env: ARCH="macos32x86" FLAVOR="pharo.cog.spur.lowcode" - - env: ARCH="linux64x64" FLAVOR="pharo.sista.spur" HEARTBEAT="threaded" - - env: ARCH="linux32x86" FLAVOR="pharo.sista.spur" HEARTBEAT="threaded" - - env: ARCH="linux64x64" FLAVOR="pharo.sista.spur" HEARTBEAT="itimer" - - env: ARCH="linux32x86" FLAVOR="pharo.sista.spur" HEARTBEAT="itimer" - - env: ARCH="macos64x64" FLAVOR="pharo.sista.spur" - - env: ARCH="macos32x86" FLAVOR="pharo.sista.spur" - - env: ARCH="linux64x64" FLAVOR="pharo.stack.spur" - - env: ARCH="linux32x86" FLAVOR="pharo.stack.spur" - - env: ARCH="macos64x64" FLAVOR="pharo.stack.spur" - - env: ARCH="macos32x86" FLAVOR="pharo.stack.spur" - - env: ARCH="linux64x64" FLAVOR="pharo.stack.spur.lowcode" - - env: ARCH="linux32x86" FLAVOR="pharo.stack.spur.lowcode" - - env: ARCH="macos64x64" FLAVOR="pharo.stack.spur.lowcode" - - env: ARCH="macos32x86" FLAVOR="pharo.stack.spur.lowcode" - - env: ARCH="linux32ARMv6" FLAVOR="pharo.cog.spur" - - env: ARCH="linux32ARMv6" FLAVOR="pharo.stack.spur" - -install: ./scripts/ci/travis_install.sh - -before_script: $CHROOT ./scripts/ci/travis_build.sh - -script: ./scripts/ci/travis_test.sh - -after_success: (cd deploy && ./filter-exec.sh pack-vm.sh) - -deploy: - - provider: script # Deploy bleeding edge to Bintray - script: (cd deploy && ./filter-exec.sh ./bintray.sh) - skip_cleanup: true - on: - repo: OpenSmalltalk/opensmalltalk-vm - branch: Cog - - provider: script # Deploy to files.pharo.org - script: (cd deploy/pharo && ./filter-exec.sh ./deploy.sh) - skip_cleanup: true - on: - repo: OpenSmalltalk/opensmalltalk-vm - branch: Cog - condition: $FLAVOR == pharo* - - provider: releases # Deploy stable tags to GitHub releases - api_key: - secure: ASzbVm1ootfvzfAYm50rWCfIvwp/O+6N1NMv2lymvswj/sGW7MxmYGHj2UNtLg9OAD+lL9YyElyy94MCpSK496+pD7GrOdRAitilMreWR6jGab0D92pPcujMAsDDSRTPNZsui1kvK1skWGMCN41mXLlwtCxSqWdhQ1viMmjXeK29TJbHykFEdfgZc6RcB97NdMyz6Pp9uqbxXSA656UxeLJzsKX88mXFcd5983pVt1ME8dfeUC9dwTihG5IAEg3Uz6HDxcR3uero0alLXycer5zI1kHLede03aNNvcRcUnVjBa5rNY8ON884DblDC+lcc+8b104MQTAGKWbyibjpm+9b0oWJV/tB20VdJUxZ2MpuktLzUrFBjVFjSrB5NmkITtJ1o+eYmjJOzWZNqFueNIsEkbGItDQJkKhNySBnUZ3/gyxnTBwmulUF2i8dimdwAuZlMiTN5mqpSLzLCE9ZrGWz9zuuCCombvpNIAc2IMsaTlpj391TjQfqGvu+Z88hmJOmDwpdUsGwNHo+Cz1N+KivAfySgj1T+CfE4xnuKOQzVbUK1Aqv/uGl1ieS1MfgyrqfgvRWEcGQh7/35n6yxG5s2z1qrs9Vl0e0rN261GQuK5ElNsQSLVRNH13+PdDwTCEZ/APzo+0uGRGTmGKJtzAofmkeAsrwmgGJPAuip/0= - file_glob: true - file: "./products/*.{dmg,gz,zip}" - skip_cleanup: true - on: - repo: OpenSmalltalk/opensmalltalk-vm - tags: true - -after_deploy: (cd deploy && ./filter-exec.sh bintray-cleanup.sh) diff --git a/build.linux32ARMv6/newspeak.cog.spur/build.assert/mvm b/build.linux32ARMv6/newspeak.cog.spur/build.assert/mvm index a326033d29..d45b87fe5e 100755 --- a/build.linux32ARMv6/newspeak.cog.spur/build.assert/mvm +++ b/build.linux32ARMv6/newspeak.cog.spur/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert VM with VM profiler and threaded heartbeat INSTALLDIR=assert/nscogspurlinuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0" +OPT="-g3 -O1 -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/newspeak.cog.spur/build.debug/mvm b/build.linux32ARMv6/newspeak.cog.spur/build.debug/mvm index 6230102f16..105ca1d50a 100755 --- a/build.linux32ARMv6/newspeak.cog.spur/build.debug/mvm +++ b/build.linux32ARMv6/newspeak.cog.spur/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug Spur VM with VM profiler and threaded heartbeat INSTALLDIR=debug/nscogspurlinuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1" +OPT="-g3 -O0 -DDEBUGVM=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/newspeak.stack.spur/build.assert/mvm b/build.linux32ARMv6/newspeak.stack.spur/build.assert/mvm index 0c65983d3d..610e0a3bea 100755 --- a/build.linux32ARMv6/newspeak.stack.spur/build.assert/mvm +++ b/build.linux32ARMv6/newspeak.stack.spur/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert Stack Spur VM with VM profiler and threaded heartbeat INSTALLDIR=assert/nsstkspurlinuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0" +OPT="-g3 -O1 -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/newspeak.stack.spur/build.debug/mvm b/build.linux32ARMv6/newspeak.stack.spur/build.debug/mvm index 25efa5b365..6ef2ddf2a3 100755 --- a/build.linux32ARMv6/newspeak.stack.spur/build.debug/mvm +++ b/build.linux32ARMv6/newspeak.stack.spur/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug Stack Spur VM with VM profiler and threaded heartbeat INSTALLDIR=debug/nsstkspurlinuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1" +OPT="-g3 -O0 -DDEBUGVM=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/newspeak.stack.spur/build/mvm b/build.linux32ARMv6/newspeak.stack.spur/build/mvm index f2166fb1c0..a2bbe5322e 100755 --- a/build.linux32ARMv6/newspeak.stack.spur/build/mvm +++ b/build.linux32ARMv6/newspeak.stack.spur/build/mvm @@ -2,7 +2,7 @@ set -e # Stack Spur VM and threaded heartbeat INSTALLDIR=nsstkspurlinuxhtRPi -OPT="-m32 -g -O3 -DNDEBUG -DDEBUGVM=0 -DNO_VM_PROFILE=1" +OPT="-g -O3 -DNDEBUG -DDEBUGVM=0 -DNO_VM_PROFILE=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/pharo.cog.spur/build.assert/mvm b/build.linux32ARMv6/pharo.cog.spur/build.assert/mvm index c5a177b465..045da2d100 100755 --- a/build.linux32ARMv6/pharo.cog.spur/build.assert/mvm +++ b/build.linux32ARMv6/pharo.cog.spur/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert PharoVM with VM profiler and threaded heartbeat INSTALLDIR=assert/phcogspurlinuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0 -DPharoVM" +OPT="-g3 -O1 -DDEBUGVM=0 -DPharoVM" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/pharo.cog.spur/build.debug/mvm b/build.linux32ARMv6/pharo.cog.spur/build.debug/mvm index 0f959eb87e..b82030db2b 100755 --- a/build.linux32ARMv6/pharo.cog.spur/build.debug/mvm +++ b/build.linux32ARMv6/pharo.cog.spur/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug PharoVM with VM profiler and threaded heartbeat INSTALLDIR=debug/phcogspurlinuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1 -DPharoVM" +OPT="-g3 -O0 -DDEBUGVM=1 -DPharoVM" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.cog.spur/build.assert/mvm b/build.linux32ARMv6/squeak.cog.spur/build.assert/mvm index 0254afa9f4..0e28f57503 100755 --- a/build.linux32ARMv6/squeak.cog.spur/build.assert/mvm +++ b/build.linux32ARMv6/squeak.cog.spur/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert VM with VM profiler and threaded heartbeat INSTALLDIR=assert/sqcogspurlinuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0" +OPT="-g3 -O1 -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.cog.spur/build.debug/mvm b/build.linux32ARMv6/squeak.cog.spur/build.debug/mvm index 764e80f084..c35c5e9f6f 100755 --- a/build.linux32ARMv6/squeak.cog.spur/build.debug/mvm +++ b/build.linux32ARMv6/squeak.cog.spur/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug Spur VM with VM profiler and threaded heartbeat INSTALLDIR=debug/sqcogspurlinuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1" +OPT="-g3 -O0 -DDEBUGVM=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.cog.spur/build/mvm b/build.linux32ARMv6/squeak.cog.spur/build/mvm index 7a5cbe4d5d..f16d72208d 100755 --- a/build.linux32ARMv6/squeak.cog.spur/build/mvm +++ b/build.linux32ARMv6/squeak.cog.spur/build/mvm @@ -2,7 +2,7 @@ set -e # Spur VM with VM profiler and threaded heartbeat INSTALLDIR=sqcogspurlinuxhtRPi -OPT=" -g -O2 -DNDEBUG -DDEBUGVM=0" +OPT="-g -O2 -DNDEBUG -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.cog.v3/build.assert/mvm b/build.linux32ARMv6/squeak.cog.v3/build.assert/mvm index 70adcfadba..7f8c9ed586 100755 --- a/build.linux32ARMv6/squeak.cog.v3/build.assert/mvm +++ b/build.linux32ARMv6/squeak.cog.v3/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert VM with VM profiler and threaded heartbeat INSTALLDIR=assert/sqcogv3linuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0" +OPT="-g3 -O1 -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.cog.v3/build.debug/mvm b/build.linux32ARMv6/squeak.cog.v3/build.debug/mvm index 10a0b0baf3..a4129c7017 100755 --- a/build.linux32ARMv6/squeak.cog.v3/build.debug/mvm +++ b/build.linux32ARMv6/squeak.cog.v3/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug V3 VM with VM profiler and threaded heartbeat INSTALLDIR=debug/sqcogv3linuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1" +OPT="-g3 -O0 -DDEBUGVM=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.cog.v3/build/mvm b/build.linux32ARMv6/squeak.cog.v3/build/mvm index b107527dd6..2800e6e131 100755 --- a/build.linux32ARMv6/squeak.cog.v3/build/mvm +++ b/build.linux32ARMv6/squeak.cog.v3/build/mvm @@ -2,7 +2,7 @@ set -e # V3 VM with VM profiler and threaded heartbeat INSTALLDIR=sqcogv3linuxhtRPi -OPT="-m32 -g -O2 -DNDEBUG -DDEBUGVM=0" +OPT="-g -O2 -DNDEBUG -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.stack.spur/build.assert/mvm b/build.linux32ARMv6/squeak.stack.spur/build.assert/mvm index 3aac75b7ce..f4d5e2ecc4 100755 --- a/build.linux32ARMv6/squeak.stack.spur/build.assert/mvm +++ b/build.linux32ARMv6/squeak.stack.spur/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert Stack Spur VM with VM profiler and threaded heartbeat INSTALLDIR=assert/sqstkspurlinuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0" +OPT="-g3 -O1 -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.stack.spur/build.debug/mvm b/build.linux32ARMv6/squeak.stack.spur/build.debug/mvm index 57dd6a5e84..881a5be225 100755 --- a/build.linux32ARMv6/squeak.stack.spur/build.debug/mvm +++ b/build.linux32ARMv6/squeak.stack.spur/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug Stack Spur VM with VM profiler and threaded heartbeat INSTALLDIR=debug/sqstkspurlinuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1" +OPT="-g3 -O0 -DDEBUGVM=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.stack.spur/build/mvm b/build.linux32ARMv6/squeak.stack.spur/build/mvm index 6f9a6d1816..56eff33d15 100755 --- a/build.linux32ARMv6/squeak.stack.spur/build/mvm +++ b/build.linux32ARMv6/squeak.stack.spur/build/mvm @@ -2,7 +2,7 @@ set -e # Stack Spur VM and threaded heartbeat INSTALLDIR=sqstkspurlinuxhtRPi -OPT="-m32 -g -O3 -DNDEBUG -DDEBUGVM=0 -DNO_VM_PROFILE=1" +OPT="-g -O3 -DNDEBUG -DDEBUGVM=0 -DNO_VM_PROFILE=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.stack.v3/build.assert/mvm b/build.linux32ARMv6/squeak.stack.v3/build.assert/mvm index 20ddd48019..838c6fed9a 100755 --- a/build.linux32ARMv6/squeak.stack.v3/build.assert/mvm +++ b/build.linux32ARMv6/squeak.stack.v3/build.assert/mvm @@ -2,7 +2,7 @@ set -e # assert Stack VM with VM profiler and threaded heartbeat INSTALLDIR=assert/sqstklinuxhtRPi -OPT="-m32 -g3 -O1 -DDEBUGVM=0" +OPT="-g3 -O1 -DDEBUGVM=0" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.stack.v3/build.debug/mvm b/build.linux32ARMv6/squeak.stack.v3/build.debug/mvm index ac07a14ffa..467fdffa63 100755 --- a/build.linux32ARMv6/squeak.stack.v3/build.debug/mvm +++ b/build.linux32ARMv6/squeak.stack.v3/build.debug/mvm @@ -2,7 +2,7 @@ set -e # debug Stack VM with VM profiler and threaded heartbeat INSTALLDIR=debug/sqstklinuxhtRPi -OPT="-m32 -g3 -O0 -DDEBUGVM=1" +OPT="-g3 -O0 -DDEBUGVM=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv6/squeak.stack.v3/build/mvm b/build.linux32ARMv6/squeak.stack.v3/build/mvm index 1c85b53ea8..7a08e672be 100755 --- a/build.linux32ARMv6/squeak.stack.v3/build/mvm +++ b/build.linux32ARMv6/squeak.stack.v3/build/mvm @@ -2,7 +2,7 @@ set -e # Stack VM with VM profiler and threaded heartbeat INSTALLDIR=sqstklinuxhtRPi -OPT="-m32 -g -O3 -DNDEBUG -DDEBUGVM=0 -DNO_VM_PROFILE=1" +OPT="-g -O3 -DNDEBUG -DDEBUGVM=0 -DNO_VM_PROFILE=1" if [ $# -ge 1 ]; then INSTALLDIR="$1"; shift diff --git a/build.linux32ARMv7/newspeak.cog.spur/plugins.ext b/build.linux32ARMv7/newspeak.cog.spur/plugins.ext new file mode 100644 index 0000000000..f97d8b6cdd --- /dev/null +++ b/build.linux32ARMv7/newspeak.cog.spur/plugins.ext @@ -0,0 +1,3 @@ +# Copied, perhaps edited, from ../../../nscogsrc/examplePlugins.ext +EXTERNAL_PLUGINS = \ +SqueakSSL diff --git a/build.linux32ARMv7/newspeak.cog.spur/plugins.int b/build.linux32ARMv7/newspeak.cog.spur/plugins.int new file mode 100644 index 0000000000..cfd6f4c2c0 --- /dev/null +++ b/build.linux32ARMv7/newspeak.cog.spur/plugins.int @@ -0,0 +1,29 @@ +# Copied, perhaps edited, from ../../../nscogsrc/examplePlugins.int +INTERNAL_PLUGINS = \ +AioPlugin \ +AsynchFilePlugin \ +BMPReadWriterPlugin \ +B2DPlugin \ +BitBltPlugin \ +DSAPrims \ +DropPlugin \ +FileCopyPlugin \ +FilePlugin \ +Float64ArrayPlugin \ +FloatArrayPlugin \ +FloatMathPlugin \ +HostWindowPlugin \ +ZipPlugin \ +JPEGReadWriter2Plugin \ +JPEGReaderPlugin \ +LargeIntegers \ +Matrix2x3Plugin \ +MiscPrimitivePlugin \ +IA32ABI \ +RePlugin \ +SecurityPlugin \ +SocketPlugin \ +SurfacePlugin \ +UUIDPlugin \ +UnixOSProcessPlugin \ +VMProfileLinuxSupportPlugin diff --git a/build.linux32ARMv7/newspeak.stack.spur/plugins.ext b/build.linux32ARMv7/newspeak.stack.spur/plugins.ext new file mode 100644 index 0000000000..f97d8b6cdd --- /dev/null +++ b/build.linux32ARMv7/newspeak.stack.spur/plugins.ext @@ -0,0 +1,3 @@ +# Copied, perhaps edited, from ../../../nscogsrc/examplePlugins.ext +EXTERNAL_PLUGINS = \ +SqueakSSL diff --git a/build.linux32ARMv7/newspeak.stack.spur/plugins.int b/build.linux32ARMv7/newspeak.stack.spur/plugins.int new file mode 100644 index 0000000000..cfd6f4c2c0 --- /dev/null +++ b/build.linux32ARMv7/newspeak.stack.spur/plugins.int @@ -0,0 +1,29 @@ +# Copied, perhaps edited, from ../../../nscogsrc/examplePlugins.int +INTERNAL_PLUGINS = \ +AioPlugin \ +AsynchFilePlugin \ +BMPReadWriterPlugin \ +B2DPlugin \ +BitBltPlugin \ +DSAPrims \ +DropPlugin \ +FileCopyPlugin \ +FilePlugin \ +Float64ArrayPlugin \ +FloatArrayPlugin \ +FloatMathPlugin \ +HostWindowPlugin \ +ZipPlugin \ +JPEGReadWriter2Plugin \ +JPEGReaderPlugin \ +LargeIntegers \ +Matrix2x3Plugin \ +MiscPrimitivePlugin \ +IA32ABI \ +RePlugin \ +SecurityPlugin \ +SocketPlugin \ +SurfacePlugin \ +UUIDPlugin \ +UnixOSProcessPlugin \ +VMProfileLinuxSupportPlugin diff --git a/build.linux32x86/pharo.cog.spur.lowcode/build/mvm b/build.linux32x86/pharo.cog.spur.lowcode/build/mvm index b8e61423e1..fb59b3c605 100755 --- a/build.linux32x86/pharo.cog.spur.lowcode/build/mvm +++ b/build.linux32x86/pharo.cog.spur.lowcode/build/mvm @@ -35,7 +35,7 @@ test -f plugins.int || (test -f ../plugins.int && cp -p ../plugins.int . || cp - test -f plugins.ext || (test -f ../plugins.ext && cp -p ../plugins.ext . || cp -p ../../plugins.ext .) for lib in ${THIRDPARTYLIBS}; do - ../../third-party/${lib}/mvm + ../../third-party/mvm ${lib} done test -f config.h || ../../../platforms/unix/config/configure \ @@ -49,7 +49,9 @@ rm -rf ../../../products/$INSTALLDIR # prefer make install prefix=`readlink -f \`pwd\`/../../../products/$INSTALLDIR` # but older linux readlinks lack the -f flag make install-squeak install-plugins prefix=`(cd ../../../;pwd)`/products/$INSTALLDIR 2>&1 | tee LOG +productDir=`find ../../../products/$INSTALLDIR -name "5.0*"` +productDir=`(cd $productDir;pwd)` for lib in ${THIRDPARTYLIBS}; do - ../../third-party/${lib}/mvm install `find ../../../products/$INSTALLDIR -name "5.0*"` + ../../third-party/mvm ${lib} install $productDir done ../../editpharoinstall.sh ../../../products/$INSTALLDIR "$@" diff --git a/build.linux32x86/pharo.stack.spur.lowcode/build/mvm b/build.linux32x86/pharo.stack.spur.lowcode/build/mvm index 8ab2ec9f24..175c862dac 100755 --- a/build.linux32x86/pharo.stack.spur.lowcode/build/mvm +++ b/build.linux32x86/pharo.stack.spur.lowcode/build/mvm @@ -35,7 +35,7 @@ test -f plugins.int || (test -f ../plugins.int && cp -p ../plugins.int . || cp - test -f plugins.ext || (test -f ../plugins.ext && cp -p ../plugins.ext . || cp -p ../../plugins.ext .) for lib in ${THIRDPARTYLIBS}; do - ../../third-party/${lib}/mvm + ../../third-party/mvm ${lib} done test -f config.h || ../../../platforms/unix/config/configure \ @@ -49,7 +49,9 @@ rm -rf ../../../products/$INSTALLDIR # prefer make install prefix=`readlink -f \`pwd\`/../../../products/$INSTALLDIR` # but older linux readlinks lack the -f flag make install-squeak install-plugins prefix=`(cd ../../../;pwd)`/products/$INSTALLDIR 2>&1 | tee LOG +productDir=`find ../../../products/$INSTALLDIR -name "5.0*"` +productDir=`(cd $productDir;pwd)` for lib in ${THIRDPARTYLIBS}; do - ../../third-party/${lib}/mvm install `find ../../../products/$INSTALLDIR -name "5.0*"` + ../../third-party/mvm ${lib} install $productDir done ../../editpharoinstall.sh ../../../products/$INSTALLDIR "$@" diff --git a/deploy/bintray-cleanup.sh b/deploy/bintray-cleanup.sh deleted file mode 100755 index 6bb724b361..0000000000 --- a/deploy/bintray-cleanup.sh +++ /dev/null @@ -1,37 +0,0 @@ -#!/bin/bash -set -e - -# Remove old versions from bintray, leaving only the last version per month -if [[ "${TRAVIS_OS_NAME}" == "linux" ]] && [[ "${ARCH}" == "linux64x64" ]] && [[ "${FLAVOR}" == "squeak.cog.spur" ]]; then - ruby -rdate -rnet/http -rjson -e "lastver=DateTime.now; - user='osvm'; - pass='${BINTRAYAPIKEY}'; - url='https://api.bintray.com/packages/opensmalltalk/vm/cog'; - uri=URI(url); - json=nil; - http=Net::HTTP.new(uri.host,uri.port); - http.use_ssl=true; - http.start { - req=Net::HTTP::Get.new(uri.request_uri); - req.basic_auth(user,pass); - resp=http.request(req); - json=JSON.parse(resp.body) - }; - (json['versions'][10..-1] || []).each { |v| - ver=DateTime.parse(v); - if ver.month != lastver.month then - lastver=ver; next - else - lastver=ver - end; - uri=URI(url+'/versions/'+v); - http=Net::HTTP.new(uri.host,uri.port); - http.use_ssl=true; - http.start { - req=Net::HTTP::Delete.new(uri.request_uri); - req.basic_auth(user,pass); - resp=http.request(req); - puts 'Deleted ' + v + ' ' + resp.body - } - }" -fi diff --git a/deploy/bintray.json b/deploy/bintray.json deleted file mode 100644 index 52ccf92350..0000000000 --- a/deploy/bintray.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "package": { - "name": "cog", - "repo": "vm", - "subject": "opensmalltalk" - }, - "version": { - "name": "$Rev$", - "desc": "Automatic build" - }, - "files": [ - {"includePattern": "../products/((newspeak|pharo|squeak).*\\.(?:gz|zip|dmg))", "uploadPattern": "$1"} - ], - "publish": true -} diff --git a/deploy/bintray.sh b/deploy/bintray.sh deleted file mode 100755 index 976cc86fcd..0000000000 --- a/deploy/bintray.sh +++ /dev/null @@ -1,22 +0,0 @@ -#!/bin/bash -set -e - -if [[ -n "${TRAVIS_TAG:-${APPVEYOR_REPO_TAG_NAME}}" ]]; then - echo "Skipping a deployment to Bintray because build was pushed by a tag." - exit -fi - -echo "$(cat bintray.json | ../.git_filters/RevDateURL.smudge)" > bintray.json -sed -i.bak 's/$Rev: \([0-9][0-9]*\) \$/\1/' bintray.json -sed -i.bak 's/$Date: \(.*\) \$/\1/' bintray.json -rm -f bintray.json.bak - -if [[ "${APPVEYOR}" ]]; then - appveyor DownloadFile https://curl.haxx.se/ca/cacert.pem - export SSL_CERT_FILE=cacert.pem - export PATH="C:\\Ruby23\\bin:$PATH" - export CMDSHELL="cmd /C " -fi - -$CMDSHELL gem install dpl -$CMDSHELL dpl --provider=bintray --user=osvm --key=$BINTRAYAPIKEY --file=bintray.json --skip_cleanup=true diff --git a/deploy/filter-exec.sh b/deploy/filter-exec.sh deleted file mode 100755 index bec92a41d5..0000000000 --- a/deploy/filter-exec.sh +++ /dev/null @@ -1,35 +0,0 @@ -#!/bin/bash -# Deployment filter (compatible with Travis and AppVeyor) -# -# execute script if: -# - $BINTRAYAPIKEY is set -# - REPOSITORY=OpenSmalltalk/opensmalltalk-vm -# - Build is not triggered by a pull request -# - BRANCH=Cog or TAG_NAME is not empty - -readonly REPO_NAME="${TRAVIS_REPO_SLUG:-${APPVEYOR_REPO_NAME}}" -readonly PR_SHA="${TRAVIS_PULL_REQUEST_SHA:-${APPVEYOR_PULL_REQUEST_HEAD_COMMIT}}" -readonly BRANCH_NAME="${TRAVIS_BRANCH:-${APPVEYOR_REPO_BRANCH}}" -readonly TAG_NAME="${TRAVIS_TAG:-${APPVEYOR_REPO_TAG_NAME}}" - -if [[ -z "${BINTRAYAPIKEY}" ]]; then - echo 'Skipping a deployment because $BINTRAYAPIKEY was not provided.' - exit -fi - -if [[ "${REPO_NAME}" != "OpenSmalltalk/opensmalltalk-vm" ]]; then - echo "Trying to deploy in repository: ${REPO_NAME}. Skipping." - exit -fi - -if [[ -n "${PR_SHA}" ]]; then - echo "Skipping a deployment with the script provider because PRs are not permitted." - exit -fi - -if [[ "${BRANCH_NAME}" != "Cog" ]] && [[ -z "${TAG_NAME}" ]]; then - echo "Skipping a deployment with the script provider because this branch is not permitted." - exit -fi - -`dirname $0`/$1 diff --git a/deploy/pack-vm.sh b/deploy/pack-vm.sh index b9c7f233d3..de5a26388b 100755 --- a/deploy/pack-vm.sh +++ b/deploy/pack-vm.sh @@ -1,108 +1,62 @@ #!/bin/bash -set -e - -readonly BUILD_DIR="${TRAVIS_BUILD_DIR:-$(cygpath ${APPVEYOR_BUILD_FOLDER})}" -readonly PRODUCTS_DIR="${BUILD_DIR}/products" -if [[ ! -d "${PRODUCTS_DIR}" ]]; then - echo "No products directory found." - exit 10 -fi +# Pack the VM into platform-specific container. All packing functions are +# evaluated in the ${PRODUCTS_PATH}. All binaries are expected to be there, +# already signed if required. +# +# Uses: +# - APP_NAME +# - PRODUCTS_PATH +# - ASSET_NAME +# +# Provides: +# - ASSET_EXTENSION (e.g., "tar.gz", "dmg", "zip") -BUILD_SYSTEM_SUFFIX="" -if [ "${BUILD_WITH_CMAKE}" = "yes" ]; then - BUILD_SYSTEM_SUFFIX="-cmake-minhdls" -fi -readonly BUILD_SYSTEM_SUFFIX -readonly REV=$(grep -m1 "SvnRawRevisionString" "${BUILD_DIR}/platforms/Cross/vm/sqSCCSVersion.h" | sed 's/[^0-9.]*\([0-9.]*\).*/\1/') -readonly IDENTIFIER="${FLAVOR}${BUILD_SYSTEM_SUFFIX}_${ARCH}_${REV}" -readonly IDENTIFIER_ITIMER="${FLAVOR}${BUILD_SYSTEM_SUFFIX}_${ARCH}_itimer_${REV}" -readonly KEY_CHAIN=macos-build.keychain +set -e -macos_codesign() { - local app_dir=$1 - local path_cer=$2 - local path_p12=$3 - local cert_pass=$4 - local sign_identity=$5 +[[ ! -d "${PRODUCTS_PATH}/${APP_NAME}" ]] && exit 31 +[[ -z "${ASSET_NAME}" ]] && exit 32 - echo "Signing app bundle..." - # Set up keychain - security create-keychain -p travis "${KEY_CHAIN}" - security default-keychain -s "${KEY_CHAIN}" - security unlock-keychain -p travis "${KEY_CHAIN}" - security set-keychain-settings -t 3600 -u "${KEY_CHAIN}" - security import "${path_cer}" -k ~/Library/Keychains/"${KEY_CHAIN}" -T /usr/bin/codesign - security import "${path_p12}" -k ~/Library/Keychains/"${KEY_CHAIN}" -P "${cert_pass}" -T /usr/bin/codesign - security set-key-partition-list -S apple-tool:,apple: -s -k travis "${KEY_CHAIN}" - # Invoke codesign - if [[ -d "${app_dir}/Contents/MacOS/Plugins" ]]; then # Pharo.app does not (yet) have its plugins in Resources dir - codesign -s "${sign_identity}" --force --deep "${app_dir}/Contents/MacOS/Plugins/"* - fi - codesign -s "${sign_identity}" --force --deep "${app_dir}" - # Remove sensitive files again - rm -rf "${path_cer}" "${path_p12}" - security delete-keychain "${KEY_CHAIN}" +# Pack the Linux build as .tar.gz archive +pack_Linux() { + readonly ASSET_EXTENSION="tar.gz" + tar czf "${PRODUCTS_PATH}/${ASSET_NAME}.${ASSET_EXTENSION}" "${APP_NAME}" } -pushd "${PRODUCTS_DIR}" -if [[ "${TRAVIS_OS_NAME}" == "linux" ]]; then - counter=0 - for dir in */; do - if [[ "${ARCH}" == *"ARM"* || "${dir}" == *"ht/" ]]; then - name="${IDENTIFIER}" - else - name="${IDENTIFIER_ITIMER}" - fi - tar czf "${name}.tar.gz" "${dir}" - counter=$((counter+1)) - if [[ "${counter}" -gt 2 ]]; then - echo "No more than two directories expected (threaded and/or itimer)" - exit 20 - fi - done -elif [[ "${TRAVIS_OS_NAME}" == "osx" ]]; then - APP_DIR=$(find "${PRODUCTS_DIR}" -type d -path "*.app" | head -n 1) - if [[ -z "${APP_DIR}" ]]; then - echo "Unable to locate app bundle." - exit 30 - fi - readonly DEPLOY_DIR="${TRAVIS_BUILD_DIR}/deploy" - if [[ "${FLAVOR}" == "squeak"* ]]; then - path_cer="${DEPLOY_DIR}/squeak/sign.cer" - path_p12="${DEPLOY_DIR}/squeak/sign.p12" - openssl aes-256-cbc -k "${SQUEAK_SIGN_PASSWORD}" -in "${path_cer}.enc" -out "${path_cer}" -d - openssl aes-256-cbc -k "${SQUEAK_SIGN_PASSWORD}" -in "${path_p12}.enc" -out "${path_p12}" -d - macos_codesign "${APP_DIR}" "${path_cer}" "${path_p12}" "${SQUEAK_CERT_PASSWORD}" "${SQUEAK_SIGN_IDENTITY}" - elif [[ "${FLAVOR}" == "pharo"* ]]; then - path_cer="${DEPLOY_DIR}/pharo/pharo.cer" - path_p12="${DEPLOY_DIR}/pharo/pharo.p12" - openssl aes-256-cbc -k "${PHARO_SIGN_PASSWORD}" -in "${path_cer}.enc" -out "${path_cer}" -d - openssl aes-256-cbc -k "${PHARO_SIGN_PASSWORD}" -in "${path_p12}.enc" -out "${path_p12}" -d - macos_codesign "${APP_DIR}" "${path_cer}" "${path_p12}" "${PHARO_CERT_PASSWORD}" "${PHARO_SIGN_IDENTITY}" - elif [[ "${FLAVOR}" == "newspeak"* ]]; then - NEW_APP_DIR="${PRODUCTS_DIR}/Newspeak.app" - mv "${APP_DIR}" "${NEW_APP_DIR}" - APP_DIR="${NEW_APP_DIR}" - path_cer="${DEPLOY_DIR}/newspeak/sign.cer" - path_p12="${DEPLOY_DIR}/newspeak/sign.p12" - openssl aes-256-cbc -k "${NEWSPEAK_SIGN_PASSWORD}" -in "${path_cer}.enc" -out "${path_cer}" -d - openssl aes-256-cbc -k "${NEWSPEAK_SIGN_PASSWORD}" -in "${path_p12}.enc" -out "${path_p12}" -d - macos_codesign "${APP_DIR}" "${path_cer}" "${path_p12}" "${NEWSPEAK_CERT_PASSWORD}" "${NEWSPEAK_SIGN_IDENTITY}" - fi - TMP_DMG="temp.dmg" - hdiutil create -size 64m -volname "${IDENTIFIER}" -srcfolder "${APP_DIR}" \ +# Pack the macOS .app as .dmg container +pack_macOS() { + readonly ASSET_EXTENSION="dmg" + readonly APP_PATH="${PRODUCTS_PATH}/${APP_NAME}" + TMP_DMG="temp.${ASSET_EXTENSION}" + hdiutil create -size 64m -volname "${ASSET_NAME}" -srcfolder "${APP_PATH}" \ -fs HFS+ -fsargs "-c c=64,a=16,e=16" -format UDRW -nospotlight "${TMP_DMG}" DEVICE="$(hdiutil attach -readwrite -noautoopen -nobrowse "${TMP_DMG}" | awk 'NR==1{print$1}')" VOLUME="$(mount | grep "$DEVICE" | sed 's/^[^ ]* on //;s/ ([^)]*)$//')" hdiutil detach "$DEVICE" - hdiutil convert "${TMP_DMG}" -format UDBZ -imagekey bzip2-level=9 -o "${IDENTIFIER}.dmg" + hdiutil convert "${TMP_DMG}" -format UDBZ -imagekey bzip2-level=9 -o "${ASSET_NAME}.${ASSET_EXTENSION}" rm -f "${TMP_DMG}" -elif [[ "${APPVEYOR}" ]]; then - cd "./vm" - rm -f *.def *.exp *.lib *.map *.o *.res *Unstripped* # remove temporary build files - zip -r "${PRODUCTS_DIR}/${IDENTIFIER}.zip" "./" -else - echo "Unsupported platform '$(uname -s)'." 1>&2 - exit 90 +} + +# Pack the Windows build as .zip archive +pack_Windows() { + readonly ASSET_EXTENSION="zip" + cd "${APP_NAME}" + rm -f *.def *.exp *.lib *.map *.o *.res *Unstripped* *.ignore # remove temporary build files + 7z a -tzip -r "${PRODUCTS_PATH}/${ASSET_NAME}.${ASSET_EXTENSION}" "./" +} + +if [[ ! -d "${PRODUCTS_PATH}" ]]; then + echo "No products directory found." + exit 10 fi + +if [[ ! $(type -t pack_$RUNNER_OS) ]]; then + echo "Unsupported runner OS ${RUNNER_OS}." + exit 99 +fi + +pushd "${PRODUCTS_PATH}" +pack_$RUNNER_OS popd + +[[ -z "${ASSET_EXTENSION}" ]] && exit 95 +echo "ASSET_EXTENSION=${ASSET_EXTENSION}" >> $GITHUB_ENV diff --git a/deploy/sign-vm.sh b/deploy/sign-vm.sh new file mode 100755 index 0000000000..4d97705b5b --- /dev/null +++ b/deploy/sign-vm.sh @@ -0,0 +1,100 @@ +#!/bin/bash +# Uses: +# - PRODUCTS_PATH +# - APP_NAME +# - *_SIGN_PASSWORD (secret) +# - *_CERT_PASSWORD (secret) +# - *_SIGN_IDENTITY (secret) +set -e + +[[ ! -d "${PRODUCTS_PATH}/${APP_NAME}" ]] && exit 30 + +readonly APP_PATH="${PRODUCTS_PATH}/${APP_NAME}" +readonly KEY_CHAIN=macos-build.keychain + +sign_Linux() { + echo "Not implemented." + exit 999 +} + +sign_macOS() { + local -r cert_path="deploy" + + if [[ "${FLAVOR}" == "squeak"* ]]; then + cert_filepath_cer="${cert_path}/squeak/sign.cer" + cert_filepath_p12="${cert_path}/squeak/sign.p12" + sign_password="${SQUEAK_SIGN_PASSWORD}" + cert_password="${SQUEAK_CERT_PASSWORD}" + sign_identity="${SQUEAK_SIGN_IDENTITY}" + elif [[ "${FLAVOR}" == "pharo"* ]]; then + cert_filepath_cer="${cert_path}/pharo/pharo.cer" + cert_filepath_p12="${cert_path}/pharo/pharo.p12" + sign_password="${PHARO_SIGN_PASSWORD}" + cert_password="${PHARO_CERT_PASSWORD}" + sign_identity="${PHARO_SIGN_IDENTITY}" + elif [[ "${FLAVOR}" == "newspeak"* ]]; then + cert_filepath_cer="${cert_path}/newspeak/sign.cer" + cert_filepath_p12="${cert_path}/newspeak/sign.p12" + sign_password="${NEWSPEAK_SIGN_PASSWORD}" + cert_password="${NEWSPEAK_CERT_PASSWORD}" + sign_identity="${NEWSPEAK_SIGN_IDENTITY}" + else + echo "Unsupported VM flavor ${FLAVOR}." + exit 35 + fi + + if [[ -z "${sign_password}" ]]; then + echo "[Error] No password given to decrypt certificates for ${FLAVOR}. Cannot sign." + exit 234 + fi + + echo "::group::Decrypt certificate files..." + openssl aes-256-cbc \ + -k "${sign_password}" \ + -in "${cert_filepath_cer}.enc" \ + -out "${cert_filepath_cer}" \ + -d + openssl aes-256-cbc \ + -k "${sign_password}" \ + -in "${cert_filepath_p12}.enc" \ + -out "${cert_filepath_p12}" \ + -d + echo "::endgroup::" + + echo "::group::Signing app bundle..." + # Set up keychain + security create-keychain -p travis "${KEY_CHAIN}" + security default-keychain -s "${KEY_CHAIN}" + security unlock-keychain -p travis "${KEY_CHAIN}" + security set-keychain-settings -t 3600 -u "${KEY_CHAIN}" + security import "${cert_filepath_cer}" -k ~/Library/Keychains/"${KEY_CHAIN}" -T /usr/bin/codesign + security import "${cert_filepath_p12}" -k ~/Library/Keychains/"${KEY_CHAIN}" -P "${cert_password}" -T /usr/bin/codesign + security set-key-partition-list -S apple-tool:,apple: -s -k travis "${KEY_CHAIN}" + # Invoke codesign + if [[ -d "${APP_PATH}/Contents/MacOS/Plugins" ]]; then + # Pharo.app does not (yet) have its plugins in Resources dir + codesign -s "${sign_identity}" --force --deep "${APP_PATH}/Contents/MacOS/Plugins/"* + fi + codesign -s "${sign_identity}" --force --deep "${APP_PATH}" + # Remove sensitive files again + rm -rf "${cert_filepath_cer}" "${cert_filepath_p12}" + security delete-keychain "${KEY_CHAIN}" + echo "::endgroup::" +} + +sign_Windows() { + echo "Not implemented." + exit 999 +} + +if [[ ! -d "${PRODUCTS_PATH}" ]]; then + echo "No products directory found." + exit 10 +fi + +if [[ ! $(type -t sign_$RUNNER_OS) ]]; then + echo "Unsupported runner OS ${RUNNER_OS}." + exit 99 +fi + +sign_$RUNNER_OS diff --git a/platforms/Cross/plugins/IA32ABI/ia32abi.h b/platforms/Cross/plugins/IA32ABI/ia32abi.h index 7f981d79cf..5774701489 100644 --- a/platforms/Cross/plugins/IA32ABI/ia32abi.h +++ b/platforms/Cross/plugins/IA32ABI/ia32abi.h @@ -101,3 +101,7 @@ extern thunkEntryType thunkEntry (INT_REG_ARGS DBL_REG_ARGS void *,sqIntptr_t * extern void *allocateExecutablePage(sqIntptr_t *pagesize); extern VMCallbackContext *getMostRecentCallbackContext(void); #undef thunkEntryType + +#if NewspeakVM +int ioDrainEventQueue(void); +#endif diff --git a/platforms/unix/vm/sqUnixMemory.c b/platforms/unix/vm/sqUnixMemory.c index b8b7f350b1..17d5343a26 100644 --- a/platforms/unix/vm/sqUnixMemory.c +++ b/platforms/unix/vm/sqUnixMemory.c @@ -427,7 +427,7 @@ allocateJITMemory(usqInt *desiredSize) exit(1); } // Note the address for sqAllocateMemory above - endOfJITZone = (char *)result + *desiredSize; + // endOfJITZone = (char *)result + *desiredSize; return result; } diff --git a/scripts/ci/actions_build.sh b/scripts/ci/actions_build.sh new file mode 100755 index 0000000000..a69f624b4b --- /dev/null +++ b/scripts/ci/actions_build.sh @@ -0,0 +1,182 @@ +#!/bin/bash +set -e + +# This script locates and executes the platform and flavor-specific +# build scripts, which are typically Makefile-based, to compile and +# link the configured VM flavor. It then copies the build artifacts to +# to the ./products directory for subsequent steps such as signing and +# packing and deploying. +# +# This script uses/requires to following variables: +# - ARCH (e.g., "macos64x64") +# - ARCH_ARM (only set for ARM builds in docker container) +# - FLAVOR (e.g., "squeak.cog.spur") +# - RUNNER_OS (i.e., "Linux", "macOS", "Windows") +# - HEARTBEAT (i.e., "threaded" or "itimer"; !! Linux only !!) +# +# This script provides variables for subsequent steps: +# - ASSET_REVISION (e.g., "202107261048") +# - ASSET_NAME (e.g., "squeak.cog.spur_macos64x64") +# - PRODUCTS_PATH (e.g., "products") +# - APP_NAME (e.g., "vm" or "sqcogspur64linuxht" or "Squeak.app") + + + +if [[ "${RUNNER_OS}" == "Windows" ]]; then + source ./scripts/ci/actions_prepare_msys.sh +fi + +echo "$(cat platforms/Cross/vm/sqSCCSVersion.h | .git_filters/RevDateURL.smudge)" > platforms/Cross/vm/sqSCCSVersion.h +echo "$(cat platforms/Cross/plugins/sqPluginsSCCSVersion.h | .git_filters/RevDateURL.smudge)" > platforms/Cross/plugins/sqPluginsSCCSVersion.h + +[[ -z "${ARCH}" ]] && exit 2 +[[ -z "${FLAVOR}" ]] && exit 3 + +readonly ASSET_REVISION=$(grep -m1 "SvnRawRevisionString" "platforms/Cross/vm/sqSCCSVersion.h" | sed 's/[^0-9.]*\([0-9.]*\).*/\1/') + +ASSET_NAME="${FLAVOR}_${ARCH}" +BUILD_PATH="$(pwd)/build.${ARCH}/${FLAVOR}" + +PRODUCTS_PATH="$(pwd)/products" +mkdir "${PRODUCTS_PATH}" || true # ensure PRODUCTS_PATH exists + +check_buildPath() { + if [[ ! -d "${BUILD_PATH}" ]]; then + echo "Build path does not exist: ${BUILD_PATH}" + exit 11 + fi +} + +skip_BochsPlugins() { + echo "Skipping Bochs plugins..." + sed -i 's/Bochs.* //g' plugins.ext + sed -i 's/Bochs.* //g' plugins.int +} + +export_variable() { + local var_name=$1 + local var_value=$2 + if [[ ! -z "${ARCH_ARM}" ]]; then + # We are in a docker container. See https://github.com/uraimo/run-on-arch-action + echo "::set-output name=${var_name}::${var_value}" + else + echo "${var_name}=${var_value}" >> $GITHUB_ENV + fi +} + +# export COGVREV="$(git describe --tags --always)" +# export COGVDATE="$(git show -s --format=%cd HEAD)" +# export COGVURL="$(git config --get remote.origin.url)" +# export COGVOPTS="-DCOGVREV=\"${COGVREV}\" -DCOGVDATE=\"${COGVDATE// /_}\" -DCOGVURL=\"${COGVURL//\//\\\/}\"" + +build_Linux() { + echo '::group::Running "make configure" in platforms/unix/config ...' + (cd platforms/unix/config/ && make configure) + echo '::endgroup::' + + BUILD_PATH="${BUILD_PATH}/build" + if [[ "${MODE}" == "debug" ]]; then + BUILD_PATH="${BUILD_PATH}.debug" + PRODUCTS_PATH="${PRODUCTS_PATH}/debug" + elif [[ "${MODE}" == "assert" ]]; then + BUILD_PATH="${BUILD_PATH}.assert" + PRODUCTS_PATH="${PRODUCTS_PATH}/assert" + fi + + if [[ ! -z "$HEARTBEAT" ]] && [[ "${HEARTBEAT}" != "threaded" ]]; then + BUILD_PATH="${BUILD_PATH}.itimerheartbeat" + ASSET_NAME="${ASSET_NAME}_itimer" + fi + + pushd "${BUILD_PATH}" + + echo "::group::Building ${BUILD_PATH}..." + echo n | bash -e ./mvm || exit 1 + echo "::endgroup::" + + cd "${PRODUCTS_PATH}" + readonly APP_NAME=$(find * -type d | head -n 1) + + popd +} + +build_macOS() { + check_buildPath + + pushd "${BUILD_PATH}" + + echo "::group::Building ${BUILD_PATH}..." + if [[ "${MODE}" == "debug" ]]; then + bash -e ./mvm -d || exit 1 + elif [[ "${MODE}" == "assert" ]]; then + bash -e ./mvm -a || exit 1 + else + bash -e ./mvm -f || exit 1 + fi + echo "::endgroup::" + + echo "::group::Moving build artifacts to ${PRODUCTS_PATH}..." + if [[ "${FLAVOR}" == "newspeak"* ]]; then + # TODO: Why does the Newspeak flavor have to wrong name? Should be set in its build scripts (or Makefile ...) + mv ./*.app "${PRODUCTS_PATH}/Newspeak.app" + else + mv ./*.app "${PRODUCTS_PATH}/" + fi + echo "::endgroup::" + + cd "${PRODUCTS_PATH}" + readonly APP_NAME=$(find * -type d -path "*.app" | head -n 1) + + popd +} + +build_Windows() { + check_buildPath + pushd "${BUILD_PATH}" + + echo "::group::Building ${BUILD_PATH}..." + skip_BochsPlugins + if [[ "${MODE}" == "debug" ]]; then + bash -e ./mvm -d || exit 1 + elif [[ "${MODE}" == "assert" ]]; then + bash -e ./mvm -a || exit 1 + else + bash -e ./mvm -f || exit 1 + fi + echo "::endgroup::" + + echo "::group::Moving build artifacts to ${PRODUCTS_PATH}..." + if [[ "${MODE}" == "debug" ]]; then + mv "./builddbg/vm" "${PRODUCTS_PATH}/" + elif [[ "${MODE}" == "assert" ]]; then + mv "./buildast/vm" "${PRODUCTS_PATH}/" + else + mv "./build/vm" "${PRODUCTS_PATH}/" + fi + echo "::endgroup::" + + readonly APP_NAME="vm" + + popd +} + +if [[ ! $(type -t build_$RUNNER_OS) ]]; then + echo "Unsupported runner OS ${RUNNER_OS}." + exit 99 +fi + +build_$RUNNER_OS + +if [[ "${MODE}" == "debug" ]]; then + ASSET_NAME="${ASSET_NAME}_debug" +elif [[ "${MODE}" == "assert" ]]; then + ASSET_NAME="${ASSET_NAME}_assert" +fi + +export_variable "ASSET_REVISION" "${ASSET_REVISION}" +export_variable "ASSET_NAME" "${ASSET_NAME}" + +[[ ! -d "${PRODUCTS_PATH}" ]] && exit 13 +export_variable "PRODUCTS_PATH" "${PRODUCTS_PATH}" +[[ ! -d "${PRODUCTS_PATH}/${APP_NAME}" ]] && exit 14 +export_variable "APP_NAME" "${APP_NAME}" diff --git a/scripts/ci/actions_prepare_linux_arm.sh b/scripts/ci/actions_prepare_linux_arm.sh new file mode 100755 index 0000000000..894b9a8303 --- /dev/null +++ b/scripts/ci/actions_prepare_linux_arm.sh @@ -0,0 +1,17 @@ +#!/bin/bash +set -e + +# This script installs all packages required to build the various VM +# flavors in an ARM-compatible environment such as via QEMU or on a +# Raspberry Pi. For simplicity, the packages should cover all possible +# plugins even if those are not compiled in a particular build +# configuration. +# +# Note that "libtool automake autoconf libltdl-dev" are required to +# let the configure script pass. + +apt-get update -y +apt-get install -yq --no-install-suggests --no-install-recommends build-essential git devscripts uuid-dev libcairo2-dev libpango1.0-dev libgl1-mesa-dev libgl1-mesa-glx libssl-dev libevdev-dev m4 libpulse-dev libasound2-dev libfreetype6-dev libx11-dev libxrender-dev libtool automake autoconf libltdl-dev + +# Other packages found in older build scripts, ignored for now: +# uuid-runtime libsm-dev libice-dev cmake diff --git a/scripts/ci/actions_prepare_linux_x86.sh b/scripts/ci/actions_prepare_linux_x86.sh new file mode 100755 index 0000000000..a7b16f5a1e --- /dev/null +++ b/scripts/ci/actions_prepare_linux_x86.sh @@ -0,0 +1,68 @@ +#!/bin/bash +set -e + +# This script installs all packages required to build the various VM +# flavors in an x86-compatible environment. It supports both 32-bit +# and #64-bit architectures, which means that the host Linux platform +# has to support the older i386 packages to make 32-bit compile. + +if [[ "${ARCH}" = "linux64x64" ]]; then + sudo apt-get update -y + sudo apt-get install -yq --no-install-suggests --no-install-recommends --allow-unauthenticated \ + debhelper \ + devscripts \ + libasound2-dev \ + libc6-dev \ + libssl-dev \ + libfreetype6-dev \ + libx11-dev \ + libxext-dev \ + libxrender-dev \ + libpango1.0-dev \ + libpulse-dev \ + libaudio-dev \ + libsndio-dev \ + gcc-multilib \ + uuid-dev \ + libglu1-mesa-dev \ + automake \ + autoconf \ + libtool \ + curl \ + cmake +elif [[ "${ARCH}" = "linux32x86" ]]; then + sudo dpkg --add-architecture i386 + sudo apt-get update -y + sudo apt-get remove -q -y gvfs-daemons + sudo apt-get install -yq --no-install-suggests --no-install-recommends --allow-unauthenticated \ + devscripts \ + libc6-dev:i386 \ + libasound2:i386 \ + libasound2-dev:i386 \ + libssl-dev:i386 \ + libpng-dev:i386 \ + libfreetype6-dev:i386 \ + libx11-dev:i386 \ + libsm-dev:i386 \ + libice-dev:i386 \ + libgl1-mesa-glx:i386 \ + libgl1-mesa-dev:i386 \ + libxext-dev:i386 \ + libxrender-dev:i386 \ + libglapi-mesa:i386 \ + libcairo2-dev:i386 \ + libpango1.0-dev:i386 \ + libglib2.0-dev:i386 \ + libxft-dev:i386 \ + gir1.2-pango-1.0:i386 \ + gir1.2-freedesktop:i386 \ + gir1.2-glib-2.0:i386 \ + libgirepository-1.0-1:i386 \ + libpulse-dev:i386 \ + libaudio-dev:i386 \ + libsndio-dev:i386 \ + gcc-multilib \ + uuid-dev:i386 \ + libcurl4-openssl-dev:i386 \ + libssh2-1-dev:i386 +fi diff --git a/scripts/ci/actions_prepare_msys.sh b/scripts/ci/actions_prepare_msys.sh new file mode 100755 index 0000000000..f32f883601 --- /dev/null +++ b/scripts/ci/actions_prepare_msys.sh @@ -0,0 +1,28 @@ +#!/bin/bash +# +# Prepare MSYS environment so that all build tools have the $(TOOLPREFIX) as +# expected in Makefile.tools: +# - win64x64\common\Makefile.tools +# - win32x86\common\Makefile.tools +# Also, extend $PATH since MSYS is installed but not conveniently accessible +# in a GitHub-Actions Windows environment. + +[[ -z "${MSYS_SYS}" ]] && exit 2 +[[ -z "${MSYS_ENV}" ]] && exit 2 + +ln -f -s /c/msys64/${MSYS_SYS}/bin/clang /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-clang +ln -f -s /c/msys64/${MSYS_SYS}/bin/clang++ /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-clang++ +ln -f -s /c/msys64/${MSYS_SYS}/bin/ar /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-ar +ln -f -s /c/msys64/${MSYS_SYS}/bin/dlltool /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-dlltool +ln -f -s /c/msys64/${MSYS_SYS}/bin/as /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-as +ln -f -s /c/msys64/${MSYS_SYS}/bin/windres /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-windres +ln -f -s /c/msys64/${MSYS_SYS}/bin/nm /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-nm +ln -f -s /c/msys64/${MSYS_SYS}/bin/dllwrap /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-dllwrap +ln -f -s /c/msys64/${MSYS_SYS}/bin/strip /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-strip +ln -f -s /c/msys64/${MSYS_SYS}/bin/objcopy /c/msys64/${MSYS_SYS}/bin/${MSYS_ENV}-w64-mingw32-objcopy + +# Add MinGW tools for build scripts +PATH=$PATH:/c/msys64/${MSYS_SYS}/bin + +# Add other GNU tools (e.g., wget) for third-party build scripts +PATH=$PATH:/c/msys64/usr/bin diff --git a/scripts/ci/travis_build.sh b/scripts/ci/travis_build.sh deleted file mode 100755 index 946ba595af..0000000000 --- a/scripts/ci/travis_build.sh +++ /dev/null @@ -1,142 +0,0 @@ -#!/bin/bash -set -e - -source ./scripts/ci/travis_helpers.sh - -if [[ "${APPVEYOR}" ]]; then - TRAVIS_BUILD_DIR="$(pwd)" - TRAVIS_TAG="${APPVEYOR_REPO_TAG}" - PLATFORM="windows" - - # Appveyor's GCC is pretty new, patch the Makefiles and replace the tools to - # make it work - - echo - echo "Using gcc $(i686-w64-mingw32-gcc --version)" - echo "Using 64-bit gcc $(x86_64-w64-mingw32-gcc --version)" - echo - test -d /usr/i686-w64-mingw32/sys-root/mingw/lib || echo "No lib dir" - test -d /usr/i686-w64-mingw32/sys-root/mingw/include || echo "No inc dir" -else - PLATFORM="${TRAVIS_OS_NAME}" -fi - -[[ -z "${ARCH}" ]] && exit 2 -[[ -z "${FLAVOR}" ]] && exit 3 - -if [[ "${ARCH}" == "linux32ARM"* ]]; then - # we're in chroot at this point - export LC_ALL=C - export LC_CTYPE=C - export LANG=C - export LANGUAGE=C - TRAVIS_BUILD_DIR="$(pwd)" -fi - -echo "$(cat platforms/Cross/vm/sqSCCSVersion.h | .git_filters/RevDateURL.smudge)" > platforms/Cross/vm/sqSCCSVersion.h -echo "$(cat platforms/Cross/plugins/sqPluginsSCCSVersion.h | .git_filters/RevDateURL.smudge)" > platforms/Cross/plugins/sqPluginsSCCSVersion.h - -# echo $PATH -if [[ "${BUILD_WITH_CMAKE}" == "yes" ]]; then - [[ -z "${CPU_ARCH}" ]] && exit 2 - PLATFORM="minheadless_with_cmake" - BUILD_DIRECTORY="$(pwd)/build.minheadless.cmake/${CPU_ARCH}/${FLAVOR}"; -else - BUILD_DIRECTORY="$(pwd)/build.${ARCH}/${FLAVOR}"; -fi -readonly BUILD_DIRECTORY -readonly PRODUCTS_DIR="$(pwd)/products" -mkdir "${PRODUCTS_DIR}" || true # ensure PRODUCTS_DIR exists - -export COGVREV="$(git describe --tags --always)" -export COGVDATE="$(git show -s --format=%cd HEAD)" -export COGVURL="$(git config --get remote.origin.url)" -export COGVOPTS="-DCOGVREV=\"${COGVREV}\" -DCOGVDATE=\"${COGVDATE// /_}\" -DCOGVURL=\"${COGVURL//\//\\\/}\"" - -build_linux_in() { - local build_dir=$1 - local fold_name=$2 - - [[ ! -d "${build_dir}" ]] && exit 10 - - pushd "${build_dir}" - travis_fold start "${fold_name}" "Building OpenSmalltalk VM in ${build_dir}..." - echo n | bash -e ./mvm - travis_fold end "${fold_name}" - # cat config.log - popd -} - -build_linux() { - travis_fold start 'unix_configure' 'Running "make config" in platforms/unix/config ...' - (cd platforms/unix/config/ && make configure) - travis_fold end 'unix_configure' - - # build will include both, threaded and itimer version unless - # HEARTBEAT variable is set, in which case just one of both - # will be built. - # HEARTBEAT can be "threaded" or "itimer" - - if [ -z "$HEARTBEAT" ] || [ "$HEARTBEAT" = "threaded" ]; then - build_linux_in "${BUILD_DIRECTORY}/build" "build_vm" - fi - - # Also build VM with itimerheartbeat if available - if [[ ! -d "${BUILD_DIRECTORY}/build.itimerheartbeat" ]]; then - return - fi - - if [ -z "$HEARTBEAT" ] || [ "$HEARTBEAT" = "itimer" ]; then - build_linux_in "${BUILD_DIRECTORY}/build.itimerheartbeat" "build_itimer_vm" - fi -} - -build_osx() { - [[ ! -d "${BUILD_DIRECTORY}" ]] && exit 50 - - pushd "${BUILD_DIRECTORY}" - - travis_fold start build_vm "Building OpenSmalltalk VM..." - bash -e ./mvm -f - travis_fold end build_vm - - mv ./*.app "${PRODUCTS_DIR}/" # Move app to PRODUCTS_DIR - popd -} - -build_windows() { - [[ ! -d "${BUILD_DIRECTORY}" ]] && exit 100 - - pushd "${BUILD_DIRECTORY}" - echo "Removing bochs plugins..." - sed -i 's/Bochs.* //g' plugins.ext - - echo "Building OpenSmalltalk VM for Windows..." - # We cannot zip dbg and ast if we pass -f to just to the full thing... - # Once this builds, let's pass -A instead of -f and put the full zip (but we should do several zips in the future) - bash -e ./mvm -f || exit 1 - # zip -r "${output_file}.zip" "./builddbg/vm/" "./buildast/vm/" "./build/vm/" - mv "./build/vm" "${PRODUCTS_DIR}/" # Move result to PRODUCTS_DIR - popd -} - -build_minheadless_with_cmake() { - [[ ! -d "${BUILD_DIRECTORY}" ]] && exit 150 - - local vm_variant_name="${FLAVOR}_minheadless-cmake_${ARCH}" - - pushd "${BUILD_DIRECTORY}" - travis_fold start build_vm "Building OpenSmalltalk VM..." - bash -e ./mvm -f || exit 1 - mv ./release/install-dist/* "${PRODUCTS_DIR}/" - travis_fold end build_vm - popd - -} - -if [[ ! $(type -t build_$PLATFORM) ]]; then - echo "Unsupported platform '$(uname -s)'." 1>&2 - exit 99 -fi - -build_$PLATFORM diff --git a/scripts/ci/travis_helpers.sh b/scripts/ci/travis_helpers.sh deleted file mode 100755 index fc55f44dff..0000000000 --- a/scripts/ci/travis_helpers.sh +++ /dev/null @@ -1,12 +0,0 @@ -travis_fold() { - local action=$1 - local name=$2 - local title="${3:-}" - - if [[ "${TRAVIS:-}" = "true" ]]; then - echo -en "travis_fold:${action}:${name}\r\033[0K" - fi - if [[ -n "${title}" ]]; then - echo -e "\033[34;1m${title}\033[0m" - fi -} diff --git a/scripts/ci/travis_install.sh b/scripts/ci/travis_install.sh deleted file mode 100755 index 73150eb875..0000000000 --- a/scripts/ci/travis_install.sh +++ /dev/null @@ -1,144 +0,0 @@ -set -e - -if [[ "${ARCH}" = "linux64x64" ]]; then - sudo apt-get update -y - sudo apt-get install -yq --no-install-suggests --no-install-recommends --force-yes \ - debhelper \ - devscripts \ - libasound2-dev \ - libc6-dev \ - libssl-dev \ - libfreetype6-dev \ - libx11-dev \ - libxext-dev \ - libxrender-dev \ - libpango1.0-dev \ - libpulse-dev \ - libaudio-dev \ - libsndio-dev \ - gcc-multilib \ - uuid-dev \ - libglu1-mesa-dev \ - automake \ - autoconf \ - libtool \ - curl \ - cmake -elif [[ "${ARCH}" = "linux32x86" ]]; then - sudo apt-get update -y - sudo apt-get remove -q -y gvfs-daemons - sudo apt-get install -yq --no-install-suggests --no-install-recommends --force-yes \ - devscripts \ - libc6-dev:i386 \ - libasound2:i386 \ - libasound2-dev:i386 \ - libssl-dev:i386 \ - libssl0.9.8:i386 \ - libpng-dev:i386 \ - libfreetype6-dev:i386 \ - libx11-dev:i386 \ - libsm-dev:i386 \ - libice-dev:i386 \ - libgl1-mesa-glx:i386 \ - libgl1-mesa-dev:i386 \ - libxext-dev:i386 \ - libxrender-dev:i386 \ - libglapi-mesa:i386 \ - libcairo2-dev:i386 \ - libpango1.0-dev:i386 \ - libglib2.0-dev:i386 \ - libxft-dev:i386 \ - gir1.2-pango-1.0:i386 \ - gir1.2-freedesktop:i386 \ - gir1.2-glib-2.0:i386 \ - libgirepository-1.0-1:i386 \ - libpulse-dev:i386 \ - libaudio-dev:i386 \ - libsndio-dev:i386 \ - gcc-multilib \ - uuid-dev:i386 \ - libcurl4-openssl-dev:i386 \ - libssh2-1-dev:i386 -fi - -[[ "${ARCH}" != "linux32ARMv6" ]] && exit 0 - -MIRROR=http://archive.raspbian.org/raspbian -VERSION=jessie -# TOOLS_DIR=$PWD/tools -ARMCHROOT=$PWD/armchroot - -sudo dpkg --add-architecture i386 -sudo apt-add-repository multiverse -sudo apt-add-repository universe -sudo apt-get update -myq || true - -sudo apt-get update -y -sudo apt-get install -yq --no-install-suggests --no-install-recommends --force-yes \ - gcc-arm-linux-gnueabi \ - gcc-arm-linux-gnueabihf \ - qemu-system \ - qemu-system-arm \ - qemu-user \ - qemu-user-static \ - sbuild \ - schroot \ - scratchbox2 \ - debootstrap \ - zlib1g:i386 \ - libstdc++6:i386 \ - libffi-dev:i386 \ - libffi6:i386 \ - libssl1.0.0:i386 \ - libbz2-1.0:i386 \ - libc6-dev-i386 \ - libc6:i386 \ - libexpat1:i386 \ - libtinfo5:i386 \ - binfmt-support \ - build-essential \ - python-dev \ - libffi-dev \ - zlib1g-dev \ - libtool \ - automake \ - autoconf - -sudo chown $USER /etc/schroot/schroot.conf -echo " -[rpi] -directory=$ARMCHROOT -users=$USER -root-users=$USER -groups=$USER -aliases=default -type=directory -" >> /etc/schroot/schroot.conf -cat /etc/schroot/schroot.conf -sudo chown root /etc/schroot/schroot.conf - -# git clone https://github.com/raspberrypi/tools.git $TOOLS_DIR - -# chroot -if [ ! -e "$ARMCHROOT/etc/debian_chroot" ]; then - mkdir -p $ARMCHROOT - sudo qemu-debootstrap --no-check-gpg --include=fakeroot,build-essential --arch=armhf ${VERSION} ${ARMCHROOT} ${MIRROR} - sudo su -c "echo \"deb ${MIRROR} jessie main contrib rpi\" > ${ARMCHROOT}/etc/apt/sources.list" - schroot -c rpi -u root -- apt-get update - schroot -c rpi -u root -- apt-get --allow-unauthenticated install -y \ - build-essential libcairo2-dev libpango1.0-dev libssl-dev uuid-dev uuid-runtime libasound2-dev \ - debhelper devscripts libssl-dev libfreetype6-dev libx11-dev libxext-dev libxrender-dev \ - libx11-dev libsm-dev libice-dev libgl1-mesa-dev libgl1-mesa-glx git \ - libtool automake autoconf - #needed for third-party libraries - schroot -c rpi -u root -- apt-get --allow-unauthenticated install -y cmake curl -fi -schroot -c rpi -- uname -m - -sudo mount -o remount,size=100M /tmp || echo "No tmp size increase required" - -# Use Scratchbox2 for faster compilation -# pushd $ARMCHROOT -# sb2-init -c `which qemu-arm` rpi $TOOLS_DIR/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf-gcc -# sb2-config -d rpi -# popd diff --git a/src/plugins/EventsHandlerPlugin/EventsHandlerPlugin.c b/src/plugins/EventsHandlerPlugin/EventsHandlerPlugin.c index 12ee96a726..ca22f6cafb 100644 --- a/src/plugins/EventsHandlerPlugin/EventsHandlerPlugin.c +++ b/src/plugins/EventsHandlerPlugin/EventsHandlerPlugin.c @@ -6,7 +6,7 @@ static char __buildInfo[] = "EventsHandlerPlugin EventsHandlerPlugin-EstebanLorenzano.1 uuid: 1516ba00-d8f9-4928-93cf-a46ad8e46d70 " __DATE__ ; - +#include "config.h" #include #include #include diff --git a/src/plugins/FT2Plugin/FT2Plugin.c b/src/plugins/FT2Plugin/FT2Plugin.c index 91038c1777..49632bc4a1 100644 --- a/src/plugins/FT2Plugin/FT2Plugin.c +++ b/src/plugins/FT2Plugin/FT2Plugin.c @@ -6,7 +6,7 @@ static char __buildInfo[] = "FT2Plugin Freetype-Plugin-EstebanLorenzano.70 uuid: 3729adbd-b383-456b-96ec-dac31cd293f8 " __DATE__ ; - +#include "config.h" #include #include #include