Tidied NSNumber descriptions to conform to MacOS-X imnplementation

git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@11370 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
CaS 2001-11-12 12:09:40 +00:00
parent 0be4e1d7ac
commit 71cd221a69
5 changed files with 111 additions and 68 deletions

View file

@ -1158,7 +1158,8 @@ NSDictionary *locale)
{
long long int signed_number;
signed_number = args_value[specs[nspecs_done].data_arg].pa_long_long_int;
signed_number
= args_value[specs[nspecs_done].data_arg].pa_long_long_int;
is_negative = signed_number < 0;
number.longlong = is_negative ? (- signed_number) : signed_number;
@ -1169,10 +1170,24 @@ NSDictionary *locale)
{
long int signed_number;
if (is_long_num)
signed_number = args_value[specs[nspecs_done].data_arg].pa_long_int;
else
if (is_char)
{
signed_number = args_value[specs[nspecs_done].data_arg].pa_char;
}
else if (is_short)
{
signed_number
= args_value[specs[nspecs_done].data_arg].pa_short_int;
}
else if (is_long_num)
{
signed_number
= args_value[specs[nspecs_done].data_arg].pa_long_int;
}
else
{
signed_number = args_value[specs[nspecs_done].data_arg].pa_int;
}
is_negative = signed_number < 0;
number.word = is_negative ? (- signed_number) : signed_number;
@ -1207,7 +1222,8 @@ NSDictionary *locale)
if (is_longlong)
{
number.longlong = args_value[specs[nspecs_done].data_arg].pa_u_long_long_int;
number.longlong
= args_value[specs[nspecs_done].data_arg].pa_u_long_long_int;
LABEL (longlong_number):
if (prec < 0)
@ -1244,16 +1260,16 @@ NSDictionary *locale)
}
else
{
if (is_long_num)
number.word = args_value[specs[nspecs_done].data_arg].pa_u_long_int;
else if (is_char)
number.word = (unsigned char)
args_value[specs[nspecs_done].data_arg].pa_char;
else if (!is_short)
number.word = args_value[specs[nspecs_done].data_arg].pa_u_int;
else
number.word = (unsigned short int)
args_value[specs[nspecs_done].data_arg].pa_u_short_int;
if (is_long_num)
number.word = args_value[specs[nspecs_done].data_arg].pa_u_long_int;
else if (is_char)
number.word = (unsigned char)
args_value[specs[nspecs_done].data_arg].pa_char;
else if (!is_short)
number.word = args_value[specs[nspecs_done].data_arg].pa_u_int;
else
number.word = (unsigned short int)
args_value[specs[nspecs_done].data_arg].pa_u_short_int;
LABEL (number):
if (prec < 0)

View file

@ -40,55 +40,42 @@
defined to a number from 0 to 12 cooresponding to each number type */
#if TYPE_ORDER == 0
# define NumberTemplate NSBoolNumber
# define TYPE_FORMAT @"%u"
# define TYPE_TYPE BOOL
#elif TYPE_ORDER == 1
# define NumberTemplate NSCharNumber
# define TYPE_FORMAT @"%c"
# define TYPE_TYPE signed char
#elif TYPE_ORDER == 2
# define NumberTemplate NSUCharNumber
# define TYPE_FORMAT @"%c"
# define TYPE_TYPE unsigned char
#elif TYPE_ORDER == 3
# define NumberTemplate NSShortNumber
# define TYPE_FORMAT @"%hd"
# define TYPE_TYPE signed short
#elif TYPE_ORDER == 4
# define NumberTemplate NSUShortNumber
# define TYPE_FORMAT @"%hu"
# define TYPE_TYPE unsigned short
#elif TYPE_ORDER == 5
# define NumberTemplate NSIntNumber
# define TYPE_FORMAT @"%d"
# define TYPE_TYPE signed int
#elif TYPE_ORDER == 6
# define NumberTemplate NSUIntNumber
# define TYPE_FORMAT @"%u"
# define TYPE_TYPE unsigned int
#elif TYPE_ORDER == 7
# define NumberTemplate NSLongNumber
# define TYPE_FORMAT @"%ld"
# define TYPE_TYPE signed long
#elif TYPE_ORDER == 8
# define NumberTemplate NSULongNumber
# define TYPE_FORMAT @"%lu"
# define TYPE_TYPE unsigned long
#elif TYPE_ORDER == 9
# define NumberTemplate NSLongLongNumber
# define TYPE_FORMAT @"%lld"
# define TYPE_TYPE signed long long
#elif TYPE_ORDER == 10
# define NumberTemplate NSULongLongNumber
# define TYPE_FORMAT @"%llu"
# define TYPE_TYPE unsigned long long
#elif TYPE_ORDER == 11
# define NumberTemplate NSFloatNumber
# define TYPE_FORMAT @"%0.7f"
# define TYPE_TYPE float
#elif TYPE_ORDER == 12
# define NumberTemplate NSDoubleNumber
# define TYPE_FORMAT @"%0.16g"
# define TYPE_TYPE double
#endif
@ -389,9 +376,31 @@
- (NSString*) descriptionWithLocale: (NSDictionary*)locale
{
#if TYPE_ORDER == 0
return (data) ? @"YES" : @"NO";
#else
return [NSString stringWithFormat: TYPE_FORMAT, data];
return (data) ? @"true" : @"false";
#elif TYPE_ORDER == 1
return [NSString stringWithFormat: @"%i", (int)data];
#elif TYPE_ORDER == 2
return [NSString stringWithFormat: @"%u", (unsigned int)data];
#elif TYPE_ORDER == 3
return [NSString stringWithFormat: @"%hi", (short int)data];
#elif TYPE_ORDER == 4
return [NSString stringWithFormat: @"%hu", (unsigned short int)data];
#elif TYPE_ORDER == 5
return [NSString stringWithFormat: @"%i", data];
#elif TYPE_ORDER == 6
return [NSString stringWithFormat: @"%u", data];
#elif TYPE_ORDER == 7
return [NSString stringWithFormat: @"%li", data];
#elif TYPE_ORDER == 8
return [NSString stringWithFormat: @"%lu", data];
#elif TYPE_ORDER == 9
return [NSString stringWithFormat: @"%lli", data];
#elif TYPE_ORDER == 10
return [NSString stringWithFormat: @"%llu", data];
#elif TYPE_ORDER == 11
return [NSString stringWithFormat: @"%0.7g", (double)data];
#elif TYPE_ORDER == 12
return [NSString stringWithFormat: @"%0.16g", data];
#endif
}

View file

@ -679,42 +679,42 @@ static Class doubleNumberClass;
switch (info->typeLevel)
{
case 0:
return [self boolValue] ? @"YES" : @"NO";
return [self boolValue] ? @"true" : @"false";
case 1:
return [NSString stringWithFormat: @"%c",
[self charValue]];
return [NSString stringWithFormat: @"%i",
(int)[self charValue]];
case 2:
return [NSString stringWithFormat: @"%c",
[self unsignedCharValue]];
return [NSString stringWithFormat: @"%u",
(unsigned int)[self unsignedCharValue]];
case 3:
return [NSString stringWithFormat: @"%hd",
[self shortValue]];
return [NSString stringWithFormat: @"%hi",
(short int)[self shortValue]];
case 4:
return [NSString stringWithFormat: @"%hu",
[self unsignedShortValue]];
(unsigned short int)[self unsignedShortValue]];
case 5:
return [NSString stringWithFormat: @"%d",
return [NSString stringWithFormat: @"%i",
[self intValue]];
case 6:
return [NSString stringWithFormat: @"%u",
[self unsignedIntValue]];
case 7:
return [NSString stringWithFormat: @"%ld",
return [NSString stringWithFormat: @"%li",
[self longValue]];
case 8:
return [NSString stringWithFormat: @"%lu",
[self unsignedLongValue]];
case 9:
return [NSString stringWithFormat: @"%lld",
return [NSString stringWithFormat: @"%lli",
[self longLongValue]];
case 10:
return [NSString stringWithFormat: @"%llu",
[self unsignedLongLongValue]];
case 11:
return [NSString stringWithFormat: @"%f",
[self floatValue]];
return [NSString stringWithFormat: @"%0.7g",
(double)[self floatValue]];
case 12:
return [NSString stringWithFormat: @"%g",
return [NSString stringWithFormat: @"%0.16g",
[self doubleValue]];
default:
[NSException raise: NSInvalidArgumentException