⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timerep.cpp

📁 著名的 helix realplayer 基于手机 symbian 系统的 播放器全套源代码
💻 CPP
📖 第 1 页 / 共 2 页
字号:
UTCTimeRep::UTCTimeRep(time_t t, BOOL bUTC /* = TRUE */)
{
    m_szTime[0] = '\0';
    bUTC ? fromUTCTime(t) : fromTime(t);
}

UTCTimeRep::~UTCTimeRep(void)
{
    // Empty
}

const char*
UTCTimeRep::asRFC1123String(void)
{
    m_szTime[0] = '\0';
    struct tm* ptm = NULL;

    // If our time is valid, fetch a struct tm in GMT.
#ifdef _USE_THREADSAFE_TIME_FUNCS
    struct tm tmgmt;
    if (m_tTime != INVALID_TIME_T)
    {
        ptm = gmtime_r(&m_tTime, &tmgmt);
    }
#else
    if (m_tTime != INVALID_TIME_T)
    {
        ptm = gmtime(&m_tTime);
    }
#endif

    // If the struct tm is good, create the string.
    if (ptm != NULL)
    {
#if defined(_WIN16) || defined(WIN32_PLATFORM_PSPC)
        if (strftime16(m_szTime, MAX_UTC_TIME_LEN, "%a, %d %b %Y %H:%M:%S GMT", ptm) == 0)
#else
        if (strftime(m_szTime, MAX_UTC_TIME_LEN, "%a, %d %b %Y %H:%M:%S GMT", ptm) == 0)
#endif
        {
            // If there is an error, the string is undefined so empty it.
            m_szTime[0] = '\0';
        }
    }

    return m_szTime;
}

const char*
UTCTimeRep::asRFC850String(void)
{
    m_szTime[0] = '\0';
    struct tm* ptm = NULL;

    // If our time is valid, fetch a struct tm in GMT.
#ifdef _USE_THREADSAFE_TIME_FUNCS
    struct tm tmgmt;
    if (m_tTime != INVALID_TIME_T)
    {
        ptm = gmtime_r(&m_tTime, &tmgmt);
    }
#else
    if (m_tTime != INVALID_TIME_T)
    {
        ptm = gmtime(&m_tTime);
    }
#endif

    // If the struct tm is good, create the string.
    if (ptm != NULL)
    {
#if defined(_WIN16) || defined(WIN32_PLATFORM_PSPC)
        if (strftime16(m_szTime, MAX_UTC_TIME_LEN, "%A, %d-%b-%y %H:%M:%S GMT", ptm) == 0)
#else
        if (strftime(m_szTime, MAX_UTC_TIME_LEN, "%A, %d-%b-%y %H:%M:%S GMT", ptm) == 0)
#endif
        {
            m_szTime[0] = '\0';
        }
    }
    return m_szTime;
}

const char*
UTCTimeRep::asUTCString(void)
{
    m_szTime[0] = '\0';
    struct tm* ptm = NULL;

    // If our time is valid, fetch a struct tm in GMT.
#ifdef _USE_THREADSAFE_TIME_FUNCS
    struct tm tmgmt;
    if (m_tTime != INVALID_TIME_T)
    {
        ptm = gmtime_r(&m_tTime, &tmgmt);
    }
#else
    if (m_tTime != INVALID_TIME_T)
    {
        ptm = gmtime(&m_tTime);
    }
#endif

    // If the struct tm is good, create the string.
    if (ptm != NULL)
    {
#if defined(_WIN16) || defined(WIN32_PLATFORM_PSPC)
        if (strftime16(m_szTime, MAX_UTC_TIME_LEN, "%Y%m%dT%H%M%SZ", ptm) == 0)
#else
        if (strftime(m_szTime, MAX_UTC_TIME_LEN, "%Y%m%dT%H%M%SZ", ptm) == 0)
#endif
        {
            m_szTime[0] = '\0';
        }
    }
    return m_szTime;
}

time_t
UTCTimeRep::asUTCTimeT(void)
{
    return m_tTime;
}

void UTCTimeRep::SetLocalTime(time_t t)
{
    fromTime(t);
}

void UTCTimeRep::SetUTCTime(time_t t)
{
    fromUTCTime(t);
}

void UTCTimeRep::SetTime(const char* pStr)
{
    fromString(pStr);
}

/*
 * Convert time_t value from localtime to gmt.  First we call gmtime() to get
 * a struct tm in localtime.  This works because gmtime() does no timezone
 * conversions -- the result is in the same timezone as the input.  Then we
 * call mktime() which converts a struct tm in localtime to a time_t in GMT.
 *
 * Win32 always assumes GMT for mktime(), so we use LocalFileTimeToFileTime()
 * and a pair of conversion functions.
 */
int
UTCTimeRep::fromTime(time_t t)
{
#ifdef _WIN32
    FILETIME lft, ft;
    TimetToFileTime(t, &lft);
    LocalFileTimeToFileTime(&lft, &ft);
    m_tTime = FileTimeToTimet(&ft);
    return 0;
#else /* ! _WIN32 */
#ifdef _USE_THREADSAFE_TIME_FUNCS
    struct tm tmlocal;
    struct tm* ptm = gmtime_r(&t, &tmlocal);
#else
    struct tm* ptm = gmtime(&t);
#endif
    if (ptm != NULL)
    {
        m_tTime = mktime(ptm);
        return 0;
    }
    m_tTime = INVALID_TIME_T;
    return -1;
#endif /* _WIN32 */
}

int
UTCTimeRep::fromUTCTime(time_t t)
{
    m_tTime = t;
    return 0;
}

int
UTCTimeRep::fromTm(struct tm* ptm)
{
#ifdef _WIN32
    // See note above in fromTime()
    time_t t = mktime_gmt(ptm);
    if (t != INVALID_TIME_T)
    {
        fromTime(t);
        return 0;
    }
    return -1;
#else /* ! _WIN32 */
    if (ptm != NULL)
    {
        m_tTime = mktime(ptm);
        return 0;
    }
    m_tTime = INVALID_TIME_T;
    return -1;
#endif /* _WIN32 */
}

int
UTCTimeRep::fromUTCTm(struct tm* ptm)
{
    m_tTime = mktime_gmt(ptm);
    return ( (m_tTime == INVALID_TIME_T) ? -1 : 0 );
}

// Find next alnum field in string or bail if not found
#define NEXT_ALNUM_FIELD(p) \
    while ( isalnum(*p)) { p++; if (*p == '\0') goto bail; } \
    while (!isalnum(*p)) { p++; if (*p == '\0') goto bail; }

