diff options
author | Geoff Voelker <voelker@cs.washington.edu> | 1995-11-07 07:58:00 +0000 |
---|---|---|
committer | Geoff Voelker <voelker@cs.washington.edu> | 1995-11-07 07:58:00 +0000 |
commit | 2cc1905e48e720518e7c094107b8875856459467 (patch) | |
tree | e38dcf0843be0ae710bc56839789831b500eea2a | |
parent | bdfab656b802988778c1d3ec8df002cb6eec0346 (diff) | |
download | emacs-2cc1905e48e720518e7c094107b8875856459467.tar.gz |
(env_vars): New variable.
(add_registry): New procedure.
(main): Use values of configuration environment variables from
the registry if defined, the process environment otherwise.
-rw-r--r-- | nt/addpm.c | 86 |
1 files changed, 74 insertions, 12 deletions
diff --git a/nt/addpm.c b/nt/addpm.c index 2355b6701cc..44e1fe8aca1 100644 --- a/nt/addpm.c +++ b/nt/addpm.c @@ -23,7 +23,7 @@ * Program: addpm (adds emacs to the Windows program manager) * * Usage: - * argv[1] = full path to program to execute + * argv[1] = install path for emacs * argv[2] = full path to icon for emacs (optional) */ @@ -32,17 +32,76 @@ #include <stdlib.h> #include <stdio.h> -HDDEDATA CALLBACK DdeCallback (UINT uType, UINT uFmt, HCONV hconv, - HSZ hsz1, HSZ hsz2, HDDEDATA hdata, - DWORD dwData1, DWORD dwData2) +HDDEDATA CALLBACK +DdeCallback (UINT uType, UINT uFmt, HCONV hconv, + HSZ hsz1, HSZ hsz2, HDDEDATA hdata, + DWORD dwData1, DWORD dwData2) { - return ((HDDEDATA)NULL); + return ((HDDEDATA) NULL); } #define DdeCommand(str) \ - DdeClientTransaction (str, strlen(str)+1, HConversation, (HSZ)NULL, \ + DdeClientTransaction (str, strlen (str)+1, HConversation, (HSZ)NULL, \ CF_TEXT, XTYP_EXECUTE, 30000, NULL) +#define REG_ROOT "SOFTWARE\\GNU\\Emacs\\" + +static struct entry +{ + char *name; + char *value; +} +env_vars[] = +{ + {"emacs_path", NULL}, + {"EMACSLOADPATH", "%emacs_path%\\lisp"}, + {"SHELL", "cmd"}, + {"EMACSDATA", "%emacs_path%\\etc"}, + {"EMACSPATH", "%emacs_path%\\bin"}, + {"EMACSLOCKDIR", "%emacs_path%\\lock"}, + {"INFOPATH", "%emacs_path%\\info"}, + {"EMACSDOC", "%emacs_path%\\etc"}, + {"TERM", "cmd"} +}; + +BOOL +add_registry (path) + char *path; +{ + HKEY hrootkey = NULL; + DWORD dwDisp; + int i; + BOOL ok = TRUE; + + /* Check both the current user and the local machine to see if we + have any resources. */ + + if (RegCreateKeyEx (HKEY_LOCAL_MACHINE, REG_ROOT, + 0, "", REG_OPTION_NON_VOLATILE, + KEY_WRITE, NULL, &hrootkey, &dwDisp) != ERROR_SUCCESS + && RegCreateKeyEx (HKEY_CURRENT_USER, REG_ROOT, + 0, "", REG_OPTION_NON_VOLATILE, + KEY_WRITE, NULL, &hrootkey, &dwDisp) != ERROR_SUCCESS) + { + return FALSE; + } + + for (i = 0; i < (sizeof (env_vars) / sizeof (env_vars[0])); i++) + { + char * value = env_vars[i].value ? env_vars[i].value : path; + + if (RegSetValueEx (hrootkey, env_vars[i].name, + 0, REG_EXPAND_SZ, + value, lstrlen (value) + 1) != ERROR_SUCCESS) + ok = FALSE; + } + + RegCloseKey (hrootkey); + + return (ok); +} + +int main (argc, argv) int argc; char *argv[]; @@ -51,23 +110,26 @@ main (argc, argv) HCONV HConversation; HSZ ProgMan; char additem[MAX_PATH*2 + 100]; + char *lpext; if (argc < 2 || argc > 3) { - fprintf(stderr, "usage: addpm exe_path [icon_path]\n"); - exit(1); + fprintf (stderr, "usage: addpm emacs_path [icon_path]\n"); + exit (1); } + lpext = add_registry (argv[1]) ? "exe" : "bat"; + DdeInitialize (&idDde, (PFNCALLBACK)DdeCallback, APPCMD_CLIENTONLY, 0); ProgMan = DdeCreateStringHandle (idDde, "PROGMAN", CP_WINANSI); if (HConversation = DdeConnect (idDde, ProgMan, ProgMan, NULL)) { - DdeCommand ("[CreateGroup(Gnu Emacs)]"); - DdeCommand ("[ReplaceItem(Emacs)]"); - sprintf (additem, "[AddItem(%s,Emacs%c%s)]", - argv[1], (argc>2 ? ',' : ' '), + DdeCommand ("[CreateGroup (Gnu Emacs)]"); + DdeCommand ("[ReplaceItem (Emacs)]"); + sprintf (additem, "[AddItem (%s\\bin\\emacs.%s, Emacs%c%s)]", + argv[1], lpext, (argc>2 ? ',' : ' '), (argc>2 ? argv[2] : "")); DdeCommand (additem); |