Commit 962c8bd6 authored by Thomas G. Lockhart's avatar Thomas G. Lockhart

Accept additional values for TRUE: y, Y, 1.

Leave all other input values to return FALSE.
In next version, do more checking for valid inputs for both TRUE and FALSE.
parent 9c800b8e
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/adt/bool.c,v 1.7 1997/10/09 05:06:12 thomas Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/adt/bool.c,v 1.8 1997/10/17 05:38:32 thomas Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -24,16 +24,50 @@ ...@@ -24,16 +24,50 @@
/* /*
* boolin - converts "t" or "f" to 1 or 0 * boolin - converts "t" or "f" to 1 or 0
* *
* Check explicitly for "true/TRUE" and allow any odd ASCII value to be "true". * Check explicitly for "true/false" and TRUE/FALSE, 1/0, YES/NO.
* This handles "true/false", "yes/no", "1/0". - 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.
*/ */
bool bool
boolin(char *b) boolin(char *b)
{ {
if (b == NULL) switch(*b) {
elog(WARN, "Bad input string for type bool"); case 't':
return ((bool) (((*b) == 't') || ((*b) == 'T') || ((*b) & 1))); case 'T':
} return (TRUE);
break;
case 'f':
case 'F':
return (FALSE);
break;
case 'y':
case 'Y':
case '1':
return (TRUE);
break;
case 'n':
case 'N':
case '0':
return (FALSE);
break;
default:
#if FALSE
elog(WARN,"Invalid input string '%s'\n", b);
#endif
break;
}
return (FALSE);
} /* boolin() */
/* /*
* boolout - converts 1 or 0 to "t" or "f" * boolout - converts 1 or 0 to "t" or "f"
...@@ -46,7 +80,7 @@ boolout(bool b) ...@@ -46,7 +80,7 @@ boolout(bool b)
*result = (b) ? 't' : 'f'; *result = (b) ? 't' : 'f';
result[1] = '\0'; result[1] = '\0';
return (result); return (result);
} } /* boolout() */
/***************************************************************************** /*****************************************************************************
* PUBLIC ROUTINES * * PUBLIC ROUTINES *
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment