Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
107ef617
Commit
107ef617
authored
Dec 03, 2004
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge baker@bk-internal.mysql.com:/home/bk/mysql-5.0/
into avenger.(none):/export/brian/mysql/acinclude-5.0
parents
ae9992ec
f09c8b35
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
240 additions
and
172 deletions
+240
-172
innobase/btr/btr0btr.c
innobase/btr/btr0btr.c
+3
-2
innobase/include/data0type.ic
innobase/include/data0type.ic
+18
-1
innobase/row/row0ins.c
innobase/row/row0ins.c
+9
-7
innobase/row/row0sel.c
innobase/row/row0sel.c
+2
-0
sql/ha_innodb.cc
sql/ha_innodb.cc
+19
-0
strings/decimal.c
strings/decimal.c
+189
-162
No files found.
innobase/btr/btr0btr.c
View file @
107ef617
...
@@ -2515,6 +2515,7 @@ btr_index_rec_validate(
...
@@ -2515,6 +2515,7 @@ btr_index_rec_validate(
for
(
i
=
0
;
i
<
n
;
i
++
)
{
for
(
i
=
0
;
i
<
n
;
i
++
)
{
dtype_t
*
type
=
dict_index_get_nth_type
(
index
,
i
);
dtype_t
*
type
=
dict_index_get_nth_type
(
index
,
i
);
ulint
fixed_size
=
dtype_get_fixed_size
(
type
);
rec_get_nth_field
(
rec
,
offsets
,
i
,
&
len
);
rec_get_nth_field
(
rec
,
offsets
,
i
,
&
len
);
...
@@ -2522,8 +2523,8 @@ btr_index_rec_validate(
...
@@ -2522,8 +2523,8 @@ btr_index_rec_validate(
their type is CHAR. */
their type is CHAR. */
if
((
dict_index_get_nth_field
(
index
,
i
)
->
prefix_len
==
0
if
((
dict_index_get_nth_field
(
index
,
i
)
->
prefix_len
==
0
&&
len
!=
UNIV_SQL_NULL
&&
dtype_is_fixed_size
(
type
)
&&
len
!=
UNIV_SQL_NULL
&&
fixed_size
&&
len
!=
dtype_get_fixed_size
(
type
)
)
&&
len
!=
fixed_size
)
||
||
(
dict_index_get_nth_field
(
index
,
i
)
->
prefix_len
>
0
(
dict_index_get_nth_field
(
index
,
i
)
->
prefix_len
>
0
&&
len
!=
UNIV_SQL_NULL
&&
len
!=
UNIV_SQL_NULL
...
...
innobase/include/data0type.ic
View file @
107ef617
...
@@ -8,6 +8,17 @@ Created 1/16/1996 Heikki Tuuri
...
@@ -8,6 +8,17 @@ Created 1/16/1996 Heikki Tuuri
#include "mach0data.h"
#include "mach0data.h"
/**********************************************************************
Determines whether the given character set is of variable length.
NOTE: the prototype of this function is copied from ha_innodb.cc! If you change
this function, you MUST change also the prototype here! */
extern
ibool
innobase_is_mb_cset(
/*================*/
ulint cset); /* in: MySQL charset-collation code */
/*************************************************************************
/*************************************************************************
Sets a data type structure. */
Sets a data type structure. */
UNIV_INLINE
UNIV_INLINE
...
@@ -293,7 +304,13 @@ dtype_get_fixed_size(
...
@@ -293,7 +304,13 @@ dtype_get_fixed_size(
case DATA_FLOAT:
case DATA_FLOAT:
case DATA_DOUBLE:
case DATA_DOUBLE:
case DATA_MYSQL:
case DATA_MYSQL:
if ((type->prtype & DATA_BINARY_TYPE)
|| !innobase_is_mb_cset(
dtype_get_charset_coll(
type->prtype))) {
return(dtype_get_len(type));
return(dtype_get_len(type));
}
/* fall through for variable-length charsets */
case DATA_VARCHAR:
case DATA_VARCHAR:
case DATA_BINARY:
case DATA_BINARY:
case DATA_DECIMAL:
case DATA_DECIMAL:
...
...
innobase/row/row0ins.c
View file @
107ef617
...
@@ -473,6 +473,8 @@ row_ins_cascade_calc_update_vec(
...
@@ -473,6 +473,8 @@ row_ins_cascade_calc_update_vec(
if
(
parent_ufield
->
field_no
==
parent_field_no
)
{
if
(
parent_ufield
->
field_no
==
parent_field_no
)
{
ulint
fixed_size
;
/* A field in the parent index record is
/* A field in the parent index record is
updated. Let us make the update vector
updated. Let us make the update vector
field for the child table. */
field for the child table. */
...
@@ -512,22 +514,22 @@ row_ins_cascade_calc_update_vec(
...
@@ -512,22 +514,22 @@ row_ins_cascade_calc_update_vec(
need to pad with spaces the new value of the
need to pad with spaces the new value of the
child column */
child column */
if
(
dtype_is_fixed_size
(
type
)
fixed_size
=
dtype_get_fixed_size
(
type
);
if
(
fixed_size
&&
ufield
->
new_val
.
len
!=
UNIV_SQL_NULL
&&
ufield
->
new_val
.
len
!=
UNIV_SQL_NULL
&&
ufield
->
new_val
.
len
&&
ufield
->
new_val
.
len
<
fixed_size
)
{
<
dtype_get_fixed_size
(
type
))
{
ufield
->
new_val
.
data
=
ufield
->
new_val
.
data
=
mem_heap_alloc
(
heap
,
mem_heap_alloc
(
heap
,
dtype_get_fixed_size
(
type
));
fixed_size
);
ufield
->
new_val
.
len
=
ufield
->
new_val
.
len
=
fixed_size
;
dtype_get_fixed_size
(
type
);
ut_a
(
dtype_get_pad_char
(
type
)
ut_a
(
dtype_get_pad_char
(
type
)
!=
ULINT_UNDEFINED
);
!=
ULINT_UNDEFINED
);
memset
(
ufield
->
new_val
.
data
,
memset
(
ufield
->
new_val
.
data
,
(
byte
)
dtype_get_pad_char
(
type
),
(
byte
)
dtype_get_pad_char
(
type
),
dtype_get_fixed_size
(
type
)
);
fixed_size
);
ut_memcpy
(
ufield
->
new_val
.
data
,
ut_memcpy
(
ufield
->
new_val
.
data
,
parent_ufield
->
new_val
.
data
,
parent_ufield
->
new_val
.
data
,
parent_ufield
->
new_val
.
len
);
parent_ufield
->
new_val
.
len
);
...
...
innobase/row/row0sel.c
View file @
107ef617
...
@@ -3694,6 +3694,8 @@ rec_loop:
...
@@ -3694,6 +3694,8 @@ rec_loop:
}
}
if
(
prebuilt
->
clust_index_was_generated
)
{
if
(
prebuilt
->
clust_index_was_generated
)
{
offsets
=
rec_reget_offsets
(
index_rec
,
index
,
offsets
,
ULINT_UNDEFINED
,
heap
);
row_sel_store_row_id_to_prebuilt
(
prebuilt
,
index_rec
,
row_sel_store_row_id_to_prebuilt
(
prebuilt
,
index_rec
,
index
,
offsets
);
index
,
offsets
);
}
}
...
...
sql/ha_innodb.cc
View file @
107ef617
...
@@ -520,6 +520,25 @@ innobase_mysql_print_thd(
...
@@ -520,6 +520,25 @@ innobase_mysql_print_thd(
putc
(
'\n'
,
f
);
putc
(
'\n'
,
f
);
}
}
/**********************************************************************
Determines whether the given character set is of variable length.
NOTE that the exact prototype of this function has to be in
/innobase/data/data0type.ic! */
extern
"C"
ibool
innobase_is_mb_cset
(
/*================*/
ulint
cset
)
/* in: MySQL charset-collation code */
{
CHARSET_INFO
*
cs
;
ut_ad
(
cset
<
256
);
cs
=
all_charsets
[
cset
];
return
(
cs
&&
cs
->
mbminlen
!=
cs
->
mbmaxlen
);
}
/**********************************************************************
/**********************************************************************
Compares NUL-terminated UTF-8 strings case insensitively.
Compares NUL-terminated UTF-8 strings case insensitively.
...
...
strings/decimal.c
View file @
107ef617
...
@@ -544,7 +544,7 @@ int decimal2longlong(decimal *from, longlong *to)
...
@@ -544,7 +544,7 @@ int decimal2longlong(decimal *from, longlong *to)
so we can convert -9223372036854775808 correctly
so we can convert -9223372036854775808 correctly
*/
*/
x
=
x
*
DIG_BASE
-
*
buf
++
;
x
=
x
*
DIG_BASE
-
*
buf
++
;
if
(
unlikely
(
y
<
(
LONGLONG_M
AX
/
DIG_BASE
)
||
x
>
y
))
if
(
unlikely
(
y
<
(
LONGLONG_M
IN
/
DIG_BASE
)
||
x
>
y
))
{
{
*
to
=
from
->
sign
?
y
:
-
y
;
*
to
=
from
->
sign
?
y
:
-
y
;
return
E_DEC_OVERFLOW
;
return
E_DEC_OVERFLOW
;
...
@@ -921,6 +921,12 @@ int decimal_round(decimal *from, decimal *to, int scale, decimal_round_mode mode
...
@@ -921,6 +921,12 @@ int decimal_round(decimal *from, decimal *to, int scale, decimal_round_mode mode
x
+=
10
;
x
+=
10
;
*
buf1
=
powers10
[
pos
]
*
(
x
-
y
);
*
buf1
=
powers10
[
pos
]
*
(
x
-
y
);
}
}
if
(
frac0
<
0
)
{
dec1
*
end
=
to
->
buf
+
intg0
,
*
buf
=
buf1
+
1
;
while
(
buf
<
end
)
*
buf
++=
0
;
}
if
(
*
buf1
>=
DIG_BASE
)
if
(
*
buf1
>=
DIG_BASE
)
{
{
carry
=
1
;
carry
=
1
;
...
@@ -1647,7 +1653,7 @@ void dump_decimal(decimal *d)
...
@@ -1647,7 +1653,7 @@ void dump_decimal(decimal *d)
printf
(
"%09d} */ "
,
d
->
buf
[
i
]);
printf
(
"%09d} */ "
,
d
->
buf
[
i
]);
}
}
void
print_decimal
(
decimal
*
d
)
void
print_decimal
(
decimal
*
d
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
slen
=
sizeof
(
s
);
int
slen
=
sizeof
(
s
);
...
@@ -1655,6 +1661,11 @@ void print_decimal(decimal *d)
...
@@ -1655,6 +1661,11 @@ void print_decimal(decimal *d)
if
(
full
)
dump_decimal
(
d
);
if
(
full
)
dump_decimal
(
d
);
decimal2string
(
d
,
s
,
&
slen
);
decimal2string
(
d
,
s
,
&
slen
);
printf
(
"'%s'"
,
s
);
printf
(
"'%s'"
,
s
);
if
(
orig
&&
strcmp
(
orig
,
s
))
{
printf
(
"
\n
^^^^^^^^^^^^^ must've been '%s'
\n
"
,
orig
);
exit
(
1
);
}
}
}
void
test_d2s
()
void
test_d2s
()
...
@@ -1693,12 +1704,12 @@ void test_d2s()
...
@@ -1693,12 +1704,12 @@ void test_d2s()
dump_decimal
(
&
a
);
printf
(
" --> res=%d str='%s' len=%d
\n
"
,
res
,
s
,
slen
);
dump_decimal
(
&
a
);
printf
(
" --> res=%d str='%s' len=%d
\n
"
,
res
,
s
,
slen
);
}
}
void
test_s2d
(
char
*
s
)
void
test_s2d
(
char
*
s
,
char
*
orig
)
{
{
char
s1
[
100
];
char
s1
[
100
];
sprintf
(
s1
,
"'%s'"
,
s
);
sprintf
(
s1
,
"'%s'"
,
s
);
printf
(
"len=%2d %-30s => res=%d "
,
a
.
len
,
s1
,
string2decimal
(
s
,
&
a
,
0
));
printf
(
"len=%2d %-30s => res=%d "
,
a
.
len
,
s1
,
string2decimal
(
s
,
&
a
,
0
));
print_decimal
(
&
a
);
print_decimal
(
&
a
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
...
@@ -1715,7 +1726,7 @@ void test_d2f(char *s)
...
@@ -1715,7 +1726,7 @@ void test_d2f(char *s)
printf
(
"%-40s => res=%d %.*g
\n
"
,
s1
,
res
,
a
.
intg
+
a
.
frac
,
x
);
printf
(
"%-40s => res=%d %.*g
\n
"
,
s1
,
res
,
a
.
intg
+
a
.
frac
,
x
);
}
}
void
test_d2b2d
(
char
*
str
,
int
p
,
int
s
)
void
test_d2b2d
(
char
*
str
,
int
p
,
int
s
,
char
*
orig
)
{
{
char
s1
[
100
],
buf
[
100
];
char
s1
[
100
],
buf
[
100
];
double
x
;
double
x
;
...
@@ -1733,7 +1744,7 @@ void test_d2b2d(char *str, int p, int s)
...
@@ -1733,7 +1744,7 @@ void test_d2b2d(char *str, int p, int s)
}
}
res
=
bin2decimal
(
buf
,
&
a
,
p
,
s
);
res
=
bin2decimal
(
buf
,
&
a
,
p
,
s
);
printf
(
" => res=%d "
,
res
);
printf
(
" => res=%d "
,
res
);
print_decimal
(
&
a
);
print_decimal
(
&
a
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_f2d
(
double
from
)
void
test_f2d
(
double
from
)
...
@@ -1742,11 +1753,11 @@ void test_f2d(double from)
...
@@ -1742,11 +1753,11 @@ void test_f2d(double from)
res
=
double2decimal
(
from
,
&
a
);
res
=
double2decimal
(
from
,
&
a
);
printf
(
"%-40.*f => res=%d "
,
DBL_DIG
-
2
,
from
,
res
);
printf
(
"%-40.*f => res=%d "
,
DBL_DIG
-
2
,
from
,
res
);
print_decimal
(
&
a
);
print_decimal
(
&
a
,
0
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_ull2d
(
ulonglong
from
)
void
test_ull2d
(
ulonglong
from
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1754,11 +1765,11 @@ void test_ull2d(ulonglong from)
...
@@ -1754,11 +1765,11 @@ void test_ull2d(ulonglong from)
res
=
ulonglong2decimal
(
from
,
&
a
);
res
=
ulonglong2decimal
(
from
,
&
a
);
longlong10_to_str
(
from
,
s
,
10
);
longlong10_to_str
(
from
,
s
,
10
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
print_decimal
(
&
a
);
print_decimal
(
&
a
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_ll2d
(
longlong
from
)
void
test_ll2d
(
longlong
from
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1766,11 +1777,11 @@ void test_ll2d(longlong from)
...
@@ -1766,11 +1777,11 @@ void test_ll2d(longlong from)
res
=
longlong2decimal
(
from
,
&
a
);
res
=
longlong2decimal
(
from
,
&
a
);
longlong10_to_str
(
from
,
s
,
-
10
);
longlong10_to_str
(
from
,
s
,
-
10
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
print_decimal
(
&
a
);
print_decimal
(
&
a
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_d2ull
(
char
*
s
)
void
test_d2ull
(
char
*
s
,
char
*
orig
)
{
{
char
s1
[
100
];
char
s1
[
100
];
ulonglong
x
;
ulonglong
x
;
...
@@ -1781,9 +1792,14 @@ void test_d2ull(char *s)
...
@@ -1781,9 +1792,14 @@ void test_d2ull(char *s)
if
(
full
)
dump_decimal
(
&
a
);
if
(
full
)
dump_decimal
(
&
a
);
longlong10_to_str
(
x
,
s1
,
10
);
longlong10_to_str
(
x
,
s1
,
10
);
printf
(
"%-40s => res=%d %s
\n
"
,
s
,
res
,
s1
);
printf
(
"%-40s => res=%d %s
\n
"
,
s
,
res
,
s1
);
if
(
orig
&&
strcmp
(
orig
,
s1
))
{
printf
(
"
\n
^^^^^^^^^^^^^ must've been '%s'
\n
"
,
orig
);
exit
(
1
);
}
}
}
void
test_d2ll
(
char
*
s
)
void
test_d2ll
(
char
*
s
,
char
*
orig
)
{
{
char
s1
[
100
];
char
s1
[
100
];
longlong
x
;
longlong
x
;
...
@@ -1794,9 +1810,14 @@ void test_d2ll(char *s)
...
@@ -1794,9 +1810,14 @@ void test_d2ll(char *s)
if
(
full
)
dump_decimal
(
&
a
);
if
(
full
)
dump_decimal
(
&
a
);
longlong10_to_str
(
x
,
s1
,
-
10
);
longlong10_to_str
(
x
,
s1
,
-
10
);
printf
(
"%-40s => res=%d %s
\n
"
,
s
,
res
,
s1
);
printf
(
"%-40s => res=%d %s
\n
"
,
s
,
res
,
s1
);
if
(
orig
&&
strcmp
(
orig
,
s1
))
{
printf
(
"
\n
^^^^^^^^^^^^^ must've been '%s'
\n
"
,
orig
);
exit
(
1
);
}
}
}
void
test_da
(
char
*
s1
,
char
*
s2
)
void
test_da
(
char
*
s1
,
char
*
s2
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1805,11 +1826,11 @@ void test_da(char *s1, char *s2)
...
@@ -1805,11 +1826,11 @@ void test_da(char *s1, char *s2)
string2decimal
(
s2
,
&
b
,
0
);
string2decimal
(
s2
,
&
b
,
0
);
res
=
decimal_add
(
&
a
,
&
b
,
&
c
);
res
=
decimal_add
(
&
a
,
&
b
,
&
c
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
print_decimal
(
&
c
);
print_decimal
(
&
c
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_ds
(
char
*
s1
,
char
*
s2
)
void
test_ds
(
char
*
s1
,
char
*
s2
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1818,11 +1839,11 @@ void test_ds(char *s1, char *s2)
...
@@ -1818,11 +1839,11 @@ void test_ds(char *s1, char *s2)
string2decimal
(
s2
,
&
b
,
0
);
string2decimal
(
s2
,
&
b
,
0
);
res
=
decimal_sub
(
&
a
,
&
b
,
&
c
);
res
=
decimal_sub
(
&
a
,
&
b
,
&
c
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
print_decimal
(
&
c
);
print_decimal
(
&
c
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_dc
(
char
*
s1
,
char
*
s2
)
void
test_dc
(
char
*
s1
,
char
*
s2
,
int
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1831,9 +1852,14 @@ void test_dc(char *s1, char *s2)
...
@@ -1831,9 +1852,14 @@ void test_dc(char *s1, char *s2)
string2decimal
(
s2
,
&
b
,
0
);
string2decimal
(
s2
,
&
b
,
0
);
res
=
decimal_cmp
(
&
a
,
&
b
);
res
=
decimal_cmp
(
&
a
,
&
b
);
printf
(
"%-40s => res=%d
\n
"
,
s
,
res
);
printf
(
"%-40s => res=%d
\n
"
,
s
,
res
);
if
(
orig
!=
res
)
{
printf
(
"
\n
^^^^^^^^^^^^^ must've been %d
\n
"
,
orig
);
exit
(
1
);
}
}
}
void
test_dm
(
char
*
s1
,
char
*
s2
)
void
test_dm
(
char
*
s1
,
char
*
s2
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1842,11 +1868,11 @@ void test_dm(char *s1, char *s2)
...
@@ -1842,11 +1868,11 @@ void test_dm(char *s1, char *s2)
string2decimal
(
s2
,
&
b
,
0
);
string2decimal
(
s2
,
&
b
,
0
);
res
=
decimal_mul
(
&
a
,
&
b
,
&
c
);
res
=
decimal_mul
(
&
a
,
&
b
,
&
c
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
print_decimal
(
&
c
);
print_decimal
(
&
c
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_dv
(
char
*
s1
,
char
*
s2
)
void
test_dv
(
char
*
s1
,
char
*
s2
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1858,11 +1884,11 @@ void test_dv(char *s1, char *s2)
...
@@ -1858,11 +1884,11 @@ void test_dv(char *s1, char *s2)
if
(
res
==
E_DEC_DIV_ZERO
)
if
(
res
==
E_DEC_DIV_ZERO
)
printf
(
"E_DEC_DIV_ZERO"
);
printf
(
"E_DEC_DIV_ZERO"
);
else
else
print_decimal
(
&
c
);
print_decimal
(
&
c
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
void
test_md
(
char
*
s1
,
char
*
s2
)
void
test_md
(
char
*
s1
,
char
*
s2
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1874,13 +1900,13 @@ void test_md(char *s1, char *s2)
...
@@ -1874,13 +1900,13 @@ void test_md(char *s1, char *s2)
if
(
res
==
E_DEC_DIV_ZERO
)
if
(
res
==
E_DEC_DIV_ZERO
)
printf
(
"E_DEC_DIV_ZERO"
);
printf
(
"E_DEC_DIV_ZERO"
);
else
else
print_decimal
(
&
c
);
print_decimal
(
&
c
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
char
*
round_mode
[]
=
{
"TRUNCATE"
,
"HALF_EVEN"
,
"HALF_UP"
,
"CEILING"
,
"FLOOR"
};
char
*
round_mode
[]
=
{
"TRUNCATE"
,
"HALF_EVEN"
,
"HALF_UP"
,
"CEILING"
,
"FLOOR"
};
void
test_ro
(
char
*
s1
,
int
n
,
decimal_round_mode
mode
)
void
test_ro
(
char
*
s1
,
int
n
,
decimal_round_mode
mode
,
char
*
orig
)
{
{
char
s
[
100
];
char
s
[
100
];
int
res
;
int
res
;
...
@@ -1888,7 +1914,7 @@ void test_ro(char *s1, int n, decimal_round_mode mode)
...
@@ -1888,7 +1914,7 @@ void test_ro(char *s1, int n, decimal_round_mode mode)
string2decimal
(
s1
,
&
a
,
0
);
string2decimal
(
s1
,
&
a
,
0
);
res
=
decimal_round
(
&
a
,
&
b
,
n
,
mode
);
res
=
decimal_round
(
&
a
,
&
b
,
n
,
mode
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
printf
(
"%-40s => res=%d "
,
s
,
res
);
print_decimal
(
&
b
);
print_decimal
(
&
b
,
orig
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
...
@@ -1905,17 +1931,17 @@ main()
...
@@ -1905,17 +1931,17 @@ main()
test_d2s
();
test_d2s
();
printf
(
"==== string2decimal ====
\n
"
);
printf
(
"==== string2decimal ====
\n
"
);
test_s2d
(
"12345"
);
test_s2d
(
"12345"
,
"12345"
);
test_s2d
(
"12345."
);
test_s2d
(
"12345."
,
"12345"
);
test_s2d
(
"123.45"
);
test_s2d
(
"123.45"
,
"123.45"
);
test_s2d
(
"-123.45"
);
test_s2d
(
"-123.45"
,
"-123.45"
);
test_s2d
(
".00012345000098765"
);
test_s2d
(
".00012345000098765"
,
".00012345000098765"
);
test_s2d
(
".12345000098765"
);
test_s2d
(
".12345000098765"
,
".12345000098765"
);
test_s2d
(
"-.000000012345000098765"
);
test_s2d
(
"-.000000012345000098765"
,
"-.000000012345000098765"
);
test_s2d
(
"1234500009876.5"
);
test_s2d
(
"1234500009876.5"
,
"1234500009876.5"
);
a
.
len
=
1
;
a
.
len
=
1
;
test_s2d
(
"123450000098765"
);
test_s2d
(
"123450000098765"
,
"98765"
);
test_s2d
(
"123450.000098765"
);
test_s2d
(
"123450.000098765"
,
"123450"
);
a
.
len
=
sizeof
(
buf1
)
/
sizeof
(
dec1
);
a
.
len
=
sizeof
(
buf1
)
/
sizeof
(
dec1
);
printf
(
"==== decimal2double ====
\n
"
);
printf
(
"==== decimal2double ====
\n
"
);
...
@@ -1933,159 +1959,160 @@ main()
...
@@ -1933,159 +1959,160 @@ main()
test_f2d
(
1234500009876
.
5
);
test_f2d
(
1234500009876
.
5
);
printf
(
"==== ulonglong2decimal ====
\n
"
);
printf
(
"==== ulonglong2decimal ====
\n
"
);
test_ull2d
(
ULL
(
12345
));
test_ull2d
(
ULL
(
12345
)
,
"12345"
);
test_ull2d
(
ULL
(
0
));
test_ull2d
(
ULL
(
0
)
,
"0"
);
test_ull2d
(
ULL
(
18446744073709551615
));
test_ull2d
(
ULL
(
18446744073709551615
)
,
"18446744073709551615"
);
printf
(
"==== decimal2ulonglong ====
\n
"
);
printf
(
"==== decimal2ulonglong ====
\n
"
);
test_d2ull
(
"12345"
);
test_d2ull
(
"12345"
,
"12345"
);
test_d2ull
(
"0"
);
test_d2ull
(
"0"
,
"0"
);
test_d2ull
(
"18446744073709551615"
);
test_d2ull
(
"18446744073709551615"
,
"18446744073709551615"
);
test_d2ull
(
"18446744073709551616"
);
test_d2ull
(
"18446744073709551616"
,
"18446744073"
);
test_d2ull
(
"-1"
);
test_d2ull
(
"-1"
,
"0"
);
test_d2ull
(
"1.23"
);
test_d2ull
(
"1.23"
,
"1"
);
test_d2ull
(
"9999999999999999999999999.000"
);
test_d2ull
(
"9999999999999999999999999.000"
,
"9999999999999999"
);
printf
(
"==== longlong2decimal ====
\n
"
);
printf
(
"==== longlong2decimal ====
\n
"
);
test_ll2d
(
LL
(
-
12345
));
test_ll2d
(
LL
(
-
12345
)
,
"-12345"
);
test_ll2d
(
LL
(
-
1
));
test_ll2d
(
LL
(
-
1
)
,
"-1"
);
test_ll2d
(
LL
(
-
9223372036854775807
));
test_ll2d
(
LL
(
-
9223372036854775807
)
,
"-9223372036854775807"
);
test_ll2d
(
ULL
(
9223372036854775808
));
test_ll2d
(
ULL
(
9223372036854775808
)
,
"-9223372036854775808"
);
printf
(
"==== decimal2longlong ====
\n
"
);
printf
(
"==== decimal2longlong ====
\n
"
);
test_d2ll
(
"18446744073709551615"
);
test_d2ll
(
"18446744073709551615"
,
"18446744073"
);
test_d2ll
(
"-1"
);
test_d2ll
(
"-1"
,
"-1"
);
test_d2ll
(
"-1.23"
);
test_d2ll
(
"-1.23"
,
"-1"
);
test_d2ll
(
"-9223372036854775807"
);
test_d2ll
(
"-9223372036854775807"
,
"-9223372036854775807"
);
test_d2ll
(
"-9223372036854775808"
);
test_d2ll
(
"-9223372036854775808"
,
"-9223372036854775808"
);
test_d2ll
(
"9223372036854775808"
);
test_d2ll
(
"9223372036854775808"
,
"9223372036854775807"
);
printf
(
"==== do_add ====
\n
"
);
printf
(
"==== do_add ====
\n
"
);
test_da
(
".00012345000098765"
,
"123.45"
);
test_da
(
".00012345000098765"
,
"123.45"
,
"123.45012345000098765"
);
test_da
(
".1"
,
".45"
);
test_da
(
".1"
,
".45"
,
".55"
);
test_da
(
"1234500009876.5"
,
".00012345000098765"
);
test_da
(
"1234500009876.5"
,
".00012345000098765"
,
"1234500009876.50012345000098765"
);
test_da
(
"9999909999999.5"
,
".555"
);
test_da
(
"9999909999999.5"
,
".555"
,
"9999910000000.055"
);
test_da
(
"99999999"
,
"1"
);
test_da
(
"99999999"
,
"1"
,
"100000000"
);
test_da
(
"989999999"
,
"1"
);
test_da
(
"989999999"
,
"1"
,
"990000000"
);
test_da
(
"999999999"
,
"1"
);
test_da
(
"999999999"
,
"1"
,
"1000000000"
);
test_da
(
"12345"
,
"123.45"
);
test_da
(
"12345"
,
"123.45"
,
"12468.45"
);
test_da
(
"-12345"
,
"-123.45"
);
test_da
(
"-12345"
,
"-123.45"
,
"-12468.45"
);
test_ds
(
"-12345"
,
"123.45"
);
test_ds
(
"-12345"
,
"123.45"
,
"-12468.45"
);
test_ds
(
"12345"
,
"-123.45"
);
test_ds
(
"12345"
,
"-123.45"
,
"12468.45"
);
printf
(
"==== do_sub ====
\n
"
);
printf
(
"==== do_sub ====
\n
"
);
test_ds
(
".00012345000098765"
,
"123.45"
);
test_ds
(
".00012345000098765"
,
"123.45"
,
"-123.44987654999901235"
);
test_ds
(
"1234500009876.5"
,
".00012345000098765"
);
test_ds
(
"1234500009876.5"
,
".00012345000098765"
,
"1234500009876.49987654999901235"
);
test_ds
(
"9999900000000.5"
,
".555"
);
test_ds
(
"9999900000000.5"
,
".555"
,
"9999899999999.945"
);
test_ds
(
"1111.5551"
,
"1111.555"
);
test_ds
(
"1111.5551"
,
"1111.555"
,
".0001"
);
test_ds
(
".555"
,
".555"
);
test_ds
(
".555"
,
".555"
,
"0"
);
test_ds
(
"10000000"
,
"1"
);
test_ds
(
"10000000"
,
"1"
,
"9999999"
);
test_ds
(
"1000001000"
,
".1"
);
test_ds
(
"1000001000"
,
".1"
,
"1000000999.9"
);
test_ds
(
"1000000000"
,
".1"
);
test_ds
(
"1000000000"
,
".1"
,
"999999999.9"
);
test_ds
(
"12345"
,
"123.45"
);
test_ds
(
"12345"
,
"123.45"
,
"12221.55"
);
test_ds
(
"-12345"
,
"-123.45"
);
test_ds
(
"-12345"
,
"-123.45"
,
"-12221.55"
);
test_da
(
"-12345"
,
"123.45"
);
test_da
(
"-12345"
,
"123.45"
,
"-12221.55"
);
test_da
(
"12345"
,
"-123.45"
);
test_da
(
"12345"
,
"-123.45"
,
"12221.55"
);
test_ds
(
"123.45"
,
"12345"
);
test_ds
(
"123.45"
,
"12345"
,
"-12221.55"
);
test_ds
(
"-123.45"
,
"-12345"
);
test_ds
(
"-123.45"
,
"-12345"
,
"12221.55"
);
test_da
(
"123.45"
,
"-12345"
);
test_da
(
"123.45"
,
"-12345"
,
"-12221.55"
);
test_da
(
"-123.45"
,
"12345"
);
test_da
(
"-123.45"
,
"12345"
,
"12221.55"
);
test_da
(
"5"
,
"-6.0"
);
test_da
(
"5"
,
"-6.0"
,
"-1.0"
);
printf
(
"==== decimal_mul ====
\n
"
);
printf
(
"==== decimal_mul ====
\n
"
);
test_dm
(
"12"
,
"10"
);
test_dm
(
"12"
,
"10"
,
"120"
);
test_dm
(
"-123.456"
,
"98765.4321"
);
test_dm
(
"-123.456"
,
"98765.4321"
,
"-12193185.1853376"
);
test_dm
(
"-123456000000"
,
"98765432100000"
);
test_dm
(
"-123456000000"
,
"98765432100000"
,
"-12193185185337600000000000"
);
test_dm
(
"123456"
,
"987654321"
);
test_dm
(
"123456"
,
"987654321"
,
"121931851853376"
);
test_dm
(
"123456"
,
"9876543210"
);
test_dm
(
"123456"
,
"9876543210"
,
"1219318518533760"
);
test_dm
(
"123"
,
"0.01"
);
test_dm
(
"123"
,
"0.01"
,
"1.23"
);
test_dm
(
"123"
,
"0"
);
test_dm
(
"123"
,
"0"
,
"0"
);
printf
(
"==== decimal_div ====
\n
"
);
printf
(
"==== decimal_div ====
\n
"
);
test_dv
(
"120"
,
"10"
);
test_dv
(
"120"
,
"10"
,
"12.000000000"
);
test_dv
(
"123"
,
"0.01"
);
test_dv
(
"123"
,
"0.01"
,
"12300.000000000"
);
test_dv
(
"120"
,
"100000000000.00000"
);
test_dv
(
"120"
,
"100000000000.00000"
,
".000000001200000000"
);
test_dv
(
"123"
,
"0"
);
test_dv
(
"123"
,
"0"
,
""
);
test_dv
(
"-12193185.1853376"
,
"98765.4321"
);
test_dv
(
"-12193185.1853376"
,
"98765.4321"
,
"-123.456000000000000000"
);
test_dv
(
"121931851853376"
,
"987654321"
);
test_dv
(
"121931851853376"
,
"987654321"
,
"123456.000000000"
);
test_dv
(
"0"
,
"987"
);
test_dv
(
"0"
,
"987"
,
"0"
);
test_dv
(
"1"
,
"3"
);
test_dv
(
"1"
,
"3"
,
".333333333"
);
test_dv
(
"1.000000000000"
,
"3"
);
test_dv
(
"1.000000000000"
,
"3"
,
".333333333333333333"
);
test_dv
(
"1"
,
"1"
);
test_dv
(
"1"
,
"1"
,
"1.000000000"
);
test_dv
(
"0.0123456789012345678912345"
,
"9999999999"
);
test_dv
(
"0.0123456789012345678912345"
,
"9999999999"
,
".000000000001234567890246913578148141"
);
printf
(
"==== decimal_mod ====
\n
"
);
printf
(
"==== decimal_mod ====
\n
"
);
test_md
(
"234"
,
"10"
);
test_md
(
"234"
,
"10"
,
"4"
);
test_md
(
"234.567"
,
"10.555"
);
test_md
(
"234.567"
,
"10.555"
,
"2.357"
);
test_md
(
"-234.567"
,
"10.555"
);
test_md
(
"-234.567"
,
"10.555"
,
"-2.357"
);
test_md
(
"234.567"
,
"-10.555"
);
test_md
(
"234.567"
,
"-10.555"
,
"2.357"
);
if
(
full
)
if
(
full
)
{
{
c
.
buf
[
1
]
=
0x3ABECA
;
c
.
buf
[
1
]
=
0x3ABECA
;
test_md
(
"99999999999999999999999999999999999999"
,
"3"
);
test_md
(
"99999999999999999999999999999999999999"
,
"3"
,
"0"
);
printf
(
"%X
\n
"
,
c
.
buf
[
1
]);
printf
(
"%X
\n
"
,
c
.
buf
[
1
]);
}
}
printf
(
"==== decimal2bin/bin2decimal ====
\n
"
);
printf
(
"==== decimal2bin/bin2decimal ====
\n
"
);
test_d2b2d
(
"-10.55"
,
4
,
2
);
test_d2b2d
(
"-10.55"
,
4
,
2
,
"-10.55"
);
test_d2b2d
(
"0.0123456789012345678912345"
,
30
,
25
);
test_d2b2d
(
"0.0123456789012345678912345"
,
30
,
25
,
".0123456789012345678912345"
);
test_d2b2d
(
"12345"
,
5
,
0
);
test_d2b2d
(
"12345"
,
5
,
0
,
"12345"
);
test_d2b2d
(
"12345"
,
10
,
3
);
test_d2b2d
(
"12345"
,
10
,
3
,
"12345.000"
);
test_d2b2d
(
"123.45"
,
10
,
3
);
test_d2b2d
(
"123.45"
,
10
,
3
,
"123.450"
);
test_d2b2d
(
"-123.45"
,
20
,
10
);
test_d2b2d
(
"-123.45"
,
20
,
10
,
"-123.4500000000"
);
test_d2b2d
(
".00012345000098765"
,
15
,
14
);
test_d2b2d
(
".00012345000098765"
,
15
,
14
,
".00012345000098"
);
test_d2b2d
(
".00012345000098765"
,
22
,
20
);
test_d2b2d
(
".00012345000098765"
,
22
,
20
,
".00012345000098765000"
);
test_d2b2d
(
".12345000098765"
,
30
,
20
);
test_d2b2d
(
".12345000098765"
,
30
,
20
,
".12345000098765000000"
);
test_d2b2d
(
"-.000000012345000098765"
,
30
,
20
);
test_d2b2d
(
"-.000000012345000098765"
,
30
,
20
,
"-.00000001234500009876"
);
test_d2b2d
(
"1234500009876.5"
,
30
,
5
);
test_d2b2d
(
"1234500009876.5"
,
30
,
5
,
"1234500009876.50000"
);
test_d2b2d
(
"111111111.11"
,
10
,
2
);
test_d2b2d
(
"111111111.11"
,
10
,
2
,
"11111111.11"
);
printf
(
"==== decimal_cmp ====
\n
"
);
printf
(
"==== decimal_cmp ====
\n
"
);
test_dc
(
"12"
,
"13"
);
test_dc
(
"12"
,
"13"
,
-
1
);
test_dc
(
"13"
,
"12"
);
test_dc
(
"13"
,
"12"
,
1
);
test_dc
(
"-10"
,
"10"
);
test_dc
(
"-10"
,
"10"
,
-
1
);
test_dc
(
"10"
,
"-10"
);
test_dc
(
"10"
,
"-10"
,
1
);
test_dc
(
"-12"
,
"-13"
);
test_dc
(
"-12"
,
"-13"
,
1
);
test_dc
(
"0"
,
"12"
);
test_dc
(
"0"
,
"12"
,
-
1
);
test_dc
(
"-10"
,
"0"
);
test_dc
(
"-10"
,
"0"
,
-
1
);
test_dc
(
"4"
,
"4"
);
test_dc
(
"4"
,
"4"
,
0
);
printf
(
"==== decimal_round ====
\n
"
);
printf
(
"==== decimal_round ====
\n
"
);
test_ro
(
"5678.123451"
,
-
4
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
-
4
,
TRUNCATE
,
"0"
);
test_ro
(
"5678.123451"
,
-
3
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
-
3
,
TRUNCATE
,
"5000"
);
test_ro
(
"5678.123451"
,
-
2
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
-
2
,
TRUNCATE
,
"5600"
);
test_ro
(
"5678.123451"
,
-
1
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
-
1
,
TRUNCATE
,
"5670"
);
test_ro
(
"5678.123451"
,
0
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
0
,
TRUNCATE
,
"5678"
);
test_ro
(
"5678.123451"
,
1
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
1
,
TRUNCATE
,
"5678.1"
);
test_ro
(
"5678.123451"
,
2
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
2
,
TRUNCATE
,
"5678.12"
);
test_ro
(
"5678.123451"
,
3
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
3
,
TRUNCATE
,
"5678.123"
);
test_ro
(
"5678.123451"
,
4
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
4
,
TRUNCATE
,
"5678.1234"
);
test_ro
(
"5678.123451"
,
5
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
5
,
TRUNCATE
,
"5678.12345"
);
test_ro
(
"5678.123451"
,
6
,
TRUNCATE
);
test_ro
(
"5678.123451"
,
6
,
TRUNCATE
,
"5678.123451"
);
test_ro
(
"-5678.123451"
,
-
4
,
TRUNCATE
);
test_ro
(
"-5678.123451"
,
-
4
,
TRUNCATE
,
"0"
);
test_ro
(
"99999999999999999999999999999999999999"
,
-
31
,
TRUNCATE
);
memset
(
buf2
,
33
,
sizeof
(
buf2
));
test_ro
(
"15.1"
,
0
,
HALF_UP
);
test_ro
(
"99999999999999999999999999999999999999"
,
-
31
,
TRUNCATE
,
"99999990000000000000000000000000000000"
);
test_ro
(
"15.5"
,
0
,
HALF_UP
);
test_ro
(
"15.1"
,
0
,
HALF_UP
,
"15"
);
test_ro
(
"15.9"
,
0
,
HALF_UP
);
test_ro
(
"15.5"
,
0
,
HALF_UP
,
"16"
);
test_ro
(
"-15.1"
,
0
,
HALF_UP
);
test_ro
(
"15.9"
,
0
,
HALF_UP
,
"16"
);
test_ro
(
"-15.5"
,
0
,
HALF_UP
);
test_ro
(
"-15.1"
,
0
,
HALF_UP
,
"-15"
);
test_ro
(
"-15.9"
,
0
,
HALF_UP
);
test_ro
(
"-15.5"
,
0
,
HALF_UP
,
"-16"
);
test_ro
(
"15.1"
,
1
,
HALF_UP
);
test_ro
(
"-15.9"
,
0
,
HALF_UP
,
"-16"
);
test_ro
(
"-15.1"
,
1
,
HALF_UP
);
test_ro
(
"15.1"
,
1
,
HALF_UP
,
"15.1"
);
test_ro
(
"15.17"
,
1
,
HALF_UP
);
test_ro
(
"-15.1"
,
1
,
HALF_UP
,
"-15.1"
);
test_ro
(
"15.4"
,
-
1
,
HALF_UP
);
test_ro
(
"15.17"
,
1
,
HALF_UP
,
"15.2"
);
test_ro
(
"-15.4"
,
-
1
,
HALF_UP
);
test_ro
(
"15.4"
,
-
1
,
HALF_UP
,
"20"
);
test_ro
(
"5.4"
,
-
1
,
HALF_UP
);
test_ro
(
"-15.4"
,
-
1
,
HALF_UP
,
"-20"
);
test_ro
(
"15.1"
,
0
,
HALF_EVEN
);
test_ro
(
"5.4"
,
-
1
,
HALF_UP
,
"10"
);
test_ro
(
"15.5"
,
0
,
HALF_EVEN
);
test_ro
(
"15.1"
,
0
,
HALF_EVEN
,
"15"
);
test_ro
(
"14.5"
,
0
,
HALF_EVEN
);
test_ro
(
"15.5"
,
0
,
HALF_EVEN
,
"16"
);
test_ro
(
"15.9"
,
0
,
HALF_EVEN
);
test_ro
(
"14.5"
,
0
,
HALF_EVEN
,
"14"
);
test_ro
(
"15.1"
,
0
,
CEILING
);
test_ro
(
"15.9"
,
0
,
HALF_EVEN
,
"16"
);
test_ro
(
"-15.1"
,
0
,
CEILING
);
test_ro
(
"15.1"
,
0
,
CEILING
,
"16"
);
test_ro
(
"15.1"
,
0
,
FLOOR
);
test_ro
(
"-15.1"
,
0
,
CEILING
,
"-15"
);
test_ro
(
"-15.1"
,
0
,
FLOOR
);
test_ro
(
"15.1"
,
0
,
FLOOR
,
"15"
);
test_ro
(
"999999999999999999999.999"
,
0
,
CEILING
);
test_ro
(
"-15.1"
,
0
,
FLOOR
,
"-16"
);
test_ro
(
"-999999999999999999999.999"
,
0
,
FLOOR
);
test_ro
(
"999999999999999999999.999"
,
0
,
CEILING
,
"1000000000000000000000"
);
test_ro
(
"-999999999999999999999.999"
,
0
,
FLOOR
,
"-1000000000000000000000"
);
return
0
;
return
0
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment