Refactor build process and streamline executable handling

This commit is contained in:
netkas 2024-12-27 15:27:57 -05:00
parent 015f13bf12
commit 9e97a6d414
4 changed files with 134 additions and 180 deletions

View file

@ -51,7 +51,7 @@ jobs:
- name: Build project - name: Build project
run: | run: |
ncc build --config release --log-level debug ncc build --config release --build-source --log-level debug
- name: Upload build artifact - name: Upload build artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
@ -100,111 +100,13 @@ jobs:
- name: Build project - name: Build project
run: | run: |
ncc build --config debug --log-level debug ncc build --config debug --build-source --log-level debug
- name: Upload build artifact - name: Upload build artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: debug name: debug
path: build/debug/net.nosial.configlib.ncc path: build/debug/net.nosial.configlib.ncc
release-compressed:
runs-on: ubuntu-latest
container:
image: php:8.3
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install dependencies
run: |
apt update -yqq
apt install git libpq-dev libzip-dev zip make wget gnupg -yqq
- name: Install phive
run: |
wget -O phive.phar https://phar.io/releases/phive.phar
wget -O phive.phar.asc https://phar.io/releases/phive.phar.asc
gpg --keyserver hkps://keys.openpgp.org --recv-keys 0x9D8A98B29B2D5D79
gpg --verify phive.phar.asc phive.phar
chmod +x phive.phar
mv phive.phar /usr/local/bin/phive
- name: Install phab
run: |
phive install phpab --global --trust-gpg-keys 0x2A8299CE842DD38C
- name: Install latest version of NCC
run: |
git clone https://git.n64.cc/nosial/ncc.git
cd ncc
make redist
NCC_DIR=$(find build/ -type d -name "ncc_*" | head -n 1)
if [ -z "$NCC_DIR" ]; then
echo "NCC build directory not found"
exit 1
fi
php "$NCC_DIR/INSTALL" --auto
cd .. && rm -rf ncc
- name: Build project
run: |
ncc build --config release-compressed --log-level debug
- name: Upload build artifact
uses: actions/upload-artifact@v4
with:
name: release-compressed
path: build/release/net.nosial.configlib.gz.ncc
debug-compressed:
runs-on: ubuntu-latest
container:
image: php:8.3
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install dependencies
run: |
apt update -yqq
apt install git libpq-dev libzip-dev zip make wget gnupg -yqq
- name: Install phive
run: |
wget -O phive.phar https://phar.io/releases/phive.phar
wget -O phive.phar.asc https://phar.io/releases/phive.phar.asc
gpg --keyserver hkps://keys.openpgp.org --recv-keys 0x9D8A98B29B2D5D79
gpg --verify phive.phar.asc phive.phar
chmod +x phive.phar
mv phive.phar /usr/local/bin/phive
- name: Install phab
run: |
phive install phpab --global --trust-gpg-keys 0x2A8299CE842DD38C
- name: Install latest version of NCC
run: |
git clone https://git.n64.cc/nosial/ncc.git
cd ncc
make redist
NCC_DIR=$(find build/ -type d -name "ncc_*" | head -n 1)
if [ -z "$NCC_DIR" ]; then
echo "NCC build directory not found"
exit 1
fi
php "$NCC_DIR/INSTALL" --auto
cd .. && rm -rf ncc
- name: Build project
run: |
ncc build --config debug-compressed --log-level debug
- name: Upload build artifact
uses: actions/upload-artifact@v4
with:
name: debug-compressed
path: build/debug/net.nosial.configlib.gz.ncc
release-executable: release-executable:
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: container:
@ -247,7 +149,7 @@ jobs:
- name: Build project - name: Build project
run: | run: |
ncc build --config release-executable --log-level debug ncc build --config release-executable --build-source --log-level debug
- name: Upload build artifact - name: Upload build artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
@ -296,14 +198,14 @@ jobs:
- name: Build project - name: Build project
run: | run: |
ncc build --config debug-executable --log-level debug ncc build --config debug-executable --build-source --log-level debug
- name: Upload build artifact - name: Upload build artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: debug-executable name: debug-executable
path: build/debug/debug_executable_gz path: build/debug/debug_executable_gz
release-compressed-executable: release_executable:
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: container:
image: php:8.3 image: php:8.3
@ -345,14 +247,14 @@ jobs:
- name: Build project - name: Build project
run: | run: |
ncc build --config release-compressed-executable --log-level debug ncc build --config release_executable --build-source --log-level debug
- name: Upload build artifact - name: Upload build artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: release-compressed-executable name: release_executable
path: build/release/release_compressed_executable path: build/release/ConfigLib
debug-compressed-executable: debug_executable:
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: container:
image: php:8.3 image: php:8.3
@ -394,13 +296,13 @@ jobs:
- name: Build project - name: Build project
run: | run: |
ncc build --config debug-compressed-executable --log-level debug ncc build --config debug_executable --build-source --log-level debug
- name: Upload build artifact - name: Upload build artifact
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@v4
with: with:
name: debug-compressed-executable name: debug_executable
path: build/debug/debug_compressed_executable path: build/debug/ConfigLib
# Checking for phpunit.xml # Checking for phpunit.xml
@ -471,7 +373,7 @@ jobs:
path: docs.zip path: docs.zip
test: test:
needs: [release, debug, release-compressed, debug-compressed, release-executable, debug-executable, release-compressed-executable, debug-compressed-executable, check-phpunit] needs: [release, debug, release-executable, debug-executable, release_executable, debug_executable, check-phpunit]
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: container:
image: php:8.3 image: php:8.3
@ -565,7 +467,7 @@ jobs:
release-artifacts: release-artifacts:
needs: [release, debug, release-compressed, debug-compressed, release-executable, debug-executable, release-compressed-executable, debug-compressed-executable] needs: [release, debug, release-executable, debug-executable, release_executable, debug_executable]
permissions: write-all permissions: write-all
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: container:
@ -600,30 +502,6 @@ jobs:
debug/* debug/*
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download release-compressed artifact
uses: actions/download-artifact@v4
with:
name: release-compressed
path: release-compressed
- name: Upload release-compressed artifact to release
uses: softprops/action-gh-release@v1
with:
files: |
release-compressed/*
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download debug-compressed artifact
uses: actions/download-artifact@v4
with:
name: debug-compressed
path: debug-compressed
- name: Upload debug-compressed artifact to release
uses: softprops/action-gh-release@v1
with:
files: |
debug-compressed/*
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download release-executable artifact - name: Download release-executable artifact
uses: actions/download-artifact@v4 uses: actions/download-artifact@v4
with: with:
@ -648,27 +526,27 @@ jobs:
debug-executable/* debug-executable/*
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download release-compressed-executable artifact - name: Download release_executable artifact
uses: actions/download-artifact@v4 uses: actions/download-artifact@v4
with: with:
name: release-compressed-executable name: release_executable
path: release-compressed-executable path: release_executable
- name: Upload release-compressed-executable artifact to release - name: Upload release_executable artifact to release
uses: softprops/action-gh-release@v1 uses: softprops/action-gh-release@v1
with: with:
files: | files: |
release-compressed-executable/* release_executable/*
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download debug-compressed-executable artifact - name: Download debug_executable artifact
uses: actions/download-artifact@v4 uses: actions/download-artifact@v4
with: with:
name: debug-compressed-executable name: debug_executable
path: debug-compressed-executable path: debug_executable
- name: Upload debug-compressed-executable artifact to release - name: Upload debug_executable artifact to release
uses: softprops/action-gh-release@v1 uses: softprops/action-gh-release@v1
with: with:
files: | files: |
debug-compressed-executable/* debug_executable/*
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

View file

@ -1,20 +1,33 @@
# Variables # Variables
CONFIG ?= release DEFAULT_CONFIGURATION ?= release
LOG_LEVEL = debug LOG_LEVEL = debug
OUTDIR = build/$(CONFIG)
PACKAGE = $(OUTDIR)/net.nosial.configlib.ncc
# Default Target # Default Target
all: build all: release debug release-executable debug-executable release_executable debug_executable
# Build Steps # Build Steps
build: release:
ncc build --config=$(CONFIG) --log-level $(LOG_LEVEL) ncc build --config=release --log-level $(LOG_LEVEL)
debug:
ncc build --config=debug --log-level $(LOG_LEVEL)
release-executable:
ncc build --config=release-executable --log-level $(LOG_LEVEL)
debug-executable:
ncc build --config=debug-executable --log-level $(LOG_LEVEL)
release_executable:
ncc build --config=release_executable --log-level $(LOG_LEVEL)
debug_executable:
ncc build --config=debug_executable --log-level $(LOG_LEVEL)
install: build
ncc package install --package=$(PACKAGE) --skip-dependencies --build-source --reinstall -y --log-level $(LOG_LEVEL) install: release
ncc package install --package=build/release/net.nosial.configlib.ncc --skip-dependencies --build-source --reinstall -y --log-level $(LOG_LEVEL)
test: release
[ -f phpunit.xml ] || { echo "phpunit.xml not found"; exit 1; }
phpunit
clean: clean:
rm -rf build rm -rf build
.PHONY: all build install clean .PHONY: all install test clean release debug release-executable debug-executable release_executable debug_executable

24
main
View file

@ -1,6 +1,24 @@
<?php <?php
require('ncc'); if (PHP_SAPI !== 'cli')
import('net.nosial.configlib', 'latest'); {
print('net.nosial.configlib must be run from the command line.' . PHP_EOL);
exit(1);
}
\ConfigLib\Program::main(); if(!isset($argv))
{
if(isset($_SERVER['argv']))
{
$argv = $_SERVER['argv'];
}
else
{
print('net.nosial.configlib failed to run, no $argv found.' . PHP_EOL);
exit(1);
}
}
require('ncc');
\ncc\Classes\Runtime::import('net.nosial.configlib', 'latest');
exit(\ConfigLib\Program::main($argv));

View file

@ -5,6 +5,9 @@
"minimum_version": "8.0", "minimum_version": "8.0",
"maximum_version": "8.2" "maximum_version": "8.2"
}, },
"options": {
"create_symlink": true
},
"update_source": { "update_source": {
"source": "nosial/libs.config@n64", "source": "nosial/libs.config@n64",
"repository": { "repository": {
@ -13,35 +16,21 @@
"host": "git.n64.cc", "host": "git.n64.cc",
"ssl": true "ssl": true
} }
},
"options": {
"create_symlink": true
} }
}, },
"execution_policies":[
{
"name": "main",
"runner": "php",
"execute": {
"target": "main",
"working_directory": "%CWD%",
"tty": true
}
}
],
"assembly": { "assembly": {
"name": "ConfigLib", "name": "ConfigLib",
"package": "net.nosial.configlib", "package": "net.nosial.configlib",
"description": "ConfigLib is a library for reading and writing configuration files via the NCC Runtime API",
"company": "Nosial", "company": "Nosial",
"copyright": "Copyright (c) 2022-2023 Nosial", "copyright": "Copyright (c) 2022-2023 Nosial",
"description": "ConfigLib is a library for reading and writing configuration files via the NCC Runtime API",
"version": "1.1.2", "version": "1.1.2",
"uuid": "9347259e-8e4d-11ed-85a7-fd07cf28ef35" "uuid": "9347259e-8e4d-11ed-85a7-fd07cf28ef35"
}, },
"build": { "build": {
"source_path": "src", "source_path": "src",
"default_configuration": "release", "default_configuration": "release",
"main": "main", "main": "main_policy",
"define_constants": { "define_constants": {
"VERSION": "%ASSEMBLY.VERSION%" "VERSION": "%ASSEMBLY.VERSION%"
}, },
@ -49,31 +38,26 @@
{ {
"name": "net.nosial.optslib", "name": "net.nosial.optslib",
"version": "latest", "version": "latest",
"source_type": "remote",
"source": "nosial/libs.opts=latest@n64" "source": "nosial/libs.opts=latest@n64"
}, },
{ {
"name": "net.nosial.loglib", "name": "net.nosial.loglib",
"version": "latest", "version": "latest",
"source_type": "remote",
"source": "nosial/libs.log=latest@n64" "source": "nosial/libs.log=latest@n64"
}, },
{ {
"name": "com.symfony.filesystem", "name": "com.symfony.filesystem",
"version": "latest", "version": "latest",
"source_type": "remote",
"source": "symfony/filesystem=latest@packagist" "source": "symfony/filesystem=latest@packagist"
}, },
{ {
"name": "com.symfony.yaml", "name": "com.symfony.yaml",
"version": "latest", "version": "latest",
"source_type": "remote",
"source": "symfony/yaml=latest@packagist" "source": "symfony/yaml=latest@packagist"
}, },
{ {
"name": "com.symfony.process", "name": "com.symfony.process",
"version": "latest", "version": "latest",
"source_type": "remote",
"source": "symfony/process=latest@packagist" "source": "symfony/process=latest@packagist"
} }
], ],
@ -90,7 +74,68 @@
"define_constants": { "define_constants": {
"DEBUG": "1" "DEBUG": "1"
} }
},
{
"name": "release-executable",
"build_type": "executable",
"output": "build/release/release_executable_gz",
"options": {
"ncc_configuration": "release"
}
},
{
"name": "debug-executable",
"build_type": "executable",
"output": "build/debug/debug_executable_gz",
"options": {
"ncc_configuration": "debug"
}
},
{
"name": "release_executable",
"build_type": "executable",
"output": "build/release/%ASSEMBLY.NAME%",
"options": {
"ncc_configuration": "release"
}
},
{
"name": "debug_executable",
"build_type": "executable",
"output": "build/debug/%ASSEMBLY.NAME%",
"options": {
"ncc_configuration": "debug"
},
"define_constants": {
"DEBUG": "1"
}
} }
] ]
} },
"execution_policies": [
{
"name": "main",
"runner": "php",
"execute": {
"working_directory": "%CWD%",
"silent": false,
"tty": true,
"timeout": null,
"idle_timeout": null,
"target": "main"
}
},
{
"name": "main_policy",
"runner": "php",
"execute": {
"working_directory": "%CWD%",
"silent": false,
"tty": true,
"timeout": null,
"idle_timeout": null,
"target": "main"
}
}
]
} }