libavformat/cutils.c
2302dd13
 /*
2f5df0b1
  * various simple utilities for libavformat
2302dd13
  * Copyright (c) 2000, 2001, 2002 Fabrice Bellard
  *
b78e7197
  * This file is part of FFmpeg.
  *
  * FFmpeg is free software; you can redistribute it and/or
2302dd13
  * modify it under the terms of the GNU Lesser General Public
  * License as published by the Free Software Foundation; either
b78e7197
  * version 2.1 of the License, or (at your option) any later version.
2302dd13
  *
b78e7197
  * FFmpeg is distributed in the hope that it will be useful,
2302dd13
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
b78e7197
  * License along with FFmpeg; if not, write to the Free Software
5509bffa
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2302dd13
  */
 #include "avformat.h"
9a2cb05f
 #include "internal.h"
2302dd13
 
0c9fc6e1
 #define ISLEAP(y) (((y) % 4 == 0) && (((y) % 100) != 0 || ((y) % 400) == 0))
 #define LEAPS_COUNT(y) ((y)/4 - (y)/100 + (y)/400)
 
34359cab
 /* This is our own gmtime_r. It differs from its POSIX counterpart in a
0c9fc6e1
    couple of places, though. */
167f3b8d
 struct tm *ff_brktimegm(time_t secs, struct tm *tm)
115329f1
 {
0c9fc6e1
     int days, y, ny, m;
     int md[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
 
     days = secs / 86400;
     secs %= 86400;
     tm->tm_hour = secs / 3600;
     tm->tm_min = (secs % 3600) / 60;
     tm->tm_sec =  secs % 60;
 
     /* oh well, may be someone some day will invent a formula for this stuff */
     y = 1970; /* start "guessing" */
392f2273
     while (days > 365) {
bb270c08
         ny = (y + days/366);
         days -= (ny - y) * 365 + LEAPS_COUNT(ny - 1) - LEAPS_COUNT(y - 1);
         y = ny;
0c9fc6e1
     }
392f2273
     if (days==365 && !ISLEAP(y)) { days=0; y++; }
0c9fc6e1
     md[1] = ISLEAP(y)?29:28;
     for (m=0; days >= md[m]; m++)
bb270c08
          days -= md[m];
0c9fc6e1
 
     tm->tm_year = y;  /* unlike gmtime_r we store complete year here */
     tm->tm_mon = m+1; /* unlike gmtime_r tm_mon is from 1 to 12 */
     tm->tm_mday = days+1;
 
     return tm;
 }