aboutsummaryrefslogtreecommitdiff
path: root/pkg/utilities/nttools/gtedit/gtdodel.x
blob: 7292048ca2f27adb16e7c49305cad432522f0a76 (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
include <tbset.h>

# GT_DODEL -- Actually delete the rows marked for deletion

procedure gt_dodel (tp, tpr, deleted, npix)

pointer	tp
pointer	tpr
int	deleted[ARB]		# io: Array of deleted flags
int	npix			# io: # of rows in table

int	i, j, k

int	tbpsta()

begin
	if (tpr != NULL) {
	    # Append to whatever is already in the table
	    k = tbpsta (tpr, TBL_NROWS)
	    do i = 1, npix {
		if (deleted[i] == YES) {
		    k = k + 1
		    call tbrcpy (tp, tpr, i, k)
		}
	    }
	}

	for (j = npix; j> 0; j = j - 1) {
	    if (deleted[j] == YES) {
		i = j
		while (deleted[i] == YES) {
		    i = i - 1
		    if (i < 1)
			break
		}
		i = i + 1
		call tbrdel (tp, i, j)
		j = i - 1
	    }
	}
end