From be1514e8302e526302720d3a6b757a0cf89356a3 Mon Sep 17 00:00:00 2001 From: pengfeizhou Date: Thu, 25 Feb 2021 17:03:49 +0800 Subject: [PATCH] feat:Add command to run android app --- doric-cli/package.json | 3 +- doric-cli/src/index.ts | 8 ++++ doric-cli/src/run.ts | 86 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 96 insertions(+), 1 deletion(-) create mode 100644 doric-cli/src/run.ts diff --git a/doric-cli/package.json b/doric-cli/package.json index 0f267e98..391e86af 100644 --- a/doric-cli/package.json +++ b/doric-cli/package.json @@ -37,7 +37,8 @@ "shelljs": "^0.8.4", "source-map-merger": "^0.2.0", "typescript": "^3.9.7", - "ws": "^7.4.3" + "ws": "^7.4.3", + "xml-js": "^1.6.11" }, "publishConfig": { "registry": "https://registry.npmjs.org" diff --git a/doric-cli/src/index.ts b/doric-cli/src/index.ts index 4b236dbc..4d5eff86 100644 --- a/doric-cli/src/index.ts +++ b/doric-cli/src/index.ts @@ -4,6 +4,7 @@ import commander from "commander" import { build, clean } from "./actions"; import create from "./create" import dev from "./dev" +import { run } from "./run"; commander .command('create ') .action(async function (name, cmd) { @@ -29,4 +30,11 @@ commander .action(async function () { await clean(); }) + +commander + .command('run ') + .action(async function (platform, cmd) { + await run(platform); + }) commander.parse(process.argv) + diff --git a/doric-cli/src/run.ts b/doric-cli/src/run.ts new file mode 100644 index 00000000..f8957014 --- /dev/null +++ b/doric-cli/src/run.ts @@ -0,0 +1,86 @@ +import { Shell } from "./shell"; +import fs from "fs"; +import { glob } from "./util"; +import path from "path"; +import xml2js, { Element } from "xml-js"; + +export async function run(platform: string) { + switch (platform.toLowerCase()) { + case "android": + await runAndroid(); + break; + case "ios": + await runiOS(); + break; + default: + throw new Error("Donnot support " + platform); + } +} + +async function runAndroid() { + console.log("Running on Android"); + const androidDir = path.resolve(process.cwd(), "android"); + if (!fs.existsSync(androidDir)) { + console.log("Cannot find Android Project".red) + return; + } + const androidSDKHome = process.env["ANDROID_HOME"] || process.env["ANDROID_SDK_ROOT"] + if (!androidSDKHome) { + console.log("Please set env variable $ANDROID_HOME or $ANDROID_SDK_ROOT".red) + return; + } + const adbPath = path.resolve(androidSDKHome, "platform-tools", "adb"); + console.log("Waiting for building".green); + console.log("===================="); + await Shell.exec("sh", ["gradlew", "assembleDebug"], { + cwd: androidDir, + consoleHandler: (info) => console.log(info) + }); + const apkFiles = await glob("**/outputs/apk/debug/*.apk", { + cwd: androidDir, + }) + if (apkFiles == null || apkFiles.length == 0) { + console.log("Cannot find APK".red) + return; + } + const apkFile = path.resolve(androidDir, apkFiles[0]) + console.log("Built Android APK".green, apkFile.blue); + console.log("===================="); + console.log("Installing apk".green) + await Shell.exec(adbPath, ["install", "-t", "-r", apkFile], { + consoleHandler: (info) => console.log(info) + }); + + const apk_analyzer = path.resolve(androidSDKHome, "tools", "bin", "apkanalyzer"); + const ret = await Shell.execOut(apk_analyzer, ["manifest", "print", apkFile]) + const xlmobj = xml2js.xml2js(ret) as Element; + const element = xlmobj.elements + ?.find(e => e.name === "manifest")?.elements + ?.find(e => e.name === "application")?.elements + ?.filter(e => e.name === "activity") + ?.filter(e => e.elements + ?.find(e => e.name === "intent-filter" && e.elements + ?.find(e => e.name === "action")?.attributes?.["android:name"] === "android.intent.action.MAIN")) + if (element && element.length > 0) { + const activityElement = element[0]; + const mainActivity = activityElement.attributes?.["android:name"] + const packageName = xlmobj.elements + ?.find(e => e.name === "manifest")?.attributes?.["package"]; + await Shell.exec( + adbPath, + ["shell", + "am", "start", + "-n", `${packageName}/${mainActivity}`, + "-a", "android.intent.action.MAIN", + "-c", "android.intent.category.LAUNCHER"], + { + consoleHandler: (info) => console.log(info) + }); + } else { + console.log("Cannot find activity for launch") + } +} + +async function runiOS() { + +} \ No newline at end of file