diff options
| author | Sven Strickroth <email@cs-ware.de> | 2013-01-31 17:37:20 +0100 |
|---|---|---|
| committer | Sven Strickroth <email@cs-ware.de> | 2013-01-31 19:46:07 +0100 |
| commit | ec56af08a9aa9ae261325f5037ec0d5114517d55 (patch) | |
| tree | 80937a1a8e4bbb668b9812268ee7d95b01b493aa /src | |
| parent | aa3bf89df21c44f22fe70b4aac9109646fd06b48 (diff) | |
| download | libgit2-ec56af08a9aa9ae261325f5037ec0d5114517d55.tar.gz | |
Refactored: Move msysgit registry detection to it's own function
Signed-off-by: Sven Strickroth <email@cs-ware.de>
Diffstat (limited to 'src')
| -rw-r--r-- | src/win32/findfile.c | 41 | ||||
| -rw-r--r-- | src/win32/findfile.h | 1 |
2 files changed, 25 insertions, 17 deletions
diff --git a/src/win32/findfile.c b/src/win32/findfile.c index 8c4fc7a4a..c93b0727e 100644 --- a/src/win32/findfile.c +++ b/src/win32/findfile.c @@ -113,14 +113,32 @@ int win32_find_system_file_using_registry(git_buf *path, const char *filename) { struct win32_path root; + if (win32_find_msysgit_in_registry(&root, HKEY_LOCAL_MACHINE, REG_MSYSGIT_INSTALL)) { + giterr_set(GITERR_OS, "Cannot locate the system's msysgit directory"); + return -1; + } + + if (win32_find_file(path, &root, filename) < 0) { + giterr_set(GITERR_OS, "The system file '%s' doesn't exist", filename); + git_buf_clear(path); + return GIT_ENOTFOUND; + } + + return 0; +} + +int win32_find_msysgit_in_registry(struct win32_path *root, const HKEY hieve, const wchar_t *key) +{ HKEY hKey; DWORD dwType = REG_SZ; DWORD dwSize = MAX_PATH; - root.len = 0; - if (RegOpenKeyExW(HKEY_LOCAL_MACHINE, REG_MSYSGIT_INSTALL, 0, KEY_ALL_ACCESS, &hKey) == ERROR_SUCCESS) + assert(root); + + root->len = 0; + if (RegOpenKeyExW(hieve, key, 0, KEY_ALL_ACCESS, &hKey) == ERROR_SUCCESS) { - if (RegQueryValueExW(hKey, L"InstallLocation", NULL, &dwType,(LPBYTE)&root.path, &dwSize) == ERROR_SUCCESS) + if (RegQueryValueExW(hKey, L"InstallLocation", NULL, &dwType, (LPBYTE)&root->path, &dwSize) == ERROR_SUCCESS) { // InstallLocation points to the root of the msysgit directory if (dwSize + 4 > MAX_PATH) // 4 = wcslen(L"etc\\") @@ -128,22 +146,11 @@ int win32_find_system_file_using_registry(git_buf *path, const char *filename) giterr_set(GITERR_OS, "Cannot locate the system's msysgit directory - path too long"); return -1; } - wcscat(root.path, L"etc\\"); - root.len = (DWORD)wcslen(root.path) + 1; + wcscat(root->path, L"etc\\"); + root->len = (DWORD)wcslen(root->path) + 1; } } RegCloseKey(hKey); - if (!root.len) { - giterr_set(GITERR_OS, "Cannot locate the system's msysgit directory"); - return -1; - } - - if (win32_find_file(path, &root, filename) < 0) { - giterr_set(GITERR_OS, "The system file '%s' doesn't exist", filename); - git_buf_clear(path); - return GIT_ENOTFOUND; - } - - return 0; + return root->len ? 0 : GIT_ENOTFOUND; } diff --git a/src/win32/findfile.h b/src/win32/findfile.h index 918991cf9..47fe71596 100644 --- a/src/win32/findfile.h +++ b/src/win32/findfile.h @@ -18,6 +18,7 @@ int win32_expand_path(struct win32_path *s_root, const wchar_t *templ); int win32_find_file(git_buf *path, const struct win32_path *root, const char *filename); int win32_find_system_file_using_path(git_buf *path, const char *filename); int win32_find_system_file_using_registry(git_buf *path, const char *filename); +int win32_find_msysgit_in_registry(struct win32_path *root, const HKEY hieve, const wchar_t *key); #endif |
