"L. Spiro Engine"
|
00001 /* 00002 * Copyright (c) 2002-2007, Communications and Remote Sensing Laboratory, Universite catholique de Louvain (UCL), Belgium 00003 * Copyright (c) 2002-2007, Professor Benoit Macq 00004 * Copyright (c) 2001-2003, David Janssens 00005 * Copyright (c) 2002-2003, Yannick Verschueren 00006 * Copyright (c) 2003-2007, Francois-Olivier Devaux and Antonin Descampe 00007 * Copyright (c) 2005, Herve Drolon, FreeImage Team 00008 * All rights reserved. 00009 * 00010 * Redistribution and use in source and binary forms, with or without 00011 * modification, are permitted provided that the following conditions 00012 * are met: 00013 * 1. Redistributions of source code must retain the above copyright 00014 * notice, this list of conditions and the following disclaimer. 00015 * 2. Redistributions in binary form must reproduce the above copyright 00016 * notice, this list of conditions and the following disclaimer in the 00017 * documentation and/or other materials provided with the distribution. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS' 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 */ 00031 00032 00033 #ifndef __LSI_BIO_H__ 00034 #define __LSI_BIO_H__ 00035 00036 #include "../LSIImageLib.h" 00037 00038 namespace lsi { 00039 00046 class CBio { 00047 public : 00048 // == Types. 00052 typedef struct opj_bio_t { 00054 LSUINT8 * start; 00056 LSUINT8 * end; 00058 LSUINT8 * bp; 00060 LSUINT32 buf; 00062 LSINT32 ct; 00063 } * LPopj_bio_t, * const LPCopj_bio_t; 00064 00065 00066 // == Functions. 00072 static opj_bio_t * LSE_CALL bio_create(); 00073 00079 static LSVOID LSE_CALL bio_destroy( opj_bio_t * _pbBio ); 00080 00087 static LSINT32 LSE_CALL bio_numbytes( opj_bio_t * _pbBio ); 00088 00096 static LSVOID LSE_CALL bio_init_enc( opj_bio_t * _pbBio, LSUINT8 * _pui8Bp, LSINT32 _i32Len ); 00097 00105 static LSVOID LSE_CALL bio_init_dec( opj_bio_t * _pbBio, LSUINT8 * _pui8Bp, LSINT32 _i32Len ); 00106 00114 static LSVOID LSE_CALL bio_write( opj_bio_t * _pbBio, LSINT32 _i32V, LSINT32 _i32N ); 00115 00123 static LSINT32 LSE_CALL bio_read( opj_bio_t * _pbBio, LSINT32 _i32N ); 00124 00131 static LSINT32 LSE_CALL bio_flush( opj_bio_t * _pbBio ); 00132 00139 static LSINT32 LSE_CALL bio_inalign( opj_bio_t * _pbBio ); 00140 00141 00142 protected : 00143 // == Functions. 00150 static LSVOID LSE_CALL bio_putbit( opj_bio_t *_pbBio, LSINT32 _i32B ); 00151 00158 static LSINT32 LSE_CALL bio_getbit( opj_bio_t * _pbBio ); 00159 00166 static LSINT32 LSE_CALL bio_byteout( opj_bio_t * _pbBio ); 00167 00174 static LSINT32 LSE_CALL bio_bytein( opj_bio_t * _pbBio ); 00175 00176 }; 00177 00178 } // namespace lsi 00179 00180 #endif // __LSI_BIO_H__