dateformat.c 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /*
  2. +----------------------------------------------------------------------+
  3. | This source file is subject to version 3.01 of the PHP license, |
  4. | that is bundled with this package in the file LICENSE, and is |
  5. | available through the world-wide-web at the following url: |
  6. | https://www.php.net/license/3_01.txt |
  7. | If you did not receive a copy of the PHP license and are unable to |
  8. | obtain it through the world-wide-web, please send a note to |
  9. | license@php.net so we can mail you a copy immediately. |
  10. +----------------------------------------------------------------------+
  11. | Authors: Kirti Velankar <kirtig@yahoo-inc.com> |
  12. +----------------------------------------------------------------------+
  13. */
  14. #ifdef HAVE_CONFIG_H
  15. #include "config.h"
  16. #endif
  17. #include <unicode/udat.h>
  18. #include "php_intl.h"
  19. #include "dateformat_class.h"
  20. #include "dateformat.h"
  21. /* {{{ dateformat_register_constants
  22. * Register constants common for the both (OO and procedural)
  23. * APIs.
  24. */
  25. void dateformat_register_constants( INIT_FUNC_ARGS )
  26. {
  27. if( IntlDateFormatter_ce_ptr == NULL) {
  28. zend_error(E_ERROR, "DateFormat class not defined");
  29. return;
  30. }
  31. #define DATEFORMATTER_EXPOSE_CONST(x) REGISTER_LONG_CONSTANT(#x, x, CONST_PERSISTENT | CONST_CS)
  32. #define DATEFORMATTER_EXPOSE_CLASS_CONST(x) zend_declare_class_constant_long( IntlDateFormatter_ce_ptr, ZEND_STRS( #x ) - 1, UDAT_##x );
  33. #define DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST(name, value) zend_declare_class_constant_long( IntlDateFormatter_ce_ptr, ZEND_STRS( name ) - 1, value );
  34. #define DATEFORMATTER_EXPOSE_UCAL_CLASS_CONST(x) zend_declare_class_constant_long( IntlDateFormatter_ce_ptr, ZEND_STRS( #x ) - 1, UCAL_##x );
  35. /* UDateFormatStyle constants */
  36. DATEFORMATTER_EXPOSE_CLASS_CONST( FULL );
  37. DATEFORMATTER_EXPOSE_CLASS_CONST( LONG );
  38. DATEFORMATTER_EXPOSE_CLASS_CONST( MEDIUM );
  39. DATEFORMATTER_EXPOSE_CLASS_CONST( SHORT );
  40. DATEFORMATTER_EXPOSE_CLASS_CONST( NONE );
  41. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "RELATIVE_FULL", UDAT_FULL_RELATIVE );
  42. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "RELATIVE_LONG", UDAT_LONG_RELATIVE );
  43. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "RELATIVE_MEDIUM", UDAT_MEDIUM_RELATIVE );
  44. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "RELATIVE_SHORT", UDAT_SHORT_RELATIVE );
  45. /*
  46. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "GREGORIAN", DATEF_GREGORIAN );
  47. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "CUSTOMARY", DATEF_CUSTOMARY );
  48. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "BUDDHIST", DATEF_BUDDHIST );
  49. DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST( "JAPANESE_IMPERIAL", DATEF_JAPANESE_IMPERIAL );
  50. */
  51. DATEFORMATTER_EXPOSE_UCAL_CLASS_CONST( GREGORIAN );
  52. DATEFORMATTER_EXPOSE_UCAL_CLASS_CONST( TRADITIONAL );
  53. #undef DATEFORMATTER_EXPOSE_UCAL_CLASS_CONST
  54. #undef DATEFORMATTER_EXPOSE_CUSTOM_CLASS_CONST
  55. #undef DATEFORMATTER_EXPOSE_CLASS_CONST
  56. #undef DATEFORMATTER_EXPOSE_CONST
  57. }
  58. /* }}} */
  59. /* {{{ Get formatter's last error code. */
  60. PHP_FUNCTION( datefmt_get_error_code )
  61. {
  62. DATE_FORMAT_METHOD_INIT_VARS;
  63. /* Parse parameters. */
  64. if( zend_parse_method_parameters( ZEND_NUM_ARGS(), getThis(), "O",
  65. &object, IntlDateFormatter_ce_ptr ) == FAILURE )
  66. {
  67. RETURN_THROWS();
  68. }
  69. dfo = Z_INTL_DATEFORMATTER_P( object );
  70. /* Return formatter's last error code. */
  71. RETURN_LONG( INTL_DATA_ERROR_CODE(dfo) );
  72. }
  73. /* }}} */
  74. /* {{{ Get text description for formatter's last error code. */
  75. PHP_FUNCTION( datefmt_get_error_message )
  76. {
  77. zend_string *message = NULL;
  78. DATE_FORMAT_METHOD_INIT_VARS;
  79. /* Parse parameters. */
  80. if( zend_parse_method_parameters( ZEND_NUM_ARGS(), getThis(), "O",
  81. &object, IntlDateFormatter_ce_ptr ) == FAILURE )
  82. {
  83. RETURN_THROWS();
  84. }
  85. dfo = Z_INTL_DATEFORMATTER_P( object );
  86. /* Return last error message. */
  87. message = intl_error_get_message( INTL_DATA_ERROR_P(dfo) );
  88. RETURN_STR( message);
  89. }
  90. /* }}} */