1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
/* Copyright (C) 2008 Vincent Penquerc'h.
This file is part of the Kate codec library.
Written by Vincent Penquerc'h.
Use, distribution and reproduction of this library is governed
by a BSD style source license included with this source in the
file 'COPYING'. Please read these terms before distributing. */
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <stdio.h>
#include <stdlib.h>
#include <ogg/ogg.h>
#include "kate/kate.h"
#include "kutil.h"
#include "klrc.h"
void *new_lrc_data(void)
{
struct lrc_data *lrc_data=kate_malloc(sizeof(struct lrc_data));
if (lrc_data) {
lrc_data->last_event_end_time=-1;
}
return lrc_data;
}
void free_lrc_data(void *data)
{
kate_free(data);
}
static ogg_int64_t granule_to_centiseconds(const kate_info *ki,ogg_int64_t granpos)
{
return (100*granpos*ki->gps_denominator+ki->gps_numerator/2)/ki->gps_numerator;
}
static void centiseconds_to_time(ogg_int64_t cs,int *minutes,int *seconds,int *centiseconds)
{
*minutes=cs/(60*100);
*seconds=cs/100%60;
*centiseconds=cs%100;
}
void write_lrc_event(FILE *fout,void *data,const kate_event *ev,ogg_int64_t granpos)
{
struct lrc_data *lrc_data=(struct lrc_data*)data;
int m0,s0,cs0;
int m1,s1,cs1;
centiseconds_to_time(granule_to_centiseconds(ev->ki,ev->start),&m0,&s0,&cs0);
centiseconds_to_time(granule_to_centiseconds(ev->ki,ev->start+ev->duration),&m1,&s1,&cs1);
(void)granpos;
(void)data;
if (lrc_data->last_event_end_time<0) {
fprintf(fout,"[%d:%02d.%02d]",m0,s0,cs0);
}
else if (lrc_data->last_event_end_time<ev->start) {
fprintf(fout,"\n");
fprintf(fout,"[%d:%02d.%02d]",m0,s0,cs0);
}
fprintf(fout,"%s\n",ev->text);
fprintf(fout,"[%d:%02d.%02d]",m1,s1,cs1);
fflush(fout);
lrc_data->last_event_end_time=ev->start+ev->duration;
}
void write_lrc_end(FILE *fout)
{
fprintf(fout,"\n");
fflush(fout);
}
|