]> granicus.if.org Git - php/commitdiff
Add function for getting php.ini path from registry
authorStanislav Malyshev <stas@php.net>
Sun, 19 Oct 2003 10:22:21 +0000 (10:22 +0000)
committerStanislav Malyshev <stas@php.net>
Sun, 19 Oct 2003 10:22:21 +0000 (10:22 +0000)
win32/php_registry.h
win32/registry.c

index fe7c1fddd5758912aa43fb194d333c3789399016..2b111dbb8b25c9928a5eee95986cd073b401480a 100644 (file)
@@ -3,5 +3,6 @@
 
 
 void UpdateIniFromRegistry(char *path TSRMLS_DC);
+char *GetIniPathFromRegistry();
 
 #endif /* PHP_REGISTRY_H */
index 06e6bc0548f1d75a7a8a4e4e328b76b727ec4562..c2f4666587eed7ac351b912e6c1c739f82dcdbf7 100644 (file)
@@ -1,13 +1,15 @@
 #include "php.h"
 #include "php_ini.h"
 
+#define PHP_REGISTRY_KEY "SOFTWARE\\PHP"
+
 void UpdateIniFromRegistry(char *path TSRMLS_DC)
 {
        char *p, *orig_path;
        HKEY MainKey;
        char *strtok_buf = NULL;
 
-       if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, "SOFTWARE\\PHP\\Per Directory Values", 0, KEY_READ, &MainKey)!=ERROR_SUCCESS) {
+       if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, PHP_REGISTRY_KEY "\\Per Directory Values", 0, KEY_READ, &MainKey)!=ERROR_SUCCESS) {
                return;
        }
 
@@ -86,3 +88,23 @@ void UpdateIniFromRegistry(char *path TSRMLS_DC)
        RegCloseKey(MainKey);
        efree(orig_path);
 }
+
+#define PHPRC_REGISTRY_NAME "IniFilePath"
+
+char *GetIniPathFromRegistry()
+{
+       char *reg_location = NULL;
+       HKEY hKey;
+       
+       if(RegOpenKeyEx(HKEY_LOCAL_MACHINE, PHP_REGISTRY_KEY, 0, KEY_READ, &hKey) == ERROR_SUCCESS) {
+               reg_location = emalloc(MAXPATHLEN+1);
+               DWORD buflen = MAXPATHLEN;
+               if(RegQueryValueEx(hKey, PHPRC_REGISTRY_NAME, 0, NULL, reg_location, &buflen) != ERROR_SUCCESS) {
+                       efree(reg_location);
+                       reg_location = NULL;
+                       return reg_location;
+               }
+               RegCloseKey(hKey);
+       }
+       return reg_location;
+}