Skip to content

Commit

Permalink
Merge pull request #1 from theavege/add/github-actions
Browse files Browse the repository at this point in the history
add github-actions
  • Loading branch information
andreaspeters authored Dec 27, 2024
2 parents 68a76dd + 1d94eb2 commit ee4f7f8
Show file tree
Hide file tree
Showing 7 changed files with 258 additions and 0 deletions.
7 changes: 7 additions & 0 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
version: 2
updates:
- package-ecosystem: "github-actions"
directory: "/"
schedule:
interval: "monthly"
42 changes: 42 additions & 0 deletions .github/workflows/make.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
---
name: Make

on:
schedule:
- cron: '0 0 1 * *'
push:
branches:
- "**"
pull_request:
branches:
- master
- main

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

jobs:
build:
runs-on: ${{ matrix.os }}
timeout-minutes: 120
strategy:
matrix:
os:
- ubuntu-latest
- windows-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
submodules: true

- name: Build on Linux
if: runner.os == 'Linux'
shell: bash
run: bash make.sh build

- name: Build on Windows
if: runner.os == 'Windows'
shell: powershell
run: pwsh -File make.ps1 build
3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[submodule "use/LazMapViewer"]
path = use/LazMapViewer
url = [email protected]:wp-xyz/LazMapViewer.git
118 changes: 118 additions & 0 deletions make.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
#!/usr/bin/env pwsh
##############################################################################################################

Function Show-Usage {
"
Usage: pwsh -File $($PSCommandPath) [OPTIONS]
Options:
build Build program
" | Out-Host
}

Function Request-File {
While ($Input.MoveNext()) {
$VAR = @{
Uri = $Input.Current
OutFile = (Split-Path -Path $Input.Current -Leaf).Split('?')[0]
}
Invoke-WebRequest @VAR
Return $VAR.OutFile
}
}

Function Install-Program {
While ($Input.MoveNext()) {
Switch ((Split-Path -Path $Input.Current -Leaf).Split('.')[-1]) {
'msi' {
& msiexec /passive /package $Input.Current | Out-Null
}
Default {
& ".\$($Input.Current)" /SP- /VERYSILENT /SUPPRESSMSGBOXES /NORESTART | Out-Null
}
}
Remove-Item $Input.Current
}
}

Function Build-Project {
@(
@{
Cmd = 'lazbuild'
Url = 'https://fossies.org/windows/misc/lazarus-3.6-fpc-3.2.2-win64.exe'
Path = "C:\Lazarus"
}
) | Where-Object { ! (Test-Path -Path $_.Path) } |
ForEach-Object {
$_.Url | Request-File | Install-Program
$Env:PATH+=";$($_.Path)"
(Get-Command $_.Cmd).Source | Out-Host
}
If (Test-Path -Path '.gitmodules') {
& git submodule update --init --recursive --force --remote | Out-Host
".... [[$($LastExitCode)]] git submodule update" | Out-Host
}
$Env:Ext = '0'
$Env:Src = 'src'
$Env:Use = 'use'
$Env:Pkg = 'use\components.txt'
If (Test-Path -Path $Env:Use) {
If (Test-Path -Path $Env:Pkg) {
Get-Content -Path $Env:Pkg |
Where-Object {
! (Test-Path -Path "$($Env:Use)\$($_)") &&
! (& lazbuild --verbose-pkgsearch $_ ) &&
! (& lazbuild --add-package $_)
} | ForEach-Object {
Return @{
Uri = "https://packages.lazarus-ide.org/$($_).zip"
Path = "$($Env:Use)\$($_)"
OutFile = (New-TemporaryFile).FullName
}
} | ForEach-Object -Parallel {
Invoke-WebRequest -OutFile $_.OutFile -Uri $_.Uri
Expand-Archive -Path $_.OutFile -DestinationPath $_.Path
Remove-Item $_.OutFile
Return ".... download $($_.Uri)"
} | Out-Host
}
(Get-ChildItem -Filter '*.lpk' -Recurse -File –Path $Env:Use).FullName |
ForEach-Object {
& lazbuild --add-package-link $_ | Out-Host
Return ".... [$($LastExitCode)] add package link $($_)"
} | Out-Host
}
(Get-ChildItem -Filter '*.lpi' -Recurse -File –Path $Env:Src).FullName |
ForEach-Object {
$Output = (& lazbuild --build-all --recursive --no-write-project --build-mode='release' $_)
$Result = @(".... [$($LastExitCode)] build project $($_)")
If ($LastExitCode -eq 0) {
$Result += $Output | Select-String -Pattern 'Linking'
} Else {
$Env:Ext = [Int]$Env:Ext + 1
$Result += $Output | Select-String -Pattern 'Error:', 'Fatal:'
}
$Result | Out-Host
}
Exit [Int]$Env:Ext
}

Function Switch-Action {
$ErrorActionPreference = 'stop'
Set-PSDebug -Strict #-Trace 1
Invoke-ScriptAnalyzer -EnableExit -Path $PSCommandPath
If ($args.count -gt 0) {
Switch ($args[0]) {
'build' {
Build-Project
}
Default {
Show-Usage
}
}
} Else {
Show-Usage
}
}

##############################################################################################################
Switch-Action @args | Out-Null
84 changes: 84 additions & 0 deletions make.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
#!/usr/bin/env bash

function priv_clippit
(
cat <<EOF
Usage: bash ${0} [OPTIONS]
Options:
build Build program
EOF
)

function priv_lazbuild
(
if ! (command -v lazbuild); then
source '/etc/os-release'
case ${ID:?} in
debian | ubuntu)
sudo apt-get update
sudo apt-get install -y lazarus{-ide-qt5,} &
;;
esac
fi
if [[ -f '.gitmodules' ]]; then
git submodule update --init --recursive --force --remote &
fi
wait
declare -rA VAR=(
[src]='src'
[use]='use'
[pkg]='use/components.txt'
)
if [[ -d "${VAR[use]}" ]]; then
if [[ -f "${VAR[pkg]}" ]]; then
while read -r; do
if [[ -n "${REPLY}" ]] &&
! [[ -d "${VAR[use]}/${REPLY}" ]] &&
! (lazbuild --verbose-pkgsearch "${REPLY}") &&
! (lazbuild --add-package "${REPLY}"); then
declare -A TMP=(
[url]="https://packages.lazarus-ide.org/${REPLY}.zip"
[dir]="${VAR[use]}/${REPLY}"
[out]=$(mktemp)
)
wget --quiet --output-document "${TMP[out]}" "${TMP[url]}"
unzip -o "${TMP[out]}" -d "${TMP[dir]}"
rm --verbose "${TMP[out]}"
fi
done < "${VAR[pkg]}"
fi
find "${VAR[use]}" -type 'f' -name '*.lpk' -printf '\033[32m\tadd package link\t%p\033[0m\n' -exec \
lazbuild --add-package-link {} + 1>&2
fi
declare -i errors=0
while read -r; do
declare -A TMP=(
[out]=$(mktemp)
)
if (lazbuild --build-all --recursive --no-write-project --build-mode='release' --widgetset='qt5' "${REPLY}" > "${TMP[out]}"); then
printf '\x1b[32m\t[%s]\t%s\x1b[0m\n' "${?}" "${REPLY}"
grep --color='always' 'Linking' "${TMP[out]}"
else
printf '\x1b[31m\t[%s]\t%s\x1b[0m\n' "${?}" "${REPLY}"
grep --color='always' --extended-regexp '(Error|Fatal):' "${TMP[out]}"
((errors+=1))
fi 1>&2
rm "${TMP[out]}"
done < <(find "${VAR[src]}" -type 'f' -name '*.lpi' | sort)
exit "${errors}"
)

function priv_main
(
set -euo pipefail
if ((${#})); then
case ${1} in
build) priv_lazbuild ;;
*) priv_clippit ;;
esac
else
priv_clippit
fi
)

priv_main "${@}" >/dev/null
1 change: 1 addition & 0 deletions use/LazMapViewer
Submodule LazMapViewer added at 7a1464
3 changes: 3 additions & 0 deletions use/components.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
RichMemo
LazRGBGraphics
BGRABitmap

0 comments on commit ee4f7f8

Please sign in to comment.