mirror of
https://github.com/fork-maintainers/iceraven-browser
synced 2024-11-15 18:12:54 +00:00
b5e46e611d
The end result is that Android Studio can be used in Windows to build Fenix when using the "local publish" workflow managed by settings.gradle - android-components publishes automatically, although it's necessary to manually public application-services because it doesn't build on native Windows, only via WSL. So instead of trying to build it, it just prints a message indicating the manual build is necessary.
85 lines
4.1 KiB
Groovy
85 lines
4.1 KiB
Groovy
include ':app'
|
|
|
|
include ':mozilla-detekt-rules'
|
|
include ':mozilla-lint-rules'
|
|
def log(message) {
|
|
logger.lifecycle("[settings] ${message}")
|
|
}
|
|
|
|
def runCmd(cmd, workingDir, successMessage, captureStdout=true) {
|
|
def proc = cmd.execute(null, new File(workingDir))
|
|
def standardOutput = captureStdout ? new ByteArrayOutputStream() : System.out
|
|
proc.consumeProcessOutput(standardOutput, System.err)
|
|
proc.waitFor()
|
|
|
|
if (proc.exitValue() != 0) {
|
|
throw new GradleException("Process '${cmd}' finished with non-zero exit value ${proc.exitValue()}");
|
|
} else {
|
|
log(successMessage)
|
|
}
|
|
return captureStdout ? standardOutput : null
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
// Local Development overrides
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
Properties localProperties = null
|
|
String settingAppServicesPath = "autoPublish.application-services.dir"
|
|
String settingAndroidComponentsPath = "autoPublish.android-components.dir"
|
|
|
|
if (file('local.properties').canRead()) {
|
|
localProperties = new Properties()
|
|
localProperties.load(file('local.properties').newDataInputStream())
|
|
log('Loaded local.properties')
|
|
} else {
|
|
log('Missing local.properties; see https://github.com/mozilla-mobile/fenix/blob/master/README.md#local-properties-helpers for instructions.')
|
|
}
|
|
|
|
if (localProperties != null) {
|
|
localProperties.each { prop ->
|
|
gradle.ext.set("localProperties.${prop.key}", prop.value)
|
|
}
|
|
|
|
String appServicesLocalPath = localProperties.getProperty(settingAppServicesPath)
|
|
|
|
if (appServicesLocalPath != null) {
|
|
log("Enabling automatic publication of application-services from: $appServicesLocalPath")
|
|
def publishAppServicesCmd = ["./automation/publish_to_maven_local_if_modified.py"]
|
|
// Application-services doesn't build on native Windows. However, it still makes sense to
|
|
// enable these workflows on Windows, even if it isn't quote as automatic as elsewhere -
|
|
// specifically, you must run the build command on WSL, but after that you can happily build
|
|
// and debug directly from within Android Studio on native Windows - but only after following
|
|
// https://github.com/mozilla/application-services/blob/master/docs/howtos/setup-android-build-environment.md#using-windows
|
|
// So rather than fail we make noise...
|
|
if (System.properties['os.name'].toLowerCase().contains('windows')) {
|
|
log('NOTE: The autoPublish workflows do not work on native windows.');
|
|
log('You must manually ensure that the following command has completed successfully in WSL:');
|
|
log("> $publishAppServicesCmd");
|
|
log("(from the '$appServicesLocalPath' directory)");
|
|
log('Then restart the build');
|
|
} else {
|
|
runCmd(publishAppServicesCmd, appServicesLocalPath, "Published application-services for local development.", false)
|
|
}
|
|
} else {
|
|
log("Disabled auto-publication of application-services. Enable it by settings '$settingAppServicesPath' in local.properties")
|
|
}
|
|
|
|
String androidComponentsLocalPath = localProperties.getProperty(settingAndroidComponentsPath)
|
|
|
|
if (androidComponentsLocalPath != null) {
|
|
// android-components does build on native windows, so it doesn't get the special Windows treatment above.
|
|
// But it doesn't like executing .py files directly. We assume a "manually installed" python,
|
|
// which comes with a "py" launcher and respects the shebang line to specify the version.
|
|
log("Enabling automatic publication of android-components from: $androidComponentsLocalPath")
|
|
def publishAcCmd = [];
|
|
if (System.properties['os.name'].toLowerCase().contains('windows')) {
|
|
publishAcCmd << "py";
|
|
}
|
|
publishAcCmd << "./automation/publish_to_maven_local_if_modified.py";
|
|
runCmd(publishAcCmd, androidComponentsLocalPath, "Published android-components for local development.", false)
|
|
} else {
|
|
log("Disabled auto-publication of android-components. Enable it by settings '$settingAndroidComponentsPath' in local.properties")
|
|
}
|
|
}
|