[Mplayer-cvslog] CVS: main cfg-mencoder.h,1.18,1.19 mencoder.c,1.57,1.58

Arpi of Ize arpi at mplayer.dev.hu
Tue Jan 15 01:20:53 CET 2002


Update of /cvsroot/mplayer/main
In directory mplayer:/var/tmp.root/cvs-serv5719

Modified Files:
	cfg-mencoder.h mencoder.c 
Log Message:
-endpos option, patch by Fredrik Kuivinen <freku045 at student.liu.se>

Index: cfg-mencoder.h
===================================================================
RCS file: /cvsroot/mplayer/main/cfg-mencoder.h,v
retrieving revision 1.18
retrieving revision 1.19
diff -u -r1.18 -r1.19
--- cfg-mencoder.h	14 Jan 2002 23:55:51 -0000	1.18
+++ cfg-mencoder.h	15 Jan 2002 00:20:50 -0000	1.19
@@ -89,6 +89,8 @@
 	/* name, pointer, type, flags, min, max */
 	{"include", cfg_include, CONF_TYPE_FUNC_PARAM, CONF_NOSAVE, 0, 0, NULL}, /* this must be the first!!! */
 
+	{"endpos", parse_end_at, CONF_TYPE_FUNC_PARAM, 0, 0, 0, NULL},
+	
 	{"ofps", &force_ofps, CONF_TYPE_FLOAT, CONF_MIN, 0, 0, NULL},
 	{"o", &out_filename, CONF_TYPE_STRING, 0, 0, 0, NULL},
 

Index: mencoder.c
===================================================================
RCS file: /cvsroot/mplayer/main/mencoder.c,v
retrieving revision 1.57
retrieving revision 1.58
diff -u -r1.57 -r1.58
--- mencoder.c	14 Jan 2002 23:38:49 -0000	1.57
+++ mencoder.c	15 Jan 2002 00:20:50 -0000	1.58
@@ -180,6 +180,8 @@
 	return m_config_parse_config_file(mconfig, filename);
 }
 
+static int parse_end_at(struct config *conf, const char* param);
+
 #include "get_path.c"
 
 #include "cfg-mplayer-def.h"
@@ -305,6 +307,10 @@
 static int eof=0;
 static int interrupted=0;
 
+enum end_at_type_t {END_AT_NONE, END_AT_TIME, END_AT_SIZE};
+static enum end_at_type_t end_at_type = END_AT_NONE;
+static int end_at;
+
 static void exit_sighandler(int x){
     eof=1;
     interrupted=1;
@@ -1057,6 +1063,10 @@
     int in_size;
     int skip_flag=0; // 1=skip  -1=duplicate
 
+    if((end_at_type == END_AT_SIZE && end_at <= ftell(muxer_f))  ||
+       (end_at_type == END_AT_TIME && end_at < sh_video->timer))
+        break;
+
     if(play_n_frames>=0){
       --play_n_frames;
       if(play_n_frames<0) break;
@@ -1356,4 +1366,54 @@
 if(stream) free_stream(stream); // kill cache thread
 
 return interrupted;
+}
+
+static int parse_end_at(struct config *conf, const char* param)
+{
+    int i;
+
+    end_at_type = END_AT_NONE;
+    
+    /* End at size parsing */
+    {
+        char unit[4];
+        
+        end_at_type = END_AT_SIZE;
+
+        if(sscanf(param, "%d%3s", &end_at, unit) == 2) {
+            if(!strcasecmp(unit, "b"))
+                ;
+            else if(!strcasecmp(unit, "kb"))
+                end_at *= 1024;
+            else if(!strcasecmp(unit, "mb"))
+                end_at *= 1024*1024;
+            else
+                end_at_type = END_AT_NONE;
+        }
+        else
+            end_at_type = END_AT_NONE;
+    }
+
+    /* End at time parsing. This has to be last because of
+     * sscanf("%f", ...) below */
+    if(end_at_type == END_AT_NONE)
+    {
+        int a,b; float d;
+
+        end_at_type = END_AT_TIME;
+        
+        if (sscanf(param, "%d:%d:%f", &a, &b, &d) == 3)
+            end_at = 3600*a + 60*b + d;
+        else if (sscanf(param, "%d:%f", &a, &d) == 2)
+            end_at = 60*a + d;
+        else if (sscanf(param, "%f", &d) == 1)
+            end_at = d;
+        else
+            end_at_type = END_AT_NONE;
+    }
+
+    if(end_at_type == END_AT_NONE)
+        return ERR_FUNC_ERR;
+
+    return 1;
 }




More information about the MPlayer-cvslog mailing list