aboutsummaryrefslogtreecommitdiff
path: root/unix/boot/spp/rpp/ratlibr/gctoi.r
diff options
context:
space:
mode:
authorJoseph Hunkeler <jhunkeler@gmail.com>2015-07-08 20:46:52 -0400
committerJoseph Hunkeler <jhunkeler@gmail.com>2015-07-08 20:46:52 -0400
commitfa080de7afc95aa1c19a6e6fc0e0708ced2eadc4 (patch)
treebdda434976bc09c864f2e4fa6f16ba1952b1e555 /unix/boot/spp/rpp/ratlibr/gctoi.r
downloadiraf-linux-fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4.tar.gz
Initial commit
Diffstat (limited to 'unix/boot/spp/rpp/ratlibr/gctoi.r')
-rw-r--r--unix/boot/spp/rpp/ratlibr/gctoi.r58
1 files changed, 58 insertions, 0 deletions
diff --git a/unix/boot/spp/rpp/ratlibr/gctoi.r b/unix/boot/spp/rpp/ratlibr/gctoi.r
new file mode 100644
index 00000000..8efabe4f
--- /dev/null
+++ b/unix/boot/spp/rpp/ratlibr/gctoi.r
@@ -0,0 +1,58 @@
+include defs
+
+# gctoi --- convert any radix string to single precision integer
+
+ integer function gctoi (str, i, radix)
+ character str (ARB)
+ integer i, radix
+
+ integer base, v, d, j
+ external index
+ integer index
+
+ character clower
+
+ logical neg
+
+ string digits "0123456789abcdef"
+
+ v = 0
+ base = radix
+
+ while (str (i) == BLANK | str (i) == TAB)
+ i = i + 1
+
+ neg = (str (i) == MINUS)
+ if (str (i) == PLUS | str (i) == MINUS)
+ i = i + 1
+
+ if (str (i + 2) == LETR & str (i) == DIG1 & IS_DIGIT(str (i + 1))
+ | str (i + 1) == LETR & IS_DIGIT(str (i))) {
+ base = str (i) - DIG0
+ j = i
+ if (str (i + 1) != LETR) {
+ j = j + 1
+ base = base * 10 + (str (j) - DIG0)
+ }
+ if (base < 2 | base > 16)
+ base = radix
+ else
+ i = j + 2
+ }
+
+ for (; str (i) != EOS; i = i + 1) {
+ if (IS_DIGIT(str (i)))
+ d = str (i) - DIG0
+ else
+ d = index (digits, clower (str (i))) - 1
+ if (d < 0 | d >= base)
+ break
+ v = v * base + d
+ }
+
+ if (neg)
+ return (-v)
+ else
+ return (+v)
+
+ end