Fix:
[mplayer/glamo.git] / edl.c
blobbffb5926b6f163831b53e1e874ab346aa2b48df6
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include "config.h"
4 #include "mp_msg.h"
5 #include "edl.h"
6 #include "help_mp.h"
8 char *edl_filename; // file to extract EDL entries from (-edl)
9 char *edl_output_filename; // file to put EDL entries in (-edlout)
11 /**
12 * Allocates a new EDL record and makes sure allocation was successful.
14 * \return New allocated EDL record.
15 * \brief Allocate new EDL record
18 static edl_record_ptr edl_alloc_new(edl_record_ptr next_edl_record)
20 edl_record_ptr new_record = calloc(1, sizeof(struct edl_record));
21 if (!new_record) {
22 mp_msg(MSGT_CPLAYER, MSGL_FATAL, MSGTR_EdlOutOfMem);
23 exit(1);
26 if (next_edl_record) // if this isn't the first record, tell the previous one what the new one is.
27 next_edl_record->next = new_record;
28 new_record->prev = next_edl_record;
29 new_record->next = NULL;
31 return new_record;
34 /**
35 * Goes through entire EDL records and frees all memory.
36 * Assumes next_edl_record is valid or NULL.
38 * \brief Free EDL memory
41 void free_edl(edl_record_ptr next_edl_record)
43 edl_record_ptr tmp;
44 while (next_edl_record) {
45 tmp = next_edl_record->next;
46 free(next_edl_record);
47 next_edl_record = tmp;
51 /** Parses edl_filename to fill EDL operations queue.
52 * Prints out how many EDL operations recorded total.
53 * \brief Fills EDL operations queue.
56 edl_record_ptr edl_parse_file(void)
58 FILE *fd;
59 char line[100];
60 float start, stop;
61 int action;
62 int record_count = 0;
63 int lineCount = 0;
64 edl_record_ptr edl_records = NULL;
65 edl_record_ptr next_edl_record = NULL;
67 if (edl_filename)
69 if ((fd = fopen(edl_filename, "r")) == NULL)
71 return NULL;
72 } else
74 while (fgets(line, 99, fd) != NULL)
76 lineCount++;
77 if ((sscanf(line, "%f %f %d", &start, &stop, &action))
78 != 3)
80 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_EdlBadlyFormattedLine,
81 lineCount + 1);
82 continue;
83 } else
85 if (next_edl_record && start <= next_edl_record->stop_sec)
87 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_EdlNOValidLine, line);
88 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_EdlBadLineOverlap,
89 next_edl_record->prev->stop_sec, start);
90 continue;
92 if (stop <= start)
94 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_EdlNOValidLine,
95 line);
96 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_EdlBadLineBadStop);
97 continue;
99 next_edl_record = edl_alloc_new(next_edl_record);
100 if (!edl_records) edl_records = next_edl_record;
102 next_edl_record->action = action;
103 if (action == EDL_MUTE)
105 next_edl_record->length_sec = 0;
106 next_edl_record->start_sec = start;
107 next_edl_record->stop_sec = start;
109 next_edl_record = edl_alloc_new(next_edl_record);
111 next_edl_record->action = action;
112 next_edl_record->length_sec = 0;
113 next_edl_record->start_sec = stop;
114 next_edl_record->stop_sec = stop;
115 } else
117 next_edl_record->length_sec = stop - start;
118 next_edl_record->start_sec = start;
119 next_edl_record->stop_sec = stop;
121 record_count++;
125 fclose(fd);
127 if (edl_records) mp_msg(MSGT_CPLAYER, MSGL_INFO, MSGTR_EdlRecordsNo, record_count);
128 else mp_msg(MSGT_CPLAYER, MSGL_INFO, MSGTR_EdlQueueEmpty);
130 return edl_records;