1ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/*
2ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * The copyright in this software is being made available under the 2-clauses
3ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * BSD License, included below. This software may be subject to other third
4ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * party and contributor rights, including patent rights, and no such rights
5ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * are granted under this license.
6ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov *
7ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * Copyright (c) 2005, Herve Drolon, FreeImage Team
8ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * Copyright (c) 2008, 2011-2012, Centre National d'Etudes Spatiales (CNES), FR
9ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * Copyright (c) 2012, CS Systemes d'Information, France
10ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * All rights reserved.
11ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov *
12ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * Redistribution and use in source and binary forms, with or without
13ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * modification, are permitted provided that the following conditions
14ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * are met:
15ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * 1. Redistributions of source code must retain the above copyright
16ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov *    notice, this list of conditions and the following disclaimer.
17ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * 2. Redistributions in binary form must reproduce the above copyright
18ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov *    notice, this list of conditions and the following disclaimer in the
19ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov *    documentation and/or other materials provided with the distribution.
20ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov *
21ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
22ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
25ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * POSSIBILITY OF SUCH DAMAGE.
32ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov */
33ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#ifndef OPJ_INCLUDES_H
34ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#define OPJ_INCLUDES_H
35ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
36ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/*
37ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * This must be included before any system headers,
38ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov * since they can react to macro defined there
39ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov */
40ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "opj_config_private.h"
41ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
42ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/*
43ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov ==========================================================
44ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov   Standard includes used by the library
45ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov ==========================================================
46ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov*/
47ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <memory.h>
48ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <stdlib.h>
49ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <string.h>
50ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <math.h>
51ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <float.h>
52ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <time.h>
53ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <stdio.h>
54ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <stdarg.h>
55ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <ctype.h>
56ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include <assert.h>
57ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
58ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/*
59ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  Use fseeko() and ftello() if they are available since they use
60ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  'off_t' rather than 'long'.  It is wrong to use fseeko() and
61ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  ftello() only on systems with special LFS support since some systems
62ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  (e.g. FreeBSD) support a 64-bit off_t by default.
63ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov*/
64ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#if defined(OPJ_HAVE_FSEEKO) && !defined(fseek)
65ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define fseek  fseeko
66ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define ftell  ftello
67ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
68ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
69ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
70ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#if defined(WIN32) && !defined(Windows95) && !defined(__BORLANDC__) && \
71ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  !(defined(_MSC_VER) && _MSC_VER < 1400) && \
72ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  !(defined(__MINGW32__) && __MSVCRT_VERSION__ < 0x800)
73ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  /*
74ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    Windows '95 and Borland C do not support _lseeki64
75ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    Visual Studio does not support _fseeki64 and _ftelli64 until the 2005 release.
76ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    Without these interfaces, files over 2GB in size are not supported for Windows.
77ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov  */
78ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_FSEEK(stream,offset,whence) _fseeki64(stream,/* __int64 */ offset,whence)
79ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_FSTAT(fildes,stat_buff) _fstati64(fildes,/* struct _stati64 */ stat_buff)
80ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_FTELL(stream) /* __int64 */ _ftelli64(stream)
81ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_STAT_STRUCT_T struct _stati64
82ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_STAT(path,stat_buff) _stati64(path,/* struct _stati64 */ stat_buff)
83ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#else
84ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_FSEEK(stream,offset,whence) fseek(stream,offset,whence)
85ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_FSTAT(fildes,stat_buff) fstat(fildes,stat_buff)
86ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_FTELL(stream) ftell(stream)
87ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_STAT_STRUCT_T struct stat
88ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#  define OPJ_STAT(path,stat_buff) stat(path,stat_buff)
89ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
90ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
91ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
92ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/*
93ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov ==========================================================
94ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov   OpenJPEG interface
95ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov ==========================================================
96ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov */
97ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "openjpeg.h"
98ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
99ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/*
100ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov ==========================================================
101ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov   OpenJPEG modules
102ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov ==========================================================
103ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov*/
104ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
105ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/* Ignore GCC attributes if this is not GCC */
106ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#ifndef __GNUC__
107ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov	#define __attribute__(x) /* __attribute__(x) */
108ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
109ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
110ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
111ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/* Are restricted pointers available? (C99) */
112ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#if (__STDC_VERSION__ != 199901L)
113ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov	/* Not a C99 compiler */
114ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov	#ifdef __GNUC__
115ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov		#define restrict __restrict__
116ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov	#else
117ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov		#define restrict /* restrict */
118ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov	#endif
119ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
120ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
121ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/* MSVC before 2013 and Borland C do not have lrintf */
122ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#if defined(_MSC_VER) && (_MSC_VER < 1800) || defined(__BORLANDC__)
123ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganovstatic INLINE long lrintf(float f){
124ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#ifdef _M_X64
125ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    return (long)((f>0.0f) ? (f + 0.5f):(f -0.5f));
126ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#else
127ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    int i;
128ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
129ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    _asm{
130ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov        fld f
131ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov        fistp i
132ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    };
133ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
134ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov    return i;
135ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
136ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov}
137ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
138ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
139ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "opj_inttypes.h"
140ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "opj_clock.h"
141ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "opj_malloc.h"
142ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "function_list.h"
143ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "event.h"
144ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "bio.h"
145ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "cio.h"
146ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
147ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "image.h"
148ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "invert.h"
149ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "j2k.h"
150ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "jp2.h"
151ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
152ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "mqc.h"
153ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "raw.h"
154ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "bio.h"
155ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
156ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "pi.h"
157ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "tgt.h"
158ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "tcd.h"
159ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "t1.h"
160ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "dwt.h"
161ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "t2.h"
162ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "mct.h"
163ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "opj_intmath.h"
164ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
165ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#ifdef USE_JPIP
166ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "cidx_manager.h"
167ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "indexbox_manager.h"
168ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif
169ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
170ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/* JPWL>> */
171ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#ifdef USE_JPWL
172ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "openjpwl/jpwl.h"
173ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif /* USE_JPWL */
174ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/* <<JPWL */
175ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
176ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov/* V2 */
177ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#include "opj_codec.h"
178ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
179ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov
180ee451cb395940862dad63c85adfe8f2fd55e864cSvet Ganov#endif /* OPJ_INCLUDES_H */
181