📄 main.cpp
字号:
/******************************************************************************** Copyright (C) 1992-2006 Trolltech ASA. All rights reserved.**** This file is part of the Qt Linguist of the Qt Toolkit.**** This file may be used under the terms of the GNU General Public** License version 2.0 as published by the Free Software Foundation** and appearing in the file LICENSE.GPL included in the packaging of** this file. Please review the following information to ensure GNU** General Public Licensing requirements will be met:** http://www.trolltech.com/products/qt/opensource.html**** If you are unsure which license is appropriate for your use, please** review the following information:** http://www.trolltech.com/products/qt/licensing.html or contact the** sales department at sales@trolltech.com.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.******************************************************************************/#include "metatranslator.h"#include "proparser.h"#include <QDir>#include <QFile>#include <QFileInfo>#include <QString>#include <QStringList>#include <QTextStream>#include <errno.h>#include <string.h>// defined in fetchtr.cppextern void fetchtr_cpp( const char *fileName, MetaTranslator *tor, const char *defaultContext, bool mustExist, const QByteArray &codecForSource );extern void fetchtr_ui( const char *fileName, MetaTranslator *tor, const char *defaultContext, bool mustExist );// defined in merge.cppextern void merge( MetaTranslator *tor, const MetaTranslator *virginTor, bool verbose, bool noObsolete );typedef QList<MetaTranslatorMessage> TML;static const char *g_defaultExtensions = "ui,c,c++,cc,cpp,cxx,ch,h,h++,hh,hpp,hxx";static void printUsage(){ fprintf( stderr, "Usage:\n" " lupdate [options] [project-file]\n" " lupdate [options] [source-file|path]... -ts ts-files\n" "Options:\n" " -help Display this information and exit.\n" " -noobsolete\n" " Drop all obsolete strings.\n" " -extensions <ext>[,<ext>]...\n" " Process files with the given extensions only.\n" " The extension list must be separated with commas, not with whitespace.\n" " Default: '%s'.\n" " -verbose\n" " Explain what is being done.\n" " -version\n" " Display the version of lupdate and exit.\n", g_defaultExtensions);}static void updateTsFiles( const MetaTranslator& fetchedTor, const QStringList& tsFileNames, const QString& codecForTr, bool noObsolete, bool verbose ){ QStringList::ConstIterator t = tsFileNames.begin(); while ( t != tsFileNames.end() ) { MetaTranslator tor; tor.load( *t ); if ( !codecForTr.isEmpty() ) tor.setCodec( codecForTr.toLatin1() ); if ( verbose ) fprintf( stderr, "Updating '%s'...\n", (*t).toLatin1().data() ); merge( &tor, &fetchedTor, verbose, noObsolete ); if ( noObsolete ) tor.stripObsoleteMessages(); tor.stripEmptyContexts(); if ( !tor.save(*t) ) {#if defined(_MSC_VER) && _MSC_VER >= 1400 char buf[100]; strerror_s(buf, sizeof(buf), errno); fprintf( stderr, "lupdate error: Cannot save '%s': %s\n", (*t).toLatin1().constData(), buf );#else fprintf( stderr, "lupdate error: Cannot save '%s': %s\n", (*t).toLatin1().constData(), strerror(errno) );#endif } ++t; }}void recursiveFileInfoList(const QDir &dir, const QStringList &nameFilters, QDir::Filters filter, bool recursive, QFileInfoList *fileinfolist){ if (recursive) filter |= QDir::AllDirs; QFileInfoList entries = dir.entryInfoList(nameFilters, filter); QFileInfoList::iterator it; for (it = entries.begin(); it != entries.end(); ++it) { QString fname = it->fileName(); if (fname != QLatin1String(".") && fname != QLatin1String("..")) { if (it->isDir()) { recursiveFileInfoList(QDir(it->absoluteFilePath()), nameFilters, filter, recursive, fileinfolist); }else { fileinfolist->append(*it); } } }}int main( int argc, char **argv ){ QString defaultContext = "@default"; MetaTranslator fetchedTor; QByteArray codecForTr; QByteArray codecForSource; QStringList tsFileNames; bool verbose = false; bool noObsolete = false; bool metSomething = false; int numFiles = 0; bool standardSyntax = true; bool metTsFlag = false; int i; QString extensions = QLatin1String(g_defaultExtensions); QStringList extensionsNameFilters; for ( i = 1; i < argc; i++ ) { if ( qstrcmp(argv[i], "-ts") == 0 ) standardSyntax = false; } for ( i = 1; i < argc; i++ ) { if ( qstrcmp(argv[i], "-help") == 0 ) { printUsage(); return 0; } else if ( qstrcmp(argv[i], "-noobsolete") == 0 ) { noObsolete = true; continue; } else if ( qstrcmp(argv[i], "-verbose") == 0 ) { verbose = true; continue; } else if ( qstrcmp(argv[i], "-version") == 0 ) { fprintf( stderr, "lupdate version %s\n", QT_VERSION_STR ); return 0; } else if ( qstrcmp(argv[i], "-ts") == 0 ) { metTsFlag = true; continue; } else if ( qstrcmp(argv[i], "-extensions") == 0 ) { ++i; if (i == argc) { fprintf( stderr, "The -extensions option should be followed by an extension list."); return 1; } extensions = QString(QLatin1String(argv[i])); continue; } numFiles++; QString fullText; if ( standardSyntax && !metTsFlag ) { QFile f( argv[i] ); if ( !f.open(QIODevice::ReadOnly) ) {#if defined(_MSC_VER) && _MSC_VER >= 1400 char buf[100]; strerror_s(buf, sizeof(buf), errno); fprintf( stderr, "lupdate error: Cannot open file '%s': %s\n", argv[i], buf );#else fprintf( stderr, "lupdate error: Cannot open file '%s': %s\n", argv[i], strerror(errno) );#endif return 1; } QTextStream t( &f ); fullText = t.readAll(); f.close(); } QString oldDir = QDir::currentPath(); if ( standardSyntax ) { QDir::setCurrent( QFileInfo(argv[i]).path() ); fetchedTor = MetaTranslator(); codecForTr.clear(); codecForSource.clear(); tsFileNames.clear(); QMap<QString, QString> tagMap; if (proFileTagMap( fullText, &tagMap )) { QMap<QString, QString>::Iterator it; for ( it = tagMap.begin(); it != tagMap.end(); ++it ) { QStringList toks = tokenizeFileNames(it.value()); QStringList::Iterator t; for ( t = toks.begin(); t != toks.end(); ++t ) { if ( it.key() == "HEADERS" || it.key() == "SOURCES" ) { fetchtr_cpp( (*t).toAscii(), &fetchedTor, defaultContext.toAscii(), true, codecForSource ); metSomething = true; } else if ( it.key() == "INTERFACES" || it.key() == "FORMS" || it.key() == "FORMS3" ) { fetchtr_ui( (*t).toAscii(), &fetchedTor, defaultContext.toAscii(), true ); fetchtr_cpp( (*t).toAscii() + ".h", &fetchedTor, defaultContext.toAscii(), false, codecForSource ); metSomething = true; } else if ( it.key() == "TRANSLATIONS" ) { tsFileNames.append( *t ); metSomething = true; } else if ( it.key() == "CODEC" || it.key() == "DEFAULTCODEC" || it.key() == "CODECFORTR" ) { codecForTr = (*t).toLatin1(); } else if ( it.key() == "CODECFORSRC" ) { codecForSource = (*t).toLatin1(); } } } updateTsFiles( fetchedTor, tsFileNames, codecForTr, noObsolete, verbose ); if ( !metSomething ) { fprintf( stderr, "lupdate warning: File '%s' does not look like a" " project file\n", argv[i] ); } else if ( tsFileNames.isEmpty() ) { fprintf( stderr, "lupdate warning: Met no 'TRANSLATIONS' entry in" " project file '%s'\n", argv[i] ); } } } else { if ( metTsFlag ) { if ( QString(argv[i]).toLower().endsWith(".ts") ) { QFileInfo fi( argv[i] ); if ( !fi.exists() || fi.isWritable() ) { tsFileNames.append( argv[i] ); } else { fprintf( stderr, "lupdate warning: For some reason, I cannot" " save '%s'\n", argv[i] ); } } else { fprintf( stderr, "lupdate error: File '%s' lacks .ts extension\n", argv[i] ); } } else { QFileInfo fi(argv[i]); if (fi.isDir()) { if ( verbose ) fprintf(stderr, "Scanning directory '%s'...\n", argv[i]); QDir dir = QDir(fi.filePath()); if (extensionsNameFilters.isEmpty()) { extensions = extensions.trimmed(); // Remove the potential dot in front of each extension if (extensions.startsWith('.')) extensions.remove(0,1); extensions.replace(",.", ","); extensions.insert(0, QLatin1String("*.")); extensions.replace(',', QLatin1String(",*.")); extensionsNameFilters = extensions.split(','); } QDir::Filters filters = QDir::Files | QDir::NoSymLinks; QFileInfoList fileinfolist; recursiveFileInfoList(dir, extensionsNameFilters, filters, true, &fileinfolist); QFileInfoList::iterator ii; QByteArray fn; for (ii = fileinfolist.begin(); ii != fileinfolist.end(); ++ii) { fn = ii->filePath().toLatin1();#ifdef LINGUIST_DEBUG fprintf(stderr, "%s\n", fn.data());#endif if (fn.toLower().endsWith(".ui") ) { fetchtr_ui( fn, &fetchedTor, defaultContext.toAscii(), true ); } else { fetchtr_cpp( fn, &fetchedTor, defaultContext.toAscii(), true, codecForSource ); } } }else{ if ( QString(argv[i]).toLower().endsWith(".ui") ) { fetchtr_ui( fi.filePath().toAscii(), &fetchedTor, defaultContext.toAscii(), true ); fetchtr_cpp( fi.filePath().toAscii() + ".h", &fetchedTor, defaultContext.toAscii(), false, codecForSource ); } else { fetchtr_cpp( fi.filePath().toAscii(), &fetchedTor, defaultContext.toAscii(), true, codecForSource ); } } } } QDir::setCurrent( oldDir ); } if ( !standardSyntax ) updateTsFiles( fetchedTor, tsFileNames, codecForTr, noObsolete, verbose ); if ( numFiles == 0 ) { printUsage(); return 1; } return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -