mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-22 14:32:25 +03:00 
			
		
		
		
	Fix an assortment of improper usages of string functions
In a similar effort tof736e188cand110d81728, fixup various usages of string functions where a more appropriate function is available and more fit for purpose. These changes include: 1. Use cstring_to_text_with_len() instead of cstring_to_text() when working with a StringInfoData and the length can easily be obtained. 2. Use appendStringInfoString() instead of appendStringInfo() when no formatting is required. 3. Use pstrdup(...) instead of psprintf("%s", ...) 4. Use pstrdup(...) instead of psprintf(...) (with no formatting) 5. Use appendPQExpBufferChar() instead of appendPQExpBufferStr() when the length of the string being appended is 1. 6. appendStringInfoChar() instead of appendStringInfo() when no formatting is required and string is 1 char long. 7. Use appendPQExpBufferStr(b, .) instead of appendPQExpBuffer(b, "%s", .) 8. Don't use pstrdup when it's fine to just point to the string constant. I (David) did find other cases of #8 but opted to use #4 instead as I wasn't certain enough that applying #8 was ok (e.g in hba.c) Author: Ranier Vilela, David Rowley Discussion: https://postgr.es/m/CAApHDvo2j2+RJBGhNtUz6BxabWWh2Jx16wMUMWKUjv70Ver1vg@mail.gmail.com
This commit is contained in:
		| @@ -1453,7 +1453,7 @@ pg_get_indexdef_worker(Oid indexrelid, int colno, | ||||
| 		appendStringInfoChar(&buf, ')'); | ||||
|  | ||||
| 		if (idxrec->indnullsnotdistinct) | ||||
| 			appendStringInfo(&buf, " NULLS NOT DISTINCT"); | ||||
| 			appendStringInfoString(&buf, " NULLS NOT DISTINCT"); | ||||
|  | ||||
| 		/* | ||||
| 		 * If it has options, append "WITH (options)" | ||||
| @@ -2332,9 +2332,9 @@ pg_get_constraintdef_worker(Oid constraintId, bool fullCommand, | ||||
| 									  Anum_pg_constraint_confdelsetcols, &isnull); | ||||
| 				if (!isnull) | ||||
| 				{ | ||||
| 					appendStringInfo(&buf, " ("); | ||||
| 					appendStringInfoString(&buf, " ("); | ||||
| 					decompile_column_index_array(val, conForm->conrelid, &buf); | ||||
| 					appendStringInfo(&buf, ")"); | ||||
| 					appendStringInfoChar(&buf, ')'); | ||||
| 				} | ||||
|  | ||||
| 				break; | ||||
| @@ -2363,7 +2363,7 @@ pg_get_constraintdef_worker(Oid constraintId, bool fullCommand, | ||||
| 					((Form_pg_index) GETSTRUCT(indtup))->indnullsnotdistinct) | ||||
| 					appendStringInfoString(&buf, "NULLS NOT DISTINCT "); | ||||
|  | ||||
| 				appendStringInfoString(&buf, "("); | ||||
| 				appendStringInfoChar(&buf, '('); | ||||
|  | ||||
| 				/* Fetch and build target column list */ | ||||
| 				val = SysCacheGetAttr(CONSTROID, tup, | ||||
| @@ -3583,7 +3583,7 @@ pg_get_function_sqlbody(PG_FUNCTION_ARGS) | ||||
|  | ||||
| 	ReleaseSysCache(proctup); | ||||
|  | ||||
| 	PG_RETURN_TEXT_P(cstring_to_text(buf.data)); | ||||
| 	PG_RETURN_TEXT_P(cstring_to_text_with_len(buf.data, buf.len)); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user