|  | @@ -31,8 +31,8 @@
 | 
	
		
			
				|  |  |  enum backup_type get_version ();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  /* FIXME: We should use a conversion routine that does reasonable error
 | 
	
		
			
				|  |  | -   checking -- atoi doesn't.  For now, punt.  */
 | 
	
		
			
				|  |  | -#define intconv	atoi
 | 
	
		
			
				|  |  | +   checking -- atol doesn't.  For now, punt.  */
 | 
	
		
			
				|  |  | +#define intconv	atol
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  time_t get_date ();
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -51,16 +51,17 @@ static void usage PARAMS ((int));
 | 
	
		
			
				|  |  |  /* Miscellaneous.  */
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  /*------------------------------------------------------------------------.
 | 
	
		
			
				|  |  | -| Check if STRING is the decimal representation of number, and return its |
 | 
	
		
			
				|  |  | -| value.  If not a decimal number, return -1.				  |
 | 
	
		
			
				|  |  | +| Check if STRING0 is the decimal representation of number, and store its |
 | 
	
		
			
				|  |  | +| value.  If not a decimal number, return 0.				  |
 | 
	
		
			
				|  |  |  `------------------------------------------------------------------------*/
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static int
 | 
	
		
			
				|  |  | -check_decimal (const char *string)
 | 
	
		
			
				|  |  | +check_decimal (const char *string0, uintmax_t *result)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | -  int value = -1;
 | 
	
		
			
				|  |  | +  const char *string = string0;
 | 
	
		
			
				|  |  | +  uintmax_t value = 0;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  while (*string)
 | 
	
		
			
				|  |  | +  do
 | 
	
		
			
				|  |  |      switch (*string)
 | 
	
		
			
				|  |  |        {
 | 
	
		
			
				|  |  |        case '0':
 | 
	
	
		
			
				|  | @@ -73,14 +74,22 @@ check_decimal (const char *string)
 | 
	
		
			
				|  |  |        case '7':
 | 
	
		
			
				|  |  |        case '8':
 | 
	
		
			
				|  |  |        case '9':
 | 
	
		
			
				|  |  | -	value = value < 0 ? *string - '0' : 10 * value + *string - '0';
 | 
	
		
			
				|  |  | -	string++;
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +	  uintmax_t v10 = value * 10;
 | 
	
		
			
				|  |  | +	  uintmax_t v10d = v10 + (*string - '0');
 | 
	
		
			
				|  |  | +	  if (v10 / 10 != value || v10d < v10)
 | 
	
		
			
				|  |  | +	    return 0;
 | 
	
		
			
				|  |  | +	  value = v10d;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  |  	break;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        default:
 | 
	
		
			
				|  |  | -	return -1;
 | 
	
		
			
				|  |  | +	return 0;
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  | -    return value;
 | 
	
		
			
				|  |  | +  while (*++string);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  *result = value;
 | 
	
		
			
				|  |  | +  return 1;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  /*----------------------------------------------.
 | 
	
	
		
			
				|  | @@ -580,7 +589,7 @@ decode_options (int argc, char *const *argv)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        case 'b':
 | 
	
		
			
				|  |  |  	blocking_factor = intconv (optarg);
 | 
	
		
			
				|  |  | -	record_size = blocking_factor * BLOCKSIZE;
 | 
	
		
			
				|  |  | +	record_size = blocking_factor * (size_t) BLOCKSIZE;
 | 
	
		
			
				|  |  |  	break;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        case OBSOLETE_READ_FULL_RECORDS:
 | 
	
	
		
			
				|  | @@ -836,10 +845,13 @@ decode_options (int argc, char *const *argv)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        case GROUP_OPTION:
 | 
	
		
			
				|  |  |  	if (!gname_to_gid (optarg, &group_option))
 | 
	
		
			
				|  |  | -	  if (!check_decimal (optarg) >= 0)
 | 
	
		
			
				|  |  | -	    ERROR ((TAREXIT_FAILURE, 0, _("Invalid group given on option")));
 | 
	
		
			
				|  |  | -	  else
 | 
	
		
			
				|  |  | -	    group_option = check_decimal (optarg);
 | 
	
		
			
				|  |  | +	  {
 | 
	
		
			
				|  |  | +	    uintmax_t g;
 | 
	
		
			
				|  |  | +	    if (!check_decimal (optarg, &g) || g != (gid_t) g)
 | 
	
		
			
				|  |  | +	      ERROR ((TAREXIT_FAILURE, 0, _("Invalid group given on option")));
 | 
	
		
			
				|  |  | +	    else
 | 
	
		
			
				|  |  | +	      group_option = g;
 | 
	
		
			
				|  |  | +	  }
 | 
	
		
			
				|  |  |  	break;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        case MODE_OPTION:
 | 
	
	
		
			
				|  | @@ -862,10 +874,13 @@ decode_options (int argc, char *const *argv)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        case OWNER_OPTION:
 | 
	
		
			
				|  |  |  	if (!uname_to_uid (optarg, &owner_option))
 | 
	
		
			
				|  |  | -	  if (!check_decimal (optarg) >= 0)
 | 
	
		
			
				|  |  | -	    ERROR ((TAREXIT_FAILURE, 0, _("Invalid owner given on option")));
 | 
	
		
			
				|  |  | -	  else
 | 
	
		
			
				|  |  | -	    owner_option = check_decimal (optarg);
 | 
	
		
			
				|  |  | +	  {
 | 
	
		
			
				|  |  | +	    uintmax_t u;
 | 
	
		
			
				|  |  | +	    if (!check_decimal (optarg, &u) || u != (uid_t) u)
 | 
	
		
			
				|  |  | +	      ERROR ((TAREXIT_FAILURE, 0, _("Invalid owner given on option")));
 | 
	
		
			
				|  |  | +	    else
 | 
	
		
			
				|  |  | +	      owner_option = u;
 | 
	
		
			
				|  |  | +	  }
 | 
	
		
			
				|  |  |  	break;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |        case POSIX_OPTION:
 |