File: constraint.c

package info (click to toggle)
grass 6.4.4-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 104,028 kB
  • ctags: 40,409
  • sloc: ansic: 419,980; python: 63,559; tcl: 46,692; cpp: 29,791; sh: 18,564; makefile: 7,000; xml: 3,505; yacc: 561; perl: 559; lex: 480; sed: 70; objc: 7
file content (122 lines) | stat: -rw-r--r-- 2,724 bytes parent folder | download | duplicates (3)
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
/*!
   \file constraint.c

   \brief Vector library - constraints

   Higher level functions for reading/writing/manipulating vectors.

   These routines can affect the read_next_line funtions
   by restricting what they return.
   They are applied on a per map basis.

   These do not affect the lower level direct read functions.

   Normally, All 'Alive' lines will be returned unless overridden
   by this function.   You can specified all the types you are interested
   in  (by oring their types together).  You can use this to say 
   exclude Area type lines.

   By default all DEAD lines are ignored by the read_next_line () functions
   This too can be overridden by including their types.

   Refer to  dig_defines for the line type Defines

   All lines can be forced to be read by setting type = -1

   (C) 2001-2008 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.

   \author Original author CERL, probably Dave Gerdes or Mike Higgins.
   Update to GRASS 5.7 Radim Blazek and David D. Gray.

   \date 2001-2008
 */

#include <grass/Vect.h>
#include <grass/gis.h>

/*!
   \brief Set constraint region

   \param Map vector map
   \param n,s,e,w,t,b north, south, east, west, top, bottom coordinates

   \return 0 on success
   \return -1 on error
 */
int
Vect_set_constraint_region(struct Map_info *Map,
			   double n, double s, double e, double w, double t,
			   double b)
{
    if (n <= s)
	return (-1);
    if (e <= w)
	return (-1);

    Map->Constraint_region_flag = 1;
    Map->Constraint_N = n;
    Map->Constraint_S = s;
    Map->Constraint_E = e;
    Map->Constraint_W = w;
    Map->Constraint_T = t;
    Map->Constraint_B = b;
    Map->proj = G_projection();

    return (0);
}

/*!
   \brief Get constraint box

   \param Map vector map
   \param Box bounding box

   \return 0 on success
 */
int Vect_get_constraint_box(struct Map_info *Map, BOUND_BOX * Box)
{
    Box->N = Map->Constraint_N;
    Box->S = Map->Constraint_S;
    Box->E = Map->Constraint_E;
    Box->W = Map->Constraint_W;
    Box->T = Map->Constraint_T;
    Box->B = Map->Constraint_B;

    return 0;
}

/*!
   \brief Set constraint type

   \param Map vector map
   \param type constraint type

   \return 0 on success
 */
int Vect_set_constraint_type(struct Map_info *Map, int type)
{
    Map->Constraint_type = type;
    Map->Constraint_type_flag = 1;

    return 0;
}

/*!
   \brief Remove constraints

   \param Map vector map

   \return 0 on success
 */
int Vect_remove_constraints(struct Map_info *Map)
{
    Map->Constraint_region_flag = 0;
    Map->Constraint_type_flag = 0;

    return 0;
}