🎨 Refactoring action packaging logic
This commit is contained in:
2
.github/workflows/pake_build_next.yaml
vendored
2
.github/workflows/pake_build_next.yaml
vendored
@@ -1,4 +1,4 @@
|
|||||||
name: Build Popular App
|
name: Build All Popular Apps
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
tags:
|
tags:
|
||||||
|
|||||||
42
.github/workflows/pake_build_single_app.yaml
vendored
42
.github/workflows/pake_build_single_app.yaml
vendored
@@ -3,43 +3,43 @@ on:
|
|||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
inputs:
|
inputs:
|
||||||
name:
|
name:
|
||||||
description: "app name"
|
description: 'app name'
|
||||||
required: true
|
required: true
|
||||||
default: "twitter"
|
default: 'twitter'
|
||||||
title:
|
title:
|
||||||
description: "app title"
|
description: 'app title'
|
||||||
required: true
|
required: true
|
||||||
default: "Twitter"
|
default: 'Twitter'
|
||||||
name_zh:
|
name_zh:
|
||||||
description: "app name in Chinese"
|
description: 'app name in Chinese'
|
||||||
required: true
|
required: true
|
||||||
default: "推特"
|
default: '推特'
|
||||||
url:
|
url:
|
||||||
description: "app url"
|
description: 'app url'
|
||||||
required: true
|
required: true
|
||||||
default: "https://twitter.com/"
|
default: 'https://twitter.com/'
|
||||||
workflow_call:
|
workflow_call:
|
||||||
inputs:
|
inputs:
|
||||||
name:
|
name:
|
||||||
description: "app name"
|
description: 'app name'
|
||||||
type: string
|
type: string
|
||||||
required: true
|
required: true
|
||||||
default: "twitter"
|
default: 'twitter'
|
||||||
title:
|
title:
|
||||||
description: "app title"
|
description: 'app title'
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
default: "Twitter"
|
default: 'Twitter'
|
||||||
name_zh:
|
name_zh:
|
||||||
description: "app name in Chinese"
|
description: 'app name in Chinese'
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
default: "推特"
|
default: '推特'
|
||||||
url:
|
url:
|
||||||
description: "app url"
|
description: 'app url'
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
default: "https://twitter.com/"
|
default: 'https://twitter.com/'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build_single_app:
|
build_single_app:
|
||||||
@@ -98,8 +98,7 @@ jobs:
|
|||||||
URL: ${{ inputs.url }}
|
URL: ${{ inputs.url }}
|
||||||
run: |
|
run: |
|
||||||
npm install
|
npm install
|
||||||
npm run build:app:config
|
node ./script/build_with_pake_cli.mjs
|
||||||
|
|
||||||
|
|
||||||
- name: Build for Ubuntu
|
- name: Build for Ubuntu
|
||||||
if: matrix.os == 'ubuntu-latest'
|
if: matrix.os == 'ubuntu-latest'
|
||||||
@@ -109,7 +108,6 @@ jobs:
|
|||||||
mv src-tauri/target/release/bundle/deb/*.deb output/linux/${{inputs.title}}_`arch`.deb
|
mv src-tauri/target/release/bundle/deb/*.deb output/linux/${{inputs.title}}_`arch`.deb
|
||||||
mv src-tauri/target/release/bundle/appimage/*.AppImage output/linux/"${{inputs.title}}"_`arch`.AppImage
|
mv src-tauri/target/release/bundle/appimage/*.AppImage output/linux/"${{inputs.title}}"_`arch`.AppImage
|
||||||
|
|
||||||
|
|
||||||
- name: Build for Macos
|
- name: Build for Macos
|
||||||
if: matrix.os == 'macos-latest'
|
if: matrix.os == 'macos-latest'
|
||||||
run: |
|
run: |
|
||||||
@@ -119,7 +117,6 @@ jobs:
|
|||||||
mkdir -p output/macos
|
mkdir -p output/macos
|
||||||
mv src-tauri/target/universal-apple-darwin/release/bundle/dmg/*.dmg output/macos/"${{inputs.title}}".dmg
|
mv src-tauri/target/universal-apple-darwin/release/bundle/dmg/*.dmg output/macos/"${{inputs.title}}".dmg
|
||||||
|
|
||||||
|
|
||||||
- name: Build for Windows
|
- name: Build for Windows
|
||||||
if: matrix.os == 'windows-latest'
|
if: matrix.os == 'windows-latest'
|
||||||
run: |
|
run: |
|
||||||
@@ -143,12 +140,11 @@ jobs:
|
|||||||
src-tauri/target/
|
src-tauri/target/
|
||||||
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
|
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
|
||||||
|
|
||||||
|
|
||||||
- name: Upload For Single Build
|
- name: Upload For Single Build
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
if: startsWith(github.ref, 'refs/tags/') != true
|
if: startsWith(github.ref, 'refs/tags/') != true
|
||||||
with:
|
with:
|
||||||
path: "output/*/*.*"
|
path: 'output/*/*.*'
|
||||||
|
|
||||||
- name: Upload For Release
|
- name: Upload For Release
|
||||||
# arg info: https://github.com/ncipollo/release-action#release-action
|
# arg info: https://github.com/ncipollo/release-action#release-action
|
||||||
@@ -156,5 +152,5 @@ jobs:
|
|||||||
if: startsWith(github.ref, 'refs/tags/') == true
|
if: startsWith(github.ref, 'refs/tags/') == true
|
||||||
with:
|
with:
|
||||||
allowUpdates: true
|
allowUpdates: true
|
||||||
artifacts: "output/*/*.*"
|
artifacts: 'output/*/*.*'
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|||||||
@@ -33,7 +33,6 @@
|
|||||||
"start": "npm run dev",
|
"start": "npm run dev",
|
||||||
"dev": "npm run tauri dev",
|
"dev": "npm run tauri dev",
|
||||||
"build": "npm run tauri build --release",
|
"build": "npm run tauri build --release",
|
||||||
"build:app:config": "chmod +x ./script/app_config.mjs && node ./script/app_config.mjs",
|
|
||||||
"build:debug": "npm run tauri build -- --debug",
|
"build:debug": "npm run tauri build -- --debug",
|
||||||
"build:mac": "npm run tauri build -- --target universal-apple-darwin",
|
"build:mac": "npm run tauri build -- --target universal-apple-darwin",
|
||||||
"analyze": "cd src-tauri && cargo bloat --release --crates",
|
"analyze": "cd src-tauri && cargo bloat --release --crates",
|
||||||
|
|||||||
92
script/build_with_pake_cli.ps1
vendored
92
script/build_with_pake_cli.ps1
vendored
@@ -1,92 +0,0 @@
|
|||||||
Write-Host "Welcome to use Powershell"
|
|
||||||
Write-Host "`n======================="
|
|
||||||
Write-Host "build for windows"
|
|
||||||
Write-Host "make ture powershell == 7.2.10"
|
|
||||||
Write-Host "powershell 7.2.10 download url: https://github.com/PowerShell/PowerShell/releases/tag/v7.2.10"
|
|
||||||
Write-Host "Powershell info in your localhost "
|
|
||||||
$PSVersionTable
|
|
||||||
Write-Host "`n=======================`n"
|
|
||||||
|
|
||||||
Write-Host "`n======================="
|
|
||||||
Write-Host "pake parameters is: "
|
|
||||||
Write-Host "url: " $env:URL
|
|
||||||
Write-Host "name: " $env:NAME
|
|
||||||
Write-Host "icon: " $env:ICON
|
|
||||||
Write-Host "height: " $env:HEIGHT
|
|
||||||
Write-Host "width: " $env:WIDTH
|
|
||||||
Write-Host "transparent: " $env:TRANSPARENT
|
|
||||||
Write-Host "resize: " $env:RESIZE
|
|
||||||
Write-Host "is multi arch? only for Mac: " $env:MULTI_ARCH
|
|
||||||
Write-Host "targets type? only for Linux: " $env:TARGETS
|
|
||||||
Write-Host "===========================`n"
|
|
||||||
|
|
||||||
|
|
||||||
Set-Location node_modules/pake-cli
|
|
||||||
# init params
|
|
||||||
${Params}="node cli.js $env:URL --name $env:NAME"
|
|
||||||
|
|
||||||
# download icon
|
|
||||||
if ((($null -ne $env:ICON) -and ($env:ICON -ne ""))){
|
|
||||||
if ($IsLinux) {
|
|
||||||
curl -L "$env:ICON" -o icon.png
|
|
||||||
${Params}="${Params} --icon icon.png"
|
|
||||||
} elseif ($IsMacOS) {
|
|
||||||
curl -L "$env:ICON" -o icon.icns
|
|
||||||
${Params}="${Params} --icon icon.icns"
|
|
||||||
} elseif ($IsWindows) {
|
|
||||||
curl -L "$env:ICON" -o icon.ico
|
|
||||||
${Params}="${Params} --icon icon.ico"
|
|
||||||
} else {
|
|
||||||
Write-Host "it won't download icon, becase it can't detect you OS system!"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
# height && weight
|
|
||||||
${Params}="${Params} --height $env:HEIGHT --width $env:WIDTH"
|
|
||||||
|
|
||||||
# transparent
|
|
||||||
if ("$env:TRANSPARENT" -eq "true") {
|
|
||||||
${Params}="${Params} --transparent"
|
|
||||||
}
|
|
||||||
|
|
||||||
# resize
|
|
||||||
if ("$env:FULLSCREEN" -eq "true" ) {
|
|
||||||
${Params}="${Params} --resize"
|
|
||||||
}
|
|
||||||
|
|
||||||
# multi-arch only for mac
|
|
||||||
if (($env:MULTI_ARCH -eq "true") -and ($IsMacOS)) {
|
|
||||||
rustup target add aarch64-apple-darwin
|
|
||||||
${Params}="${Params} --multi-arch"
|
|
||||||
}
|
|
||||||
|
|
||||||
# targets type, only for linux
|
|
||||||
if (($null -ne $env:TARGETS) -and ($env:TARGETS -ne "") -and ($IsLinux)) {
|
|
||||||
${Params}="${Params} --targets $env:TARGETS"
|
|
||||||
}
|
|
||||||
|
|
||||||
# add systemTray for Window / Linux default
|
|
||||||
if ($IsWindows) {
|
|
||||||
${Params}="${Params} --show-system-tray"
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($IsLinux) {
|
|
||||||
${Params}="${Params} --show-system-tray"
|
|
||||||
}
|
|
||||||
|
|
||||||
# add menu for MacOS default
|
|
||||||
if ($IsMacOS) {
|
|
||||||
${Params}="${Params} --show-menu"
|
|
||||||
}
|
|
||||||
|
|
||||||
Write-Host "Pake parameters is: ${Params}"
|
|
||||||
Write-Host "compile...."
|
|
||||||
Invoke-Expression $Params
|
|
||||||
|
|
||||||
# output
|
|
||||||
if (-not(Test-Path output)) {
|
|
||||||
New-Item -ItemType Directory -Path "output"
|
|
||||||
}
|
|
||||||
Move-Item -Path "$env:NAME.*" -Destination "output/"
|
|
||||||
Write-Host "Build Success"
|
|
||||||
Set-Location ../..
|
|
||||||
Reference in New Issue
Block a user