forked from OSGeo/grass
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathseek.c
65 lines (54 loc) · 1.34 KB
/
seek.c
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
/**
* \file lib/segment/seek.c
*
* \brief Segment seek routines.
*
* This program is free software under the GNU General Public License
* (>=v2). Read the file COPYING that comes with GRASS for details.
*
* \author GRASS GIS Development Team
*
* \date 2005-2009
*/
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <grass/gis.h>
#include "local_proto.h"
/**
* \brief Internal use only
*
* Seek into a segment.
*
* \param[in,out] SEG segment
* \param[in] n
* \param[in] index
* \return 0 on success
* \return -1 if unable to seek
*/
#define SEG_SEEK_FAST(SEG, n, index) \
((((off_t) (n)) << (SEG)->sizebits) + (index) + (SEG)->offset)
#define SEG_SEEK_SLOW(SEG, n, index) \
((off_t) (n) * (SEG)->size + (index) + (SEG)->offset)
int seg_seek_fast(const SEGMENT * SEG, int n, int index)
{
if (lseek((SEG)->fd, SEG_SEEK_FAST(SEG, n, index),
SEEK_SET) == (off_t) -1) {
G_fatal_error("Segment seek: %s", strerror(errno));
}
return 0;
}
int seg_seek_slow(const SEGMENT * SEG, int n, int index)
{
if (lseek((SEG)->fd, SEG_SEEK_SLOW(SEG, n, index),
SEEK_SET) == (off_t) -1) {
G_fatal_error("Segment seek: %s", strerror(errno));
}
return 0;
}
int seg_seek(const SEGMENT * SEG, int n, int index)
{
return SEG->seek(SEG, n, index);
}