Home | History | Annotate | Download | only in intltest
      1 //  2016 and later: Unicode, Inc. and others.
      2 // License & terms of use: http://www.unicode.org/copyright.html
      3 /********************************************************************
      4  * COPYRIGHT:
      5  * Copyright (c) 1997-2009, International Business Machines Corporation and
      6  * others. All Rights Reserved.
      7  ********************************************************************/
      8 
      9 
     10 #ifndef _CALTZTST
     11 #define _CALTZTST
     12 
     13 #include "unicode/utypes.h"
     14 
     15 #if !UCONFIG_NO_FORMATTING
     16 
     17 #include "unicode/unistr.h"
     18 #include "unicode/calendar.h"
     19 #include "unicode/datefmt.h"
     20 #include "intltest.h"
     21 
     22 /**
     23  * This class doesn't perform any tests, but provides utility methods to its subclasses.
     24  **/
     25 class CalendarTimeZoneTest : public IntlTest
     26 {
     27 public:
     28     static void cleanup();
     29 protected:
     30     // Return true if the given status indicates failure.  Also has the side effect
     31     // of calling errln().  Msg should be of the form "Class::Method" in general.
     32     UBool failure(UErrorCode status, const char* msg, UBool possibleDataError=FALSE);
     33 
     34     // Utility method for formatting dates for printing; useful for Java->C++ conversion.
     35     // Tries to mimic the Java Date.toString() format.
     36     UnicodeString  dateToString(UDate d);
     37     UnicodeString& dateToString(UDate d, UnicodeString& str);
     38     UnicodeString& dateToString(UDate d, UnicodeString& str, const TimeZone& z);
     39 
     40     // Utility methods to create a date.  This is useful for converting Java constructs
     41     // which create a Date object.  Returns a Date in the current local time.
     42     UDate date(int32_t y, int32_t m, int32_t d, int32_t hr=0, int32_t min=0, int32_t sec=0);
     43 
     44     // Utility methods to create a date.  Returns a Date in UTC.  This will differ
     45     // from local dates returned by date() by the current default zone offset.
     46 //  Date utcDate(int y, int m, int d, int hr=0, int min=0, int sec=0);
     47 
     48     // Utility method to get the fields of a date; similar to Date.getYear() etc.
     49     void dateToFields(UDate date, int32_t& y, int32_t& m, int32_t& d, int32_t& hr, int32_t& min, int32_t& sec);
     50 
     51 protected:
     52     static DateFormat*         fgDateFormat;
     53     static Calendar*           fgCalendar;
     54 
     55     // the 'get()' functions are not static because they can call errln().
     56     // they are effectively static otherwise.
     57      DateFormat*               getDateFormat(void);
     58     static void                releaseDateFormat(DateFormat *f);
     59 
     60      Calendar*                 getCalendar(void);
     61     static void                releaseCalendar(Calendar *c);
     62 };
     63 
     64 #endif /* #if !UCONFIG_NO_FORMATTING */
     65 
     66 #endif //_CALTZTST
     67 //eof
     68