📄 bool.c
字号:
/*------------------------------------------------------------------------- * * bool.c * Functions for the built-in type "bool". * * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * * IDENTIFICATION * $Header: /cvsroot/pgsql/src/backend/utils/adt/bool.c,v 1.30 2003/09/25 06:58:03 petere Exp $ * *------------------------------------------------------------------------- */#include "postgres.h"#include "libpq/pqformat.h"#include "utils/builtins.h"/***************************************************************************** * USER I/O ROUTINES * *****************************************************************************//* * boolin - converts "t" or "f" to 1 or 0 * * Check explicitly for "true/false" and TRUE/FALSE, 1/0, YES/NO. * Reject other values. - thomas 1997-10-05 * * In the switch statement, check the most-used possibilities first. */Datumboolin(PG_FUNCTION_ARGS){ char *b = PG_GETARG_CSTRING(0); switch (*b) { case 't': case 'T': if (strncasecmp(b, "true", strlen(b)) == 0) PG_RETURN_BOOL(true); break; case 'f': case 'F': if (strncasecmp(b, "false", strlen(b)) == 0) PG_RETURN_BOOL(false); break; case 'y': case 'Y': if (strncasecmp(b, "yes", strlen(b)) == 0) PG_RETURN_BOOL(true); break; case '1': if (strncasecmp(b, "1", strlen(b)) == 0) PG_RETURN_BOOL(true); break; case 'n': case 'N': if (strncasecmp(b, "no", strlen(b)) == 0) PG_RETURN_BOOL(false); break; case '0': if (strncasecmp(b, "0", strlen(b)) == 0) PG_RETURN_BOOL(false); break; default: break; } ereport(ERROR, (errcode(ERRCODE_INVALID_TEXT_REPRESENTATION), errmsg("invalid input syntax for type boolean: \"%s\"", b))); /* not reached */ PG_RETURN_BOOL(false);}/* * boolout - converts 1 or 0 to "t" or "f" */Datumboolout(PG_FUNCTION_ARGS){ bool b = PG_GETARG_BOOL(0); char *result = (char *) palloc(2); result[0] = (b) ? 't' : 'f'; result[1] = '\0'; PG_RETURN_CSTRING(result);}/* * boolrecv - converts external binary format to bool * * The external representation is one byte. Any nonzero value is taken * as "true". */Datumboolrecv(PG_FUNCTION_ARGS){ StringInfo buf = (StringInfo) PG_GETARG_POINTER(0); int ext; ext = pq_getmsgbyte(buf); PG_RETURN_BOOL((ext != 0) ? true : false);}/* * boolsend - converts bool to binary format */Datumboolsend(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); StringInfoData buf; pq_begintypsend(&buf); pq_sendbyte(&buf, arg1 ? 1 : 0); PG_RETURN_BYTEA_P(pq_endtypsend(&buf));}/***************************************************************************** * PUBLIC ROUTINES * *****************************************************************************/Datumbooleq(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); bool arg2 = PG_GETARG_BOOL(1); PG_RETURN_BOOL(arg1 == arg2);}Datumboolne(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); bool arg2 = PG_GETARG_BOOL(1); PG_RETURN_BOOL(arg1 != arg2);}Datumboollt(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); bool arg2 = PG_GETARG_BOOL(1); PG_RETURN_BOOL(arg1 < arg2);}Datumboolgt(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); bool arg2 = PG_GETARG_BOOL(1); PG_RETURN_BOOL(arg1 > arg2);}Datumboolle(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); bool arg2 = PG_GETARG_BOOL(1); PG_RETURN_BOOL(arg1 <= arg2);}Datumboolge(PG_FUNCTION_ARGS){ bool arg1 = PG_GETARG_BOOL(0); bool arg2 = PG_GETARG_BOOL(1); PG_RETURN_BOOL(arg1 >= arg2);}/* * Per SQL92, istrue() and isfalse() should return false, not NULL, * when presented a NULL input (since NULL is our implementation of * UNKNOWN). Conversely isnottrue() and isnotfalse() should return true. * Therefore, these routines are all declared not-strict in pg_proc * and must do their own checking for null inputs. * * Note we don't need isunknown() and isnotunknown() functions, since * nullvalue() and nonnullvalue() will serve. */Datumistrue(PG_FUNCTION_ARGS){ bool b; if (PG_ARGISNULL(0)) PG_RETURN_BOOL(false); b = PG_GETARG_BOOL(0); PG_RETURN_BOOL(b);}Datumisfalse(PG_FUNCTION_ARGS){ bool b; if (PG_ARGISNULL(0)) PG_RETURN_BOOL(false); b = PG_GETARG_BOOL(0); PG_RETURN_BOOL(!b);}Datumisnottrue(PG_FUNCTION_ARGS){ bool b; if (PG_ARGISNULL(0)) PG_RETURN_BOOL(true); b = PG_GETARG_BOOL(0); PG_RETURN_BOOL(!b);}Datumisnotfalse(PG_FUNCTION_ARGS){ bool b; if (PG_ARGISNULL(0)) PG_RETURN_BOOL(true); b = PG_GETARG_BOOL(0); PG_RETURN_BOOL(b);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -