diff --git a/docs/reference/xlang-api/c-api.md b/docs/reference/xlang-api/c-api.md new file mode 100644 index 000000000..21a35d4e9 --- /dev/null +++ b/docs/reference/xlang-api/c-api.md @@ -0,0 +1,172 @@ +--- +sidebar_position: 8 +--- + +# C API + +The [C API](https://github.com/kcl-lang/lib/tree/main/c) is in the development stage and contributions are welcome. + +## Prerequisites + ++ Make ++ C Compiler ++ Cargo + +## API Reference + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```c +#include + +int exec_file(const char* file_str) { + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + struct Buffer file = { + .buffer = file_str, + .len = strlen(file_str), + }; + struct Buffer* files[] = { &file }; + struct RepeatedString strs = { .repeated = &files[0], .index = 0, .max_size = 1 }; + ExecProgram_Args args = ExecProgram_Args_init_zero; + args.k_filename_list.funcs.encode = encode_str_list; + args.k_filename_list.arg = &strs; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ExecProgram_Args_fields, &args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ExecProgram"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + if (check_error_prefix(result_buffer)) { + printf("%s", result_buffer); + return 1; + } + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + + ExecProgram_Result result = ExecProgram_Result_init_default; + + uint8_t yaml_value_buffer[BUFFER_SIZE] = { 0 }; + result.yaml_result.arg = yaml_value_buffer; + result.yaml_result.funcs.decode = decode_string; + + uint8_t json_value_buffer[BUFFER_SIZE] = { 0 }; + result.json_result.arg = json_value_buffer; + result.json_result.funcs.decode = decode_string; + + uint8_t err_value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = err_value_buffer; + result.err_message.funcs.decode = decode_string; + + uint8_t log_value_buffer[BUFFER_SIZE] = { 0 }; + result.log_message.arg = log_value_buffer; + result.log_message.funcs.decode = decode_string; + + status = pb_decode(&istream, ExecProgram_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + if (result.yaml_result.arg) { + printf("%s\n", (char*)result.yaml_result.arg); + } + + return 0; +} + +int main() +{ + exec_file("./test_data/schema.k"); + return 0; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include + +int validate(const char* code_str, const char* data_str) +{ + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + + ValidateCode_Args validate_args = ValidateCode_Args_init_zero; + validate_args.code.funcs.encode = encode_string; + validate_args.code.arg = (void*)code_str; + validate_args.data.funcs.encode = encode_string; + validate_args.data.arg = (void*)data_str; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ValidateCode_Args_fields, &validate_args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ValidateCode"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + ValidateCode_Result result = ValidateCode_Result_init_default; + + result.err_message.funcs.decode = decode_string; + uint8_t value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = value_buffer; + + status = pb_decode(&istream, ValidateCode_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + printf("Validate Status: %d\n", result.success); + if (result.err_message.arg) { + printf("Validate Error Message: %s\n", (char*)result.err_message.arg); + } + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + validate(code_str, data_str); + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/docs/reference/xlang-api/cpp-api.md b/docs/reference/xlang-api/cpp-api.md new file mode 100644 index 000000000..6173f76c8 --- /dev/null +++ b/docs/reference/xlang-api/cpp-api.md @@ -0,0 +1,115 @@ +--- +sidebar_position: 9 +--- + +# C++ API + +The [C++ API](https://github.com/kcl-lang/lib/tree/main/cpp) is in the development stage and contributions are welcome. + +## Prerequisites + ++ CMake >= 3.10 ++ C++ Compiler with C++17 Support ++ Cargo + +## Installation + +### CMake + +You can use FetchContent to add KCL C++ Lib to your project. + +```shell +FetchContent_Declare( + kcl-lib + GIT_REPOSITORY https://github.com/kcl-lang/lib.git + GIT_TAG v0.9.1 + SOURCE_SUBDIR cpp +) +FetchContent_MakeAvailable(kcl-lib) +``` + +Or you can download the source code and add it to your project. + +```shell +mkdir third_party +cd third_party +git clone https://github.com/kcl-lang/lib.git +``` + +Update your CMake files. + +```shell +add_subdirectory(third_party/lib/cpp) +``` + +```shell +target_link_libraries(your_target kcl-lib-cpp) +``` + +## API Reference + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```cpp +#include "kcl_lib.hpp" +#include + +int main() +{ + auto args = kcl_lib::ExecProgramArgs(); + auto files = rust::Vec(); + files.push_back(rust::String("../test_data/schema.k")); + args.k_filename_list = files; + auto result = kcl_lib::exec_program(args); + std::cout << result.yaml_result.c_str() << std::endl; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include "kcl_lib.hpp" +#include + +int validate(const char* code_str, const char* data_str) { + auto args = kcl_lib::ValidateCodeArgs(); + args.code = rust::String(code_str); + args.data = rust::String(data_str); + auto result = kcl_lib::validate_code(args); + std::cout << result.success << std::endl; + std::cout << result.err_message.c_str() << std::endl; + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + // Right case + validate(code_str, data_str); + // Error case + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/current/reference/xlang-api/c-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/current/reference/xlang-api/c-api.md new file mode 100644 index 000000000..55259822e --- /dev/null +++ b/i18n/zh-CN/docusaurus-plugin-content-docs/current/reference/xlang-api/c-api.md @@ -0,0 +1,172 @@ +--- +sidebar_position: 8 +--- + +# C API + +KCL [C API](https://github.com/kcl-lang/lib/tree/main/c) 正在开发中,欢迎贡献。 + +## 前置依赖 + ++ Make ++ C Compiler ++ Cargo + +## API 参考 + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```c +#include + +int exec_file(const char* file_str) { + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + struct Buffer file = { + .buffer = file_str, + .len = strlen(file_str), + }; + struct Buffer* files[] = { &file }; + struct RepeatedString strs = { .repeated = &files[0], .index = 0, .max_size = 1 }; + ExecProgram_Args args = ExecProgram_Args_init_zero; + args.k_filename_list.funcs.encode = encode_str_list; + args.k_filename_list.arg = &strs; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ExecProgram_Args_fields, &args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ExecProgram"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + if (check_error_prefix(result_buffer)) { + printf("%s", result_buffer); + return 1; + } + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + + ExecProgram_Result result = ExecProgram_Result_init_default; + + uint8_t yaml_value_buffer[BUFFER_SIZE] = { 0 }; + result.yaml_result.arg = yaml_value_buffer; + result.yaml_result.funcs.decode = decode_string; + + uint8_t json_value_buffer[BUFFER_SIZE] = { 0 }; + result.json_result.arg = json_value_buffer; + result.json_result.funcs.decode = decode_string; + + uint8_t err_value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = err_value_buffer; + result.err_message.funcs.decode = decode_string; + + uint8_t log_value_buffer[BUFFER_SIZE] = { 0 }; + result.log_message.arg = log_value_buffer; + result.log_message.funcs.decode = decode_string; + + status = pb_decode(&istream, ExecProgram_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + if (result.yaml_result.arg) { + printf("%s\n", (char*)result.yaml_result.arg); + } + + return 0; +} + +int main() +{ + exec_file("./test_data/schema.k"); + return 0; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include + +int validate(const char* code_str, const char* data_str) +{ + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + + ValidateCode_Args validate_args = ValidateCode_Args_init_zero; + validate_args.code.funcs.encode = encode_string; + validate_args.code.arg = (void*)code_str; + validate_args.data.funcs.encode = encode_string; + validate_args.data.arg = (void*)data_str; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ValidateCode_Args_fields, &validate_args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ValidateCode"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + ValidateCode_Result result = ValidateCode_Result_init_default; + + result.err_message.funcs.decode = decode_string; + uint8_t value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = value_buffer; + + status = pb_decode(&istream, ValidateCode_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + printf("Validate Status: %d\n", result.success); + if (result.err_message.arg) { + printf("Validate Error Message: %s\n", (char*)result.err_message.arg); + } + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + validate(code_str, data_str); + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/current/reference/xlang-api/cpp-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/current/reference/xlang-api/cpp-api.md new file mode 100644 index 000000000..820f8336e --- /dev/null +++ b/i18n/zh-CN/docusaurus-plugin-content-docs/current/reference/xlang-api/cpp-api.md @@ -0,0 +1,115 @@ +--- +sidebar_position: 9 +--- + +# C++ API + +KCL [C++ API](https://github.com/kcl-lang/lib/tree/main/cpp) 正在开发中,欢迎贡献。 + +## 前置依赖 + ++ CMake >= 3.10 ++ C++ Compiler with C++17 Support ++ Cargo + +## 安装 + +### CMake + +You can use FetchContent to add KCL C++ Lib to your project. + +```shell +FetchContent_Declare( + kcl-lib + GIT_REPOSITORY https://github.com/kcl-lang/lib.git + GIT_TAG v0.9.1 + SOURCE_SUBDIR cpp +) +FetchContent_MakeAvailable(kcl-lib) +``` + +Or you can download the source code and add it to your project. + +```shell +mkdir third_party +cd third_party +git clone https://github.com/kcl-lang/lib.git +``` + +Update your CMake files. + +```shell +add_subdirectory(third_party/lib/cpp) +``` + +```shell +target_link_libraries(your_target kcl-lib-cpp) +``` + +## API 参考 + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```cpp +#include "kcl_lib.hpp" +#include + +int main() +{ + auto args = kcl_lib::ExecProgramArgs(); + auto files = rust::Vec(); + files.push_back(rust::String("../test_data/schema.k")); + args.k_filename_list = files; + auto result = kcl_lib::exec_program(args); + std::cout << result.yaml_result.c_str() << std::endl; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include "kcl_lib.hpp" +#include + +int validate(const char* code_str, const char* data_str) { + auto args = kcl_lib::ValidateCodeArgs(); + args.code = rust::String(code_str); + args.data = rust::String(data_str); + auto result = kcl_lib::validate_code(args); + std::cout << result.success << std::endl; + std::cout << result.err_message.c_str() << std::endl; + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + // Right case + validate(code_str, data_str); + // Error case + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-0.9/reference/xlang-api/c-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-0.9/reference/xlang-api/c-api.md new file mode 100644 index 000000000..55259822e --- /dev/null +++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-0.9/reference/xlang-api/c-api.md @@ -0,0 +1,172 @@ +--- +sidebar_position: 8 +--- + +# C API + +KCL [C API](https://github.com/kcl-lang/lib/tree/main/c) 正在开发中,欢迎贡献。 + +## 前置依赖 + ++ Make ++ C Compiler ++ Cargo + +## API 参考 + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```c +#include + +int exec_file(const char* file_str) { + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + struct Buffer file = { + .buffer = file_str, + .len = strlen(file_str), + }; + struct Buffer* files[] = { &file }; + struct RepeatedString strs = { .repeated = &files[0], .index = 0, .max_size = 1 }; + ExecProgram_Args args = ExecProgram_Args_init_zero; + args.k_filename_list.funcs.encode = encode_str_list; + args.k_filename_list.arg = &strs; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ExecProgram_Args_fields, &args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ExecProgram"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + if (check_error_prefix(result_buffer)) { + printf("%s", result_buffer); + return 1; + } + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + + ExecProgram_Result result = ExecProgram_Result_init_default; + + uint8_t yaml_value_buffer[BUFFER_SIZE] = { 0 }; + result.yaml_result.arg = yaml_value_buffer; + result.yaml_result.funcs.decode = decode_string; + + uint8_t json_value_buffer[BUFFER_SIZE] = { 0 }; + result.json_result.arg = json_value_buffer; + result.json_result.funcs.decode = decode_string; + + uint8_t err_value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = err_value_buffer; + result.err_message.funcs.decode = decode_string; + + uint8_t log_value_buffer[BUFFER_SIZE] = { 0 }; + result.log_message.arg = log_value_buffer; + result.log_message.funcs.decode = decode_string; + + status = pb_decode(&istream, ExecProgram_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + if (result.yaml_result.arg) { + printf("%s\n", (char*)result.yaml_result.arg); + } + + return 0; +} + +int main() +{ + exec_file("./test_data/schema.k"); + return 0; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include + +int validate(const char* code_str, const char* data_str) +{ + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + + ValidateCode_Args validate_args = ValidateCode_Args_init_zero; + validate_args.code.funcs.encode = encode_string; + validate_args.code.arg = (void*)code_str; + validate_args.data.funcs.encode = encode_string; + validate_args.data.arg = (void*)data_str; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ValidateCode_Args_fields, &validate_args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ValidateCode"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + ValidateCode_Result result = ValidateCode_Result_init_default; + + result.err_message.funcs.decode = decode_string; + uint8_t value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = value_buffer; + + status = pb_decode(&istream, ValidateCode_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + printf("Validate Status: %d\n", result.success); + if (result.err_message.arg) { + printf("Validate Error Message: %s\n", (char*)result.err_message.arg); + } + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + validate(code_str, data_str); + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/i18n/zh-CN/docusaurus-plugin-content-docs/version-0.9/reference/xlang-api/cpp-api.md b/i18n/zh-CN/docusaurus-plugin-content-docs/version-0.9/reference/xlang-api/cpp-api.md new file mode 100644 index 000000000..820f8336e --- /dev/null +++ b/i18n/zh-CN/docusaurus-plugin-content-docs/version-0.9/reference/xlang-api/cpp-api.md @@ -0,0 +1,115 @@ +--- +sidebar_position: 9 +--- + +# C++ API + +KCL [C++ API](https://github.com/kcl-lang/lib/tree/main/cpp) 正在开发中,欢迎贡献。 + +## 前置依赖 + ++ CMake >= 3.10 ++ C++ Compiler with C++17 Support ++ Cargo + +## 安装 + +### CMake + +You can use FetchContent to add KCL C++ Lib to your project. + +```shell +FetchContent_Declare( + kcl-lib + GIT_REPOSITORY https://github.com/kcl-lang/lib.git + GIT_TAG v0.9.1 + SOURCE_SUBDIR cpp +) +FetchContent_MakeAvailable(kcl-lib) +``` + +Or you can download the source code and add it to your project. + +```shell +mkdir third_party +cd third_party +git clone https://github.com/kcl-lang/lib.git +``` + +Update your CMake files. + +```shell +add_subdirectory(third_party/lib/cpp) +``` + +```shell +target_link_libraries(your_target kcl-lib-cpp) +``` + +## API 参考 + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```cpp +#include "kcl_lib.hpp" +#include + +int main() +{ + auto args = kcl_lib::ExecProgramArgs(); + auto files = rust::Vec(); + files.push_back(rust::String("../test_data/schema.k")); + args.k_filename_list = files; + auto result = kcl_lib::exec_program(args); + std::cout << result.yaml_result.c_str() << std::endl; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include "kcl_lib.hpp" +#include + +int validate(const char* code_str, const char* data_str) { + auto args = kcl_lib::ValidateCodeArgs(); + args.code = rust::String(code_str); + args.data = rust::String(data_str); + auto result = kcl_lib::validate_code(args); + std::cout << result.success << std::endl; + std::cout << result.err_message.c_str() << std::endl; + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + // Right case + validate(code_str, data_str); + // Error case + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/versioned_docs/version-0.9/reference/xlang-api/c-api.md b/versioned_docs/version-0.9/reference/xlang-api/c-api.md new file mode 100644 index 000000000..21a35d4e9 --- /dev/null +++ b/versioned_docs/version-0.9/reference/xlang-api/c-api.md @@ -0,0 +1,172 @@ +--- +sidebar_position: 8 +--- + +# C API + +The [C API](https://github.com/kcl-lang/lib/tree/main/c) is in the development stage and contributions are welcome. + +## Prerequisites + ++ Make ++ C Compiler ++ Cargo + +## API Reference + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```c +#include + +int exec_file(const char* file_str) { + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + struct Buffer file = { + .buffer = file_str, + .len = strlen(file_str), + }; + struct Buffer* files[] = { &file }; + struct RepeatedString strs = { .repeated = &files[0], .index = 0, .max_size = 1 }; + ExecProgram_Args args = ExecProgram_Args_init_zero; + args.k_filename_list.funcs.encode = encode_str_list; + args.k_filename_list.arg = &strs; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ExecProgram_Args_fields, &args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ExecProgram"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + if (check_error_prefix(result_buffer)) { + printf("%s", result_buffer); + return 1; + } + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + + ExecProgram_Result result = ExecProgram_Result_init_default; + + uint8_t yaml_value_buffer[BUFFER_SIZE] = { 0 }; + result.yaml_result.arg = yaml_value_buffer; + result.yaml_result.funcs.decode = decode_string; + + uint8_t json_value_buffer[BUFFER_SIZE] = { 0 }; + result.json_result.arg = json_value_buffer; + result.json_result.funcs.decode = decode_string; + + uint8_t err_value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = err_value_buffer; + result.err_message.funcs.decode = decode_string; + + uint8_t log_value_buffer[BUFFER_SIZE] = { 0 }; + result.log_message.arg = log_value_buffer; + result.log_message.funcs.decode = decode_string; + + status = pb_decode(&istream, ExecProgram_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + if (result.yaml_result.arg) { + printf("%s\n", (char*)result.yaml_result.arg); + } + + return 0; +} + +int main() +{ + exec_file("./test_data/schema.k"); + return 0; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include + +int validate(const char* code_str, const char* data_str) +{ + uint8_t buffer[BUFFER_SIZE]; + uint8_t result_buffer[BUFFER_SIZE]; + size_t message_length; + bool status; + + ValidateCode_Args validate_args = ValidateCode_Args_init_zero; + validate_args.code.funcs.encode = encode_string; + validate_args.code.arg = (void*)code_str; + validate_args.data.funcs.encode = encode_string; + validate_args.data.arg = (void*)data_str; + + pb_ostream_t stream = pb_ostream_from_buffer(buffer, sizeof(buffer)); + status = pb_encode(&stream, ValidateCode_Args_fields, &validate_args); + message_length = stream.bytes_written; + + if (!status) { + printf("Encoding failed: %s\n", PB_GET_ERROR(&stream)); + return 1; + } + + const char* api_str = "KclvmService.ValidateCode"; + size_t result_length = call_native((const uint8_t*)api_str, strlen(api_str), buffer, message_length, result_buffer); + pb_istream_t istream = pb_istream_from_buffer(result_buffer, result_length); + ValidateCode_Result result = ValidateCode_Result_init_default; + + result.err_message.funcs.decode = decode_string; + uint8_t value_buffer[BUFFER_SIZE] = { 0 }; + result.err_message.arg = value_buffer; + + status = pb_decode(&istream, ValidateCode_Result_fields, &result); + + if (!status) { + printf("Decoding failed: %s\n", PB_GET_ERROR(&istream)); + return 1; + } + + printf("Validate Status: %d\n", result.success); + if (result.err_message.arg) { + printf("Validate Error Message: %s\n", (char*)result.err_message.arg); + } + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + validate(code_str, data_str); + validate(code_str, error_data_str); + return 0; +} +``` + +

