diff options
| author | Bruce Momjian <bruce@momjian.us> | 2010-10-19 21:38:16 +0000 | 
|---|---|---|
| committer | Bruce Momjian <bruce@momjian.us> | 2010-10-19 21:38:34 +0000 | 
| commit | e13f7e9a711c9117e438516537066bbe61df6455 (patch) | |
| tree | 1c805eb384b78475cbf7d69257188bbd26fa75cd /contrib/pg_upgrade/option.c | |
| parent | 6e74a91b2bf0e0032ccd60dd99d6cf47c190c428 (diff) | |
Restructure the pg_upgrade code to use several global structures rather
than packing everything into 'ctx' and passing that to every function.
Diffstat (limited to 'contrib/pg_upgrade/option.c')
| -rw-r--r-- | contrib/pg_upgrade/option.c | 141 | 
1 files changed, 72 insertions, 69 deletions
| diff --git a/contrib/pg_upgrade/option.c b/contrib/pg_upgrade/option.c index 945889016e3..75f0db5ddde 100644 --- a/contrib/pg_upgrade/option.c +++ b/contrib/pg_upgrade/option.c @@ -16,11 +16,14 @@  #endif -static void usage(migratorContext *ctx); -static void validateDirectoryOption(migratorContext *ctx, char **dirpath, +static void usage(void); +static void validateDirectoryOption(char **dirpath,  				   char *envVarName, char *cmdLineOption, char *description); -static void get_pkglibdirs(migratorContext *ctx); -static char *get_pkglibdir(migratorContext *ctx, const char *bindir); +static void get_pkglibdirs(void); +static char *get_pkglibdir(const char *bindir); + + +UserOpts     user_opts;  /* @@ -30,7 +33,7 @@ static char *get_pkglibdir(migratorContext *ctx, const char *bindir);   *	and initializes the rest of the object.   */  void -parseCommandLine(migratorContext *ctx, int argc, char *argv[]) +parseCommandLine(int argc, char *argv[])  {  	static struct option long_options[] = {  		{"old-datadir", required_argument, NULL, 'd'}, @@ -55,39 +58,39 @@ parseCommandLine(migratorContext *ctx, int argc, char *argv[])  	if (getenv("PGUSER"))  	{ -		pg_free(ctx->user); -		ctx->user = pg_strdup(ctx, getenv("PGUSER")); +		pg_free(os_info.user); +		os_info.user = pg_strdup(getenv("PGUSER"));  	} -	ctx->progname = get_progname(argv[0]); -	ctx->old.port = getenv("PGPORT") ? atoi(getenv("PGPORT")) : DEF_PGPORT; -	ctx->new.port = getenv("PGPORT") ? atoi(getenv("PGPORT")) : DEF_PGPORT; +	os_info.progname = get_progname(argv[0]); +	old_cluster.port = getenv("PGPORT") ? atoi(getenv("PGPORT")) : DEF_PGPORT; +	new_cluster.port = getenv("PGPORT") ? atoi(getenv("PGPORT")) : DEF_PGPORT;  	/* must save value, getenv()'s pointer is not stable */ -	ctx->transfer_mode = TRANSFER_MODE_COPY; +	user_opts.transfer_mode = TRANSFER_MODE_COPY;  	/* user lookup and 'root' test must be split because of usage() */ -	user_id = get_user_info(ctx, &ctx->user); +	user_id = get_user_info(&os_info.user);  	if (argc > 1)  	{  		if (strcmp(argv[1], "--help") == 0 || strcmp(argv[1], "-h") == 0 ||  			strcmp(argv[1], "-?") == 0)  		{ -			usage(ctx); -			exit_nicely(ctx, false); +			usage(); +			exit_nicely(false);  		}  		if (strcmp(argv[1], "--version") == 0 || strcmp(argv[1], "-V") == 0)  		{ -			pg_log(ctx, PG_REPORT, "pg_upgrade " PG_VERSION "\n"); -			exit_nicely(ctx, false); +			pg_log(PG_REPORT, "pg_upgrade " PG_VERSION "\n"); +			exit_nicely(false);  		}  	}  	if (user_id == 0) -		pg_log(ctx, PG_FATAL, "%s: cannot be run as root\n", ctx->progname); +		pg_log(PG_FATAL, "%s: cannot be run as root\n", os_info.progname); -	getcwd(ctx->cwd, MAXPGPATH); +	getcwd(os_info.cwd, MAXPGPATH);  	while ((option = getopt_long(argc, argv, "d:D:b:B:cgG:kl:p:P:u:v",  								 long_options, &optindex)) != -1) @@ -95,81 +98,81 @@ parseCommandLine(migratorContext *ctx, int argc, char *argv[])  		switch (option)  		{  			case 'd': -				ctx->old.pgdata = pg_strdup(ctx, optarg); +				old_cluster.pgdata = pg_strdup(optarg);  				break;  			case 'D': -				ctx->new.pgdata = pg_strdup(ctx, optarg); +				new_cluster.pgdata = pg_strdup(optarg);  				break;  			case 'b': -				ctx->old.bindir = pg_strdup(ctx, optarg); +				old_cluster.bindir = pg_strdup(optarg);  				break;  			case 'B': -				ctx->new.bindir = pg_strdup(ctx, optarg); +				new_cluster.bindir = pg_strdup(optarg);  				break;  			case 'c': -				ctx->check = true; +				user_opts.check = true;  				break;  			case 'g': -				pg_log(ctx, PG_REPORT, "Running in debug mode\n"); -				ctx->debug = true; +				pg_log(PG_REPORT, "Running in debug mode\n"); +				log.debug = true;  				break;  			case 'G': -				if ((ctx->debug_fd = fopen(optarg, "w")) == NULL) +				if ((log.debug_fd = fopen(optarg, "w")) == NULL)  				{ -					pg_log(ctx, PG_FATAL, "cannot open debug file\n"); -					exit_nicely(ctx, false); +					pg_log(PG_FATAL, "cannot open debug file\n"); +					exit_nicely(false);  				}  				break;  			case 'k': -				ctx->transfer_mode = TRANSFER_MODE_LINK; +				user_opts.transfer_mode = TRANSFER_MODE_LINK;  				break;  			case 'l': -				ctx->logfile = pg_strdup(ctx, optarg); +				log.filename = pg_strdup(optarg);  				break;  			case 'p': -				if ((ctx->old.port = atoi(optarg)) <= 0) +				if ((old_cluster.port = atoi(optarg)) <= 0)  				{ -					pg_log(ctx, PG_FATAL, "invalid old port number\n"); -					exit_nicely(ctx, false); +					pg_log(PG_FATAL, "invalid old port number\n"); +					exit_nicely(false);  				}  				break;  			case 'P': -				if ((ctx->new.port = atoi(optarg)) <= 0) +				if ((new_cluster.port = atoi(optarg)) <= 0)  				{ -					pg_log(ctx, PG_FATAL, "invalid new port number\n"); -					exit_nicely(ctx, false); +					pg_log(PG_FATAL, "invalid new port number\n"); +					exit_nicely(false);  				}  				break;  			case 'u': -				pg_free(ctx->user); -				ctx->user = pg_strdup(ctx, optarg); +				pg_free(os_info.user); +				os_info.user = pg_strdup(optarg);  				break;  			case 'v': -				pg_log(ctx, PG_REPORT, "Running in verbose mode\n"); -				ctx->verbose = true; +				pg_log(PG_REPORT, "Running in verbose mode\n"); +				log.verbose = true;  				break;  			default: -				pg_log(ctx, PG_FATAL, +				pg_log(PG_FATAL,  					   "Try \"%s --help\" for more information.\n", -					   ctx->progname); +					   os_info.progname);  				break;  		}  	} -	if (ctx->logfile != NULL) +	if (log.filename != NULL)  	{  		/*  		 * We must use append mode so output generated by child processes via @@ -177,39 +180,39 @@ parseCommandLine(migratorContext *ctx, int argc, char *argv[])  		 * start.  		 */  		/* truncate */ -		if ((ctx->log_fd = fopen(ctx->logfile, "w")) == NULL) -			pg_log(ctx, PG_FATAL, "Cannot write to log file %s\n", ctx->logfile); -		fclose(ctx->log_fd); -		if ((ctx->log_fd = fopen(ctx->logfile, "a")) == NULL) -			pg_log(ctx, PG_FATAL, "Cannot write to log file %s\n", ctx->logfile); +		if ((log.fd = fopen(log.filename, "w")) == NULL) +			pg_log(PG_FATAL, "Cannot write to log file %s\n", log.filename); +		fclose(log.fd); +		if ((log.fd = fopen(log.filename, "a")) == NULL) +			pg_log(PG_FATAL, "Cannot write to log file %s\n", log.filename);  	}  	else -		ctx->logfile = strdup(DEVNULL); +		log.filename = strdup(DEVNULL);  	/* if no debug file name, output to the terminal */ -	if (ctx->debug && !ctx->debug_fd) +	if (log.debug && !log.debug_fd)  	{ -		ctx->debug_fd = fopen(DEVTTY, "w"); -		if (!ctx->debug_fd) -			pg_log(ctx, PG_FATAL, "Cannot write to terminal\n"); +		log.debug_fd = fopen(DEVTTY, "w"); +		if (!log.debug_fd) +			pg_log(PG_FATAL, "Cannot write to terminal\n");  	}  	/* Get values from env if not already set */ -	validateDirectoryOption(ctx, &ctx->old.pgdata, "OLDDATADIR", "-d", +	validateDirectoryOption(&old_cluster.pgdata, "OLDDATADIR", "-d",  							"old cluster data resides"); -	validateDirectoryOption(ctx, &ctx->new.pgdata, "NEWDATADIR", "-D", +	validateDirectoryOption(&new_cluster.pgdata, "NEWDATADIR", "-D",  							"new cluster data resides"); -	validateDirectoryOption(ctx, &ctx->old.bindir, "OLDBINDIR", "-b", +	validateDirectoryOption(&old_cluster.bindir, "OLDBINDIR", "-b",  							"old cluster binaries reside"); -	validateDirectoryOption(ctx, &ctx->new.bindir, "NEWBINDIR", "-B", +	validateDirectoryOption(&new_cluster.bindir, "NEWBINDIR", "-B",  							"new cluster binaries reside"); -	get_pkglibdirs(ctx); +	get_pkglibdirs();  }  static void -usage(migratorContext *ctx) +usage(void)  {  	printf(_("\nUsage: pg_upgrade [OPTIONS]...\n\  \n\ @@ -243,7 +246,7 @@ When you run pg_upgrade, you must provide the following information:\n\  \n\  For example:\n\    pg_upgrade -d oldCluster/data -D newCluster/data -b oldCluster/bin -B newCluster/bin\n\ -or\n"), ctx->old.port, ctx->new.port, ctx->user); +or\n"), old_cluster.port, new_cluster.port, os_info.user);  #ifndef WIN32  	printf(_("\    $ export OLDDATADIR=oldCluster/data\n\ @@ -275,7 +278,7 @@ or\n"), ctx->old.port, ctx->new.port, ctx->user);   * user hasn't provided the required directory name.   */  static void -validateDirectoryOption(migratorContext *ctx, char **dirpath, +validateDirectoryOption(char **dirpath,  					char *envVarName, char *cmdLineOption, char *description)  {  	if (*dirpath == NULL || (strlen(*dirpath) == 0)) @@ -283,10 +286,10 @@ validateDirectoryOption(migratorContext *ctx, char **dirpath,  		const char *envVar;  		if ((envVar = getenv(envVarName)) && strlen(envVar)) -			*dirpath = pg_strdup(ctx, envVar); +			*dirpath = pg_strdup(envVar);  		else  		{ -			pg_log(ctx, PG_FATAL, "You must identify the directory where the %s\n" +			pg_log(PG_FATAL, "You must identify the directory where the %s\n"  				   "Please use the %s command-line option or the %s environment variable\n",  				   description, cmdLineOption, envVarName);  		} @@ -306,15 +309,15 @@ validateDirectoryOption(migratorContext *ctx, char **dirpath,  static void -get_pkglibdirs(migratorContext *ctx) +get_pkglibdirs(void)  { -	ctx->old.libpath = get_pkglibdir(ctx, ctx->old.bindir); -	ctx->new.libpath = get_pkglibdir(ctx, ctx->new.bindir); +	old_cluster.libpath = get_pkglibdir(old_cluster.bindir); +	new_cluster.libpath = get_pkglibdir(new_cluster.bindir);  }  static char * -get_pkglibdir(migratorContext *ctx, const char *bindir) +get_pkglibdir(const char *bindir)  {  	char		cmd[MAXPGPATH];  	char		bufin[MAX_STRING]; @@ -324,7 +327,7 @@ get_pkglibdir(migratorContext *ctx, const char *bindir)  	snprintf(cmd, sizeof(cmd), "\"%s/pg_config\" --pkglibdir", bindir);  	if ((output = popen(cmd, "r")) == NULL) -		pg_log(ctx, PG_FATAL, "Could not get pkglibdir data: %s\n", +		pg_log(PG_FATAL, "Could not get pkglibdir data: %s\n",  			   getErrorText(errno));  	fgets(bufin, sizeof(bufin), output); @@ -338,5 +341,5 @@ get_pkglibdir(migratorContext *ctx, const char *bindir)  	if (bufin[i] == '\n')  		bufin[i] = '\0'; -	return pg_strdup(ctx, bufin); +	return pg_strdup(bufin);  } | 
