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
|
/*!
\file lib/vector/vedit/flip.c
\brief Vedit library - flip lines
(C) 2007-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 Martin Landa <landa.martin gmail.com>
*/
#include <grass/vedit.h>
/*!
\brief Flip direction of selected lines
\param Map pointer to Map_info
\param List list of selected lines
\return number of modified lines
\return -1 on error
*/
int Vedit_flip_lines(struct Map_info *Map, struct ilist *List)
{
struct line_cats *Cats;
struct line_pnts *Points;
int i, line, type;
int nlines_flipped;
nlines_flipped = 0;
Points = Vect_new_line_struct();
Cats = Vect_new_cats_struct();
for (i = 0; i < List->n_values; i++) {
line = List->value[i];
if (!Vect_line_alive(Map, line))
continue;
type = Vect_read_line(Map, Points, Cats, line);
if (!(type & GV_LINES))
continue;
Vect_line_reverse(Points);
if (Vect_rewrite_line(Map, line, type, Points, Cats) < 0) {
return -1;
}
G_debug(3, "Vedit_flip_lines(): line=%d", line);
nlines_flipped++;
}
/* destroy structures */
Vect_destroy_line_struct(Points);
Vect_destroy_cats_struct(Cats);
return nlines_flipped;
}
|