1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-25 13:17:41 +03:00

Check explicitly for valid input strings for both TRUE and FALSE.

Allow true/false, yes/no, 1/0. Throw elog warning if anything else.
Allow shorter strings, so "t", "tr", "tru" and "true" match "true".
Old behavior accepted anything starting with "t" as TRUE,
 everything else as FALSE.
This commit is contained in:
Thomas G. Lockhart
1997-10-25 05:09:58 +00:00
parent 200bc52b8d
commit 3eb1bc67b1

View File

@@ -7,11 +7,12 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/adt/bool.c,v 1.8 1997/10/17 05:38:32 thomas Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/adt/bool.c,v 1.9 1997/10/25 05:09:58 thomas Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
#include <string.h>
#include "postgres.h" #include "postgres.h"
#include "utils/builtins.h" /* where the declarations go */ #include "utils/builtins.h" /* where the declarations go */
@@ -26,10 +27,6 @@
* *
* Check explicitly for "true/false" and TRUE/FALSE, 1/0, YES/NO. * Check explicitly for "true/false" and TRUE/FALSE, 1/0, YES/NO.
* Reject other values. - thomas 1997-10-05 * Reject other values. - thomas 1997-10-05
* For now, allow old behavior of everything FALSE if not TRUE.
* After v6.2.1 release, then enable code to reject goofy values.
* Also, start checking the entire string rather than just the first character.
* - thomas 1997-10-16
* *
* In the switch statement, check the most-used possibilities first. * In the switch statement, check the most-used possibilities first.
*/ */
@@ -39,33 +36,43 @@ boolin(char *b)
switch(*b) { switch(*b) {
case 't': case 't':
case 'T': case 'T':
if (strncasecmp(b, "true", strlen(b)) == 0)
return (TRUE); return (TRUE);
break; break;
case 'f': case 'f':
case 'F': case 'F':
if (strncasecmp(b, "false", strlen(b)) == 0)
return (FALSE); return (FALSE);
break; break;
case 'y': case 'y':
case 'Y': case 'Y':
if (strncasecmp(b, "yes", strlen(b)) == 0)
return (TRUE);
break;
case '1': case '1':
if (strncasecmp(b, "1", strlen(b)) == 0)
return (TRUE); return (TRUE);
break; break;
case 'n': case 'n':
case 'N': case 'N':
if (strncasecmp(b, "no", strlen(b)) == 0)
return (FALSE);
break;
case '0': case '0':
if (strncasecmp(b, "0", strlen(b)) == 0)
return (FALSE); return (FALSE);
break; break;
default: default:
#if FALSE
elog(WARN,"Invalid input string '%s'\n", b);
#endif
break; break;
} }
elog(WARN,"Invalid input string '%s'\n", b);
return (FALSE); return (FALSE);
} /* boolin() */ } /* boolin() */