summaryrefslogtreecommitdiff
blob: 5fd9ea6fc7014f88213d25e3fe7736fa2fdb07e0 (plain)
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
--- src/input/vcd/xineplug_inp_vcd.c.old	2004-08-11 02:55:35.296492264 +0900
+++ src/input/vcd/xineplug_inp_vcd.c	2004-08-11 02:59:45.897395136 +0900
@@ -48,6 +48,7 @@
 #define SHORT_PLUGIN_NAME "VCD"
 #define MRL_PREFIX "vcd://"
 #define MRL_PREFIX_LEN strlen(MRL_PREFIX)
+#define MRL_MAX_LEN 1024
 
 #define xine_config_entry_t xine_cfg_entry_t
 
@@ -474,7 +475,7 @@
     return false;
   }
 
-  count = sscanf (p, "%[^@]@%1[EePpSsTt]%u", 
+  count = sscanf (p, "%1024[^@]@%1[EePpSsTt]%u", 
 		  device_str, type_str, &num);
   itemid->num = num;
   
@@ -498,7 +499,7 @@
     {
       /* No device/file given, so use the default device and try again. */
       if (NULL == default_vcd_device) return false;
-      strcpy(device_str, default_vcd_device);
+      strncpy(device_str, default_vcd_device, MRL_MAX_LEN);
       if (p[0] == '@') p++;
       count = sscanf (p, "%1[EePpSsTt]%u", type_str, &num);
       type_str[0] = toupper(type_str[0]);
@@ -790,7 +791,7 @@
 vcd_class_get_dir (input_class_t *this_gen, const char *filename, 
                     int *num_files) {
 
-  char             intended_vcd_device[1024]="";
+  char             intended_vcd_device[MRL_MAX_LEN+1]="";
   vcdinfo_itemid_t itemid;
 
   vcd_input_class_t *class = (vcd_input_class_t *) this_gen;
@@ -922,7 +923,7 @@
 static char *
 vcd_class_get_identifier (input_class_t *this_gen) {
   dbg_print((INPUT_DBG_CALL|INPUT_DBG_EXT), "called\n");
-  return SHORT_PLUGIN_NAME;
+  return strdup(SHORT_PLUGIN_NAME);
 }
 
 /* 
@@ -1452,7 +1453,7 @@
 {
   vcd_input_class_t  *class = (vcd_input_class_t *) class_gen;
 
-  char intended_vcd_device[1024]="";
+  char intended_vcd_device[MRL_MAX_LEN+1]="";
   vcdinfo_itemid_t itemid;
   char *check_mrl=NULL;
   bool used_default;