int
UTCTimeRep::fromString(const char* pStr)
{
    unsigned int n;
    struct tm stm;

    memset(&stm, 0, sizeof(stm));
    if (pStr == NULL || pStr[0] == '\0')
    {
        goto bail;
    }

    /*
     * RFC1123: wkday "," SP DD SP month SP YYYY HH:MM:SS (Wed, 02 Jun 1982)
     * RFC850 : weekday "," SP DD-month-YY HH:MM:SS       (Wednesday, 02-Jun-82)
     * asctime: wkday SP month SP dD HH:MM:SS YYYY        (Wed Jun  2 09:00:00 1982)
     * UTC    : YYYYMMDD'T'HHMMSS'Z'
     */
    if (isdigit(pStr[0]))
    {
        // UTC
        if(strlen(pStr) != 16)
        {
            goto bail;
        }

        for (n = 0; n < 8; n++)
        {
            if (!isdigit(pStr[n]))
            {
                goto bail;
            }
        }
        stm.tm_year = (pStr[0]-'0')*1000 + (pStr[1]-'0')*100 +
                      (pStr[2]-'0')*10 + (pStr[3]-'0') - 1900;
        stm.tm_mon = (pStr[4]-'0')*10 + (pStr[5]-'0');
        stm.tm_mday = (pStr[6]-'0')*10 + (pStr[7]-'0');

        for (n = 9; n < 15; n++)
        {
            if (!isdigit(pStr[n]))
            {
                goto bail;
            }
        }
        stm.tm_hour = (pStr[9]-'0')*10 + (pStr[10]-'0');
        stm.tm_min = (pStr[11]-'0')*10 + (pStr[12]-'0');
        stm.tm_sec = (pStr[13]-'0')*10 + (pStr[14]-'0');

        // We have a struct tm in GMT
        return fromUTCTm(&stm);
    }
    else
    {
        if (weekday_from_string(pStr) < 0)
        {
            goto bail;
        }
        NEXT_ALNUM_FIELD(pStr);
        if (isdigit(pStr[0]))
        {
            // RFC1123 or RFC850
            if (!isdigit(pStr[1]) || isalnum(pStr[2]))
            {
                goto bail;
            }
            stm.tm_mday = (pStr[0]-'0')*10 + (pStr[1]-'0');
            NEXT_ALNUM_FIELD(pStr);
            if ((stm.tm_mon = month_from_string(pStr)) < 0)
            {
                goto bail;
            }
            NEXT_ALNUM_FIELD(pStr);
            if (!isdigit(pStr[0]) || !isdigit(pStr[1]))
            {
                goto bail;
            }
            if (!isdigit(pStr[2]))
            {
                // RFC850
                stm.tm_year = (pStr[0]-'0')*10 + (pStr[1]-'0');
            }
            else if (isdigit(pStr[3]) && !isdigit(pStr[4]))
            {
                // RFC1123
                stm.tm_year = (pStr[0]-'0')*1000 + (pStr[1]-'0')*100 +
                              (pStr[2]-'0')*10 + (pStr[3]-'0') - 1900;
            }
            else
            {
                goto bail;
            }
            NEXT_ALNUM_FIELD(pStr);
            for (n = 0; n < 8; n++)
            {
                if (n == 2 || n == 5)
                {
                    if (pStr[n] != ':')
                    {
                        goto bail;
                    }
                }
                else if (!isdigit(pStr[n]))
                {
                    goto bail;
                }
            }
            stm.tm_hour = (pStr[0]-'0')*10 + (pStr[1]-'0');
            stm.tm_min = (pStr[3]-'0')*10 + (pStr[4]-'0');
            stm.tm_sec = (pStr[6]-'0')*10 + pStr[7]-'0';
            pStr += 8;

            NEXT_ALNUM_FIELD(pStr);
            if (strncasecmp(pStr, "GMT", 3) != 0)
            {
                goto bail;
            }

            // We have a struct tm in GMT
            return fromUTCTm(&stm);
        }
        else
        {
            // asctime
            NEXT_ALNUM_FIELD(pStr);
            if ((stm.tm_mon = month_from_string(pStr)) == -1)
            {
                goto bail;
            }
            NEXT_ALNUM_FIELD(pStr);
            if (isdigit(pStr[0]) && pStr[1] == ' ')
            {
                stm.tm_mday = (pStr[0]-'0');
            }
            else if (isdigit(pStr[0]) && isdigit(pStr[1]) && pStr[2] == ' ')
            {
                stm.tm_mday = (pStr[0]-'0')*10 + (pStr[1]-'0');
            }
            else
            {
                goto bail;
            }
            NEXT_ALNUM_FIELD(pStr);
            for (n = 0; n < 8; n++)
            {
                if (n == 2 || n == 5)
                {
                    if (pStr[n] != ':')
                    {
                        goto bail;
                    }
                }
                else if (!isdigit(pStr[n]))
                {
                    goto bail;
                }
            }
            stm.tm_hour = (pStr[0]-'0')*10 + (pStr[1]-'0');
            stm.tm_min = (pStr[3]-'0')*10 + (pStr[4]-'0');
            stm.tm_sec = (pStr[6]-'0')*10 + pStr[7]-'0';
            pStr += 8;
            NEXT_ALNUM_FIELD(pStr);
            if (!isdigit(pStr[0]) || !isdigit(pStr[1]) ||
                !isdigit(pStr[2]) || !isdigit(pStr[3]) ||
                isdigit(pStr[4]))
            {
                goto bail;
            }
            stm.tm_year = (pStr[0]-'0')*1000 + (pStr[1]-'0')*100 +
                          (pStr[2]-'0')*10 + (pStr[3]-'0') - 1900;

            // We have a struct tm in localtime
            return fromTm(&stm);
        }
    }
    /* NOTREACHED */
bail:
    m_tTime = INVALID_TIME_T;
    return -1;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -