⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 main.cpp

📁 qt-x11-opensource-src-4.1.4.tar.gz源码
💻 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 + -