diff options
| -rw-r--r-- | src/input/input_cdda.c | 51 | ||||
| -rw-r--r-- | src/input/input_dvb.c | 7 | ||||
| -rw-r--r-- | src/input/input_pvr.c | 21 | ||||
| -rw-r--r-- | src/input/libreal/sdpplin.c | 2 | ||||
| -rw-r--r-- | src/input/librtsp/rtsp.c | 2 | ||||
| -rw-r--r-- | src/input/pnm.c | 4 | ||||
| -rw-r--r-- | src/libsputext/xine_sputext_decoder.c | 2 | ||||
| -rw-r--r-- | src/libxineadec/xine_speex_decoder.c | 6 | ||||
| -rw-r--r-- | src/xine-engine/load_plugins.c | 4 | ||||
| -rw-r--r-- | src/xine-engine/xine.c | 2 | 
10 files changed, 34 insertions, 67 deletions
| diff --git a/src/input/input_cdda.c b/src/input/input_cdda.c index 047916a07..92eca7559 100644 --- a/src/input/input_cdda.c +++ b/src/input/input_cdda.c @@ -1307,20 +1307,17 @@ static void _cdda_mkdir_recursive_safe(xine_t *xine, char *path) {      if(p && strlen(p)) {  #ifdef WIN32 -		if (*buf2 != '\0') { +      if (*buf2 != '\0') {  #endif - -      int size = strlen(buf2); -      snprintf(buf2 + size, sizeof(buf2) - size, "/%s", p); - +	size_t size = strlen(buf2); +	snprintf(buf2 + size, sizeof(buf2) - size, "/%s", p);  #ifdef WIN32 -		} -		else { -          snprintf(buf2, sizeof(buf2), "%s", p); -		} - +      } +      else { +	snprintf(buf2, sizeof(buf2), "%s", p); +      }  #endif /* WIN32 */ - +              _cdda_mkdir_safe(xine, buf2);      }    } @@ -1438,13 +1435,13 @@ static int _cdda_cddb_handle_code(char *buf) {   */  static int _cdda_load_cached_cddb_infos(cdda_input_plugin_t *this) {    char  cdir[XINE_PATH_MAX + XINE_NAME_MAX + 1]; +  size_t cdir_size = 0;    DIR  *dir;    if(this == NULL)      return 0; -  memset(&cdir, 0, sizeof(cdir)); -  snprintf(cdir, sizeof(cdir), "%s", this->cddb.cache_dir); +  cdir_size = snprintf(cdir, sizeof(cdir), "%s", this->cddb.cache_dir);    if((dir = opendir(cdir)) != NULL) {      struct dirent *pdir; @@ -1452,14 +1449,12 @@ static int _cdda_load_cached_cddb_infos(cdda_input_plugin_t *this) {      while((pdir = readdir(dir)) != NULL) {        char discid[9]; -      memset(&discid, 0, sizeof(discid));        snprintf(discid, sizeof(discid), "%08lx", this->cddb.disc_id);        if(!strcasecmp(pdir->d_name, discid)) {  	FILE *fd; -	int size = strlen(cdir); -	snprintf(cdir + size, sizeof(cdir) - size, "/%s", discid); +	cdir_size += snprintf(cdir + cdir_size, sizeof(cdir) - cdir_size, "/%s", discid);  	if((fd = fopen(cdir, "r")) == NULL) {  	  xprintf(this->stream->xine, XINE_VERBOSITY_DEBUG,  		  "input_cdda: fopen(%s) failed: %s.\n", cdir, strerror(errno)); @@ -1537,14 +1532,9 @@ static int _cdda_load_cached_cddb_infos(cdda_input_plugin_t *this) {  		int   nyear;  		y = strstr(buffer, "YEAR:"); -		if(y) { -		  if (sscanf(y+5, "%4d", &nyear) == 1) { -		    char year[5]; - -		    snprintf(year, 5, "%d", nyear); -		    if (this->cddb.disc_year == NULL) -		      this->cddb.disc_year = strdup(year); -		  } +		if (y && this->cddb.disc_year == NULL) { +		  if (sscanf(y+5, "%4d", &nyear) == 1) +		    asprintf(&this->cddb.disc_year, "%d", nyear);  		}  	      }  	    } @@ -1812,7 +1802,7 @@ static int _cdda_cddb_retrieve(cdda_input_plugin_t *this) {      while (strcmp(buffer, ".")) {        char buf[2048];        int tnum; -      int bufsize = strlen(buffercache); +      size_t bufsize = strlen(buffercache);        memset(&buffer, 0, sizeof(buffer));        _cdda_cddb_socket_read(this, buffer, sizeof(buffer) - 1); @@ -1880,14 +1870,9 @@ static int _cdda_cddb_retrieve(cdda_input_plugin_t *this) {            int   nyear;            y = strstr(buffer, "YEAR:"); -          if (y) { -            if (sscanf(y+5, "%4d", &nyear) == 1) { -              char year[5]; - -              snprintf(year, 5, "%d", nyear); -              if (this->cddb.disc_year == NULL) -                this->cddb.disc_year = strdup(year); -            } +          if (y && this->cddb.disc_year == NULL) { +            if (sscanf(y+5, "%4d", &nyear) == 1) +	      asprintf(&this->cddb.disc_year, "%d", nyear);            }          }        } diff --git a/src/input/input_dvb.c b/src/input/input_dvb.c index 669cd1e14..9166a80a6 100644 --- a/src/input/input_dvb.c +++ b/src/input/input_dvb.c @@ -884,7 +884,6 @@ static channel_t *load_channels(xine_t *xine, xine_stream_t *stream, int *num_ch    channel_t *channels = NULL;    int        num_channels = 0;    int        num_alloc = 0; -  int        i;    struct stat st;    snprintf(filename, BUFSIZE, "%s/.xine/channels.conf", xine_get_homedir()); @@ -909,8 +908,8 @@ static channel_t *load_channels(xine_t *xine, xine_stream_t *stream, int *num_ch    while ( fgets (str, BUFSIZE, f)) {      channel_t channel = {0}; -    /* lose trailing spaces & control characters */  -    i = strlen (str); +    /* lose trailing spaces & control characters */ +    size_t i = strlen (str);      while (i && str[i - 1] <= ' ')        --i;      if (i == 0) @@ -2816,7 +2815,7 @@ static int dvb_plugin_open(input_plugin_t * this_gen)  	    * that the channels have really ugly names, sometimes prefixed  	    * by numbers...  	    */ -	    int chanlen = strlen(channame); +	    size_t chanlen = strlen(channame);  	    int offset = 0;  	    xprintf(this->class->xine, XINE_VERBOSITY_LOG, diff --git a/src/input/input_pvr.c b/src/input/input_pvr.c index e5c70c64d..af6070a9e 100644 --- a/src/input/input_pvr.c +++ b/src/input/input_pvr.c @@ -504,34 +504,24 @@ static void pvr_adjust_realtime_speed(pvr_input_plugin_t *this, fifo_buffer_t *f  }  #define PVR_FILENAME      "%s%08d_%08d.vob" -#define PVR_FILENAME_SIZE 1+8+1+8+4+1  static char *make_temp_name(pvr_input_plugin_t *this, int page) { -    char *filename; -  int size = strlen(this->tmp_prefix)+PVR_FILENAME_SIZE; -  filename = malloc(size); -       -  snprintf(filename, size, PVR_FILENAME, this->tmp_prefix, this->session, page); +  asprintf(&filename, PVR_FILENAME, this->tmp_prefix, this->session, page);    return filename;  }  #define SAVE_BASE_FILENAME     "ch%03d %02d-%02d-%04d %02d:%02d:%02d" -#define SAVE_BASE_FILENAME_SIZE 2+3+1+2+1+2+1+4+1+2+1+2+1+2+1  static char *make_base_save_name(int channel, time_t tm) { -      struct tm rec_time;    char *filename; -  int size = SAVE_BASE_FILENAME_SIZE; -  filename = malloc(size); -      localtime_r(&tm, &rec_time); -  snprintf(filename, size, SAVE_BASE_FILENAME,  +  asprintf(&filename, SAVE_BASE_FILENAME,              channel, rec_time.tm_mon+1, rec_time.tm_mday,             rec_time.tm_year+1900, rec_time.tm_hour, rec_time.tm_min,             rec_time.tm_sec); @@ -539,16 +529,11 @@ static char *make_base_save_name(int channel, time_t tm) {  }  #define SAVE_FILENAME      "%s%s_%04d.vob" -#define SAVE_FILENAME_SIZE 1+4+4+1  static char *make_save_name(pvr_input_plugin_t *this, char *base, int page) { -    char *filename; -  int size = strlen(this->save_prefix)+strlen(base)+SAVE_FILENAME_SIZE; -  filename = malloc(size); -       -  snprintf(filename, size, SAVE_FILENAME, this->save_prefix, base, page); +  asprintf(&filename, SAVE_FILENAME, this->save_prefix, base, page);    return filename;  } diff --git a/src/input/libreal/sdpplin.c b/src/input/libreal/sdpplin.c index 2596391f9..4c1687d41 100644 --- a/src/input/libreal/sdpplin.c +++ b/src/input/libreal/sdpplin.c @@ -99,7 +99,7 @@ static char *nl(char *data) {  static int filter(const char *in, const char *filter, char **out) { -  int flen=strlen(filter); +  size_t flen=strlen(filter);    size_t len;    if (!in) diff --git a/src/input/librtsp/rtsp.c b/src/input/librtsp/rtsp.c index 4e17c1e57..07769064a 100644 --- a/src/input/librtsp/rtsp.c +++ b/src/input/librtsp/rtsp.c @@ -127,7 +127,7 @@ static char *rtsp_get(rtsp_t *s) {  static void rtsp_put(rtsp_t *s, const char *string) { -  int len=strlen(string); +  size_t len=strlen(string);    char *buf = malloc(sizeof(char)*len+2);    lprintf(">> '%s'", string); diff --git a/src/input/pnm.c b/src/input/pnm.c index 5b8aa7c42..cbd245e7b 100644 --- a/src/input/pnm.c +++ b/src/input/pnm.c @@ -415,8 +415,8 @@ static void pnm_send_request(pnm_t *p, uint32_t bandwidth) {   */  static void pnm_send_response(pnm_t *p, const char *response) { - -  int size=strlen(response); +  /** @TODO should check that sze is always < 256 */ +  size_t size=strlen(response);    p->buffer[0]=0x23;    p->buffer[1]=0; diff --git a/src/libsputext/xine_sputext_decoder.c b/src/libsputext/xine_sputext_decoder.c index 9d5a7cc29..55082476f 100644 --- a/src/libsputext/xine_sputext_decoder.c +++ b/src/libsputext/xine_sputext_decoder.c @@ -643,7 +643,7 @@ static void draw_subtitle(sputext_decoder_t *this, int64_t sub_start, int64_t su      buf[0] = 0;      for(line = 0; line < this->lines; line++) { -      int len = strlen(buf); +      size_t len = strlen(buf);        if (len) {          buf[len] = ' ';          len++; diff --git a/src/libxineadec/xine_speex_decoder.c b/src/libxineadec/xine_speex_decoder.c index 1ae310d80..46ea3a9f9 100644 --- a/src/libxineadec/xine_speex_decoder.c +++ b/src/libxineadec/xine_speex_decoder.c @@ -170,16 +170,16 @@ void read_metadata (speex_decoder_t *this, char * comments, int length)  #endif      for (i = 0; speex_comment_keys[i].key != NULL; i++) { +      size_t keylen = strlen(speex_comment_keys[i].key);        if ( !strncasecmp (speex_comment_keys[i].key, c, -			 strlen(speex_comment_keys[i].key)) ) { -	int keylen = strlen(speex_comment_keys[i].key); +			 keylen) ) {  	char meta_info[(len - keylen) + 1];  	lprintf ("known metadata %d %d\n",  		 i, speex_comment_keys[i].xine_metainfo_index); -	snprintf(meta_info, (len - keylen), "%s", c + keylen); +	strncpy(meta_info, &c[keylen], len-keylen);  	_x_meta_info_set_utf8(this->stream, speex_comment_keys[i].xine_metainfo_index, meta_info);        }      } diff --git a/src/xine-engine/load_plugins.c b/src/xine-engine/load_plugins.c index d08837dc5..09474082e 100644 --- a/src/xine-engine/load_plugins.c +++ b/src/xine-engine/load_plugins.c @@ -313,7 +313,6 @@ static void _insert_node (xine_t *this,    const input_info_t   *input_old;    uint32_t             *types;    char                  key[80]; -  char                  desc[100];    int                   i;    _x_assert(list); @@ -378,12 +377,11 @@ static void _insert_node (xine_t *this,      entry->priority = decoder_new->priority = decoder_old->priority;      snprintf(key, sizeof(key), "engine.decoder_priorities.%s", info->id); -    snprintf(desc, sizeof(desc), _("priority for %s decoder"), info->id);      /* write the description on the heap because the config system       * does not strdup() it, so we have to provide a different pointer       * for each decoder */      for (i = 0; catalog->prio_desc[i]; i++); -    catalog->prio_desc[i] = strdup(desc); +    asprintf(&catalog->prio_desc[i], _("priority for %s decoder"), info->id);      this->config->register_num (this->config,  				key,  				0, diff --git a/src/xine-engine/xine.c b/src/xine-engine/xine.c index fd10a7401..8c4ce8e4e 100644 --- a/src/xine-engine/xine.c +++ b/src/xine-engine/xine.c @@ -735,7 +735,7 @@ xine_stream_t *xine_stream_new (xine_t *this,  }  void _x_mrl_unescape(char *mrl) { -  int i, len = strlen(mrl); +  size_t i, len = strlen(mrl);    for (i = 0; i < len; i++) {      if ((mrl[i]=='%') && (i<(len-2))) { | 
