parse_coerce.h
上传用户:blenddy
上传日期:2007-01-07
资源大小:6495k
文件大小:4k
源码类别:

数据库系统

开发平台:

Unix_Linux

  1. /*-------------------------------------------------------------------------
  2.  *
  3.  * parse_coerce.h
  4.  *
  5.  *
  6.  *
  7.  * Copyright (c) 1994, Regents of the University of California
  8.  *
  9.  * $Id: parse_coerce.h,v 1.12 1999/05/25 22:43:17 momjian Exp $
  10.  *
  11.  *-------------------------------------------------------------------------
  12.  */
  13. #ifndef PARSE_COERCE_H
  14. #define PARSE_COERCE_H
  15. typedef enum CATEGORY
  16. {
  17. INVALID_TYPE,
  18. UNKNOWN_TYPE,
  19. BOOLEAN_TYPE,
  20. STRING_TYPE,
  21. NUMERIC_TYPE,
  22. DATETIME_TYPE,
  23. TIMESPAN_TYPE,
  24. GEOMETRIC_TYPE,
  25. NETWORK_TYPE,
  26. USER_TYPE,
  27. MIXED_TYPE
  28. } CATEGORY;
  29. /* IS_BUILTIN_TYPE()
  30.  * Check for types which are in the core distribution.
  31.  * The built-in types can have more explicit support for type coersion, etc,
  32.  * since we know apriori how they should behave.
  33.  * - thomas 1998-05-13
  34.  */
  35. #define IS_BUILTIN_TYPE(t) 
  36.   (((t) == OIDOID) 
  37. || ((t) == BOOLOID) 
  38. || ((t) == BPCHAROID) 
  39. || ((t) == VARCHAROID) 
  40. || ((t) == TEXTOID) 
  41. || ((t) == INT4OID) 
  42. || ((t) == INT8OID) 
  43. || ((t) == FLOAT8OID) 
  44. || ((t) == DATETIMEOID) 
  45. || ((t) == TIMESTAMPOID) 
  46. || ((t) == ABSTIMEOID) 
  47. || ((t) == RELTIMEOID) 
  48. || ((t) == CHAROID) 
  49. || ((t) == NAMEOID) 
  50. || ((t) == CASHOID) 
  51. || ((t) == POINTOID) 
  52. || ((t) == LSEGOID) 
  53. || ((t) == LINEOID) 
  54. || ((t) == BOXOID) 
  55. || ((t) == PATHOID) 
  56. || ((t) == POLYGONOID) 
  57. || ((t) == CIRCLEOID) 
  58. || ((t) == INETOID) 
  59. || ((t) == CIDROID) )
  60. /* IS_BINARY_COMPATIBLE()
  61.  * Check for types with the same underlying binary representation.
  62.  * This allows us to cheat and directly exchange values without
  63.  * going through the trouble of calling a conversion function.
  64.  * Remove equivalencing of FLOAT8 and DATETIME. They really are not
  65.  * close enough in behavior, with the DATETIME reserved values
  66.  * and special formatting. - thomas 1999-01-24
  67.  */
  68. #define IS_BINARY_COMPATIBLE(a,b) 
  69.   (((a) == BPCHAROID && (b) == TEXTOID) 
  70. || ((a) == BPCHAROID && (b) == VARCHAROID) 
  71. || ((a) == VARCHAROID && (b) == TEXTOID) 
  72. || ((a) == VARCHAROID && (b) == BPCHAROID) 
  73. || ((a) == TEXTOID && (b) == BPCHAROID) 
  74. || ((a) == TEXTOID && (b) == VARCHAROID) 
  75. || ((a) == OIDOID && (b) == INT4OID) 
  76. || ((a) == OIDOID && (b) == REGPROCOID) 
  77. || ((a) == INT4OID && (b) == OIDOID) 
  78. || ((a) == INT4OID && (b) == REGPROCOID) 
  79. || ((a) == REGPROCOID && (b) == OIDOID) 
  80. || ((a) == REGPROCOID && (b) == INT4OID) 
  81. || ((a) == ABSTIMEOID && (b) == TIMESTAMPOID) 
  82. || ((a) == ABSTIMEOID && (b) == INT4OID) 
  83. || ((a) == TIMESTAMPOID && (b) == ABSTIMEOID) 
  84. || ((a) == TIMESTAMPOID && (b) == INT4OID) 
  85. || ((a) == INT4OID && (b) == ABSTIMEOID) 
  86. || ((a) == INT4OID && (b) == TIMESTAMPOID) 
  87. || ((a) == RELTIMEOID && (b) == INT4OID) 
  88. || ((a) == INT4OID && (b) == RELTIMEOID) 
  89. || ((a) == INETOID && (b) == CIDROID) 
  90. || ((a) == CIDROID && (b) == INETOID))
  91. /* IS_HIGHER_TYPE()
  92.  * These types are the most general in each of the type categories.
  93.  */
  94. #define IS_HIGHER_TYPE(t) 
  95.   (((t) == TEXTOID) 
  96. || ((t) == FLOAT8OID) 
  97. || ((t) == TIMESPANOID) 
  98. || ((t) == DATETIMEOID) 
  99. || ((t) == POLYGONOID) 
  100. || ((t) == INETOID) )
  101. /* IS_HIGHEST_TYPE()
  102.  * These types are the most general in each of the type categories.
  103.  * Since timespan and datetime overload so many functions, let's
  104.  * give datetime the preference.
  105.  * Since text is a generic string type let's leave it out too.
  106.  */
  107. #define IS_HIGHEST_TYPE(t) 
  108.   (((t) == FLOAT8OID) 
  109. || ((t) == DATETIMEOID) 
  110. || ((t) == TIMESPANOID))
  111. extern bool IsPreferredType(CATEGORY category, Oid type);
  112. extern CATEGORY TypeCategory(Oid type);
  113. extern bool can_coerce_type(int nargs, Oid *input_typeids, Oid *func_typeids);
  114. extern Node *coerce_type(ParseState *pstate, Node *node, Oid inputTypeId,
  115. Oid targetTypeId, int32 atttypmod);
  116. #endif  /* PARSE_COERCE_H */