Create a new band duplicated from source band.
Memory is allocated for band path (if band is offline) or band data (if band is online). The caller is responsible for freeing the memory when the returned rt_band is destroyed.
Memory is allocated for band path (if band is offline) or band data (if band is online). The caller is responsible for freeing the memory when the returned rt_band is destroyed.
438 {
440
441 assert(band != NULL);
442
443
449 band->data.offline.bandNum, (
const char *)
band->data.offline.path
450 );
451 }
452
453 else {
454 uint8_t *
data = NULL;
456 if (data == NULL) {
457 rterror(
"rt_band_duplicate: Out of memory allocating online band data");
458 return NULL;
459 }
461
466 data
467 );
469 }
470
471 if (rtn == NULL) {
472 rterror(
"rt_band_duplicate: Could not copy band");
473 return NULL;
474 }
475
476 return rtn;
477}
void rterror(const char *fmt,...) __attribute__((format(printf
Wrappers used for reporting errors and info.
void * rtalloc(size_t size)
Wrappers used for managing memory.
int rt_pixtype_size(rt_pixtype pixtype)
Return size in bytes of a value in the given pixtype.
rt_band rt_band_new_inline(uint16_t width, uint16_t height, rt_pixtype pixtype, uint32_t hasnodata, double nodataval, uint8_t *data)
Create an in-db rt_band with no data.
void rt_band_set_ownsdata_flag(rt_band band, int flag)
rt_band rt_band_new_offline(uint16_t width, uint16_t height, rt_pixtype pixtype, uint32_t hasnodata, double nodataval, uint8_t bandNum, const char *path)
Create an out-db rt_band.