aboutsummaryrefslogtreecommitdiff
path: root/vendor/x11iraf/ximtool/clients.old/x_ism.f
blob: 218b5d0b67d0c4cc2764548adbdf3dc86a4a62d7 (plain) (blame)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
integer function sysruk (task, cmd, rukarf, rukint)
      integer rukarf
      integer rukint
      integer*2 task(*)
      integer*2 cmd(*)
      integer i
      integer ntasks
      integer lmarg
      integer rmarg
      integer maxch
      integer ncol
      integer rukean
      integer envgei
      integer envscn
      logical streq
      logical xerpop
      logical xerflg
      common /xercom/ xerflg
      integer iyy
      integer dp(2)
      integer*2 dict(7)
      integer*2 st0001(9)
      integer*2 st0002(6)
      integer*2 st0003(3)
      integer*2 st0004(6)
      integer*2 st0005(6)
      integer*2 st0006(4)
      integer*2 st0007(6)
      integer*2 st0008(2)
      integer*2 st0009(29)
      integer*2 st0010(25)
      save
      data dict /119, 99,115,112,105,120, 0/
      data (st0001(iyy),iyy= 1, 8) /116,116,121,110, 99,111,108,115/
      data (st0001(iyy),iyy= 9, 9) / 0/
      data st0002 / 99,104,100,105,114, 0/
      data st0003 / 99,100, 0/
      data st0004 /104,111,109,101, 36, 0/
      data st0005 / 72, 79, 77, 69, 36, 0/
      data st0006 /115,101,116, 0/
      data st0007 /114,101,115,101,116, 0/
      data st0008 / 9, 0/
      data (st0009(iyy),iyy= 1, 8) /105,110,118, 97,108,105,100, 32/
      data (st0009(iyy),iyy= 9,16) /115,101,116, 32,115,116, 97,116/
      data (st0009(iyy),iyy=17,24) /101,109,101,110,116, 58, 32, 39/
      data (st0009(iyy),iyy=25,29) / 37,115, 39, 10, 0/
      data (st0010(iyy),iyy= 1, 8) /105,110,118, 97,108,105,100, 32/
      data (st0010(iyy),iyy= 9,16) / 83, 69, 84, 32,105,110, 32, 73/
      data (st0010(iyy),iyy=17,24) / 82, 65, 70, 32, 77, 97,105,110/
      data (st0010(iyy),iyy=25,25) / 0/
      data (dp(iyy),iyy= 1, 2) / 1, 0/
      data lmarg /5/, maxch /0/, ncol /0/, rukean /3/
      data ntasks /0/
         if (.not.(ntasks .eq. 0)) goto 110
            i=1
120         if (.not.(dp(i) .ne. 0)) goto 122
121            i=i+1
               goto 120
122         continue
            ntasks = i - 1
110      continue
         if (.not.(task(1) .eq. 63)) goto 130
            call xerpsh
            rmarg = envgei (st0001)
            if (.not.xerpop()) goto 140
               rmarg = 80
140         continue
            call strtbl (4, dict, dp, ntasks, lmarg, rmarg, maxch, ncol)
            sysruk = (0)
            goto 100
130      continue
         if (.not.(streq(task,st0002) .or. streq(task,st0003))) goto 150
            call xerpsh
            if (.not.(cmd(rukarf) .eq. 0)) goto 170
               call xerpsh
               call xfchdr(st0004)
               if (.not.xerpop()) goto 180
                  call xfchdr(st0005)
180            continue
               goto 171
170         continue
               call xfchdr(cmd(rukarf))
171         continue
162         if (.not.xerpop()) goto 160
               if (.not.(rukint .eq. 1)) goto 190
                  call erract (rukean)
                  if (xerflg) goto 100
                  goto 191
190            continue
191            continue
160         continue
            sysruk = (0)
            goto 100
150      continue
         if (.not.(streq(task,st0006) .or. streq(task,st0007))) goto 200
            call xerpsh
            if (.not.(cmd(rukarf) .eq. 0)) goto 220
               call envlit (4, st0008, 1)
               call xffluh(4)
               goto 221
220         continue
            if (.not.(envscn (cmd) .le. 0)) goto 230
               if (.not.(rukint .eq. 1)) goto 240
                  call eprinf (st0009)
                  call pargsr (cmd)
                  goto 241
240            continue
                  goto 91
241            continue
230         continue
221         continue
212         if (.not.xerpop()) goto 210
               if (.not.(rukint .eq. 1)) goto 250
                  call erract (rukean)
                  if (xerflg) goto 100
                  goto 251
250            continue
91                call syspac (0, st0010)
251            continue
210         continue
            sysruk = (0)
            goto 100
200      continue
151      continue
131      continue
         if (.not.(streq (task, dict(dp(1))))) goto 260
            call twcspx
            sysruk = (0)
            goto 100
260      continue
         sysruk = (-1)
         goto 100
100      return
      end
c     rukint  ruk_interact
c     sysruk  sys_runtask
c     envscn  envscan
c     twcspx  t_wcspix
c     envgei  envgeti
c     syspac  sys_panic
c     eprinf  eprintf
c     rukarf  ruk_argoff
c     rukean  ruk_eawarn
c     pargsr  pargstr
c     envlit  envlist