add skip param
This commit is contained in:
parent
66d4ef18b4
commit
ede26c9a27
1 changed files with 34 additions and 40 deletions
|
|
@ -3,7 +3,6 @@ import "package:ffigen/ffigen.dart";
|
|||
import "package:path/path.dart";
|
||||
|
||||
void main(List<String> args) async {
|
||||
// Where we put the Gomuks repo and compiled library
|
||||
final buildDir = Directory.fromUri(
|
||||
Platform.script.resolve(join("..", "build", "gomuks")),
|
||||
);
|
||||
|
|
@ -11,7 +10,7 @@ void main(List<String> args) async {
|
|||
|
||||
final repoDir = Directory(join(buildDir.path, "source"));
|
||||
|
||||
bool skipBuild = false;
|
||||
var skipBuild = args.contains("--skip");
|
||||
|
||||
final generatedSourcePath = join("src", "third_party", "gomuks.g.dart");
|
||||
final generatedLibPath = Platform.script.resolve(
|
||||
|
|
@ -19,9 +18,7 @@ void main(List<String> args) async {
|
|||
);
|
||||
final bindingsFile = File(generatedLibPath.toFilePath());
|
||||
|
||||
if (await bindingsFile.exists() &&
|
||||
await repoDir.exists() &&
|
||||
!args.contains("--rebuild")) {
|
||||
if (await bindingsFile.exists() && await repoDir.exists()) {
|
||||
final result = await Process.run("git", [
|
||||
"fetch",
|
||||
"--dry-run",
|
||||
|
|
@ -32,46 +29,43 @@ void main(List<String> args) async {
|
|||
}
|
||||
}
|
||||
|
||||
if (skipBuild) {
|
||||
return print(
|
||||
"Gomuks build skipped: bindings and library exist and repo is up to date.",
|
||||
);
|
||||
}
|
||||
if (!skipBuild) {
|
||||
if (await repoDir.exists()) await repoDir.delete(recursive: true);
|
||||
|
||||
if (await repoDir.exists()) await repoDir.delete(recursive: true);
|
||||
print("Cloning Gomuks repository...");
|
||||
final cloneResult = await Process.run("git", [
|
||||
"clone",
|
||||
"--branch",
|
||||
"tulir/ffi",
|
||||
"--depth",
|
||||
"1",
|
||||
"https://mau.dev/gomuks/gomuks",
|
||||
repoDir.path,
|
||||
]);
|
||||
|
||||
print("Cloning Gomuks repository...");
|
||||
final cloneResult = await Process.run("git", [
|
||||
"clone",
|
||||
"--branch",
|
||||
"tulir/ffi",
|
||||
"--depth",
|
||||
"1",
|
||||
"https://mau.dev/gomuks/gomuks",
|
||||
repoDir.path,
|
||||
]);
|
||||
if (cloneResult.exitCode != 0) {
|
||||
throw Exception(
|
||||
"Failed to clone Gomuks repository: \n${cloneResult.stderr}",
|
||||
);
|
||||
}
|
||||
|
||||
for (final name in ["libgomuks.so", "libgomuks.dylib", "libgomuks.dll"]) {
|
||||
final libFile = File(join(buildDir.path, name));
|
||||
|
||||
print("Building Gomuks shared library $name...");
|
||||
final result = await Process.run("go", [
|
||||
"build",
|
||||
"-o",
|
||||
libFile.path,
|
||||
"-buildmode=c-shared",
|
||||
], workingDirectory: join(repoDir.path, "pkg/ffi"));
|
||||
|
||||
if (result.exitCode != 0) {
|
||||
if (cloneResult.exitCode != 0) {
|
||||
throw Exception(
|
||||
"Failed to build Gomuks shared library\n${result.stderr}",
|
||||
"Failed to clone Gomuks repository: \n${cloneResult.stderr}",
|
||||
);
|
||||
}
|
||||
|
||||
for (final name in ["libgomuks.so", "libgomuks.dylib", "libgomuks.dll"]) {
|
||||
final libFile = File(join(buildDir.path, name));
|
||||
|
||||
print("Building Gomuks shared library $name...");
|
||||
final result = await Process.run("go", [
|
||||
"build",
|
||||
"-o",
|
||||
libFile.path,
|
||||
"-buildmode=c-shared",
|
||||
], workingDirectory: join(repoDir.path, "pkg/ffi"));
|
||||
|
||||
if (result.exitCode != 0) {
|
||||
throw Exception(
|
||||
"Failed to build Gomuks shared library\n${result.stderr}",
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
print("Generating FFI Bindings...");
|
||||
|
|
@ -82,7 +76,7 @@ void main(List<String> args) async {
|
|||
),
|
||||
headers: Headers(
|
||||
entryPoints: [File(join(buildDir.path, "libgomuks.h")).uri],
|
||||
compilerOptions: ["-I${String.fromEnvironment("CPATH")}"],
|
||||
// compilerOptions: ["-I${String.fromEnvironment("CPATH")}"],
|
||||
),
|
||||
functions: Functions.includeAll,
|
||||
).generate();
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue