annotate ffmpeg/libavformat/cutils.c @ 13:844d341cf643 tip

Back up before ISMIR
author Yading Song <yading.song@eecs.qmul.ac.uk>
date Thu, 31 Oct 2013 13:17:06 +0000
parents f445c3017523
children
rev   line source
yading@11 1 /*
yading@11 2 * various simple utilities for libavformat
yading@11 3 * Copyright (c) 2000, 2001, 2002 Fabrice Bellard
yading@11 4 *
yading@11 5 * This file is part of FFmpeg.
yading@11 6 *
yading@11 7 * FFmpeg is free software; you can redistribute it and/or
yading@11 8 * modify it under the terms of the GNU Lesser General Public
yading@11 9 * License as published by the Free Software Foundation; either
yading@11 10 * version 2.1 of the License, or (at your option) any later version.
yading@11 11 *
yading@11 12 * FFmpeg is distributed in the hope that it will be useful,
yading@11 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@11 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@11 15 * Lesser General Public License for more details.
yading@11 16 *
yading@11 17 * You should have received a copy of the GNU Lesser General Public
yading@11 18 * License along with FFmpeg; if not, write to the Free Software
yading@11 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@11 20 */
yading@11 21 #include "avformat.h"
yading@11 22 #include "internal.h"
yading@11 23
yading@11 24 #define ISLEAP(y) (((y) % 4 == 0) && (((y) % 100) != 0 || ((y) % 400) == 0))
yading@11 25 #define LEAPS_COUNT(y) ((y)/4 - (y)/100 + (y)/400)
yading@11 26
yading@11 27 /* This is our own gmtime_r. It differs from its POSIX counterpart in a
yading@11 28 couple of places, though. */
yading@11 29 struct tm *ff_brktimegm(time_t secs, struct tm *tm)
yading@11 30 {
yading@11 31 int days, y, ny, m;
yading@11 32 int md[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
yading@11 33
yading@11 34 days = secs / 86400;
yading@11 35 secs %= 86400;
yading@11 36 tm->tm_hour = secs / 3600;
yading@11 37 tm->tm_min = (secs % 3600) / 60;
yading@11 38 tm->tm_sec = secs % 60;
yading@11 39
yading@11 40 /* oh well, may be someone some day will invent a formula for this stuff */
yading@11 41 y = 1970; /* start "guessing" */
yading@11 42 while (days > 365) {
yading@11 43 ny = (y + days/366);
yading@11 44 days -= (ny - y) * 365 + LEAPS_COUNT(ny - 1) - LEAPS_COUNT(y - 1);
yading@11 45 y = ny;
yading@11 46 }
yading@11 47 if (days==365 && !ISLEAP(y)) { days=0; y++; }
yading@11 48 md[1] = ISLEAP(y)?29:28;
yading@11 49 for (m=0; days >= md[m]; m++)
yading@11 50 days -= md[m];
yading@11 51
yading@11 52 tm->tm_year = y; /* unlike gmtime_r we store complete year here */
yading@11 53 tm->tm_mon = m+1; /* unlike gmtime_r tm_mon is from 1 to 12 */
yading@11 54 tm->tm_mday = days+1;
yading@11 55
yading@11 56 return tm;
yading@11 57 }