mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
e2009c063b
* feat: add archive for compression * feat: add service to manage zipped work spaces * feat: export service in barrel file * feat: ignore .ephemeral directory * feat: add first compressed workspace file * fix: directory path was wrong * feat: add a somewhat useful test * fix: move to same file (delete later) * fix: use script path vs. working directory for CI * fix: read from asset bundle instead of file system * fix: workaround to run integration in multiple files on desktop (flutter/flutter#101031 * feat: remove .ephemeral from .gitignore, no longer created * feat: document test changes * fix: lucas suggestion * feat: mark assets as excluded in pubspec.yaml * feat: add class for build utilities * feat: add script runner for release builds * feat: add build script as task in flowy project * fix: typo in pubspec.yaml * chore: use constants for exclude tag * feat: add appversion as argument to build tool * feat: use dart script in release.yml * chore: remove task * fix: careless error Co-authored-by: Mihir <84044317+squidrye@users.noreply.github.com> * feat: add translations for view of * fix: typo in getAllDatabase * feat: add view of database * fix: remove unused import * fix: use effective dart typing * fix: insertPage marked as async, should return future * fix: Remove multi-line string * fix: ref can be null * fix: unused imports caused analyzer to fail * feat: also fix. Add empty document as option and change name to _name * chore: move referenced database tests to empty document test file * feat: add test utilities * feat: add new integration test on an empty document * feat: register test in runner * fix: missing reference in insert_page_command * fix: analyzer errors --------- Co-authored-by: Mihir <84044317+squidrye@users.noreply.github.com>
116 lines
3.4 KiB
Dart
116 lines
3.4 KiB
Dart
part of 'build_flowy.dart';
|
|
|
|
enum _ScanMode {
|
|
ignore,
|
|
target,
|
|
}
|
|
|
|
enum _ModifyMode {
|
|
include,
|
|
exclude,
|
|
}
|
|
|
|
class _BuildTool {
|
|
const _BuildTool({
|
|
required this.repositoryRoot,
|
|
required this.appVersion,
|
|
});
|
|
|
|
final String repositoryRoot;
|
|
final String appVersion;
|
|
|
|
String get projectRoot =>
|
|
[repositoryRoot, 'appflowy_flutter'].join(Platform.pathSeparator);
|
|
|
|
File get pubspec =>
|
|
File([projectRoot, 'pubspec.yaml'].join(Platform.pathSeparator));
|
|
|
|
Future<String> get _architecture async =>
|
|
await Process.run('uname', ['-m']).then((value) => value.stdout.trim());
|
|
|
|
Future<String> get _commandForOS async {
|
|
// Check the operating system and CPU architecture
|
|
var os = Platform.operatingSystem;
|
|
var arch = Platform.isMacOS ? await _architecture : Platform.localHostname;
|
|
|
|
// Determine the appropriate command based on the OS and architecture
|
|
if (os == 'windows') {
|
|
return 'cargo make --env APP_VERSION=$appVersion --profile production-windows-x86 appflowy';
|
|
}
|
|
|
|
if (os == 'linux') {
|
|
return 'cargo make --env APP_VERSION=$appVersion --profile production-linux-x86_64 appflowy';
|
|
}
|
|
|
|
if (os == 'macos') {
|
|
if (arch == 'x86_64') {
|
|
return 'cargo make --env APP_VERSION=$appVersion --profile production-mac-x86_64 appflowy';
|
|
}
|
|
if (arch == 'arm64') {
|
|
return 'cargo make --env APP_VERSION=$appVersion --profile production-mac-arm64 appflowy';
|
|
}
|
|
throw 'Unsupported CPU architecture: $arch';
|
|
}
|
|
|
|
throw 'Unsupported operating system: $os';
|
|
}
|
|
|
|
/// Scans a file for lines between # BEGIN: EXCLUDE_IN_RELEASE and
|
|
/// END: EXCLUDE_IN_RELEASE. Will add a comment to remove those assets
|
|
/// from the build.
|
|
Future<void> _process_directives(
|
|
File file, {
|
|
required _ModifyMode mode,
|
|
}) async {
|
|
// Read the contents of the file into a list
|
|
var lines = await file.readAsLines();
|
|
|
|
// Find the lines between BEGIN: EXCLUDE_IN_RELEASE and END: EXCLUDE_IN_RELEASE
|
|
var scanMode = _ScanMode.ignore;
|
|
for (var i = 0; i < lines.length; i++) {
|
|
var line = lines[i];
|
|
if (line.contains(excludeTagBegin)) {
|
|
scanMode = _ScanMode.target;
|
|
} else if (line.contains(excludeTagEnd)) {
|
|
scanMode = _ScanMode.ignore;
|
|
} else if (scanMode == _ScanMode.target) {
|
|
lines[i] = _modify(line, mode: mode);
|
|
}
|
|
}
|
|
|
|
// Write the modified contents back to the file
|
|
await file.writeAsString(lines.join('\n'));
|
|
}
|
|
|
|
String _modify(String line, {required _ModifyMode mode}) {
|
|
switch (mode) {
|
|
case _ModifyMode.include:
|
|
return line.split('#').where((element) => element != '#').join();
|
|
case _ModifyMode.exclude:
|
|
return '#$line';
|
|
}
|
|
}
|
|
|
|
Future<void> _build() async {
|
|
final cwd = Directory.current;
|
|
Directory.current = repositoryRoot;
|
|
|
|
final cmd = await _commandForOS;
|
|
// Run the command using the Process.run() function
|
|
// final build = await Process.run('echo', ['hello'], runInShell: true);
|
|
final build =
|
|
await Process.start(cmd.split(' ')[0], cmd.split(' ').sublist(1));
|
|
await stdout.addStream(build.stdout);
|
|
await stderr.addStream(build.stderr);
|
|
Directory.current = cwd;
|
|
}
|
|
|
|
Future<void> run() async {
|
|
final pubspec = this.pubspec;
|
|
|
|
await _process_directives(pubspec, mode: _ModifyMode.exclude);
|
|
await _build();
|
|
await _process_directives(pubspec, mode: _ModifyMode.include);
|
|
}
|
|
}
|