File: process_row.c

package info (click to toggle)
grass 8.4.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 277,040 kB
  • sloc: ansic: 460,798; python: 227,732; cpp: 42,026; sh: 11,262; makefile: 7,007; xml: 3,637; sql: 968; lex: 520; javascript: 484; yacc: 450; asm: 387; perl: 157; sed: 25; objc: 6; ruby: 4
file content (54 lines) | stat: -rw-r--r-- 1,668 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
/****************************************************************************
 *
 * MODULE:       r.buffer
 *
 * AUTHOR(S):    Michael Shapiro - CERL
 *
 * PURPOSE:      This program creates distance zones from non-zero
 *               cells in a grid layer. Distances are specified in
 *               meters (on the command-line). Window does not have to
 *               have square cells. Works both for planimetric
 *               (UTM, State Plane) and lat-long.
 *
 * COPYRIGHT:    (C) 2005 by the GRASS Development Team
 *
 *               This program is free software under the GNU General Public
 *               License (>=v2). Read the file COPYING that comes with GRASS
 *               for details.
 *
 ****************************************************************************/

#include "distance.h"
#include "local_proto.h"

int process_row(int row, int start_col)
{
    int r, first_zone, col;

    /* go north */

    begin_distance(row);
    for (r = row; r >= 0 && (first_zone = find_distances(r)) >= 0; r--) {
        col = start_col;
        while (col <= maxcol) {
            process_left(row, r, col, first_zone);
            col = process_at(row, r, col, first_zone);
            col = process_right(row, r, col, first_zone);
        }
    }

    /* go south */

    reset_distances();
    for (r = row + 1; r < window.rows && (first_zone = find_distances(r)) >= 0;
         r++) {
        col = start_col;
        while (col <= maxcol) {
            process_left(row, r, col, first_zone);
            col = process_at(row, r, col, first_zone);
            col = process_right(row, r, col, first_zone);
        }
    }

    return 0;
}