mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-22 14:32:25 +03:00 
			
		
		
		
	Improve message style for messages associated with not being able to
identify the system time zone setting. Per recent discussion.
This commit is contained in:
		| @@ -6,7 +6,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2010, PostgreSQL Global Development Group |  * Portions Copyright (c) 1996-2010, PostgreSQL Global Development Group | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $PostgreSQL: pgsql/src/timezone/pgtz.c,v 1.71 2010/04/09 11:49:51 mha Exp $ |  *	  $PostgreSQL: pgsql/src/timezone/pgtz.c,v 1.72 2010/04/15 18:46:45 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -498,7 +498,9 @@ identify_system_timezone(void) | |||||||
| 	if (std_zone_name[0] == '\0') | 	if (std_zone_name[0] == '\0') | ||||||
| 	{ | 	{ | ||||||
| 		ereport(LOG, | 		ereport(LOG, | ||||||
| 				(errmsg("could not determine system time zone, defaulting to \"%s\"", "GMT"), | 				(errmsg("could not determine system time zone"), | ||||||
|  | 				 errdetail("The PostgreSQL time zone will be set to \"%s\".", | ||||||
|  | 						   "GMT"), | ||||||
| 				 errhint("You can specify the correct timezone in postgresql.conf."))); | 				 errhint("You can specify the correct timezone in postgresql.conf."))); | ||||||
| 		return NULL;			/* go to GMT */ | 		return NULL;			/* go to GMT */ | ||||||
| 	} | 	} | ||||||
| @@ -533,7 +535,8 @@ identify_system_timezone(void) | |||||||
| 			 (-std_ofs > 0) ? "+" : "", -std_ofs / 3600); | 			 (-std_ofs > 0) ? "+" : "", -std_ofs / 3600); | ||||||
|  |  | ||||||
| 	ereport(LOG, | 	ereport(LOG, | ||||||
| 		 (errmsg("could not recognize system timezone, defaulting to \"%s\"", | 			(errmsg("could not recognize system time zone"), | ||||||
|  | 			 errdetail("The PostgreSQL time zone will be set to \"%s\".", | ||||||
| 					   resultbuf), | 					   resultbuf), | ||||||
| 			 errhint("You can specify the correct timezone in postgresql.conf."))); | 			 errhint("You can specify the correct timezone in postgresql.conf."))); | ||||||
| 	return resultbuf; | 	return resultbuf; | ||||||
| @@ -1076,9 +1079,12 @@ identify_system_timezone(void) | |||||||
|  |  | ||||||
| 	if (!tm) | 	if (!tm) | ||||||
| 	{ | 	{ | ||||||
| 		ereport(WARNING, | 		ereport(LOG, | ||||||
| 				(errmsg_internal("could not determine current date/time: localtime failed"))); | 				(errmsg("could not identify system time zone: localtime() failed"), | ||||||
| 		return NULL; | 				 errdetail("The PostgreSQL time zone will be set to \"%s\".", | ||||||
|  | 						   "GMT"), | ||||||
|  | 				 errhint("You can specify the correct timezone in postgresql.conf."))); | ||||||
|  | 		return NULL;			/* go to GMT */ | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	memset(tzname, 0, sizeof(tzname)); | 	memset(tzname, 0, sizeof(tzname)); | ||||||
| @@ -1089,7 +1095,7 @@ identify_system_timezone(void) | |||||||
| 		if (strcmp(tzname, win32_tzmap[i].stdname) == 0 || | 		if (strcmp(tzname, win32_tzmap[i].stdname) == 0 || | ||||||
| 			strcmp(tzname, win32_tzmap[i].dstname) == 0) | 			strcmp(tzname, win32_tzmap[i].dstname) == 0) | ||||||
| 		{ | 		{ | ||||||
| 			elog(DEBUG4, "TZ \"%s\" matches Windows timezone \"%s\"", | 			elog(DEBUG4, "TZ \"%s\" matches system time zone \"%s\"", | ||||||
| 				 win32_tzmap[i].pgtzname, tzname); | 				 win32_tzmap[i].pgtzname, tzname); | ||||||
| 			return win32_tzmap[i].pgtzname; | 			return win32_tzmap[i].pgtzname; | ||||||
| 		} | 		} | ||||||
| @@ -1107,9 +1113,13 @@ identify_system_timezone(void) | |||||||
| 					 KEY_READ, | 					 KEY_READ, | ||||||
| 					 &rootKey) != ERROR_SUCCESS) | 					 &rootKey) != ERROR_SUCCESS) | ||||||
| 	{ | 	{ | ||||||
| 		ereport(WARNING, | 		ereport(LOG, | ||||||
| 				(errmsg_internal("could not open registry key to identify Windows timezone: %i", (int) GetLastError()))); | 				(errmsg("could not open registry key to identify system time zone: %i", | ||||||
| 		return NULL; | 						(int) GetLastError()), | ||||||
|  | 				 errdetail("The PostgreSQL time zone will be set to \"%s\".", | ||||||
|  | 						   "GMT"), | ||||||
|  | 				 errhint("You can specify the correct timezone in postgresql.conf."))); | ||||||
|  | 		return NULL;			/* go to GMT */ | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	for (idx = 0;; idx++) | 	for (idx = 0;; idx++) | ||||||
| @@ -1134,15 +1144,15 @@ identify_system_timezone(void) | |||||||
| 		{ | 		{ | ||||||
| 			if (r == ERROR_NO_MORE_ITEMS) | 			if (r == ERROR_NO_MORE_ITEMS) | ||||||
| 				break; | 				break; | ||||||
| 			ereport(WARNING, | 			ereport(LOG, | ||||||
| 					(errmsg_internal("could not enumerate registry subkeys to identify Windows timezone: %i", (int) r))); | 					(errmsg_internal("could not enumerate registry subkeys to identify system time zone: %i", (int) r))); | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if ((r = RegOpenKeyEx(rootKey, keyname, 0, KEY_READ, &key)) != ERROR_SUCCESS) | 		if ((r = RegOpenKeyEx(rootKey, keyname, 0, KEY_READ, &key)) != ERROR_SUCCESS) | ||||||
| 		{ | 		{ | ||||||
| 			ereport(WARNING, | 			ereport(LOG, | ||||||
| 					(errmsg_internal("could not open registry subkey to identify Windows timezone: %i", (int) r))); | 					(errmsg_internal("could not open registry subkey to identify system time zone: %i", (int) r))); | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -1150,8 +1160,8 @@ identify_system_timezone(void) | |||||||
| 		namesize = sizeof(zonename); | 		namesize = sizeof(zonename); | ||||||
| 		if ((r = RegQueryValueEx(key, "Std", NULL, NULL, zonename, &namesize)) != ERROR_SUCCESS) | 		if ((r = RegQueryValueEx(key, "Std", NULL, NULL, zonename, &namesize)) != ERROR_SUCCESS) | ||||||
| 		{ | 		{ | ||||||
| 			ereport(WARNING, | 			ereport(LOG, | ||||||
| 					(errmsg_internal("could not query value for 'std' to identify Windows timezone \"%s\": %i", | 					(errmsg_internal("could not query value for key \"std\" to identify system time zone \"%s\": %i", | ||||||
| 									 keyname, (int) r))); | 									 keyname, (int) r))); | ||||||
| 			RegCloseKey(key); | 			RegCloseKey(key); | ||||||
| 			continue; /* Proceed to look at the next timezone */ | 			continue; /* Proceed to look at the next timezone */ | ||||||
| @@ -1167,8 +1177,8 @@ identify_system_timezone(void) | |||||||
| 		namesize = sizeof(zonename); | 		namesize = sizeof(zonename); | ||||||
| 		if ((r = RegQueryValueEx(key, "Dlt", NULL, NULL, zonename, &namesize)) != ERROR_SUCCESS) | 		if ((r = RegQueryValueEx(key, "Dlt", NULL, NULL, zonename, &namesize)) != ERROR_SUCCESS) | ||||||
| 		{ | 		{ | ||||||
| 			ereport(WARNING, | 			ereport(LOG, | ||||||
| 					(errmsg_internal("could not query value for 'dlt' to identify Windows timezone \"%s\": %i", | 					(errmsg_internal("could not query value for key \"dlt\" to identify system time zone \"%s\": %i", | ||||||
| 									 keyname, (int) r))); | 									 keyname, (int) r))); | ||||||
| 			RegCloseKey(key); | 			RegCloseKey(key); | ||||||
| 			continue; /* Proceed to look at the next timezone */ | 			continue; /* Proceed to look at the next timezone */ | ||||||
| @@ -1194,17 +1204,20 @@ identify_system_timezone(void) | |||||||
| 			if (strcmp(localtzname, win32_tzmap[i].stdname) == 0 || | 			if (strcmp(localtzname, win32_tzmap[i].stdname) == 0 || | ||||||
| 				strcmp(localtzname, win32_tzmap[i].dstname) == 0) | 				strcmp(localtzname, win32_tzmap[i].dstname) == 0) | ||||||
| 			{ | 			{ | ||||||
| 				elog(DEBUG4, "TZ \"%s\" matches localized Windows timezone \"%s\" (\"%s\")", | 				elog(DEBUG4, "TZ \"%s\" matches localized system time zone \"%s\" (\"%s\")", | ||||||
| 					 win32_tzmap[i].pgtzname, tzname, localtzname); | 					 win32_tzmap[i].pgtzname, tzname, localtzname); | ||||||
| 				return win32_tzmap[i].pgtzname; | 				return win32_tzmap[i].pgtzname; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	ereport(WARNING, | 	ereport(LOG, | ||||||
| 			(errmsg("could not find a match for Windows timezone \"%s\"", | 			(errmsg("could not find a match for system time zone \"%s\"", | ||||||
| 					tzname))); | 					tzname), | ||||||
| 	return NULL; | 			 errdetail("The PostgreSQL time zone will be set to \"%s\".", | ||||||
|  | 					   "GMT"), | ||||||
|  | 			 errhint("You can specify the correct timezone in postgresql.conf."))); | ||||||
|  | 	return NULL;			/* go to GMT */ | ||||||
| } | } | ||||||
| #endif   /* WIN32 */ | #endif   /* WIN32 */ | ||||||
|  |  | ||||||
| @@ -1541,7 +1554,7 @@ pg_tzenumerate_next(pg_tzenum *dir) | |||||||
| 			/* Step into the subdirectory */ | 			/* Step into the subdirectory */ | ||||||
| 			if (dir->depth >= MAX_TZDIR_DEPTH - 1) | 			if (dir->depth >= MAX_TZDIR_DEPTH - 1) | ||||||
| 				ereport(ERROR, | 				ereport(ERROR, | ||||||
| 						(errmsg("timezone directory stack overflow"))); | 						(errmsg_internal("timezone directory stack overflow"))); | ||||||
| 			dir->depth++; | 			dir->depth++; | ||||||
| 			dir->dirname[dir->depth] = pstrdup(fullname); | 			dir->dirname[dir->depth] = pstrdup(fullname); | ||||||
| 			dir->dirdesc[dir->depth] = AllocateDir(fullname); | 			dir->dirdesc[dir->depth] = AllocateDir(fullname); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user