1 ;
--------------------------------------------------------------------------
4 ; Copyright
(C
) 2020-2021, Sergey Belyashov
6 ; This library is free software; you can redistribute it
and/or modify it
7 ; under the terms of the GNU General Public License as published by the
8 ; Free Software Foundation; either version
2, or (at your option
) any
11 ; This library is distributed in the hope that it will
be useful
,
12 ; but WITHOUT ANY WARRANTY; without even the implied warranty of
13 ; MERCHANTABILITY
or FITNESS FOR
A PARTICULAR PURPOSE. See the
14 ; GNU General Public License for more details.
16 ; You should have received
a copy of the GNU General Public License
17 ; along with this library; see the file COPYING. If
not, write to the
18 ; Free Software Foundation
, 51 Franklin Street
, Fifth Floor
, Boston
,
21 ; As
a special exception
, if you link this library with other files
,
22 ; some of which are compiled with SDCC
, to produce an executable
,
23 ; this library does
not by itself cause the resulting executable to
24 ;
be covered by the GNU General Public License. This exception does
25 ;
not however invalidate any other reasons why the executable file
26 ; might
be covered by the GNU General Public License.
27 ;
--------------------------------------------------------------------------
30 .optsdcc -mz80 sdcccall(1)
37 ;void __itoa
(long value
, char
*string
, unsigned char radix
);
47 ; HLDE
, -4 (ix
) - value
53 ;positive
/negative numbers are supported only for radix
=10
57 ;
add minus sign to result
and inverse value
70 ld (hl
), #0x2D ;minus symbol
76 ;void __uitoa
(unsigned int value
, char
*string
, unsigned char radix
);
86 ; HLDE
, -4 (ix
) - value
106 cp
a, #10 ;most popular radix
109 ;
-------- decimal conversion
110 ;this algorithm is
20% faster than generic one
122 pop de ;DE
- pointer to string
124 add hl
, sp ;HL
- pointer to BCD value
125 ld b, #5 ;number of bytes in BCD value
126 ld a, #0x30 ;ASCII code of '0'
138 ;skip trailing zeroes
139 ld b, #10 ;real decimal number is at most 10 digits
144 jr NZ
, 107$ ;break loop if non-zero found
147 inc de ;always point to symbol next to last significant
151 ;
---------------------------
155 jr C
, 190$ ;radix is less than
2
162 ;
-------- radix is power of
2
164 ; DE
- lower
16 bits of value
, HL
- pointer to string
, C
- mask
178 cp
a, #0x3A ;convert to 0...9A...Z
191 ;
---------------------------
193 ;
-------- custom radix
(generic algorithm
)
222 ;
---------------------------
224 ;
-------- finish string
and reverse order
229 call ___strreverse_reg
238 ;in
: DEHL
- divident
, C
- divisor
239 ;out
: DEHL
- quotient
, A - remainder