// comptest.cpp : Defines the entry point for the console application. // #pragma warning( disable:4786 ) #include #include #include "media.h" using namespace std; extern "C" { WCHAR NativeSourcePaths[MAX_SOURCE_COUNT][MAX_PATH]; } char *NativeSourcePathsA = NULL; /*extern "C" { WCHAR *NativeSourcePaths[] = {0}; }*/ // // main() entry point // bool bUITest = FALSE; bool bVerbose = FALSE; bool bDebug = FALSE; int __cdecl main( int argc, char * argv[] ) { bool bOutputFile = FALSE; char *pCompFileName = NULL; ComplianceFile *pCompFile; ofstream *pOutFile; if (argc > 1) { try { int count = 1; while ( count < argc) { if( argv[count] && (sizeof(argv[count]) > 3) && (*argv[count] == '-')) { switch ( *(argv[count]+1)) { case 's': case 'S': NativeSourcePathsA = argv[count]+3; MultiByteToWideChar( CP_ACP, 0, NativeSourcePathsA, -1, NativeSourcePaths[0], sizeof(NativeSourcePaths[0])/sizeof(NativeSourcePaths[0][0])); wprintf( L"NativeSourcePaths %s\n",NativeSourcePaths[0]); if ( NativeSourcePaths[0][0]) { ReadMediaData(); } break; case 'i': case 'I': pCompFileName = argv[count]+3; break; case 'o': case 'O': cerr << "outFile " << argv[count]+3 <good()) { throw ComplianceFile::InvalidFileName(argv[count]+3); } bOutputFile = TRUE; break; case 'u': case 'U': bUITest = TRUE; break; case 'd': case 'D': bDebug = TRUE; break; case 'v': case 'V': bVerbose = TRUE; break; default: break; } } count++; } if ( !pCompFileName) { cerr << "-i:inputfile must be specified" << endl; } else { pCompFile = new ComplianceFile(pCompFileName); if ( bOutputFile) { (pCompFile)->executeTestCases(*pOutFile); } else { (pCompFile)->executeTestCases(cerr); } MediaDataCleanUp(); } } catch (ComplianceFile::InvalidFileFormat iff) { cerr << iff; } catch (ComplianceFile::InvalidFileName ifn) { cerr << ifn; } catch (ComplianceFile::MissingSection ms) { cerr << ms; } catch (Section::InvalidSectionFormat isf) { cerr << isf; } catch (Section::InvalidSectionName isn) { cerr << isn; } catch (ValueSection::ValueNotFound vnf) { cerr << vnf; } catch (TestCase::InvalidFormat itf) { cerr << itf; } catch (...) { cerr << "Unknown Exception caught... :(" << endl; } } else { cerr << "illegal usage :(" << endl; } return 0; } /* namespace Compliance { // // static data initialization // const string UpgradeTestCase::m_szDelimiters = ":#"; // // utility function to tokenize a given line based on the delimiters // specified // template< class T > unsigned Tokenize(const T &szInput, const T & szDelimiters, vector& tokens) { unsigned uDelimiterCount = 0; tokens.clear(); if(!szInput.empty()){ if(!szDelimiters.empty()){ T::const_iterator inputIter = szInput.begin(); T::const_iterator copyIter = szInput.begin(); while(inputIter != szInput.end()){ if(szDelimiters.find(*inputIter) != string::npos){ if (copyIter < inputIter) { tokens.push_back(szInput.substr(copyIter - szInput.begin(), inputIter - copyIter)); } uDelimiterCount++; inputIter++; copyIter = inputIter; continue; } inputIter++; } if(copyIter != inputIter){ tokens.push_back(szInput.substr(copyIter - szInput.begin(), inputIter - szInput.begin())); } } else tokens.push_back(szInput); } return uDelimiterCount; } // // debug output for section // ostream& operator<<(ostream &os, const Section §ion){ os << "Section Name: " << section.name() << endl; os << "Number of child sections : " << section.childSections().size() << endl; os << "Section content : " << endl; vector::const_iterator liter = section.lines().begin(); while (liter != section.lines().end()) os << *liter++ << endl; // dump all the child sections vector
::const_iterator iter = section.childSections().begin(); while (iter != section.childSections().end()) { os << (const Section &)(*iter) << endl; iter++; } return os; } // // debug output for compliance file // ostream& operator<<(ostream& os, const ComplianceFile &cf){ os << "------------------------------------------------------------" << endl; os << "Compliance File State - Dump" << endl; os << "Name : " << cf.name() << endl; os << "Num Lines : " << cf.lines().size() << endl; os << "Section Dump : " << endl; if (cf.topLevelSection()) os << *(cf.topLevelSection()) << endl; os << "------------------------------------------------------------" << endl; return os; } } */