/*M///////////////////////////////////////////////////////////////////////////////////////
//
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
// By downloading, copying, installing or using the software you agree to this license.
// If you do not agree to this license, do not download, install,
// copy or use the software.
//
//
// Intel License Agreement
// For Open Source Computer Vision Library
//
// Copyright (C) 2000, Intel Corporation, all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// * Redistribution's of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistribution's in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * The name of Intel Corporation may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/
#include "_highgui.h"
#include "grfmt_base.h"
#include "bitstrm.h"
GrFmtReader::GrFmtReader( const char* filename )
{
strncpy( m_filename, filename, sizeof(m_filename) - 1 );
m_filename[sizeof(m_filename)-1] = '\0';
m_width = m_height = 0;
m_iscolor = false;
m_bit_depth = 8;
m_native_depth = false;
m_isfloat = false;
}
GrFmtReader::~GrFmtReader()
{
Close();
}
void GrFmtReader::Close()
{
m_width = m_height = 0;
m_iscolor = false;
}
GrFmtWriter::GrFmtWriter( const char* filename )
{
strncpy( m_filename, filename, sizeof(m_filename) - 1 );
m_filename[sizeof(m_filename)-1] = '\0';
}
bool GrFmtWriter::IsFormatSupported( int depth )
{
return depth == IPL_DEPTH_8U;
}
GrFmtFilterFactory::GrFmtFilterFactory()
{
m_description = m_signature = 0;
m_sign_len = 0;
}
bool GrFmtFilterFactory::CheckFile( const char* filename )
{
FILE* f = 0;
char signature[4096];
int sign_len = 0;
int cur_sign_len = GetSignatureLength();
if( !filename ) return false;
assert( cur_sign_len <= (int)sizeof( signature ) );
f = fopen( filename, "rb" );
if( f )
{
sign_len = (int)fread( signature, 1, cur_sign_len, f );
fclose( f );
if( cur_sign_len <= sign_len && CheckSignature( signature ) )
return true;
}
return false;
}
bool GrFmtFilterFactory::CheckSignature( const char* signature )
{
return m_sign_len > 0 && signature != 0 &&
memcmp( signature, m_signature, m_sign_len ) == 0;
}
static int GetExtensionLength( const char* buffer )
{
int len = 0;
if( buffer )
{
const char* ext = strchr( buffer, '.');
if( ext++ )
while( isalnum(ext[len]) && len < _MAX_PATH )
len++;
}
return len;
}
bool GrFmtFilterFactory::CheckExtension( const char* format )
{
const char* descr = 0;
int len = 0;
if( !format || !m_description )
return false;
// find the right-most extension of the passed format string
for(;;)
{
const char* ext = strchr( format + 1, '.' );
if( !ext ) break;
format = ext;
}
len = GetExtensionLength( format );
if( format[0] != '.' || len == 0 )
return false;
descr = strchr( m_description, '(' );
while( descr )
{
descr = strchr( descr + 1, '.' );
int i, len2 = GetExtensionLength( descr );
if( len2 == 0 )
break;
if( len2 == len )
{
for( i = 0; i < len; i++ )
{
int c1 = tolower(format[i+1]);
int c2 = tolower(descr[i+1]);
if( c1 != c2 )
break;
}
if( i == len )
return true;
}
}
return false;
}
///////////////////// GrFmtFilterList //////////////////////////
GrFmtFactoriesList::GrFmtFactoriesList()
{
m_factories = 0;
RemoveAll();
}
GrFmtFactoriesList::~GrFmtFactoriesList()
{
RemoveAll();
}
void GrFmtFactoriesList::RemoveAll()
{
if( m_factories )
{
for( int i = 0; i < m_curFactories; i++ ) delete m_factories[i];
delete[] m_factories;
}
m_factories = 0;
m_maxFactories = m_curFactories = 0;
}
bool GrFmtFactoriesList::AddFactory( GrFmtFilterFactory* factory )
{
assert( factory != 0 );
if( m_curFactories == m_maxFactories )
{
// reallocate the factorys pointers storage
int newMaxFactories = 2*m_maxFactories;
if( newMaxFactories < 16 ) newMaxFactories = 16;
GrFmtFilterFactory** newFactories = new GrFmtFilterFactory*[newMaxFactories];
for( int i = 0; i < m_curFactories; i++ ) newFactories[i] = m_factories[i];
delete[] m_factories;
m_factories = newFactories;
m_maxFactories = newMaxFactories;
}
m_factories[m_curFactories++] = factory;
return true;
}
ListPosition GrFmtFactoriesList::GetFirstFactoryPos()
{
return (ListPosition)m_factories;
}
GrFmtFilterFactory* GrFmtFactoriesList::GetNextFactory( ListPosition& pos )
{
GrFmtFilterFactory* factory = 0;
GrFmtFilterFactory** temp = (GrFmtFilterFactory**)pos;
assert( temp == 0 || (m_factories <= temp && temp < m_factories + m_curFactories));
if( temp )
{
factory = *temp++;
pos = (ListPosition)(temp < m_factories + m_curFactories ? temp : 0);
}
return factory;
}
GrFmtReader* GrFmtFactoriesList::FindReader( const char* filename )
{
if( !filename ) return 0;
GrFmtReader* reader = 0;
ListPosition pos = GetFirstFactoryPos();
while( pos )
{
GrFmtFilterFactory* tempFactory = GetNextFactory( pos );
if( tempFactory->CheckFile( filename ) )
{
reader = tempFactory->NewReader( filename );
break;
}
}
return reader;
}
GrFmtWriter* GrFmtFactoriesList::FindWriter( const char* filename )
{
GrFmtWriter* writer = 0;
ListPosition pos = GetFirstFactoryPos();
if( !filename ) return 0;
while( pos )
{
GrFmtFilterFactory* tempFactory = GetNextFactory(pos);
if( tempFactory->CheckExtension( filename ))
{
writer = tempFactory->NewWriter( filename );
break;
}
}
return writer;
}
/* End of file. */