/** * \file lib/segment/get.c * * \brief Get segment 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-2018 */ #include #include "local_proto.h" /*bugfix: buf: char* vs int* -> wrong pointer arithmetics!!!. Pierre de Mouveaux - 09 april 2000 */ /* int Segment_get (SEGMENT *SEG, register int *buf,int row,int col) */ /** * \brief Get value from segment file. * * Provides random read access to the segmented data. It gets * len bytes of data into buf from the segment file * seg for the corresponding row and col in the * original data matrix. * * \param[in] SEG segment * \param[in,out] buf value return buffer * \param[in] row * \param[in] col * \return 1 of successful * \return -1 if unable to seek or read segment file */ int Segment_get(SEGMENT * SEG, void *buf, off_t row, off_t col) { int index, n, i; if (SEG->cache) { memcpy(buf, SEG->cache + ((size_t)row * SEG->ncols + col) * SEG->len, SEG->len); return 1; } SEG->address(SEG, row, col, &n, &index); if ((i = seg_pagein(SEG, n)) < 0) return -1; memcpy(buf, &SEG->scb[i].buf[index], SEG->len); return 1; }