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);