shithub: openh264

ref: edba95536681d8c589ed6dccc1b88a8499a98d3b
dir: /codec/console/enc/src/read_config.cpp/

View raw version
/*!
 * \copy
 *     Copyright (c)  2008-2013, Cisco Systems
 *     All rights reserved.
 *
 *     Redistribution and use in source and binary forms, with or without
 *     modification, are permitted provided that the following conditions
 *     are met:
 *
 *        * Redistributions of source code must retain the above copyright
 *          notice, this list of conditions and the following disclaimer.
 *
 *        * Redistributions 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.
 *
 *     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
 *     COPYRIGHT HOLDER 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.
 *
 *  read_config.h
 *
 *  Abstract
 *      Class for reading parameter settings in a configure file.
 *
 *  History
 *      08/18/2008 Created
 *
 *****************************************************************************/

#include <stdio.h>
#include <string.h>
#include "read_config.h"

#if defined(_MSC_VER)
#pragma warning(push)
#pragma warning(disable:4996)
#endif

CReadConfig::CReadConfig()
: m_pCfgFile( NULL )
, m_strCfgFileName("")
, m_iLines( 0 )
{
}

CReadConfig::CReadConfig( const char *kpConfigFileName )
: m_pCfgFile(0)
, m_strCfgFileName(kpConfigFileName)
, m_iLines(0)
{
	if ( strlen(kpConfigFileName) > 0 ){	// confirmed_safe_unsafe_usage
		m_pCfgFile = fopen(kpConfigFileName, "r");
	}
}

CReadConfig::CReadConfig( const string& kpConfigFileName )
: m_pCfgFile(0)
, m_strCfgFileName(kpConfigFileName)
, m_iLines(0)
{
	if ( kpConfigFileName.length() > 0 )
	{
		m_pCfgFile = fopen(kpConfigFileName.c_str(), "r");
	}
}

CReadConfig::~CReadConfig()
{
	if ( m_pCfgFile ){
		fclose( m_pCfgFile );
		m_pCfgFile = NULL;
	}
}

void CReadConfig::Openf(const char *kpStrFile)
{
	if ( kpStrFile != NULL && strlen(kpStrFile) > 0 )	// confirmed_safe_unsafe_usage
	{
		m_strCfgFileName = kpStrFile;
		m_pCfgFile = fopen(kpStrFile, "r");
	}
}

long CReadConfig::ReadLine( string* pVal, const int kiValSize/* = 4*/ )
{
	if ( m_pCfgFile == NULL || pVal == NULL || kiValSize <= 1)
		return 0;
	
	string *strTags = &pVal[0];
	int nTagNum = 0, n = 0;
	bool bCommentFlag = false;	
	
	while (n < kiValSize) {
		pVal[n]	= "";
		++ n;
	}	

	do {
		const char kCh = (char)fgetc(m_pCfgFile);
		
		if ( kCh == '\n' || feof(m_pCfgFile) ){
			++ m_iLines;
			break;
		}
		if ( kCh == '#' )
			bCommentFlag = true;
		if ( !bCommentFlag ){
			if ( kCh == '\t' || kCh == ' ' ){
				if ( nTagNum >= kiValSize )
					break;
				if ( !(*strTags).empty() ){
					++ nTagNum;
					strTags	= &pVal[nTagNum];
				}
			}
			else
				*strTags += kCh;
		}
		
	} while(true);
	
	return 1+nTagNum;
}

const bool CReadConfig::EndOfFile()
{
	if (m_pCfgFile == NULL)
		return true;
	return feof(m_pCfgFile) ? true : false;
}

const int CReadConfig::GetLines()
{
	return m_iLines;
}

const bool CReadConfig::ExistFile()
{
	return (m_pCfgFile != NULL);
}

const string& CReadConfig::GetFileName()
{
	return m_strCfgFileName;
}

#if defined(_MSC_VER)
#pragma warning(pop)
#endif