Mercurial > emacs
changeset 13438:705eb8c3d935
(env_vars): New variable.
(add_registry): New procedure.
(main): Use values of configuration environment variables from
the registry if defined, the process environment otherwise.
author | Geoff Voelker <voelker@cs.washington.edu> |
---|---|
date | Tue, 07 Nov 1995 07:58:00 +0000 |
parents | e1d271d0dd02 |
children | c38b7ee76ecc |
files | nt/addpm.c |
diffstat | 1 files changed, 74 insertions(+), 12 deletions(-) [+] |
line wrap: on
line diff
--- a/nt/addpm.c Tue Nov 07 07:57:46 1995 +0000 +++ b/nt/addpm.c Tue Nov 07 07:58:00 1995 +0000 @@ -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 @@ 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);