Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,25 @@ struct JsTypedArrayOutputHandler : JsBaseOutputHandler<vector<T>> {
}) {}
};


struct JsStringArrayOutputHandler
: public JsBaseOutputHandler<std::vector<std::string>> {
Comment thread
jesusmb1995 marked this conversation as resolved.
JsStringArrayOutputHandler()
: JsBaseOutputHandler<std::vector<std::string>>(
[this](
const std::vector<std::string>& stringVector) -> js_value_t* {
auto array = js::Array::create(this->env_);

for (size_t i = 0; i < stringVector.size(); ++i) {
js_value_t* str;
auto jsString = js::String::create(this->env_, stringVector[i]);
array.set(this->env_, i, jsString);
}

return array;
}) {}
};

template <typename ContainerT, typename T>
class Js2DArrayOutputHandler : public JsBaseOutputHandler<ContainerT> {
template <typename C, typename = void> struct has_size : false_type {};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -99,4 +99,27 @@ TEST(JsOutputHandlerTest, Js2DArrayOutputHandlerCanHandleFlattened2DArray) {
EXPECT_TRUE(handler.canHandle(testData));
}

// ============================================================================
// JsStringOutputHandler Tests
// ============================================================================

TEST(JsOutputHandlerTest, JsStringArrayOutputHandlerCanInstantiate) {
js_env_t env;
out_handl::JsStringArrayOutputHandler handler;
handler.setEnv(&env);
EXPECT_TRUE(true);
}

TEST(JsOutputHandlerTest, JsStringArrayOutputHandlerCanHandleString) {
js_env_t env;
out_handl::JsStringArrayOutputHandler handler;
Comment thread
jesusmb1995 marked this conversation as resolved.
handler.setEnv(&env);

std::vector<std::string> testString = {
"test string", "test string 2", "hello world"};
std::any testData = std::any(testString);

EXPECT_TRUE(handler.canHandle(testData));
}

} // namespace qvac_lib_inference_addon_cpp
2 changes: 1 addition & 1 deletion packages/qvac-lib-inference-addon-cpp/vcpkg.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "qvac-lib-inference-addon-cpp",
"version": "1.0.0",
Comment thread
Sero1000 marked this conversation as resolved.
"version": "1.1.0",
"dependencies": [
{
"name": "qvac-lint-cpp",
Expand Down
Loading