]> granicus.if.org Git - postgresql/commitdiff
Fix 'pg_ctl reload' to properly preserve postmaster commend-line
authorBruce Momjian <bruce@momjian.us>
Fri, 27 Jun 2008 01:53:31 +0000 (01:53 +0000)
committerBruce Momjian <bruce@momjian.us>
Fri, 27 Jun 2008 01:53:31 +0000 (01:53 +0000)
arguments on restart.  Patch to releases 8.0 - 8.3.X.

src/backend/postmaster/postmaster.c
src/bin/pg_ctl/pg_ctl.c

index fe1ed795f91666b929711656704d0b6f54ce9c4e..9f41a433b6b3c7889e125ed46fdcf62ec20a4651 100644 (file)
@@ -37,7 +37,7 @@
  *
  *
  * IDENTIFICATION
- *       $PostgreSQL: pgsql/src/backend/postmaster/postmaster.c,v 1.551 2008/01/11 00:54:09 tgl Exp $
+ *       $PostgreSQL: pgsql/src/backend/postmaster/postmaster.c,v 1.551.2.1 2008/06/27 01:53:31 momjian Exp $
  *
  * NOTES
  *
@@ -4163,7 +4163,7 @@ CreateOptsFile(int argc, char *argv[], char *fullprogname)
 
        fprintf(fp, "%s", fullprogname);
        for (i = 1; i < argc; i++)
-               fprintf(fp, " %s%s%s", SYSTEMQUOTE, argv[i], SYSTEMQUOTE);
+               fprintf(fp, " \"%s\"", argv[i]);
        fputs("\n", fp);
 
        if (fclose(fp))
index 83fa412282a59ce906b9334c0e493eed530ed8c7..57cb6597939d35cbe85ddb7020be6eefb1362365 100644 (file)
@@ -4,7 +4,7 @@
  *
  * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
  *
- * $PostgreSQL: pgsql/src/bin/pg_ctl/pg_ctl.c,v 1.92.2.3 2008/02/29 23:31:42 adunstan Exp $
+ * $PostgreSQL: pgsql/src/bin/pg_ctl/pg_ctl.c,v 1.92.2.4 2008/06/27 01:53:31 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -613,15 +613,18 @@ read_post_opts(void)
                        {
                                char       *arg1;
 
-                               arg1 = strchr(optline, *SYSTEMQUOTE);
-                               if (arg1 == NULL || arg1 == optline)
-                                       post_opts = "";
-                               else
+                               /*
+                                * Are we at the first option, as defined by space and
+                                * double-quote?
+                                */
+                               if ((arg1 = strstr(optline, " \"")) != NULL ||
+                                       /* check in case this is an older server */
+                                   (arg1 = strstr(optline, " -")) != NULL)
                                {
-                                       *(arg1 - 1) = '\0'; /* this should be a space */
-                                       post_opts = arg1;
+                                       *arg1 = '\0';   /* terminate so we get only program name */
+                                       post_opts = arg1 + 1; /* point past whitespace */
                                }
-                               if (postgres_path != NULL)
+                               if (postgres_path == NULL)
                                        postgres_path = optline;
                        }
                        else