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
1 change: 1 addition & 0 deletions binding.gyp
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
"native-src/virtual_drive/create_file_placeholder.cpp",
"native-src/virtual_drive/create_folder_placeholder.cpp",
"native-src/virtual_drive/get_file_identity.cpp",
"native-src/virtual_drive/hydrate_file.cpp",
"native-src/virtual_drive/register_sync_root.cpp"
],
"include_dirs": [
Expand Down
Binary file modified dist/addon.node
Binary file not shown.
5 changes: 5 additions & 0 deletions include/virtual_drive/hydrate_file.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
#pragma once

#include <node_api.h>

napi_value hydrate_file_impl(napi_env env, napi_callback_info args);
6 changes: 0 additions & 6 deletions native-src/sync_root_interface/SyncRoot.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -68,12 +68,6 @@ void SyncRoot::HydrateFile(const wchar_t *filePath)
wprintf(L"Hydration finished %ls\n", filePath);
}
}
// }
// else
// {
// wprintf(L"File is already hydrated: %ls\n", filePath);
// Logger::getInstance().log("File is already hydrated " + Logger::fromWStringToString(filePath), LogLevel::INFO);
// }
}
}
}
Expand Down
46 changes: 2 additions & 44 deletions native-src/virtual_drive/Wrappers.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
#include "create_file_placeholder.h"
#include "get_file_identity.h"
#include "connect_sync_root.h"
#include "hydrate_file.h"
#include "napi_safe_wrap.h"

std::string WStringToUTF8(const std::wstring &wstr)
Expand Down Expand Up @@ -408,50 +409,7 @@ napi_value UpdateFileIdentityWrapper(napi_env env, napi_callback_info args)

napi_value HydrateFileWrapper(napi_env env, napi_callback_info args)
{
size_t argc = 1;
napi_value argv[1];
napi_value thisArg;
napi_get_cb_info(env, args, &argc, argv, &thisArg, nullptr);

if (argc < 1)
{
napi_throw_type_error(env, nullptr, "The file path is required for HydrateFile");
return nullptr;
}

// Obtener el argumento de JavaScript y convertirlo a una cadena de C++
size_t pathLength;
napi_get_value_string_utf16(env, argv[0], nullptr, 0, &pathLength);
std::wstring fullPath(pathLength, L'\0');
napi_get_value_string_utf16(env, argv[0], reinterpret_cast<char16_t *>(&fullPath[0]), pathLength + 1, nullptr);

// Crear una promesa
napi_deferred deferred;
napi_value promise;
napi_create_promise(env, &deferred, &promise);

// Lanzar la operación asíncrona en un hilo separado
std::thread([deferred, fullPath, env]()
{
try {
SyncRoot::HydrateFile(fullPath.c_str());
Logger::getInstance().log("finish... " + Logger::fromWStringToString(fullPath.c_str()), LogLevel::INFO);

napi_value result;
napi_get_undefined(env, &result);
napi_resolve_deferred(env, deferred, result);
} catch (const std::exception& e) {
napi_value error;
napi_create_string_utf8(env, e.what(), NAPI_AUTO_LENGTH, &error);
napi_reject_deferred(env, deferred, error);
} catch (...) {
napi_value error;
napi_create_string_utf8(env, "Unknown error", NAPI_AUTO_LENGTH, &error);
napi_reject_deferred(env, deferred, error);
} })
.detach();

return promise;
return napi_safe_wrap(env, args, hydrate_file_impl);
}

napi_value DehydrateFileWrapper(napi_env env, napi_callback_info args)
Expand Down
53 changes: 53 additions & 0 deletions native-src/virtual_drive/hydrate_file.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
#include <Windows.h>
#include "Logger.h"
#include "SyncRoot.h"

napi_value hydrate_file_impl(napi_env env, napi_callback_info args)
{
size_t argc = 1;
napi_value argv[1];
napi_value thisArg;
napi_get_cb_info(env, args, &argc, argv, &thisArg, nullptr);

if (argc < 1)
{
napi_throw_type_error(env, nullptr, "The file path is required for HydrateFile");
return nullptr;
}

// Obtener el argumento de JavaScript y convertirlo a una cadena de C++
size_t pathLength;
napi_get_value_string_utf16(env, argv[0], nullptr, 0, &pathLength);
std::wstring fullPath(pathLength, L'\0');
napi_get_value_string_utf16(env, argv[0], reinterpret_cast<char16_t *>(&fullPath[0]), pathLength + 1, nullptr);

// Crear una promesa
napi_deferred deferred;
napi_value promise;
napi_create_promise(env, &deferred, &promise);

// Lanzar la operación asíncrona en un hilo separado
std::thread([deferred, fullPath, env]()
{
try {
SyncRoot::HydrateFile(fullPath.c_str());
Logger::getInstance().log("finish... " + Logger::fromWStringToString(fullPath.c_str()), LogLevel::INFO);

napi_value result;
napi_get_undefined(env, &result);
napi_resolve_deferred(env, deferred, result);
} catch (const std::exception& e) {
napi_value error;
napi_create_string_utf8(env, e.what(), NAPI_AUTO_LENGTH, &error);
napi_reject_deferred(env, deferred, error);
} catch (...) {
napi_value error;
napi_create_string_utf8(env, "Unknown error", NAPI_AUTO_LENGTH, &error);
napi_reject_deferred(env, deferred, error);
} })
.detach();

wprintf(L"FINISHHHHHn");

return promise;
}