diff -r d2ab7c3d0c48 -r 11157e26c4a7 dependencies/mifconv/src/mifconv_argumentmanager.cpp
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/dependencies/mifconv/src/mifconv_argumentmanager.cpp Thu Mar 25 16:25:17 2010 +0100
@@ -0,0 +1,991 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: Mifconv argument manager class.
+*
+*/
+
+
+#include "mifconv.h"
+#include "mifconv_argumentmanager.h"
+#include "mifconv_exception.h"
+#include "mifconv_util.h"
+
+// Static singleton initialization
+MifConvArgumentManager* MifConvArgumentManager::iInstance = 0;
+
+/**
+ * Returns pointer to the singleton object
+ */
+MifConvArgumentManager* MifConvArgumentManager::Instance()
+{
+ if( iInstance == 0 )
+ {
+ iInstance = new MifConvArgumentManager();
+ }
+ return iInstance;
+}
+
+/**
+ * Free the allocated memory
+ */
+void MifConvArgumentManager::Reset()
+{
+ delete iInstance;
+ iInstance = 0;
+}
+
+/**
+ *
+ */
+inline void MifConvArgumentManager::THROW_USAGE_EXCEPTION() const
+{
+ MifConvString usageStr;
+ SetUsageString(usageStr);
+ throw MifConvException(usageStr, MifConvString(__FILE__), __LINE__);
+}
+
+inline void MifConvArgumentManager::THROW_ERROR( const MifConvString& errorMsg, const MifConvString& file, int line ) const
+{
+ throw MifConvException( MifConvString("ERROR: " + errorMsg + "\nType mifconv -? for help\n"), file, line);
+}
+
+/**
+ *
+ */
+MifConvArgumentManager::MifConvArgumentManager()
+:
+iEpocRoot(DEFAULT_EPOCROOT)
+{
+ GetMifEnv();
+}
+
+/**
+ *
+ */
+MifConvArgumentManager::~MifConvArgumentManager()
+{}
+
+/**
+ * This function checks if the given argument is boolean type of argument.
+ * Boolean type arguments are listed in a MifConvBooleanArguments
table
+ * and this function checks if the given string matches any of those. Returns the length
+ * of the argument name if found, zero otherwise.
+ */
+size_t MifConvArgumentManager::IsBooleanArgument( const MifConvString& argName ) const
+{
+ if( IsArgument(argName) )
+ {
+ try {
+ int tblSize = sizeof(MifConvBooleanArguments) / sizeof(MifConvString);
+ for( int i = 0; i < tblSize; ++i )
+ {
+ size_t tmpLen = MifConvBooleanArguments[i].length();
+ if( argName.length() > tmpLen )
+ {
+ if( MifConvUtil::CompareIgnoreCase(MifConvString(argName.begin()+1, argName.begin() + 1 + tmpLen), MifConvBooleanArguments[i]) == 0 )
+ {
+ return tmpLen;
+ }
+ }
+ }
+ }
+ catch(...)
+ {
+ THROW_USAGE_EXCEPTION();
+ }
+ }
+ return 0;
+}
+
+/**
+ * This function checks if the given argument is a help argument.
+ * Help arguments are listed in a MifConvHelpArguments
table
+ * and this function checks if the given string matches any of those. Returns the length
+ * of the argument name if found, zero otherwise.
+ */
+size_t MifConvArgumentManager::IsHelpArgument( const MifConvString& argName ) const
+{
+ if( IsArgument(argName) )
+ {
+ try {
+ int tblSize = sizeof(MifConvHelpArguments) / sizeof(MifConvString);
+ for( int i = 0; i < tblSize; ++i )
+ {
+ size_t tmpLen = MifConvHelpArguments[i].length();
+
+ // Following check separates -H from -Hheadername.mbg parameter:
+ if( argName.length() == tmpLen+1 )
+ {
+ if( MifConvUtil::CompareIgnoreCase(MifConvString(argName.begin()+1, argName.begin() + 1 + tmpLen), MifConvHelpArguments[i]) == 0 )
+ {
+ return tmpLen;
+ }
+ }
+ }
+ }
+ catch(...)
+ {
+ THROW_USAGE_EXCEPTION();
+ }
+ }
+ return 0;
+}
+
+/**
+ * This function checks if the given argument is string type of argument.
+ * String type arguments are listed in a MifConvStringArguments
table
+ * and this function checks if the given string matches any of those. Returns the length
+ * of the argument name if found, zero otherwise.
+ */
+size_t MifConvArgumentManager::IsStringArgument( const MifConvString& argName ) const
+{
+ if( IsArgument(argName) )
+ {
+ try {
+ int tblSize = sizeof(MifConvStringArguments) / sizeof(MifConvString);
+ for( int i = 0; i < tblSize; ++i )
+ {
+ size_t tmpLen = MifConvStringArguments[i].length();
+ if( argName.length() > tmpLen )
+ {
+ if( MifConvUtil::CompareIgnoreCase(MifConvString(argName.begin()+1, argName.begin()+1+tmpLen), MifConvStringArguments[i]) == 0 )
+ {
+ return tmpLen;
+ }
+ }
+ }
+ }
+ catch(...)
+ {
+ THROW_USAGE_EXCEPTION();
+ }
+ }
+ return 0;
+}
+
+/**
+ * This function checks if the given argument is string list type of argument.
+ * String list type arguments are listed in a MifConvStringListArguments
table
+ * and this function checks if the given string matches any of those. Returns the length
+ * of the argument name if found, zero otherwise.
+ */
+size_t MifConvArgumentManager::IsStringListArgument( const MifConvString& argName ) const
+{
+ if( IsArgument(argName) )
+ {
+ try {
+ int tblSize = sizeof(MifConvStringListArguments) / sizeof(MifConvString);
+ for( int i = 0; i < tblSize; ++i )
+ {
+ size_t tmpLen = MifConvStringListArguments[i].length();
+ if( argName.length() > tmpLen )
+ {
+ if( MifConvUtil::CompareIgnoreCase(MifConvString(argName.begin()+1, argName.begin()+1+tmpLen), MifConvStringListArguments[i]) == 0 )
+ {
+ return tmpLen;
+ }
+ }
+ }
+ }
+ catch(...)
+ {
+ THROW_USAGE_EXCEPTION();
+ }
+ }
+ return 0;
+}
+
+/**
+ *
+ */
+bool MifConvArgumentManager::IsDepthArgument( const MifConvString& argName ) const
+{
+ if( IsArgument(argName) )
+ {
+ try {
+ int tblSize = sizeof(MifConvDepthArguments) / sizeof(MifConvString);
+ for( int i = 0; i < tblSize; ++i )
+ {
+ size_t tmpLen = MifConvDepthArguments[i].length();
+ if( argName.length() > tmpLen )
+ {
+ MifConvString trimmedArgument(argName.begin()+1, argName.begin() + 1 + tmpLen);
+ if( MifConvUtil::CompareIgnoreCase(trimmedArgument, MifConvDepthArguments[i]) == 0 )
+ {
+ return true;
+ }
+ }
+ }
+ }
+ catch(...)
+ {
+ THROW_USAGE_EXCEPTION();
+ }
+ }
+ return false;
+}
+
+/**
+ *
+ */
+bool MifConvArgumentManager::IsAnimatedFlag( const MifConvString& argName ) const
+{
+ return IsArgument( argName ) && argName.length() > MifConvAnimatedIconArg.length() &&
+ MifConvUtil::CompareIgnoreCase(MifConvString(argName.begin()+1, argName.end() ), MifConvAnimatedIconArg ) == 0;
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::SetTargetFile( const MifConvString& arg )
+{
+ iTargetFile = arg;
+}
+
+/**
+ *
+ */
+const MifConvString& MifConvArgumentManager::TargetFile() const
+{
+ return iTargetFile;
+}
+
+/**
+ *
+ */
+IconDisplayMode MifConvArgumentManager::ConvertToDisplayMode(IconDepth depth) const
+{
+ MifConvIconDisplayModeMap::const_iterator i = iDisplayModeMap.find(depth);
+ if( i != iDisplayModeMap.end() )
+ return i->second;
+
+ return DisplayMode_None;
+}
+
+/**
+ *
+ */
+IconDisplayMode MifConvArgumentManager::ConvertToMaskDisplayMode(IconMaskDepth depth) const
+{
+ MifConvMaskIconDisplayModeMap::const_iterator i = iMaskDisplayModeMap.find(depth);
+ if( i != iMaskDisplayModeMap.end() )
+ return i->second;
+
+ return DisplayMode_None;
+}
+
+/**
+ *
+ */
+IconDepth MifConvArgumentManager::ConvertToDepth( const MifConvString& depthStr ) const
+{
+ MifConvIconDepthMap::const_iterator i = iDepthMap.find(depthStr);
+ if( i != iDepthMap.end() )
+ return i->second;
+
+ return IconDepth_Undefined;
+}
+/**
+ *
+ */
+IconMaskDepth MifConvArgumentManager::ConvertToMaskDepth( const MifConvString depthStr ) const
+{
+ MifConvIconMaskDepthMap::const_iterator i = iMaskDepthMap.find(depthStr);
+ if( i != iMaskDepthMap.end() )
+ return i->second;
+
+ return IconMaskDepth_Undefined;
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::Init( const MifConvStringList& argList )
+{
+ // Build maps for mapping depth, mask and displaymode constants:
+ PopulateDepthAndMaskMaps();
+ // Allocate search paths where to search source files:
+ MifConvString epocRoot(EpocRoot());
+
+ // Global icons folder can contain only .svg files:
+ iSearchRules.push_back(MifConvSourceSearchRule(MifConvString(epocRoot + S60_ICONS_PATH), vector(1, SVG_FILE_EXTENSION)));
+ // Global bitmaps folder can contain only .bmp files:
+ iSearchRules.push_back(MifConvSourceSearchRule(MifConvString(epocRoot + S60_BITMAPS_PATH), vector(1, BMP_FILE_EXTENSION)));
+ // EPOCROOT, if given in environment variables:
+ if( epocRoot.length() > 0 )
+ {
+ iSearchRules.push_back(MifConvSourceSearchRule(epocRoot+EPOC32_PATH, vector(1, MIFCONV_WILDCARD)));
+ }
+
+ AddArguments(argList);
+
+ // check if the parameter file is given:
+ const MifConvString& paramFilename = StringValue(MifConvParameterFileArg);
+ if( paramFilename.length() > 0 )
+ {
+ // Add arguments from the parameter file:
+ MifConvStringList paramListFromFile;
+ ReadParameterFile( paramFilename, paramListFromFile );
+ if( paramListFromFile.size() > 0 )
+ {
+ AddArguments(paramListFromFile, true);
+ }
+ }
+ // Resolve file type extensions using given flags and investigating the existing files:
+ FinalizeArguments();
+}
+
+/**
+ * Read string argument value:
+ */
+MifConvString MifConvArgumentManager::ReadStringArgument(const MifConvStringList& argList, MifConvStringList::const_iterator& i, unsigned int argNameLen)
+{
+ // Take the actual argument value, for example /TmyTempDir --> myTempDir
+ MifConvString argValue((*i).begin() + argNameLen, (*i).end());
+ if( argValue.length() > 0 )
+ {
+ // String arguments can have spaces when they are enclosed with " marks (For example directory names).
+ if( argValue[0] == '\"' )
+ {
+ MifConvString quotedArgValue(argValue);
+ // Check if the last char is also ":
+ if( quotedArgValue[ quotedArgValue.length()-1 ] == '\"' )
+ {
+ return quotedArgValue;
+ }
+
+ // See if the next string ends with \" mark, for example "My Folder" is presented with following argument list:
+ // argList[0] = "My
+ // argList[1] = Folder"
+ while(++i != argList.end())
+ {
+ MifConvString nextString((*i).begin(), (*i).end());
+ quotedArgValue += " " + nextString;
+ if( nextString[ nextString.length()-1 ] == '\"' )
+ {
+ return "\"" + quotedArgValue + "\"";
+ }
+ }
+ }
+ }
+ return argValue;
+}
+
+/**
+ * Read string argument value:
+ */
+void MifConvArgumentManager::ReadStringListArgument(MifConvStringList::const_iterator& i, unsigned int argNameLen, MifConvStringList& StringValueList)
+{
+ // Take the actual argument value, for example /imyInputDir;myTempDir --> myTempDir
+ MifConvString argValue((*i).begin() + argNameLen, (*i).end());
+ MifConvUtil::SplitString( argValue, STRING_LIST_ARGUMENT_SEPARATOR, StringValueList );
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::AddArguments( const MifConvStringList& argList, bool paramsFromFile )
+{
+ MifConvStringList::const_iterator i = argList.begin();
+
+ if( i == argList.end() )
+ {
+ THROW_ERROR("No arguments", MifConvString(__FILE__), __LINE__);
+ }
+
+ // Check if help is needed:
+ while( i != argList.end() )
+ {
+ if( IsHelpArgument(*i) )
+ {
+ THROW_USAGE_EXCEPTION();
+ }
+ ++i;
+ }
+
+ i = argList.begin();
+
+ while( i != argList.end() )
+ {
+ unsigned int argLen = 0;
+ if( i == argList.begin() && paramsFromFile == false )
+ {
+ // First command line argument must be the target file.
+ // If the given list (argList) is read from the file, then
+ // the first one is not target file.
+ if( !IsArgument(*i) )
+ {
+ MifConvString targetFile(ReadStringArgument( argList, i, 0 ));
+ // Make sure that the file extension is .mif:
+ targetFile = MifConvUtil::FilenameWithoutExtension(targetFile);
+ targetFile += MifConvString(FILE_EXTENSION_SEPARATOR) + MifConvString(MIF_FILE_EXTENSION);
+ SetTargetFile(targetFile);
+ }
+ else
+ {
+ THROW_ERROR( "Target file must be given as first argument.", MifConvString(__FILE__), __LINE__ );
+ }
+ ++i;
+ if( i == argList.end() )
+ {
+ THROW_ERROR("Missing arguments", MifConvString(__FILE__), __LINE__);
+ }
+ }
+ else if( IsBooleanArgument(*i) )
+ {
+ // Insert boolean type argument to the boolean arguments list:
+ MifConvString argName((*i).begin()+1, (*i).end());
+ MifConvUtil::ToLower(argName); // Lower the cases to make comparison easier later
+ std::pair res = iBooleanArguments.insert(std::make_pair(
+ argName, MifConvBooleanArgument( argName, true )));
+ if( res.second == false )
+ {
+ // parameter already exists in the map, update the value:
+ res.first->second = MifConvBooleanArgument( argName, true );
+ }
+ ++i;
+ }
+ else if( (argLen = (unsigned int) IsStringArgument(*i) ) > 0 )
+ {
+ MifConvString argName((*i).begin()+1, (*i).begin() + 1 + argLen);
+ MifConvUtil::ToLower(argName); // Lower the cases to make comparison easier later
+ MifConvString argValue(ReadStringArgument( argList, i, argLen+1 ));
+ if( argValue.length() == 0 )
+ {
+ // Do not accept string arguments with zero length (E.g. "/H")
+ THROW_ERROR( "Missing argument value for " + *i, MifConvString(__FILE__), __LINE__ );
+ }
+ // Insert string type argument to the string arguments list:
+ std::pair res = iStringArguments.insert(std::make_pair(
+ argName, MifConvStringArgument( argName, argValue )));
+ if( res.second == false )
+ {
+ // parameter already exists in the map, update the value:
+ res.first->second = MifConvStringArgument( argName, argValue );
+ }
+ ++i;
+ }
+ else if( (argLen = (unsigned int) IsStringListArgument(*i)) > 0 )
+ {
+ MifConvString argName((*i).begin()+1, (*i).begin() + 1 + argLen);
+ MifConvUtil::ToLower(argName); // Lower the cases to make comparison easier later
+ MifConvStringList argValue;
+ ReadStringListArgument( i, argLen+1, argValue );
+
+ if( argValue.size() == 0 )
+ {
+ // Do not accept string arguments with zero length (E.g. "/H")
+ THROW_ERROR( "Missing argument value for " + *i, MifConvString(__FILE__), __LINE__ );
+ }
+ // Insert string list type argument to the string arguments list:
+ std::pair res = iStringListArguments.insert(std::make_pair(
+ argName, MifConvStringListArgument( argName, argValue )));
+ if( res.second == false )
+ {
+ // parameter already exists in the map, update the value:
+ res.first->second = MifConvStringListArgument( argName, argValue );
+ }
+ ++i;
+ }
+ else if( IsDepthArgument(*i) )
+ {
+ // Let's build source file argument...
+ // ... first is depth and mask:
+ MifConvString depthAndMask(*i);
+ MifConvUtil::ToLower(depthAndMask); // Lower the cases to make comparison easier later
+ ++i;
+ // Check that there is still an argument:
+ if( i == argList.end() )
+ {
+ THROW_ERROR( "Missing source file argument.", MifConvString(__FILE__), __LINE__ );
+ }
+
+ // Then we check if animated flag is given next:
+ bool isAnimated = IsAnimatedFlag(*i);
+
+ if( isAnimated )
+ {
+ // This was an animated flag, so next must be filename:
+ ++i;
+ // Check that there is still an argument:
+ if( i == argList.end() )
+ {
+ THROW_ERROR( "Missing source file argument.", MifConvString(__FILE__), __LINE__ );
+ //THROW_USAGE_EXCEPTION();
+ }
+ }
+
+ // One more check... Check that the next string is not an argument (starting with '-' or '/')
+ // It should be a filename for the source icon.
+ if( IsArgument(*i) )
+ {
+ THROW_ERROR( "Missing source file argument.", MifConvString(__FILE__), __LINE__ );
+ }
+
+ MifConvSourceFile srcFile;
+ srcFile.SetDepthAndMask(depthAndMask);
+ srcFile.SetDisplayMode(ConvertToDisplayMode(srcFile.Depth()));
+ srcFile.SetMaskDisplayMode(ConvertToMaskDisplayMode(srcFile.MaskDepth()));
+ srcFile.SetFilename(ReadStringArgument( argList, i, 0 ));
+ srcFile.SetAnimated(isAnimated);
+ iSourceFiles.push_back(srcFile);
+ ++i;
+ }
+ else if( IsAnimatedFlag(*i) )
+ {
+ // Icon animated flag found
+ // Let's see if the next is depth argument:
+ ++i;
+ MifConvString depthAndMask;
+ if( IsDepthArgument(*i) )
+ {
+ depthAndMask = *i;
+ MifConvUtil::ToLower(depthAndMask);
+ ++i;
+ }
+
+ // One more check... Check that the next string is not an argument (starting with '-' or '/')
+ if( IsArgument(*i) )
+ {
+ THROW_ERROR( "Missing source file argument.", MifConvString(__FILE__), __LINE__ );
+ }
+
+ MifConvSourceFile srcFile;
+ srcFile.SetDepthAndMask(depthAndMask);
+ srcFile.SetDisplayMode(ConvertToDisplayMode(srcFile.Depth()));
+ srcFile.SetMaskDisplayMode(ConvertToMaskDisplayMode(srcFile.MaskDepth()));
+ srcFile.SetFilename(*i);
+ srcFile.SetAnimated(true);
+ iSourceFiles.push_back(srcFile);
+ ++i;
+ }
+ else
+ {
+ THROW_ERROR( "Invalid argument: " + *i, MifConvString(__FILE__), __LINE__ );
+ }
+ }
+}
+
+/**
+ * Resolves correct type for the source file. Sets also mask filenames for bmp-files:
+ */
+void MifConvArgumentManager::ResolveSourceFileTypes()
+{
+ bool extensionFlag = BooleanValue(MifConvUseExtensionArg);
+
+ // check if the input directory is given:
+ const MifConvStringList& inputDirList = StringListValue(MifConvIconSourceDirectory);
+
+ // Add user-defined input directory to search directory list, put MIFCONV_WILDCARD
+ // as filetype rule, because user defined directory can contain all supported filetypes:
+ int indexcounter = 0;
+ for( MifConvStringList::const_iterator iDir = inputDirList.begin(); iDir != inputDirList.end(); ++iDir )
+ {
+ MifConvSourceSearchRule customRule(*iDir, MifConvStringList(1, MIFCONV_WILDCARD));
+ MifConvUtil::ReplaceChar(customRule.SearchPath(), INCORRECT_DIR_SEPARATOR2, DIR_SEPARATOR2);
+ MifConvUtil::RemoveDuplicateDirSeparators(customRule.SearchPath());
+ iSearchRules.insert(iSearchRules.begin()+indexcounter, customRule);
+
+ ++indexcounter;
+ }
+
+ for( MifConvSourceFileList::iterator src = iSourceFiles.begin(); src != iSourceFiles.end(); ++ src )
+ {
+ if( extensionFlag )
+ {
+ MifConvString extension = MifConvUtil::FileExtension(src->Filename());
+ if( !FindAndSetPathAndType( *src, extension ) )
+ {
+ THROW_ERROR_COMMON("File not found " + src->Filename(), MifConvString(__FILE__), __LINE__ );
+ }
+ }
+ else
+ {
+ // "Use extension" -flag not given, so resolve extensions for source files
+ if( !FindAndSetPathAndType( *src, SVGB_BINARY_FILE_EXTENSION ) )
+ {
+ if( !FindAndSetPathAndType( *src, SVG_FILE_EXTENSION ) )
+ {
+ if( !FindAndSetPathAndType( *src, BMP_FILE_EXTENSION ) )
+ {
+ THROW_ERROR_COMMON("File not found " + src->Filename(), MifConvString(__FILE__), __LINE__ );
+ }
+ }
+ }
+ }
+ }
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::GetMifEnv()
+{
+ // Read EPOCROOT environment variable
+ char* tmpPtr = 0;
+ tmpPtr = getenv(EPOCROOT_ENV.c_str());
+ if( tmpPtr )
+ {
+ iEpocRoot = MifConvString(tmpPtr);
+ MifConvUtil::ReplaceChar(iEpocRoot, INCORRECT_DIR_SEPARATOR2, DIR_SEPARATOR2);
+ // Make sure that the last char is directory separator
+ if( iEpocRoot.length() > 0 && iEpocRoot.at( iEpocRoot.length()-1) != DIR_SEPARATOR2 )
+ {
+ iEpocRoot += DIR_SEPARATOR;
+ }
+ }
+}
+
+/**
+ *
+ */
+const MifConvString& MifConvArgumentManager::EpocRoot() const
+{
+ return iEpocRoot;
+}
+
+/**
+ *
+ */
+bool MifConvArgumentManager::FindAndSetPathAndType( MifConvSourceFile& srcFile, const MifConvString& extension )
+{
+ // Search the filename first "as is":
+ MifConvString tmp( MifConvUtil::FilenameWithoutExtension( srcFile.Filename() ) + MifConvString(FILE_EXTENSION_SEPARATOR) + extension );
+ if( MifConvUtil::FileExists(tmp) )
+ {
+ srcFile.SetFilename(tmp);
+ MifConvUtil::FindAndSetBitmapMaskFile(srcFile);
+ return true;
+ }
+
+ // If the absolute path was given, return false, because the file was not found with given path and filename.
+ // Otherwise continue searching.
+ if( //(srcFile.Filename().length() > 0 && srcFile.Filename().at(0) == DIR_SEPARATOR2) ||
+ (srcFile.Filename().length() > 1 && srcFile.Filename().at(1) == ':') )
+ {
+ return false;
+ }
+
+ // Search from the pre-defined locations:
+ for( SearchRules::iterator i = iSearchRules.begin(); i != iSearchRules.end(); ++i )
+ {
+ bool validPath = false;
+ const MifConvStringList& allowedTypes = i->AllowedFileTypes();
+
+ // See if the file with given extension is allowed to locate in search path.
+ // For example, epoc32\s60\icons folder can contain only .svg files and epoc32\s60\bitmaps
+ // can contain only .bmp files:
+ for( MifConvStringList::const_iterator typeIter = allowedTypes.begin(); typeIter != allowedTypes.end(); ++typeIter )
+ {
+ if( *typeIter == MIFCONV_WILDCARD || *typeIter == extension )
+ {
+ validPath = true;
+ break;
+ }
+ }
+
+ if( validPath )
+ {
+ MifConvString searchPath(i->SearchPath());
+
+ // Make sure that the last char is directory separator
+ if( searchPath.length() > 0 && searchPath.at( searchPath.length()-1) != DIR_SEPARATOR2 )
+ {
+ searchPath += DIR_SEPARATOR;
+ }
+
+ searchPath += MifConvUtil::FilenameWithoutExtension( srcFile.Filename() ) + MifConvString(FILE_EXTENSION_SEPARATOR) + extension;
+
+ MifConvUtil::RemoveDuplicateDirSeparators(searchPath);
+
+ if( MifConvUtil::FileExists( searchPath ) )
+ {
+ srcFile.SetFilename(searchPath);
+ MifConvUtil::FindAndSetBitmapMaskFile(srcFile);
+ return true;
+ }
+ }
+ }
+ return false;
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::ProcessArgumentPaths()
+{
+ // Fix directory separators first:
+ for( StringArgMap::iterator i = iStringArguments.begin(); i != iStringArguments.end(); ++i )
+ {
+ MifConvString tmp = i->second.Value();
+ MifConvUtil::ReplaceChar(tmp, INCORRECT_DIR_SEPARATOR2, DIR_SEPARATOR2);
+ MifConvUtil::RemoveDuplicateDirSeparators(tmp);
+ i->second.SetValue(tmp);
+ }
+
+ // Fix directory separators in source filenames also:
+ for( MifConvSourceFileList::iterator j = iSourceFiles.begin(); j != iSourceFiles.end(); ++j )
+ {
+ MifConvString tmp = j->Filename();
+ MifConvUtil::ReplaceChar(tmp, INCORRECT_DIR_SEPARATOR2, DIR_SEPARATOR2);
+ MifConvUtil::RemoveDuplicateDirSeparators(tmp);
+ j->SetFilename(tmp);
+ }
+
+ // Fix directory separators in search rule directories also:
+ for( SearchRules::iterator k = iSearchRules.begin(); k != iSearchRules.end(); ++k )
+ {
+ MifConvString& tmp = k->SearchPath();
+ MifConvUtil::ReplaceChar(tmp, INCORRECT_DIR_SEPARATOR2, DIR_SEPARATOR2);
+ MifConvUtil::RemoveDuplicateDirSeparators(tmp);
+ }
+
+ // Fix target file also:
+ MifConvUtil::ReplaceChar(iTargetFile, INCORRECT_DIR_SEPARATOR2, DIR_SEPARATOR2);
+ MifConvUtil::RemoveDuplicateDirSeparators(iTargetFile);
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::FinalizeArguments()
+{
+ ProcessArgumentPaths();
+ ResolveSourceFileTypes();
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::SetUsageString( MifConvString& usageStr ) const
+{
+ usageStr = "";
+
+ usageStr += "Copyright (c) " + MifConvYears + " Nokia Corporation and/or its subsidiary(-ies). All rights reserved.\n";
+ usageStr += "\n";
+ usageStr += "Usage: mifconv [-F] ]\n";
+ usageStr += "\n";
+ usageStr += "Where:\n";
+ usageStr += " MIFFILE Specifies the target MIF file to be created\n";
+ usageStr += " -F Specifies a parameter file, which can contain any of the options\n";
+ usageStr += " and sources separated by spaces or newlines\n";
+ usageStr += "\n";
+ usageStr += "Options:\n";
+ usageStr += " -H Specifies a name of the MIF header file (default extension MBG)\n";
+ usageStr += " -I Specifies a set of custom source directories where source files\n";
+ usageStr += " will be searched. As a fallback, global source directories are\n";
+ usageStr += " used\n";
+ usageStr += " -E Specifies that source icons are only loaded with given file\n";
+ usageStr += " extensions. By default, Mifconv prefers source icons with\n";
+ usageStr += " extension .SVG over .BMP, regardless of which is given as\n";
+ usageStr += " a parameter\n";
+ usageStr += " -X Disables SVG compression. If this flag is set, SVG icons are\n";
+ usageStr += " added to MIF file without compressing them first\n";
+ usageStr += " -P Specifies a path to custom palette file for bitmap files\n";
+ usageStr += " -T Specifies a path where temporary files are created\n";
+ usageStr += " -B Specifies a path for non-default BMConv utility\n";
+ usageStr += " -S Specifies a path for non-default SVGTBinenCode utility\n";
+ usageStr += " -V Specifies a non-platform default format version of SVGT binary\n";
+ usageStr += " conversion. It can be any of the following value:\n";
+ usageStr += " 1 BGR / float encoding\n";
+ usageStr += " 2 BGR / fixed point encoding\n";
+ usageStr += " 3 RGB / fixed point encoding\n";
+ usageStr += " 4 RGB / float encoding\n";
+ usageStr += "Sources:\n";
+ usageStr += " [-A] [ [-A] ... ]\n";
+ usageStr += " [-A] Specifies animated flag for the icon\n";
+ usageStr += " [DEPTH] Specifies icon depth, it can be any of these values\n";
+ usageStr += " -1,-2,-4,-8,-c4,-c8,-c12,-c16,-c24,-c32\n";
+ usageStr += " [MASK] Specifies icon mask depth, it can be any of these values\n";
+ usageStr += " 1,8\n";
+ usageStr += " [FILE] Specifies path to the input file, supported file extensions are\n";
+ usageStr += " SVG, SVGB, BMP\n";
+ usageStr += "\n";
+ usageStr += "Other info:\n";
+#ifdef WIN32
+ usageStr += " * '-' or '/' can be used as parameter switch prefix\n";
+#endif
+ usageStr += " * Value of icon mask and depth is meaningful only for bitmap files, but the mask\n";
+ usageStr += " value defines if mask entry will be available or not in the header file\n";
+ usageStr += " * If mask parameter is defined for a BMP file, Mifconv automatically pics\n";
+ usageStr += " a file ending _mask_soft for value 8 and _mask for value 1 of mask\n";
+ usageStr += "\n";
+ usageStr += "Examples:\n";
+ usageStr += " mifconv mybuttons.mif -Hmybuttons.mbg -c8,8 button1 -c8,8 button2\n";
+}
+
+/**
+ *
+ */
+const MifConvString& MifConvArgumentManager::StringValue( const MifConvString& argName ) const
+{
+ StringArgMap::const_iterator i = iStringArguments.find(argName);
+ if( i != iStringArguments.end() )
+ {
+ return i->second.Value();
+ }
+
+ return iDummyString;
+}
+
+/**
+ *
+ */
+const MifConvStringList& MifConvArgumentManager::StringListValue( const MifConvString& argName ) const
+{
+ StringListArgMap::const_iterator i = iStringListArguments.find(argName);
+ if( i != iStringListArguments.end() )
+ {
+ return i->second.Value();
+ }
+
+ return iDummyStringList;
+}
+
+/**
+ *
+ */
+bool MifConvArgumentManager::BooleanValue( const MifConvString& argName ) const
+{
+ BooleanArgMap::const_iterator i = iBooleanArguments.find(argName);
+ if( i != iBooleanArguments.end() )
+ {
+ return i->second.Value();
+ }
+
+ return false;
+}
+
+/**
+ *
+ */
+const MifConvSourceFileList& MifConvArgumentManager::SourceFiles() const
+{
+ return iSourceFiles;
+}
+
+/**
+ *
+ */
+bool MifConvArgumentManager::IsArgument( const MifConvString& str ) const
+{
+ try {
+ return str.at(0) == OPTION_PREFIX1_CHAR || str.at(0) == OPTION_PREFIX2_CHAR;
+ }
+ catch(...)
+ {
+ THROW_ERROR("Zero or corrupted string in MifConvArgumentManager::IsArgument()\n", MifConvString(__FILE__), __LINE__);
+ }
+ return false;
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::PopulateDepthAndMaskMaps()
+{
+ // Insert value-string pairs for the icon depths:
+ iDepthMap.insert(std::make_pair(MifConvDepth_1, IconDepth_1));
+ iDepthMap.insert(std::make_pair(MifConvDepth_2, IconDepth_2));
+ iDepthMap.insert(std::make_pair(MifConvDepth_4, IconDepth_4));
+ iDepthMap.insert(std::make_pair(MifConvDepth_8, IconDepth_8));
+ iDepthMap.insert(std::make_pair(MifConvDepth_c4, IconDepth_c4));
+ iDepthMap.insert(std::make_pair(MifConvDepth_c8, IconDepth_c8));
+ iDepthMap.insert(std::make_pair(MifConvDepth_c12, IconDepth_c12));
+ iDepthMap.insert(std::make_pair(MifConvDepth_c16, IconDepth_c16));
+ iDepthMap.insert(std::make_pair(MifConvDepth_c24, IconDepth_c24));
+ iDepthMap.insert(std::make_pair(MifConvDepth_c32, IconDepth_c32));
+
+ // Insert value-string pairs for the icon masks:
+ iMaskDepthMap.insert(std::make_pair(MifConvMaskDepth_1, IconMaskDepth_1));
+ iMaskDepthMap.insert(std::make_pair(MifConvMaskDepth_8, IconMaskDepth_8));
+
+ // Insert value-pairs for display modes:
+ iDisplayModeMap.insert(std::make_pair(IconDepth_1, DisplayMode_Gray2));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_2, DisplayMode_Gray4));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_4, DisplayMode_Gray16));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_8, DisplayMode_Gray256));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_c4, DisplayMode_Color16));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_c8, DisplayMode_Color256));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_c12, DisplayMode_Color4K));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_c16, DisplayMode_Color64K));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_c24, DisplayMode_Color16M));
+ iDisplayModeMap.insert(std::make_pair(IconDepth_c32, DisplayMode_Color16MU));
+
+ iMaskDisplayModeMap.insert(std::make_pair(IconMaskDepth_1, DisplayMode_Gray2));
+ iMaskDisplayModeMap.insert(std::make_pair(IconMaskDepth_8, DisplayMode_Gray256));
+}
+
+/**
+ *
+ */
+void MifConvArgumentManager::ReadParameterFile(const MifConvString& paramFilename, MifConvStringList& paramList)
+{
+ // Check if the file exists:
+ if( MifConvUtil::FileExists(paramFilename) == false )
+ {
+ THROW_ERROR_COMMON("Unable to open file for reading! " + paramFilename, MifConvString(__FILE__), __LINE__ );
+ }
+
+ MifConvFileData paramFileData = MifConvUtil::FileContents(paramFilename);
+
+ MifConvString tmpString;
+ for(size_t i = 0; i < paramFileData.second; ++i )
+ {
+ if( MifConvUtil::IsWhiteSpace(paramFileData.first[i]) == false )
+ {
+ tmpString += paramFileData.first[i];
+ }
+ else if( tmpString.length() > 0 )
+ {
+ paramList.push_back( tmpString );
+ tmpString = MifConvString();
+ }
+ }
+
+ if( tmpString.length() > 0 )
+ {
+ paramList.push_back( tmpString );
+ tmpString = MifConvString();
+ }
+ delete[] paramFileData.first;
+}
+
+/**
+ * Helper class for source search rules
+ */
+
+MifConvSourceSearchRule::MifConvSourceSearchRule(const MifConvString& path, const MifConvStringList& types)
+:
+iSearchPath(path),
+iAllowedFileTypes(types)
+{}
+
+MifConvSourceSearchRule::~MifConvSourceSearchRule()
+{}
+
+const MifConvString& MifConvSourceSearchRule::SearchPath() const
+{
+ return iSearchPath;
+}
+
+MifConvString& MifConvSourceSearchRule::SearchPath()
+{
+ return iSearchPath;
+}
+
+const MifConvStringList& MifConvSourceSearchRule::AllowedFileTypes() const
+{
+ return iAllowedFileTypes;
+}