static void processFile(char *name) { switch(mode) { case MD_DETECT_FILE_TYPE: detectFileType(name); break; case MD_DUMP: dumpFile(name); break; case MD_SHOW_SIGBLK_PARAMS: showSigblkParams(name); break; case MD_VERIFY: case MD_EXTEND: verify(name); break; } }
int KEduVocDocument::open( const KUrl& url ) { // save csv delimiter to preserve it in case this is a csv document QString csv = d->m_csvDelimiter; // clear all other properties d->init(); if ( !url.isEmpty() ) { d->m_url = url; } d->m_csvDelimiter = csv; bool read = false; QString errorMessage = i18n( "<qt>Cannot open file<br /><b>%1</b></qt>", url.path() ); QString temporaryFile; if ( KIO::NetAccess::download( url, temporaryFile, 0 ) ) { QIODevice * f = KFilterDev::deviceForFile( temporaryFile ); if ( !f->open( QIODevice::ReadOnly ) ) { kError() << errorMessage; delete f; return FileCannotRead; } FileType ft = detectFileType( temporaryFile ); switch ( ft ) { case Kvtml: { kDebug(1100) << "Reading KVTML document..."; KEduVocKvtml2Reader kvtmlReader( f ); read = kvtmlReader.readDoc( this ); if ( !read ) { errorMessage = kvtmlReader.errorMessage(); } } break; case Wql: { kDebug(1100) << "Reading WordQuiz (WQL) document..."; KEduVocWqlReader wqlReader( f ); d->m_url.setFileName( i18n( "Untitled" ) ); read = wqlReader.readDoc( this ); if ( !read ) { errorMessage = wqlReader.errorMessage(); } } break; case Pauker: { kDebug(1100) << "Reading Pauker document..."; KEduVocPaukerReader paukerReader( this ); d->m_url.setFileName( i18n( "Untitled" ) ); read = paukerReader.read( f ); if ( !read ) { errorMessage = i18n( "Parse error at line %1, column %2:\n%3", paukerReader.lineNumber(), paukerReader.columnNumber(), paukerReader.errorString() ); } } break; case Vokabeln: { kDebug(1100) << "Reading Vokabeln document..."; KEduVocVokabelnReader vokabelnReader( f ); d->m_url.setFileName( i18n( "Untitled" ) ); read = vokabelnReader.readDoc( this ); if ( !read ) { errorMessage = vokabelnReader.errorMessage(); } } break; case Csv: { kDebug(1100) << "Reading CVS document..."; KEduVocCsvReader csvReader( f ); read = csvReader.readDoc( this ); if ( !read ) { errorMessage = csvReader.errorMessage(); } } break; case Xdxf: { kDebug(1100) << "Reading XDXF document..."; KEduVocXdxfReader xdxfReader( this ); d->m_url.setFileName( i18n( "Untitled" ) ); read = xdxfReader.read( f ); if ( !read ) { errorMessage = i18n( "Parse error at line %1, column %2:\n%3", xdxfReader.lineNumber(), xdxfReader.columnNumber(), xdxfReader.errorString() ); } } break; default: { kDebug(1100) << "Reading KVTML document (fallback)..."; KEduVocKvtml2Reader kvtmlReader( f ); read = kvtmlReader.readDoc( this ); if ( !read ) { errorMessage = kvtmlReader.errorMessage(); } } } if ( !read ) { QString msg = i18n( "Could not open or properly read \"%1\"\n(Error reported: %2)", url.path(), errorMessage ); kError() << msg << i18n( "Error Opening File" ); ///@todo make the readers return int, pass on the error message properly delete f; return FileReaderFailed; } f->close(); delete f; KIO::NetAccess::removeTempFile( temporaryFile ); } if ( !read ) { return FileReaderFailed; } setModified(false); return 0; }
static void processFile(char *name) { char errbuf[4096]; switch(mode) { case MD_DETECT_FILE_TYPE: if(verbose) fprintf(stdout, "ProcessMode: Detect Filetype\n"); #ifdef ENABLEGT if (apimode == API_GT) detectFileType(name); #endif #ifdef ENABLEKSI if (apimode == API_KSI) detectFileTypeKSI(name); #endif break; case MD_DUMP: if(verbose) fprintf(stdout, "ProcessMode: Dump FileHashes\n"); if (apimode == API_GT) #ifdef ENABLEGT dumpFile(name); #else fprintf(stderr, "ERROR, unable to perform dump using GuardTime Api, rsyslog need to be configured with --enable-guardtime.\n"); #endif if (apimode == API_KSI) #ifdef ENABLEKSI dumpFileKSI(name); #else fprintf(stderr, "ERROR, unable to perform dump using GuardTime KSI Api, rsyslog need to be configured with --enable-gt-ksi.\n"); #endif break; case MD_SHOW_SIGBLK_PARAMS: if(verbose) fprintf(stdout, "ProcessMode: Show SigBlk Params\n"); #ifdef ENABLEGT if (apimode == API_GT) showSigblkParams(name); #endif #ifdef ENABLEKSI if (apimode == API_KSI) showSigblkParamsKSI(name); #endif break; case MD_CONVERT: #ifdef ENABLEGT if (apimode == API_GT) convertFile(name); #endif #ifdef ENABLEKSI if (apimode == API_KSI) convertFileKSI(name); #endif break; case MD_VERIFY: case MD_EXTEND: if(verbose) fprintf(stdout, "ProcessMode: Verify/Extend\n"); verify(name, errbuf); break; } }
TEST_F(MeshVTKLoaderTest, detectFileType) { ASSERT_EQ(MeshVTKLoader::LEGACY, detectFileType(DataRepository.getFile("mesh/liver.vtk").c_str())); ASSERT_EQ(MeshVTKLoader::XML, detectFileType(DataRepository.getFile("mesh/Armadillo_Tetra_4406.vtu").c_str())); }