📄 _time_facets.c
字号:
/* * Copyright (c) 1999 * Silicon Graphics Computer Systems, Inc. * * Copyright (c) 1999 * Boris Fomitchev * * This material is provided "as is", with absolutely no warranty expressed * or implied. Any use is at your own risk. * * Permission to use or copy this software for any purpose is hereby granted * without fee, provided the above notices are retained on all copies. * Permission to modify the code and to distribute modified code is granted, * provided the above notices are retained, and a notice that the code was * modified is included with the above copyright notice. * */#ifndef _STLP_TIME_FACETS_C#define _STLP_TIME_FACETS_C#ifndef _STLP_INTERNAL_TIME_FACETS_H# include <stl/_time_facets.h>#endif#ifndef _STLP_INTERNAL_NUM_PUT_H# include <stl/_num_put.h>#endif#ifndef _STLP_INTERNAL_NUM_GET_H# include <stl/_num_get.h>#endif_STLP_BEGIN_NAMESPACE//----------------------------------------------------------------------// Declarations of static template members.#if (_STLP_STATIC_TEMPLATE_DATA > 0)# if !defined (__BORLANDC__)template <class _CharT, class _InputIterator>locale::id time_get<_CharT, _InputIterator>::id;template <class _CharT, class _OutputIterator>locale::id time_put<_CharT, _OutputIterator>::id;# endif# if (defined (__CYGWIN__) || defined (__MINGW32__)) && \ defined (_STLP_USE_DYNAMIC_LIB) && !defined (__BUILDING_STLPORT)/* * Under cygwin, when STLport is used as a shared library, the id needs * to be specified as imported otherwise they will be duplicated in the * calling executable. */template <>_STLP_DECLSPEC locale::id time_get<char, istreambuf_iterator<char, char_traits<char> > >::id;/*template <>_STLP_DECLSPEC locale::id time_get<char, const char*>::id;*/template <>_STLP_DECLSPEC locale::id time_put<char, ostreambuf_iterator<char, char_traits<char> > >::id;/*template <>_STLP_DECLSPEC locale::id time_put<char, char*>::id;*/# ifndef _STLP_NO_WCHAR_Ttemplate <>_STLP_DECLSPEC locale::id time_get<wchar_t, istreambuf_iterator<wchar_t, char_traits<wchar_t> > >::id;/*template <>_STLP_DECLSPEC locale::id time_get<wchar_t, const wchar_t*>::id;*/template <>_STLP_DECLSPEC locale::id time_put<wchar_t, ostreambuf_iterator<wchar_t, char_traits<wchar_t> > >::id;/*template <>_STLP_DECLSPEC locale::id time_put<wchar_t, wchar_t*>::id;*/# endif /* _STLP_NO_WCHAR_T */# endif /* __CUGWIN__ && _STLP_USE_DYNAMIC_LIB */#else /* ( _STLP_STATIC_TEMPLATE_DATA > 0 ) *///typedef time_get<char, const char*> time_get_char;typedef time_get<char, istreambuf_iterator<char, char_traits<char> > > time_get_char_2;//typedef time_put<char, char*> time_put_char;typedef time_put<char, ostreambuf_iterator<char, char_traits<char> > > time_put_char_2;//__DECLARE_INSTANCE(locale::id, time_get_char::id, );__DECLARE_INSTANCE(locale::id, time_get_char_2::id, );//__DECLARE_INSTANCE(locale::id, time_put_char::id, );__DECLARE_INSTANCE(locale::id, time_put_char_2::id, );# if !defined (_STLP_NO_WCHAR_T)//typedef time_get<wchar_t, const wchar_t*> time_get_wchar_t;typedef time_get<wchar_t, istreambuf_iterator<wchar_t, char_traits<wchar_t> > > time_get_wchar_t_2;//typedef time_put<wchar_t, wchar_t*> time_put_wchar_t;typedef time_put<wchar_t, ostreambuf_iterator<wchar_t, char_traits<wchar_t> > > time_put_wchar_t_2;//__DECLARE_INSTANCE(locale::id, time_get_wchar_t::id, );__DECLARE_INSTANCE(locale::id, time_get_wchar_t_2::id, );//__DECLARE_INSTANCE(locale::id, time_put_wchar_t::id, );__DECLARE_INSTANCE(locale::id, time_put_wchar_t_2::id, );# endif#endif /* ( _STLP_STATIC_TEMPLATE_DATA > 0 ) */_STLP_MOVE_TO_PRIV_NAMESPACEtemplate <class _InIt, class _CharT>const string* _STLP_CALL__match(_InIt& __first, _InIt& __last, const string *__name, const string *__name_end, const ctype<_CharT>& __ct) { typedef ptrdiff_t difference_type; difference_type __n = __name_end - __name; difference_type __i; size_t __pos = 0; difference_type __check_count = __n; bool __do_check[_MAXNAMES]; const string* __matching_name[_MAX_NAME_LENGTH]; for (__i = 0; __i < _MAXNAMES; ++__i) __do_check[__i] = true; for (__i = 0; __i < _MAX_NAME_LENGTH; ++__i) __matching_name[__i] = __name_end; while (__first != __last) { for (__i = 0; __i < __n; ++__i) { if (__do_check[__i]) { if (*__first == __ct.widen(__name[__i][__pos])) { if (__pos == (__name[__i].size() - 1)) { __do_check[__i] = 0; __matching_name[__pos + 1] = __name + __i; --__check_count; if (__check_count == 0) { ++__first; return __name + __i; } } } else { __do_check[__i] = 0; --__check_count; if (__check_count == 0) return __matching_name[__pos]; } } } ++__first; ++__pos; } return __matching_name[__pos];}// __get_formatted_time reads input that is assumed to be formatted// according to the rules for the C strftime function (C standard,// 7.12.3.5). This function is used to implement the do_get_time// and do_get_date virtual functions, which depend on the locale// specifications for the time and day formats respectively.// Note the catchall default case, intended mainly for the '%Z'// format designator, which does not make sense here since the// representation of timezones is not part of the locale.//// The case branches are implemented either by doing a match using// the appopriate name table or by doing a __get_integer_nogroup.//// 'y' format is assumed to mean that the input represents years// since 1900. That is, 2002 should be represented as 102. There// is no century-guessing.//// The match is successful if and only if the second component of the// return value is format_end.// Note that the antepenultimate parameter is being used only to determine// the correct overloading for the calls to __get_integer_nogroup.template <class _InIt1, class _Ch>string::const_iterator _STLP_CALL__get_formatted_time _STLP_WEAK (_InIt1 __first, _InIt1 __last, string::const_iterator __format, string::const_iterator __format_end, _Ch*, const _Time_Info& __table, const ios_base& __s, ios_base::iostate& __err, tm* __t) { const ctype<_Ch>& __ct = *__STATIC_CAST(const ctype<_Ch>*, __s._M_ctype_facet()); while (__first != __last && __format != __format_end) { if (*__format == '%') { ++__format; char __c = *__format; if (__c == '#') { //MS extension ++__format; __c = *__format; } switch (__c) { case 'a': { const string* __pr = __match(__first, __last, __table._M_dayname + 0, __table._M_dayname + 7, __ct); if (__pr == __table._M_dayname + 7) return __format; __t->tm_wday = __STATIC_CAST(int, __pr - __table._M_dayname); break; } case 'A': { const string* __pr = __match(__first, __last, __table._M_dayname + 7, __table._M_dayname + 14, __ct); if (__pr == __table._M_dayname + 14) return __format; __t->tm_wday = __STATIC_CAST(int, __pr - __table._M_dayname - 7); break; } case 'b': { const string* __pr = __match(__first, __last, __table._M_monthname + 0, __table._M_monthname + 12, __ct); if (__pr == __table._M_monthname + 12) return __format; __t->tm_mon = __STATIC_CAST(int, __pr - __table._M_monthname); break; } case 'B': { const string* __pr = __match(__first, __last, __table._M_monthname + 12, __table._M_monthname + 24, __ct); if (__pr == __table._M_monthname + 24) return __format; __t->tm_mon = __STATIC_CAST(int, __pr - __table._M_monthname - 12); break; } case 'd': { bool __pr = __get_decimal_integer(__first, __last, __t->tm_mday, __STATIC_CAST(_Ch*, 0)); if (!__pr || __t->tm_mday < 1 || __t->tm_mday > 31) { __err |= ios_base::failbit; return __format; } break; } case 'H': case 'I': { bool __pr = __get_decimal_integer(__first, __last, __t->tm_hour, __STATIC_CAST(_Ch*, 0)); if (!__pr) return __format; break; }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -