diff options
Diffstat (limited to 'TOOLS/subrip.c')
-rw-r--r-- | TOOLS/subrip.c | 237 |
1 files changed, 0 insertions, 237 deletions
diff --git a/TOOLS/subrip.c b/TOOLS/subrip.c deleted file mode 100644 index fb9395c413..0000000000 --- a/TOOLS/subrip.c +++ /dev/null @@ -1,237 +0,0 @@ -/* - * Use with CVS JOCR/GOCR. - * - * You will have to change 'vobsub_id' value if you want another subtitle than number 0. - * - * HINT: you can view the subtitle that is being decoded with "display subtitle-*.pgm" - * - * This program 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. - * - * This program 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 this program; if not, write to the Free Software Foundation, Inc., - * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. - */ - -/* Make sure this accesses the CVS version of JOCR/GOCR */ -#define GOCR_PROGRAM "gocr" - -#include <ctype.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <unistd.h> -#include <sys/types.h> -#include <sys/wait.h> -#include "libvo/video_out.h" -#include "sub/vobsub.h" -#include "sub/spudec.h" - -/* linking hacks */ -char *mplayer_version; - -/* XXX Kludge ahead, this MUST be the same as the definitions found in ../spudec.c */ -typedef struct packet_t packet_t; -struct packet_t { - unsigned char *packet; - unsigned int palette[4]; - unsigned int alpha[4]; - unsigned int control_start; /* index of start of control data */ - unsigned int current_nibble[2]; /* next data nibble (4 bits) to be - processed (for RLE decoding) for - even and odd lines */ - int deinterlace_oddness; /* 0 or 1, index into current_nibble */ - unsigned int start_col, end_col; - unsigned int start_row, end_row; - unsigned int width, height, stride; - unsigned int start_pts, end_pts; - packet_t *next; -}; -typedef struct { - packet_t *queue_head; - packet_t *queue_tail; - unsigned int global_palette[16]; - unsigned int orig_frame_width, orig_frame_height; - unsigned char* packet; - size_t packet_reserve; /* size of the memory pointed to by packet */ - unsigned int packet_offset; /* end of the currently assembled fragment */ - unsigned int packet_size; /* size of the packet once all fragments are assembled */ - unsigned int packet_pts; /* PTS for this packet */ - unsigned int palette[4]; - unsigned int alpha[4]; - unsigned int cuspal[4]; - unsigned int custom; - unsigned int now_pts; - unsigned int start_pts, end_pts; - unsigned int start_col, end_col; - unsigned int start_row, end_row; - unsigned int width, height, stride; - size_t image_size; /* Size of the image buffer */ - unsigned char *image; /* Grayscale value */ - unsigned char *aimage; /* Alpha value */ - unsigned int scaled_frame_width, scaled_frame_height; - unsigned int scaled_start_col, scaled_start_row; - unsigned int scaled_width, scaled_height, scaled_stride; - size_t scaled_image_size; - unsigned char *scaled_image; - unsigned char *scaled_aimage; - int auto_palette; /* 1 if we lack a palette and must use an heuristic. */ - int font_start_level; /* Darkest value used for the computed font */ - const vo_functions_t *hw_spu; - int spu_changed; -} spudec_handle_t; - -int vobsub_id=0; -int sub_pos=0; - -static spudec_handle_t *spudec; -static FILE *fsub = NULL; -static unsigned int sub_idx = 0; - -static void -process_gocr_output(const char *const fname, unsigned int start, unsigned int end) -{ - FILE *file; - int temp, h, m, s, ms; - int c, bol; - file = fopen(fname, "r"); - if (file == NULL) { - perror("fopen failed"); - return; - } - temp = start; - temp /= 90; - h = temp / 3600000; - temp %= 3600000; - m = temp / 60000; - temp %= 60000; - s = temp / 1000; - temp %= 1000; - ms = temp; - fprintf(fsub, "%d\n%02d:%02d:%02d,%03d --> ", ++sub_idx, h, m, s, ms); - temp = end; - temp /= 90; - h = temp / 3600000; - temp %= 3600000; - m = temp / 60000; - temp %= 60000; - s = temp / 1000; - temp %= 1000; - ms = temp; - fprintf(fsub, "%02d:%02d:%02d,%03d\n", h, m, s, ms); - bol = 1; - while ((c = getc(file)) != EOF) { - if (bol) { - if (!isspace(c)) { - putc(c, fsub); - bol=0; - } - } - else if (!bol) { - putc(c, fsub); - bol = c == '\n'; - } - } - putc('\n', fsub); - fflush(fsub); - fclose(file); -} - -static void -output_pgm(FILE *f, int w, int h, unsigned char *src, unsigned char *srca, int stride) -{ - int x, y; - fprintf(f, - "P5\n" - "%d %d\n" - "255\n", - w, h); - for (y = 0; y < h; ++y) { - for (x = 0; x < w; ++x) { - int res; - if (srca[x]) - res = src[x] * (256 - srca[x]); - else - res = 0; - res = (65535 - res) >> 8; - putc(res&0xff, f); - - } - src += stride; - srca += stride; - } - putc('\n', f); -} - -static void -draw_alpha(int x0, int y0, int w, int h, unsigned char *src, unsigned char *srca, int stride) -{ - FILE *f; - char buf[128]; - char cmd[512]; - int cmdres; - const char *const tmpfname = tmpnam(NULL); - sprintf(buf, "subtitle-%d-%d.pgm", spudec->start_pts / 90, spudec->end_pts / 90); - f = fopen(buf, "w"); - output_pgm(f, w, h, src, srca, stride); - fclose(f); - /* see <URL:http://cvs.sourceforge.net/cgi-bin/viewcvs.cgi/subtitleripper/subtitleripper/src/README.gocr?rev=HEAD&content-type=text/vnd.viewcvs-markup> */ - sprintf(cmd, GOCR_PROGRAM" -v 1 -s 7 -d 0 -m 130 -m 256 -m 32 -i %s -o %s", buf, tmpfname); - cmdres = system(cmd); - if (cmdres < 0) { - perror("system failed"); - exit(EXIT_FAILURE); - } - else if (cmdres) { - fprintf(stderr, GOCR_PROGRAM" returned %d\n", cmdres); - exit(cmdres); - } - process_gocr_output(tmpfname, spudec->start_pts, spudec->end_pts); - unlink(buf); - unlink(tmpfname); -} - -int -main(int argc, char **argv) -{ - const char *vobsubname, *subripname; - void *vobsub; - void *packet; - int packet_len; - unsigned int pts100; - - if (argc < 2 || 4 < argc) { - fprintf(stderr, "Usage: %s <vobsub basename> [<subid> [<output filename>] ]\n", argv[0]); - exit(EXIT_FAILURE); - } - vobsubname = argv[1]; - subripname = NULL; - fsub = stdout; - if (argc >= 3) - vobsub_id = atoi(argv[2]); - if (argc >= 4) { - subripname = argv[3]; - fsub = fopen(subripname, "w"); - } - - vobsub = vobsub_open(vobsubname, NULL, 0, &spudec); - while ((packet_len=vobsub_get_next_packet(vobsub, &packet, &pts100)) >= 0) { - spudec_assemble(spudec, packet, packet_len, pts100); - if (spudec->queue_head) { - spudec_heartbeat(spudec, spudec->queue_head->start_pts); - if (spudec_changed(spudec)) - spudec_draw(spudec, draw_alpha); - } - } - - if (vobsub) - vobsub_close(vobsub); - exit(EXIT_SUCCESS); -} |