Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| a0b3adc288 | |||
| 44ac517223 | |||
| c609e0e90e | |||
| b4ff5884b9 | |||
| beccfa05b3 |
+55
@@ -0,0 +1,55 @@
|
||||
# Miscellaneous
|
||||
*.class
|
||||
*.log
|
||||
*.pyc
|
||||
*.swp
|
||||
.DS_Store
|
||||
.atom/
|
||||
.build/
|
||||
.buildlog/
|
||||
.history
|
||||
.svn/
|
||||
.swiftpm/
|
||||
migrate_working_dir/
|
||||
|
||||
# IntelliJ related
|
||||
*.iml
|
||||
*.ipr
|
||||
*.iws
|
||||
.idea/
|
||||
|
||||
# The .vscode folder contains launch configuration and tasks you configure in
|
||||
# VS Code which you may wish to be included in version control, so this line
|
||||
# is commented out by default.
|
||||
#.vscode/
|
||||
|
||||
# Flutter/Dart/Pub related
|
||||
**/doc/api/
|
||||
**/ios/Flutter/.last_build_id
|
||||
.dart_tool/
|
||||
.flutter-plugins-dependencies
|
||||
.pub-cache/
|
||||
.pub/
|
||||
/build/
|
||||
/coverage/
|
||||
|
||||
# Symbolication related
|
||||
app.*.symbols
|
||||
|
||||
# Obfuscation related
|
||||
app.*.map.json
|
||||
|
||||
# Android Studio will place build artifacts here
|
||||
/android/app/debug
|
||||
/android/app/profile
|
||||
/android/app/release
|
||||
|
||||
.flutter-plugins-dependencies
|
||||
android/key.properties
|
||||
windows/installer/*
|
||||
bugreport*
|
||||
!downloads/*
|
||||
android/builds.json
|
||||
macos/builds.json
|
||||
ios/builds.json
|
||||
windows/busylight-buddy-windows-installer-builder.iss
|
||||
@@ -0,0 +1,30 @@
|
||||
# This file tracks properties of this Flutter project.
|
||||
# Used by Flutter tool to assess capabilities and perform upgrades etc.
|
||||
#
|
||||
# This file should be version controlled and should not be manually edited.
|
||||
|
||||
version:
|
||||
revision: "2c9eb20739dfec95e2c74bd3dfa4601b0a8a36aa"
|
||||
channel: "stable"
|
||||
|
||||
project_type: app
|
||||
|
||||
# Tracks metadata for the flutter migrate command
|
||||
migration:
|
||||
platforms:
|
||||
- platform: root
|
||||
create_revision: 2c9eb20739dfec95e2c74bd3dfa4601b0a8a36aa
|
||||
base_revision: 2c9eb20739dfec95e2c74bd3dfa4601b0a8a36aa
|
||||
- platform: windows
|
||||
create_revision: 2c9eb20739dfec95e2c74bd3dfa4601b0a8a36aa
|
||||
base_revision: 2c9eb20739dfec95e2c74bd3dfa4601b0a8a36aa
|
||||
|
||||
# User provided section
|
||||
|
||||
# List of Local paths (relative to this file) that should be
|
||||
# ignored by the migrate tool.
|
||||
#
|
||||
# Files that are not part of the templates will be ignored by default.
|
||||
unmanaged_files:
|
||||
- 'lib/main.dart'
|
||||
- 'ios/Runner.xcodeproj/project.pbxproj'
|
||||
@@ -1,6 +1,6 @@
|
||||
# BusyLight Buddy
|
||||
|
||||
Multiplatform Flutter app to control your DIY [BusyLight](https://github.com/igox/busylight) (ESP32 + MicroPython + Microdot).
|
||||
Multiplatform Flutter app to control your DIY [BusyLight](https://code.igox.org/iGoX/busylight) (ESP32 + MicroPython + Microdot).
|
||||
|
||||
Supports **iOS**, **ipadOS**, **Android**, **macOS**, and **Windows**.
|
||||
|
||||
@@ -8,10 +8,10 @@ Supports **iOS**, **ipadOS**, **Android**, **macOS**, and **Windows**.
|
||||
|
||||
## Downloads
|
||||
|
||||
[](https://github.com/igox/busylight-buddy/releases/download/v0.0.1/BusyLight-Buddy-Installer.exe)
|
||||
[](https://github.com/igox/busylight-buddy/releases/download/v0.0.1/org.igox.apps.android.busylight-buddy-release.apk)
|
||||
[](https://code.igox.org/iGoX/busylight-buddy/releases/download/v0.0.1/BusyLight-Buddy-Installer.exe)
|
||||
[](https://code.igox.org/iGoX/busylight-buddy/releases/download/v0.0.1/org.igox.apps.android.busylight-buddy-release.apk)
|
||||
|
||||
Or browse all releases on the [Releases page](https://github.com/igox/busylight-buddy/releases).
|
||||
Or browse all releases on the [Releases page](https://code.igox.org/iGoX/busylight-buddy/releases).
|
||||
|
||||
---
|
||||
|
||||
|
||||
@@ -1,8 +1,10 @@
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<uses-permission android:name="android.permission.INTERNET"/>
|
||||
<application
|
||||
android:label="BusyLight Buddy"
|
||||
android:name="${applicationName}"
|
||||
android:icon="@mipmap/ic_launcher">
|
||||
android:icon="@mipmap/ic_launcher"
|
||||
android:usesCleartextTraffic="true">
|
||||
<activity
|
||||
android:name=".MainActivity"
|
||||
android:exported="true"
|
||||
|
||||
@@ -1,23 +1,93 @@
|
||||
$buildType = if ($args[0]) { $args[0] } else { "debug" }
|
||||
|
||||
<#
|
||||
.SYNOPSIS
|
||||
Builds a Flutter APK with versioning support.
|
||||
|
||||
.DESCRIPTION
|
||||
This script builds a Flutter APK, manages build numbers, and renames output files.
|
||||
|
||||
.PARAMETER buildType
|
||||
The build type (release or debug). Default is "release".
|
||||
|
||||
.PARAMETER buildName
|
||||
The build name (version). Default is "0.0.0".
|
||||
|
||||
.EXAMPLE
|
||||
.\flutter-build-apk.ps1 -buildType debug -buildName 1.0.0
|
||||
Builds a debug APK with version 1.0.0.
|
||||
#>
|
||||
|
||||
[CmdletBinding()]
|
||||
param (
|
||||
[string]$buildType = "release", # Default value is "release"
|
||||
[string]$buildName = "0.0.0" # Default value is "0.0.0"
|
||||
)
|
||||
|
||||
$buildsRef = "builds.json"
|
||||
|
||||
# Check if the file exists
|
||||
if (-not (Test-Path -Path $buildsRef)) {
|
||||
# Create the file if it doesn't exist
|
||||
New-Item -Path $buildsRef -ItemType File
|
||||
$buildsMap = @{
|
||||
$buildName = 0
|
||||
}
|
||||
$buildsMap | ConvertTo-Json | Out-File $buildsRef
|
||||
Write-Output "File created: $buildsRef"
|
||||
} else {
|
||||
Write-Output "File already exists: $buildsRef"
|
||||
}
|
||||
|
||||
# Read the JSON file and convert it to a hashtable
|
||||
$jsonContent = Get-Content $buildsRef -Raw | ConvertFrom-Json
|
||||
$buildsMap = @{}
|
||||
$jsonContent.PSObject.Properties | ForEach-Object {
|
||||
$buildsMap[$_.Name] = $_.Value
|
||||
}
|
||||
|
||||
if ($buildsMap.ContainsKey($buildName)) {
|
||||
Write-Output "Build exists: $buildName"
|
||||
$buildNumber = $buildsMap[$buildName]
|
||||
$buildNumber++
|
||||
Write-Output "Next build number for ${buildName}: $buildNumber"
|
||||
$buildsMap[$buildName] = $buildNumber
|
||||
}
|
||||
else {
|
||||
$buildsMap[$buildName] = 1
|
||||
}
|
||||
|
||||
$buildsMap | ConvertTo-Json | Out-File $buildsRef
|
||||
|
||||
|
||||
$apkDir = "..\build\app\outputs\flutter-apk"
|
||||
$baseName = "org.igox.apps.android.busylight-buddy"
|
||||
|
||||
flutter build apk --$buildType
|
||||
# Build an array for arguments
|
||||
$flutterArgs = @(
|
||||
"--$buildType",
|
||||
"--build-name=$buildName",
|
||||
"--build-number=$buildNumber",
|
||||
"--target-platform=android-arm,android-arm64,android-x64"
|
||||
)
|
||||
|
||||
Write-Output "Building APK with arguments: $($flutterArgs -join ' ')"
|
||||
|
||||
& flutter build apk @flutterArgs
|
||||
|
||||
# Rename APK
|
||||
$oldApk = "$apkDir\app-$buildType.apk"
|
||||
$newApk = "$apkDir\$baseName-$buildType.apk"
|
||||
$oldApk = "$apkDir\app-${buildType}.apk"
|
||||
$newApk = "$apkDir\$baseName-${buildType}.apk"
|
||||
if (Test-Path $oldApk) {
|
||||
if (Test-Path $newApk) { Remove-Item $newApk -Force }
|
||||
Rename-Item -Path $oldApk -NewName "$baseName-$buildType.apk"
|
||||
Write-Host "APK renamed to: $baseName-$buildType.apk"
|
||||
Rename-Item -Path $oldApk -NewName "$baseName-${buildType}.apk"
|
||||
Write-Host "APK renamed to: $baseName-${buildType}.apk"
|
||||
}
|
||||
|
||||
# Rename SHA1 (if exists)
|
||||
$oldSha1 = "$apkDir\app-$buildType.apk.sha1"
|
||||
$newSha1 = "$apkDir\$baseName-$buildType.apk.sha1"
|
||||
$oldSha1 = "$apkDir\app-${buildType}.apk.sha1"
|
||||
$newSha1 = "$apkDir\$baseName-${buildType}.apk.sha1"
|
||||
if (Test-Path $oldSha1) {
|
||||
if (Test-Path $newSha1) { Remove-Item $newSha1 -Force }
|
||||
Rename-Item -Path $oldSha1 -NewName "$baseName-$buildType.apk.sha1"
|
||||
Write-Host "SHA1 renamed to: $baseName-$buildType.apk.sha1"
|
||||
Rename-Item -Path $oldSha1 -NewName "$baseName-${buildType}.apk.sha1"
|
||||
Write-Host "SHA1 renamed to: $baseName-${buildType}.apk.sha1"
|
||||
}
|
||||
@@ -1,24 +1,90 @@
|
||||
#!/bin/bash
|
||||
BUILD_TYPE=${1:-debug}
|
||||
APK_DIR="../build/app/outputs/flutter-apk"
|
||||
BASE_NAME="org.igox.apps.android.busylight-buddy"
|
||||
|
||||
flutter build apk --$BUILD_TYPE
|
||||
# Default values
|
||||
buildType="release"
|
||||
buildName="0.0.0"
|
||||
buildsRef="builds.json"
|
||||
|
||||
# Help message
|
||||
show_help() {
|
||||
echo "Usage: $0 [-t buildType] [-n buildName]"
|
||||
echo "Builds a Flutter APK with versioning support."
|
||||
echo ""
|
||||
echo "Options:"
|
||||
echo " -t, --buildType Build type (release or debug). Default: release"
|
||||
echo " -n, --buildName Build name (version). Default: 0.0.0"
|
||||
echo " -h, --help Show this help message"
|
||||
exit 0
|
||||
}
|
||||
|
||||
# Parse command-line arguments
|
||||
while [[ "$#" -gt 0 ]]; do
|
||||
case $1 in
|
||||
-t|--buildType) buildType="$2"; shift ;;
|
||||
-n|--buildName) buildName="$2"; shift ;;
|
||||
-h|--help) show_help ;;
|
||||
*) echo "Unknown parameter: $1"; show_help; exit 1 ;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
# Check if builds.json exists
|
||||
if [ ! -f "$buildsRef" ]; then
|
||||
echo "File created: $buildsRef"
|
||||
echo "{\"$buildName\": 0}" > "$buildsRef"
|
||||
else
|
||||
echo "File already exists: $buildsRef"
|
||||
fi
|
||||
|
||||
# Read the JSON file
|
||||
buildsMap=$(cat "$buildsRef")
|
||||
|
||||
# Check if buildName exists in the JSON
|
||||
if jq -e --arg key "$buildName" 'has($key)' <<< "$buildsMap" > /dev/null; then
|
||||
echo "Build exists: $buildName"
|
||||
buildNumber=$(jq --arg key "$buildName" '.[$key]' <<< "$buildsMap")
|
||||
buildNumber=$((buildNumber + 1))
|
||||
echo "Next build number for $buildName: $buildNumber"
|
||||
buildsMap=$(jq --arg key "$buildName" --argjson value "$buildNumber" '.[$key] = $value' <<< "$buildsMap")
|
||||
else
|
||||
echo "New build: $buildName, starting at build number: 1"
|
||||
buildNumber=1
|
||||
buildsMap=$(jq --arg key "$buildName" --argjson value "$buildNumber" '.[$key] = $value' <<< "$buildsMap")
|
||||
fi
|
||||
|
||||
# Save the updated JSON back to the file
|
||||
echo "$buildsMap" > "$buildsRef"
|
||||
|
||||
# Define paths
|
||||
apkDir="../build/app/outputs/flutter-apk"
|
||||
baseName="org.igox.apps.android.busylight-buddy"
|
||||
|
||||
# Build APK
|
||||
echo "Building APK with arguments: --$buildType --build-name=$buildName --build-number=$buildNumber --target-platform=android-arm,android-arm64,android-x64"
|
||||
flutter build apk --"$buildType" --build-name="$buildName" --build-number="$buildNumber" --target-platform=android-arm,android-arm64,android-x64
|
||||
|
||||
# Rename APK
|
||||
OLD_APK="$APK_DIR/app-$BUILD_TYPE.apk"
|
||||
NEW_APK="$APK_DIR/$BASE_NAME-$BUILD_TYPE.apk"
|
||||
if [ -f "$OLD_APK" ]; then
|
||||
[ -f "$NEW_APK" ] && rm -f "$NEW_APK"
|
||||
mv "$OLD_APK" "$NEW_APK"
|
||||
echo "APK renamed to: $BASE_NAME-$BUILD_TYPE.apk"
|
||||
oldApk="$apkDir/app-$buildType.apk"
|
||||
newApk="$apkDir/$baseName-$buildType.apk"
|
||||
if [ -f "$oldApk" ]; then
|
||||
if [ -f "$newApk" ]; then
|
||||
rm -f "$newApk"
|
||||
fi
|
||||
mv "$oldApk" "$newApk"
|
||||
echo "APK renamed to: $baseName-$buildType.apk"
|
||||
else
|
||||
echo "Warning: APK not found at $oldApk"
|
||||
fi
|
||||
|
||||
# Rename SHA1 (if exists)
|
||||
OLD_SHA1="$APK_DIR/app-$BUILD_TYPE.apk.sha1"
|
||||
NEW_SHA1="$APK_DIR/$BASE_NAME-$BUILD_TYPE.apk.sha1"
|
||||
if [ -f "$OLD_SHA1" ]; then
|
||||
[ -f "$NEW_SHA1" ] && rm -f "$NEW_SHA1"
|
||||
mv "$OLD_SHA1" "$NEW_SHA1"
|
||||
echo "SHA1 renamed to: $BASE_NAME-$BUILD_TYPE.apk.sha1"
|
||||
oldSha1="$apkDir/app-$buildType.apk.sha1"
|
||||
newSha1="$apkDir/$baseName-$buildType.apk.sha1"
|
||||
if [ -f "$oldSha1" ]; then
|
||||
if [ -f "$newSha1" ]; then
|
||||
rm -f "$newSha1"
|
||||
fi
|
||||
mv "$oldSha1" "$newSha1"
|
||||
echo "SHA1 renamed to: $baseName-$buildType.apk.sha1"
|
||||
else
|
||||
echo "Warning: SHA1 not found at $oldSha1"
|
||||
fi
|
||||
Executable
+60
@@ -0,0 +1,60 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Default values
|
||||
buildType="release"
|
||||
buildName="0.0.0"
|
||||
buildsRef="builds.json"
|
||||
|
||||
# Help message
|
||||
show_help() {
|
||||
echo "Usage: $0 [-t buildType] [-n buildName]"
|
||||
echo "Builds a Flutter iOS application with versioning support."
|
||||
echo ""
|
||||
echo "Options:"
|
||||
echo " -t, --buildType Build type (release or debug). Default: release"
|
||||
echo " -n, --buildName Build name (version). Default: 0.0.0"
|
||||
echo " -h, --help Show this help message"
|
||||
exit 0
|
||||
}
|
||||
|
||||
# Parse command-line arguments
|
||||
while [[ "$#" -gt 0 ]]; do
|
||||
case $1 in
|
||||
-t|--buildType) buildType="$2"; shift ;;
|
||||
-n|--buildName) buildName="$2"; shift ;;
|
||||
-h|--help) show_help ;;
|
||||
*) echo "Unknown parameter: $1"; show_help; exit 1 ;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
# Check if builds.json exists
|
||||
if [ ! -f "$buildsRef" ]; then
|
||||
echo "File created: $buildsRef"
|
||||
echo "{\"$buildName\": 0}" > "$buildsRef"
|
||||
else
|
||||
echo "File already exists: $buildsRef"
|
||||
fi
|
||||
|
||||
# Read the JSON file
|
||||
buildsMap=$(cat "$buildsRef")
|
||||
|
||||
# Check if buildName exists in the JSON
|
||||
if jq -e --arg key "$buildName" 'has($key)' <<< "$buildsMap" > /dev/null; then
|
||||
echo "Build exists: $buildName"
|
||||
buildNumber=$(jq --arg key "$buildName" '.[$key]' <<< "$buildsMap")
|
||||
buildNumber=$((buildNumber + 1))
|
||||
echo "Next build number for $buildName: $buildNumber"
|
||||
buildsMap=$(jq --arg key "$buildName" --argjson value "$buildNumber" '.[$key] = $value' <<< "$buildsMap")
|
||||
else
|
||||
echo "New build: $buildName, starting at build number: 1"
|
||||
buildNumber=1
|
||||
buildsMap=$(jq --arg key "$buildName" --argjson value "$buildNumber" '.[$key] = $value' <<< "$buildsMap")
|
||||
fi
|
||||
|
||||
# Save the updated JSON back to the file
|
||||
echo "$buildsMap" > "$buildsRef"
|
||||
|
||||
# Build iOS application
|
||||
echo "Building iOS application with arguments: --$buildType --build-name=$buildName --build-number=$buildNumber"
|
||||
flutter build ios --"$buildType" --build-name="$buildName" --build-number="$buildNumber"
|
||||
@@ -10,7 +10,7 @@ import '../services/busylight_service.dart';
|
||||
const _kHostKey = 'busylight_host';
|
||||
const _kDefaultHost = 'http://igox-busylight.local';
|
||||
const _kPollIntervalKey = 'busylight_poll_interval';
|
||||
const _kDefaultPollInterval = 5; // seconds
|
||||
const _kDefaultPollInterval = 1.0; // seconds
|
||||
|
||||
final sharedPreferencesProvider = FutureProvider<SharedPreferences>(
|
||||
(_) => SharedPreferences.getInstance(),
|
||||
@@ -21,9 +21,9 @@ final deviceHostProvider = StateProvider<String>((ref) {
|
||||
return prefs?.getString(_kHostKey) ?? _kDefaultHost;
|
||||
});
|
||||
|
||||
final pollIntervalProvider = StateProvider<int>((ref) {
|
||||
final pollIntervalProvider = StateProvider<double>((ref) {
|
||||
final prefs = ref.watch(sharedPreferencesProvider).valueOrNull;
|
||||
return prefs?.getInt(_kPollIntervalKey) ?? _kDefaultPollInterval;
|
||||
return prefs?.getDouble(_kPollIntervalKey) ?? _kDefaultPollInterval.toDouble();
|
||||
});
|
||||
|
||||
// ── Service ──────────────────────────────────────────────────────────────────
|
||||
@@ -161,10 +161,11 @@ class PollingNotifier extends StateNotifier<void> {
|
||||
Timer? _timer;
|
||||
|
||||
void _start() {
|
||||
final interval = _ref.read(pollIntervalProvider);
|
||||
final intervalSeconds = _ref.read(pollIntervalProvider);
|
||||
final intervalMillis = (intervalSeconds * 1000).toInt();
|
||||
_timer?.cancel();
|
||||
if (interval <= 0) return;
|
||||
_timer = Timer.periodic(Duration(seconds: interval), (_) => _poll());
|
||||
if (intervalMillis <= 0) return;
|
||||
_timer = Timer.periodic(Duration(milliseconds: intervalMillis), (_) => _poll());
|
||||
}
|
||||
|
||||
void restart() => _start();
|
||||
|
||||
@@ -14,7 +14,7 @@ class SettingsScreen extends ConsumerStatefulWidget {
|
||||
|
||||
class _SettingsScreenState extends ConsumerState<SettingsScreen> {
|
||||
late TextEditingController _hostController;
|
||||
late int _pollInterval;
|
||||
late double _pollInterval;
|
||||
bool _startWithSession = false;
|
||||
|
||||
@override
|
||||
@@ -48,7 +48,7 @@ class _SettingsScreenState extends ConsumerState<SettingsScreen> {
|
||||
|
||||
final prefs = await SharedPreferences.getInstance();
|
||||
await prefs.setString('busylight_host', host);
|
||||
await prefs.setInt('busylight_poll_interval', _pollInterval);
|
||||
await prefs.setDouble('busylight_poll_interval', _pollInterval);
|
||||
|
||||
if (mounted) {
|
||||
ScaffoldMessenger.of(context).showSnackBar(
|
||||
@@ -58,10 +58,10 @@ class _SettingsScreenState extends ConsumerState<SettingsScreen> {
|
||||
}
|
||||
}
|
||||
|
||||
String _intervalLabel(int seconds) {
|
||||
if (seconds == 0) return 'Off';
|
||||
if (seconds < 60) return '${seconds}s';
|
||||
return '${seconds ~/ 60}m';
|
||||
String _intervalLabel(double seconds) {
|
||||
if (seconds == 0.0) return 'Off';
|
||||
if (seconds < 2.0) return '${seconds}s';
|
||||
return '${ (seconds)}s';
|
||||
}
|
||||
|
||||
@override
|
||||
@@ -124,21 +124,21 @@ class _SettingsScreenState extends ConsumerState<SettingsScreen> {
|
||||
overlayColor: Colors.amber.withOpacity(0.2),
|
||||
),
|
||||
child: Slider(
|
||||
value: _pollInterval.toDouble(),
|
||||
min: 0,
|
||||
max: 60,
|
||||
divisions: 12,
|
||||
onChanged: (v) => setState(() => _pollInterval = v.round()),
|
||||
value: _pollInterval,
|
||||
min: 0.0,
|
||||
max: 2.0,
|
||||
divisions: 4,
|
||||
onChanged: (v) => setState(() => _pollInterval = v),
|
||||
),
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Text('Off', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('5s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('10s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('30s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('1m', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('0.5s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('1s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('1.5s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
Text('2s', style: TextStyle(color: Colors.grey.shade600, fontSize: 11)),
|
||||
],
|
||||
),
|
||||
const SizedBox(height: 6),
|
||||
|
||||
@@ -330,14 +330,10 @@
|
||||
inputFileListPaths = (
|
||||
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist",
|
||||
);
|
||||
inputPaths = (
|
||||
);
|
||||
name = "[CP] Embed Pods Frameworks";
|
||||
outputFileListPaths = (
|
||||
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist",
|
||||
);
|
||||
outputPaths = (
|
||||
);
|
||||
runOnlyForDeploymentPostprocessing = 0;
|
||||
shellPath = /bin/sh;
|
||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n";
|
||||
|
||||
Executable
+60
@@ -0,0 +1,60 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Default values
|
||||
buildType="release"
|
||||
buildName="0.0.0"
|
||||
buildsRef="builds.json"
|
||||
|
||||
# Help message
|
||||
show_help() {
|
||||
echo "Usage: $0 [-t buildType] [-n buildName]"
|
||||
echo "Builds a Flutter macOS application with versioning support."
|
||||
echo ""
|
||||
echo "Options:"
|
||||
echo " -t, --buildType Build type (release or debug). Default: release"
|
||||
echo " -n, --buildName Build name (version). Default: 0.0.0"
|
||||
echo " -h, --help Show this help message"
|
||||
exit 0
|
||||
}
|
||||
|
||||
# Parse command-line arguments
|
||||
while [[ "$#" -gt 0 ]]; do
|
||||
case $1 in
|
||||
-t|--buildType) buildType="$2"; shift ;;
|
||||
-n|--buildName) buildName="$2"; shift ;;
|
||||
-h|--help) show_help ;;
|
||||
*) echo "Unknown parameter: $1"; show_help; exit 1 ;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
# Check if builds.json exists
|
||||
if [ ! -f "$buildsRef" ]; then
|
||||
echo "File created: $buildsRef"
|
||||
echo "{\"$buildName\": 0}" > "$buildsRef"
|
||||
else
|
||||
echo "File already exists: $buildsRef"
|
||||
fi
|
||||
|
||||
# Read the JSON file
|
||||
buildsMap=$(cat "$buildsRef")
|
||||
|
||||
# Check if buildName exists in the JSON
|
||||
if jq -e --arg key "$buildName" 'has($key)' <<< "$buildsMap" > /dev/null; then
|
||||
echo "Build exists: $buildName"
|
||||
buildNumber=$(jq --arg key "$buildName" '.[$key]' <<< "$buildsMap")
|
||||
buildNumber=$((buildNumber + 1))
|
||||
echo "Next build number for $buildName: $buildNumber"
|
||||
buildsMap=$(jq --arg key "$buildName" --argjson value "$buildNumber" '.[$key] = $value' <<< "$buildsMap")
|
||||
else
|
||||
echo "New build: $buildName, starting at build number: 1"
|
||||
buildNumber=1
|
||||
buildsMap=$(jq --arg key "$buildName" --argjson value "$buildNumber" '.[$key] = $value' <<< "$buildsMap")
|
||||
fi
|
||||
|
||||
# Save the updated JSON back to the file
|
||||
echo "$buildsMap" > "$buildsRef"
|
||||
|
||||
# Build macOS application
|
||||
echo "Building macOS application with arguments: --$buildType --build-name=$buildName --build-number=$buildNumber"
|
||||
flutter build macos --"$buildType" --build-name="$buildName" --build-number="$buildNumber"
|
||||
@@ -0,0 +1,55 @@
|
||||
<#
|
||||
.SYNOPSIS
|
||||
Builds a Flutter Windows installer with versioning support.
|
||||
|
||||
.DESCRIPTION
|
||||
This script builds a Flutter Windows application and creates an installer using Inno Setup.
|
||||
|
||||
.PARAMETER buildType
|
||||
The build type (release or debug). Default is "release".
|
||||
|
||||
.PARAMETER buildName
|
||||
The build name (version). Default is "0.0.0".
|
||||
|
||||
.EXAMPLE
|
||||
.\build-windows-installer.ps1 -buildType debug -buildName 1.0.0
|
||||
Builds a debug Windows application with version 1.0.0.
|
||||
#>
|
||||
|
||||
[CmdletBinding()]
|
||||
param (
|
||||
[string]$buildType = "release", # Default value is "release"
|
||||
[string]$buildName = "0.0.0" # Default value is "0.0.0"
|
||||
)
|
||||
|
||||
$buildNumber = "$(Get-Date -Format 'yyyyMMddHHmmss')"
|
||||
|
||||
# Define the file path and the new version value
|
||||
$issTplFile = "./busylight-buddy-windows-installer-builder.iss.tpl"
|
||||
$issFile = "./busylight-buddy-windows-installer-builder.iss"
|
||||
|
||||
cd $PSScriptRoot
|
||||
|
||||
# Build an array for arguments
|
||||
$flutterArgs = @(
|
||||
"--$buildType",
|
||||
"--build-name=$buildName",
|
||||
"--build-number=$buildNumber"
|
||||
)
|
||||
|
||||
Write-Output "Building Windows application with arguments: $($flutterArgs -join ' ')"
|
||||
|
||||
# Build the Windows application using Flutter
|
||||
flutter build windows @flutterArgs
|
||||
|
||||
# Build the Windows installer using Inno Setup Compiler (ISCC.exe)
|
||||
# Read the content of Inno Setup template file
|
||||
$content = Get-Content -Path $issTplFile -Raw
|
||||
|
||||
# Replace the placeholder with the new version value
|
||||
$updatedContent = $content -replace '%%MyAppVersion%%', $buildName
|
||||
|
||||
# Write the updated content back to Inno Setup file
|
||||
$updatedContent | Set-Content -Path $issFile
|
||||
|
||||
ISCC.exe $issFile
|
||||
+7
-7
@@ -3,7 +3,7 @@
|
||||
; Non-commercial use only
|
||||
|
||||
#define MyAppName "BusyLight Buddy"
|
||||
#define MyAppVersion "0.1"
|
||||
#define MyAppVersion "%%MyAppVersion%%"
|
||||
#define MyAppPublisher "iGoX"
|
||||
#define MyAppURL "https://github.com/igox/busylight-buddy"
|
||||
#define MyAppExeName "busylight_buddy.exe"
|
||||
@@ -30,13 +30,13 @@ ArchitecturesAllowed=x64compatible
|
||||
; the 64-bit view of the registry.
|
||||
ArchitecturesInstallIn64BitMode=x64compatible
|
||||
DisableProgramGroupPage=yes
|
||||
LicenseFile="LICENSE"
|
||||
LicenseFile="..\LICENSE"
|
||||
; Uncomment the following line to run in non administrative install mode (install for current user only).
|
||||
;PrivilegesRequired=lowest
|
||||
PrivilegesRequiredOverridesAllowed=dialog
|
||||
OutputDir="windows\installer"
|
||||
OutputDir="installer"
|
||||
OutputBaseFilename=BusyLight-Buddy-Installer
|
||||
SetupIconFile="windows\runner\resources\app_icon.ico"
|
||||
SetupIconFile="runner\resources\app_icon.ico"
|
||||
SolidCompression=yes
|
||||
WizardStyle=modern dynamic
|
||||
|
||||
@@ -47,9 +47,9 @@ Name: "english"; MessagesFile: "compiler:Default.isl"
|
||||
Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked
|
||||
|
||||
[Files]
|
||||
Source: "build\windows\x64\runner\Release\{#MyAppExeName}"; DestDir: "{app}"; Flags: ignoreversion
|
||||
Source: "build\windows\x64\runner\Release\flutter_windows.dll"; DestDir: "{app}"; Flags: ignoreversion
|
||||
Source: "build\windows\x64\runner\Release\data\*"; DestDir: "{app}\data"; Flags: ignoreversion recursesubdirs createallsubdirs
|
||||
Source: "..\build\windows\x64\runner\Release\{#MyAppExeName}"; DestDir: "{app}"; Flags: ignoreversion
|
||||
Source: "..\build\windows\x64\runner\Release\flutter_windows.dll"; DestDir: "{app}"; Flags: ignoreversion
|
||||
Source: "..\build\windows\x64\runner\Release\data\*"; DestDir: "{app}\data"; Flags: ignoreversion recursesubdirs createallsubdirs
|
||||
; NOTE: Don't use "Flags: ignoreversion" on any shared system files
|
||||
|
||||
[Icons]
|
||||
Reference in New Issue
Block a user