From 5140fa86974bae0720a8e080bdc3428dc10531af Mon Sep 17 00:00:00 2001 From: Miaomiao Date: Thu, 11 May 2023 18:26:57 +0800 Subject: [PATCH] add support for framework, add hiding resource-only, rm all \n --- xml2json/xml2json.py | 38 +++++++++++++++++++++++++++----------- 1 file changed, 27 insertions(+), 11 deletions(-) diff --git a/xml2json/xml2json.py b/xml2json/xml2json.py index 83d95f168c5..a0c39b8e876 100755 --- a/xml2json/xml2json.py +++ b/xml2json/xml2json.py @@ -265,7 +265,7 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat if child.get("props") is not None: # if platform_tag not in child.get("props") and "native" not in child.get("props") or remove_sdk_type in child.get("props") or platform_tag not in child.get("props") and "native" in child.get("props") and platform_tag != "windows" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios": if platform_tag not in child.get("props") and "native" not in child.get( - "props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( + "props") and "framework" not in child.get("props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( "props") and "native" in child.get( "props") and platform_tag != "cpp" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios" and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or child.get("props") == "hide" or child.get("props") == "cn": print("------------------- Tag to remove ---------------------------") @@ -890,7 +890,7 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat if child.get("props") is not None: # if platform_tag not in child.get("props") and "native" not in child.get("props") or remove_sdk_type in child.get("props") or platform_tag not in child.get("props") and "native" in child.get("props") and platform_tag != "windows" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios": if platform_tag not in child.get("props") and "native" not in child.get( - "props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( + "props") and "framework" not in child.get("props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( "props") and "native" in child.get( "props") and platform_tag != "cpp" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios" and child.get("props") != "rtc" and child.get("props") != "rtc-ng": print("------------------- Tag to remove ---------------------------") @@ -912,7 +912,7 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat if child.get("props") is not None: # if platform_tag not in child.get("props") and "native" not in child.get("props") or remove_sdk_type in child.get("props") or platform_tag not in child.get("props") and "native" in child.get("props") and platform_tag != "windows" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios": if platform_tag not in child.get("props") and "native" not in child.get( - "props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( + "props") and "framework" not in child.get("props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( "props") and "native" in child.get( "props") and platform_tag != "cpp" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios" and child.get("props") != "rtc" and child.get("props") != "rtc-ng": print("------------------- Tag to remove ---------------------------") @@ -935,7 +935,7 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat if child.get("props") is not None: # if platform_tag not in child.get("props") and "native" not in child.get("props") or remove_sdk_type in child.get("props") or platform_tag not in child.get("props") and "native" in child.get("props") and platform_tag != "windows" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios": if platform_tag not in child.get("props") and "native" not in child.get( - "props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( + "props") and "framework" not in child.get("props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( "props") and "native" in child.get( "props") and platform_tag != "cpp" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios" and child.get("props") != "rtc" and child.get("props") != "rtc-ng": print("------------------- Tag to remove ---------------------------") @@ -958,7 +958,7 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat if child.get("props") is not None: # if platform_tag not in child.get("props") and "native" not in child.get("props") or remove_sdk_type in child.get("props") or platform_tag not in child.get("props") and "native" in child.get("props") and platform_tag != "windows" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios": if platform_tag not in child.get("props") and "native" not in child.get( - "props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( + "props") and "framework" not in child.get("props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( "props") and "native" in child.get( "props") and platform_tag != "cpp" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios" and child.get("props") != "rtc" and child.get("props") != "rtc-ng": print("------------------- Tag to remove ---------------------------") @@ -981,7 +981,7 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat if child.get("props") is not None: # if platform_tag not in child.get("props") and "native" not in child.get("props") or remove_sdk_type in child.get("props") or platform_tag not in child.get("props") and "native" in child.get("props") and platform_tag != "windows" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios": if platform_tag not in child.get("props") and "native" not in child.get( - "props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( + "props") and "framework" not in child.get("props") and child.get("props") != "rtc" and child.get("props") != "rtc-ng" or remove_sdk_type in child.get("props") or platform_tag not in child.get( "props") and "native" in child.get( "props") and platform_tag != "cpp" and platform_tag != "macos" and platform_tag != "android" and platform_tag != "ios" and child.get("props") != "rtc" and child.get("props") != "rtc-ng": print("------------------- Tag to remove ---------------------------") @@ -1153,11 +1153,27 @@ def create_json_from_xml(working_dir, file_dir, android_path, cpp_path, rust_pat data = {} data['id'] = api_id - data['name'] = api_name.strip("\n ") - data['description'] = api_desc.rstrip("\n") - data['parameters'] = json_array - data['returns'] = return_values.strip("\n ") - data['is_hide'] = True if api_id in json_hide_id_list else False + + # 处理 name 字段 + data['name'] = api_name.replace("\n", "") if isinstance(api_name, str) else api_name + + # 处理 description 字段 + data['description'] = api_desc.replace("\n", "") if isinstance(api_desc, str) else api_desc + + # 处理 parameters 字段 + data['parameters'] = [ + {key.replace("\n", "") if isinstance(key, str) and key is not None else key: + value.replace("\n", "") if isinstance(value, str) and value is not None else value} + for param in json_array + for key, value in param.items() + ] + + # 处理 returns 字段 + data['returns'] = return_values.replace("\n", "") if isinstance(return_values, str) and return_values is not None else return_values + + + data['is_hide'] = True if api_id in json_hide_id_list or data['name'] == "" else False + print(data)