+
diff --git a/versioned_docs/version-0.9/reference/xlang-api/cpp-api.md b/versioned_docs/version-0.9/reference/xlang-api/cpp-api.md new file mode 100644 index 000000000..6173f76c8 --- /dev/null +++ b/versioned_docs/version-0.9/reference/xlang-api/cpp-api.md @@ -0,0 +1,115 @@ +--- +sidebar_position: 9 +--- + +# C++ API + +The [C++ API](https://github.com/kcl-lang/lib/tree/main/cpp) is in the development stage and contributions are welcome. + +## Prerequisites + ++ CMake >= 3.10 ++ C++ Compiler with C++17 Support ++ Cargo + +## Installation + +### CMake + +You can use FetchContent to add KCL C++ Lib to your project. + +```shell +FetchContent_Declare( + kcl-lib + GIT_REPOSITORY https://github.com/kcl-lang/lib.git + GIT_TAG v0.9.1 + SOURCE_SUBDIR cpp +) +FetchContent_MakeAvailable(kcl-lib) +``` + +Or you can download the source code and add it to your project. + +```shell +mkdir third_party +cd third_party +git clone https://github.com/kcl-lang/lib.git +``` + +Update your CMake files. + +```shell +add_subdirectory(third_party/lib/cpp) +``` + +```shell +target_link_libraries(your_target kcl-lib-cpp) +``` + +## API Reference + +### exec_program + +Execute KCL file with arguments and return the JSON/YAML result. + +
Example +

