]> granicus.if.org Git - postgresql/commitdiff
Add error check on getenv("DATADIR")
authorMarc G. Fournier <scrappy@hub.org>
Sun, 7 Dec 1997 20:57:45 +0000 (20:57 +0000)
committerMarc G. Fournier <scrappy@hub.org>
Sun, 7 Dec 1997 20:57:45 +0000 (20:57 +0000)
Add code to set DATADIR in postmaster.c if -D is used

src/backend/libpq/crypt.c
src/backend/postmaster/postmaster.c

index c75d8ac4590eaba87e6283082567ebdb1ca89626..4e4cb15f81b3886b46fbcb1d26e621d534da51c8 100644 (file)
@@ -25,9 +25,13 @@ char* crypt_getpwdfilename() {
   static char*     filename = NULL;
 
   if (!filename) {
-    char*     env;
+    char*     env = NULL;
 
     env = getenv("PGDATA");
+    if(env == NULL) {
+      elog(FATAL, "crypt.c: PGDATA is not defined");
+      exit(-1);
+    }
     filename = (char*)malloc(strlen(env) + strlen(CRYPT_PWD_FILE) + 2);
     sprintf(filename, "%s/%s", env, CRYPT_PWD_FILE);
   }
index b4d1f9559926883d1f1be150f3ea829c42a887c8..7201d0a6d994429cd7545f63d8fe84c83d427597 100644 (file)
@@ -10,7 +10,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/postmaster/postmaster.c,v 1.63 1997/12/04 00:27:17 scrappy Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/postmaster/postmaster.c,v 1.64 1997/12/07 20:57:45 scrappy Exp $
  *
  * NOTES
  *
@@ -332,6 +332,11 @@ PostmasterMain(int argc, char *argv[])
                        case 'D':
                                /* Set PGDATA from the command line. */
                                DataDir = optarg;
+                               {
+                                       char envEntry[2 * ARGV_SIZE];
+                                       sprintf(envEntry, "PGDATA=%s", DataDir);
+                                       putenv(envEntry);
+                               }
                                break;
                        case 'd':
 
@@ -1151,8 +1156,8 @@ BackendStartup(StartupInfo *packet,               /* client's startup packet */
                sprintf(envEntry[3], "PGDATA=%s", DataDir);
                putenv(envEntry[3]);
        }
-        sprintf(envEntry[4], "IPC_KEY=%d", ipc_key);
-        putenv(envEntry[4]);
+       sprintf(envEntry[4], "IPC_KEY=%d", ipc_key);
+       putenv(envEntry[4]);
 
        if (DebugLvl > 2)
        {