mirror of
https://github.com/mpv-player/mpv
synced 2025-01-17 04:22:41 +00:00
74b66862d7
Allow negative times. Timestamps can be negative, and we actually display negative time for other reasons too, such as when waiting for the old audio to drain with gapless audio.) Avoid overflows with relatively large time values. (We still don't handle values too large for int64_t.)
67 lines
2.0 KiB
C
67 lines
2.0 KiB
C
/*
|
|
* This file is part of MPlayer.
|
|
*
|
|
* MPlayer is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* MPlayer is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with MPlayer; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
|
|
#include <libavutil/common.h>
|
|
|
|
#include "talloc.h"
|
|
#include "core/mp_common.h"
|
|
|
|
char *mp_format_time(double time, bool fractions)
|
|
{
|
|
if (time == MP_NOPTS_VALUE)
|
|
return talloc_strdup(NULL, "unknown");
|
|
char sign[2] = {0};
|
|
if (time < 0) {
|
|
time = -time;
|
|
sign[0] = '-';
|
|
}
|
|
long long int itime = time;
|
|
int64_t h, m, s;
|
|
s = itime;
|
|
h = s / 3600;
|
|
s -= h * 3600;
|
|
m = s / 60;
|
|
s -= m * 60;
|
|
char *res = talloc_asprintf(NULL, "%s%02lld:%02lld:%02lld", sign, h, m, s);
|
|
if (fractions)
|
|
res = talloc_asprintf_append(res, ".%03d",
|
|
(int)((time - itime) * 1000));
|
|
return res;
|
|
}
|
|
|
|
// Set rc to the union of rc and rc2
|
|
void mp_rect_union(struct mp_rect *rc, const struct mp_rect *rc2)
|
|
{
|
|
rc->x0 = FFMIN(rc->x0, rc2->x0);
|
|
rc->y0 = FFMIN(rc->y0, rc2->y0);
|
|
rc->x1 = FFMAX(rc->x1, rc2->x1);
|
|
rc->y1 = FFMAX(rc->y1, rc2->y1);
|
|
}
|
|
|
|
// Set rc to the intersection of rc and src.
|
|
// Return false if the result is empty.
|
|
bool mp_rect_intersection(struct mp_rect *rc, const struct mp_rect *rc2)
|
|
{
|
|
rc->x0 = FFMAX(rc->x0, rc2->x0);
|
|
rc->y0 = FFMAX(rc->y0, rc2->y0);
|
|
rc->x1 = FFMIN(rc->x1, rc2->x1);
|
|
rc->y1 = FFMIN(rc->y1, rc2->y1);
|
|
|
|
return rc->x1 > rc->x0 && rc->y1 > rc->y0;
|
|
}
|