From f539434c8da01abf26077675dd2d2de9d022ec6a Mon Sep 17 00:00:00 2001 From: Austin <liaozhiqi7@huawei.com> Date: Tue, 5 Jul 2022 06:41:41 +0000 Subject: [PATCH] update zh-cn/device-dev/porting/porting-thirdparty-cmake.md. Signed-off-by: Austin23 <liaozhiqi7@huawei.com> --- .../porting/porting-thirdparty-cmake.md | 214 +++++++++--------- 1 file changed, 107 insertions(+), 107 deletions(-) diff --git a/zh-cn/device-dev/porting/porting-thirdparty-cmake.md b/zh-cn/device-dev/porting/porting-thirdparty-cmake.md index 55ff536c6b..043e797410 100644 --- a/zh-cn/device-dev/porting/porting-thirdparty-cmake.md +++ b/zh-cn/device-dev/porting/porting-thirdparty-cmake.md @@ -123,52 +123,52 @@ CMakeæ–¹å¼å¯é€šè¿‡æŒ‡å®šå·¥å…·é“¾è¿›è¡Œäº¤å‰ç¼–译,修改并编译该库, - 挂载æˆåŠŸåŽæ‰§è¡Œä¸‹åˆ—命令å¯åˆ—出用例所有æ¡ç›®ï¼š - ``` - cd nfs - ./cctest --list - ``` - - 上述命令执行结果部分展示: + ``` + cd nfs + ./cctest --list + ``` + 上述命令执行结果部分展示: + - ``` - test-bignum/Assign< - test-bignum/ShiftLeft< - test-bignum/AddUInt64< - test-bignum/AddBignum< - test-bignum/SubtractBignum< - test-bignum/MultiplyUInt32< - test-bignum/MultiplyUInt64< - test-bignum/MultiplyPowerOfTen< - test-bignum/DivideModuloIntBignum< - test-bignum/Compare< - test-bignum/PlusCompare< - test-bignum/Square< - test-bignum/AssignPowerUInt16< - test-bignum-dtoa/BignumDtoaVariousDoubles< - test-bignum-dtoa/BignumDtoaShortestVariousFloats< - test-bignum-dtoa/BignumDtoaGayShortest< - test-bignum-dtoa/BignumDtoaGayShortestSingle< - test-bignum-dtoa/BignumDtoaGayFixed< - test-bignum-dtoa/BignumDtoaGayPrecision< - test-conversions/DoubleToShortest< - test-conversions/DoubleToShortestSingle< - ... - ``` + ``` + test-bignum/Assign< + test-bignum/ShiftLeft< + test-bignum/AddUInt64< + test-bignum/AddBignum< + test-bignum/SubtractBignum< + test-bignum/MultiplyUInt32< + test-bignum/MultiplyUInt64< + test-bignum/MultiplyPowerOfTen< + test-bignum/DivideModuloIntBignum< + test-bignum/Compare< + test-bignum/PlusCompare< + test-bignum/Square< + test-bignum/AssignPowerUInt16< + test-bignum-dtoa/BignumDtoaVariousDoubles< + test-bignum-dtoa/BignumDtoaShortestVariousFloats< + test-bignum-dtoa/BignumDtoaGayShortest< + test-bignum-dtoa/BignumDtoaGayShortestSingle< + test-bignum-dtoa/BignumDtoaGayFixed< + test-bignum-dtoa/BignumDtoaGayPrecision< + test-conversions/DoubleToShortest< + test-conversions/DoubleToShortestSingle< + ... + ``` - 以test-bignumæ¡ç›®ä¸ºä¾‹ï¼Œæ‰§è¡Œä¸‹åˆ—命令开始测试: - ``` - ./cctest test-bignum - ``` + ``` + ./cctest test-bignum + ``` - 测试结果如下则表示通过: + 测试结果如下则表示通过: - ``` - Ran 13 tests. - ``` + ``` + Ran 13 tests. + ``` ## å°†è¯¥åº“ç¼–è¯‘æ·»åŠ åˆ°OpenHarmonyå·¥ç¨‹ä¸ @@ -189,103 +189,103 @@ CMakeæ–¹å¼å¯é€šè¿‡æŒ‡å®šå·¥å…·é“¾è¿›è¡Œäº¤å‰ç¼–译,修改并编译该库, - **新增的BUILD.gn文件实现如下,其他采用CMakeæ–¹å¼å¯ç‹¬ç«‹ç¼–译的三方库移æ¤åˆ°OpenHarmonyå¹³å°æ—¶åªéœ€ä¿®æ”¹è·¯å¾„å³å¯**。 - ``` - import("config.gni") - group("double-conversion") { - if (ohos_build_thirdparty_migrated_from_fuchisa == true) { - deps = [":make"] - } - } - if (ohos_build_thirdparty_migrated_from_fuchisa == true) { - action("make") { - script = "//third_party/double-conversion/build_thirdparty.py" - outputs = ["$root_out_dir/log_dc.txt"] - exec_path = rebase_path(rebase_path("./build", ohos_third_party_dir)) - command = "rm * .* -rf && $CMAKE_TOOLS_PATH/cmake .. $CMAKE_FLAG $CMAKE_TOOLCHAIN_FLAG && make -j" - args = [ - "--path=$exec_path", - "--command=${command}" - ] - } - } - ``` + ``` + import("config.gni") + group("double-conversion") { + if (ohos_build_thirdparty_migrated_from_fuchisa == true) { + deps = [":make"] + } + } + if (ohos_build_thirdparty_migrated_from_fuchisa == true) { + action("make") { + script = "//third_party/double-conversion/build_thirdparty.py" + outputs = ["$root_out_dir/log_dc.txt"] + exec_path = rebase_path(rebase_path("./build", ohos_third_party_dir)) + command = "rm * .* -rf && $CMAKE_TOOLS_PATH/cmake .. $CMAKE_FLAG $CMAKE_TOOLCHAIN_FLAG && make -j" + args = [ + "--path=$exec_path", + "--command=${command}" + ] + } + } + ``` - **新增的config.gni用于é…置该库,实现如下,其他采用CMakeæ–¹å¼å¯ç‹¬ç«‹ç¼–译的三方库移æ¤åˆ°OpenHarmonyæ—¶åªéœ€ä¿®æ”¹CMAKE_FLAGçš„é…ç½®å³å¯ã€‚** - ``` - #CMAKE_FLAG: config compile feature - CMAKE_FLAG = "-DBUILD_TESTING=ON -DCMAKE_CXX_STANDARD=11" + ``` + #CMAKE_FLAG: config compile feature + CMAKE_FLAG = "-DBUILD_TESTING=ON -DCMAKE_CXX_STANDARD=11" - #toolchain:follow up-layer,depend on $ohos_build_compiler - if (ohos_build_compiler == "clang") { - CMAKE_TOOLCHAIN_FLAG = "-DOHOS_SYSROOT_PATH=${ohos_root_path}prebuilts/lite/sysroot/" - } else { - CMAKE_TOOLCHAIN_FLAG = "" - } + #toolchain:follow up-layer,depend on $ohos_build_compiler + if (ohos_build_compiler == "clang") { + CMAKE_TOOLCHAIN_FLAG = "-DOHOS_SYSROOT_PATH=${ohos_root_path}prebuilts/lite/sysroot/" + } else { + CMAKE_TOOLCHAIN_FLAG = "" + } - #CMake tools path,no need setting if this path already joined to $PATH. - CMAKE_TOOLS_PATH = "setting CMake tools path..." - ``` + #CMake tools path,no need setting if this path already joined to $PATH. + CMAKE_TOOLS_PATH = "setting CMake tools path..." + ``` - **新增的build_thirdparty.py实现如下,其他采用CMakeæ–¹å¼å¯ç‹¬ç«‹ç¼–译的三方库移æ¤åˆ°OpenHarmonyæ—¶æ— éœ€ä¿®æ”¹å³å¯ä½¿ç”¨ã€‚** - ``` - import os - import sys - from subprocess import Popen - import argparse - import shlex + ``` + import os + import sys + from subprocess import Popen + import argparse + import shlex - def cmd_exec(command): - cmd = shlex.split(command) - proc = Popen(cmd) - proc.wait() - ret_code = proc.returncode - if ret_code != 0: - raise Exception("{} failed, return code is {}".format(cmd, ret_code)) + def cmd_exec(command): + cmd = shlex.split(command) + proc = Popen(cmd) + proc.wait() + ret_code = proc.returncode + if ret_code != 0: + raise Exception("{} failed, return code is {}".format(cmd, ret_code)) - def main(): - parser = argparse.ArgumentParser() - parser.add_argument('--path', help='Build path.') - parser.add_argument('--command', help='Build command.') - parser.add_argument('--enable', help='enable python.', nargs='*') - args = parser.parse_args() + def main(): + parser = argparse.ArgumentParser() + parser.add_argument('--path', help='Build path.') + parser.add_argument('--command', help='Build command.') + parser.add_argument('--enable', help='enable python.', nargs='*') + args = parser.parse_args() - if args.enable: - if args.enable[0] == 'false': + if args.enable: + if args.enable[0] == 'false': return - if args.path: - curr_dir = os.getcwd() - os.chdir(args.path) - if args.command: - if '&&' in args.command: - command = args.command.split('&&') - for data in command: + if args.path: + curr_dir = os.getcwd() + os.chdir(args.path) + if args.command: + if '&&' in args.command: + command = args.command.split('&&') + for data in command: cmd_exec(data) else: cmd_exec(args.command) os.chdir(curr_dir) - if __name__ == '__main__': - sys.exit(main()) - ``` + if __name__ == '__main__': + sys.exit(main()) + ``` - 在é…置文件ä¸æ·»åŠ å¼€å…³æŽ§åˆ¶è¯¥åº“ç¼–è¯‘ï¼Œé»˜è®¤è®¾ä¸ºå…³é— - 在//build/lite/ohos_var.gni文件ä¸æ·»åŠ 下列é…置: + 在//build/lite/ohos_var.gni文件ä¸æ·»åŠ 下列é…置: - ``` - declare_args() { - ohos_build_thirdparty_migrated_from_fuchisa = true - } - ``` + ``` + declare_args() { + ohos_build_thirdparty_migrated_from_fuchisa = true + } + ``` 3. 编译构建 - - 手动å•ç‹¬æž„建: + 手动å•ç‹¬æž„建: 执行下列命令 -- GitLab