File: gctoi.r

package info (click to toggle)
iraf 2.17-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 95,288 kB
  • sloc: ansic: 228,894; fortran: 75,606; lisp: 18,369; xml: 8,401; sh: 6,111; yacc: 5,648; lex: 596; makefile: 575; asm: 153; csh: 95; sed: 4
file content (58 lines) | stat: -rw-r--r-- 1,117 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
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 & DIG0 <= str(i+1) & str(i+1) <= DIG9
	 | str (i + 1) == LETR & DIG0 <= str(i) & str(i) <= DIG9) {
      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 (DIG0 <= str(i) & str(i) <= DIG9)
	 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