blob: 2f3589449720bb72c833d607a1bbda5e13b02e0a (
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
|
# PLLSEG.H -- Macros for sequentially reading segments of a line list.
#
# pll_init (ll, descriptor)
# npix = pll_nleft (descriptor)
# val = pll_getseg (ll, descriptor, npix, value)
#
# pll_init Initialize descriptor for sequential i/o from the linelist LL.
# pll_nleft Number of pixels left in the current line segment of constant
# value. Zero is returned at the EOL.
# pll_getseg Read NPIX pixels from the current segment, advancing to the
# next segment automatically when the the current segment is
# exhausted.
#
# The descriptor is an integer array, the contents of which are hidden from
# the application using these macros. This package uses the internal
# procedure PLL_NEXTSEG, which is included in PL package library.
# Range list i/o descriptor.
define LEN_PLLDES 7
define ld_nleft $1[1]
define ld_value $1[2]
define ld_x $1[3]
define ld_ip $1[4]
define ld_hi $1[5]
define ld_next_nleft $1[6]
define ld_next_value $1[7]
# PLL_INIT -- Initialize the linelist descriptor.
define (pll_init, { # $1=ll $2=des
# ld_x($2) = 1
ld_hi($2) = 1
if (LL_OLDFORMAT($1))
ld_ip($2) = OLL_FIRST
else
ld_ip($2) = LL_FIRST($1)
ld_next_nleft($2) = 0
ld_nleft($2) = 0
call pll_nextseg ($1, $2)
})
# PLL_NLEFT -- Number of pixels left in the current segment.
define pll_nleft ld_nleft($1)
# PLL_GETSEG -- Read pixels from the current segment.
define (pll_getseg, { # $1=ll $2=des $3=npix $4=value
$4 = ld_value($2)
# ld_x($2) = ld_x($2) + $3
ld_nleft($2) = ld_nleft($2) - $3
if (ld_nleft($2) <= 0)
if (ld_next_nleft($2) > 0) {
ld_nleft($2) = ld_next_nleft($2)
ld_value($2) = ld_next_value($2)
ld_next_nleft($2) = 0
} else
call pll_nextseg ($1, $2)
})
|