OpenJPEG 2.5.0
box_manager.h
Go to the documentation of this file.
1/*
2 * $Id$
3 *
4 * Copyright (c) 2002-2014, Universite catholique de Louvain (UCL), Belgium
5 * Copyright (c) 2002-2014, Professor Benoit Macq
6 * Copyright (c) 2010-2011, Kaori Hagihara
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
22 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 * POSSIBILITY OF SUCH DAMAGE.
29 */
30
31#ifndef BOX_MANAGER_H_
32# define BOX_MANAGER_H_
33
34#include "byte_manager.h"
35
37typedef struct box_param {
38 int fd;
42 char type[4];
43 struct box_param *next;
45
46
48typedef struct boxlist_param {
52
53
60
70
71
79box_param_t * gene_boxbyOffset(int fd, OPJ_OFF_T offset);
80
81
90
100box_param_t * gene_boxbyType(int fd, OPJ_OFF_T offset, OPJ_SIZE_T length,
101 const char TBox[]);
102
113 OPJ_SIZE_T length, const char TBox[]);
114
123
133 const char TBox[]);
134
142
143
151
152
160
161
171
180
189
198
207
208
216box_param_t * search_box(const char type[], boxlist_param_t *boxlist);
217
223void print_box(box_param_t *box);
224
225
231void print_allbox(boxlist_param_t *boxlist);
232
240
241
248void delete_box_in_list_by_type(const char type[], boxlist_param_t *boxlist);
249
250
256void delete_boxlist(boxlist_param_t **boxlist);
257
258
266
267#endif /* !BOX_MANAGER_H_ */
box_param_t * gene_boxbyOffset(int fd, OPJ_OFF_T offset)
generate box from JP2 file at the given offset
Definition: box_manager.c:86
void print_box(box_param_t *box)
print box parameters
Definition: box_manager.c:365
OPJ_SIZE_T get_DBoxlen(box_param_t *box)
get DBox length
Definition: box_manager.c:311
Byte4_t fetch_DBox4bytebigendian(box_param_t *box, OPJ_OFF_T offset)
fetch DBox (Box Contents) 4-byte big endian Byte codes in file stream
Definition: box_manager.c:336
Byte2_t fetch_DBox2bytebigendian(box_param_t *box, OPJ_OFF_T offset)
fetch DBox (Box Contents) 2-byte big endian Byte codes in file stream
Definition: box_manager.c:331
void print_allbox(boxlist_param_t *boxlist)
print all box parameters
Definition: box_manager.c:375
Byte_t * fetch_DBoxbytes(box_param_t *box, OPJ_OFF_T offset, OPJ_SIZE_T size)
fetch DBox (Box Contents) bytes of data in file stream
Definition: box_manager.c:321
Byte8_t fetch_DBox8bytebigendian(box_param_t *box, OPJ_OFF_T offset)
fetch DBox (Box Contents) 8-byte big endian Byte codes in file stream
Definition: box_manager.c:341
void delete_box_in_list_by_type(const char type[], boxlist_param_t *boxlist)
delete a box in list by Type
Definition: box_manager.c:415
box_param_t * gene_boxbyType(int fd, OPJ_OFF_T offset, OPJ_SIZE_T length, const char TBox[])
generate(search) box from JP2 file
Definition: box_manager.c:173
box_param_t * gene_boxbyTypeinStream(Byte_t *stream, OPJ_OFF_T offset, OPJ_SIZE_T length, const char TBox[])
generate(search) box from code stream
Definition: box_manager.c:243
struct box_param box_param_t
box parameters
box_param_t * gene_childboxbyOffset(box_param_t *superbox, OPJ_OFF_T offset)
generate child box from JP2 file at the given offset
Definition: box_manager.c:288
box_param_t * gene_childboxbyType(box_param_t *superbox, OPJ_OFF_T offset, const char TBox[])
generate(search) box from JP2 file
Definition: box_manager.c:293
boxlist_param_t * get_boxstructure(int fd, OPJ_OFF_T offset, OPJ_SIZE_T length)
get box structure of JP2 file
Definition: box_manager.c:60
boxlist_param_t * gene_boxlist(void)
generate a box list
Definition: box_manager.c:48
void delete_box_in_list(box_param_t **box, boxlist_param_t *boxlist)
delete a box in list
Definition: box_manager.c:395
box_param_t * gene_boxbyOffinStream(Byte_t *stream, OPJ_OFF_T offset)
generate box from code stream (JPP or JPT stream) at the given offset
Definition: box_manager.c:138
struct boxlist_param boxlist_param_t
Box list parameters.
box_param_t * search_box(const char type[], boxlist_param_t *boxlist)
search a box by box type
Definition: box_manager.c:346
OPJ_OFF_T get_DBoxoff(box_param_t *box)
get DBox offset
Definition: box_manager.c:306
Byte_t * fetch_headbytes(box_param_t *box)
fetch header bytes in file stream
Definition: box_manager.c:316
Byte_t fetch_DBox1byte(box_param_t *box, OPJ_OFF_T offset)
fetch DBox (Box Contents) 1-byte Byte codes in file stream
Definition: box_manager.c:326
void delete_boxlist(boxlist_param_t **boxlist)
delete box list
Definition: box_manager.c:423
void insert_box_into_list(box_param_t *box, boxlist_param_t *boxlist)
insert a box into list
Definition: box_manager.c:440
uint16_t Byte2_t
Definition: byte_manager.h:38
uint64_t Byte8_t
Definition: byte_manager.h:40
uint32_t Byte4_t
Definition: byte_manager.h:39
uint8_t Byte_t
Definition: byte_manager.h:37
int64_t OPJ_OFF_T
Definition: openjpeg.h:136
size_t OPJ_SIZE_T
Definition: openjpeg.h:139
box parameters
Definition: box_manager.h:37
char type[4]
type of information in the DBox
Definition: box_manager.h:42
Byte8_t length
length of the whole Box
Definition: box_manager.h:41
OPJ_OFF_T offset
byte position of the whole Box (LBox) in the file
Definition: box_manager.h:39
struct box_param * next
pointer to the next box
Definition: box_manager.h:43
Byte_t headlen
header length 8 or 16
Definition: box_manager.h:40
int fd
file descriptor
Definition: box_manager.h:38
Box list parameters.
Definition: box_manager.h:48
box_param_t * last
last box pointer of the list
Definition: box_manager.h:50
box_param_t * first
first box pointer of the list
Definition: box_manager.h:49