+ +```cpp +#include "kcl_lib.hpp" +#include + +int main() +{ + auto args = kcl_lib::ExecProgramArgs(); + auto files = rust::Vec(); + files.push_back(rust::String("../test_data/schema.k")); + args.k_filename_list = files; + auto result = kcl_lib::exec_program(args); + std::cout << result.yaml_result.c_str() << std::endl; +} +``` + +

+
+ +### validate_code + +Validate code using schema and JSON/YAML data strings. + +
Example +

+ +```rust +#include "kcl_lib.hpp" +#include + +int validate(const char* code_str, const char* data_str) { + auto args = kcl_lib::ValidateCodeArgs(); + args.code = rust::String(code_str); + args.data = rust::String(data_str); + auto result = kcl_lib::validate_code(args); + std::cout << result.success << std::endl; + std::cout << result.err_message.c_str() << std::endl; + return 0; +} + +int main() +{ + const char* code_str = "schema Person:\n" + " name: str\n" + " age: int\n" + " check:\n" + " 0 < age < 120\n"; + const char* data_str = "{\"name\": \"Alice\", \"age\": 10}"; + const char* error_data_str = "{\"name\": \"Alice\", \"age\": 1110}"; + // Right case + validate(code_str, data_str); + // Error case + validate(code_str, error_data_str); + return 0; +} +``` + +

+