diff options
author | Oswald Buddenhagen <oswald.buddenhagen@qt.io> | 2018-07-09 17:30:35 +0200 |
---|---|---|
committer | Oswald Buddenhagen <oswald.buddenhagen@qt.io> | 2018-07-16 15:44:14 +0000 |
commit | e2b90768ae2e19fe1a888c4a0ea9f5b31a973811 (patch) | |
tree | f0f2486be4c34a182d7c0888aa58fda4cd675eb0 | |
parent | 317b5d95531d0ee4c42bc0c16a8e4551e17c73a5 (diff) |
qmake: prune dysfunct libtool reader from QMakeMetaInfo
in principle, it would be good to be able to read libtool .la files as
an alternative to our "proprietary" .prl files. however, this code was
disabled 15 years ago, three months after being written and never
released, and apparently no-one was missing it.
Change-Id: Ib8b4b4017b6a611f78af4e357ebce4006567e6ab
Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io>
-rw-r--r-- | qmake/meta.cpp | 75 | ||||
-rw-r--r-- | qmake/meta.h | 1 |
2 files changed, 2 insertions, 74 deletions
diff --git a/qmake/meta.cpp b/qmake/meta.cpp index 6af368bebd..9149b87321 100644 --- a/qmake/meta.cpp +++ b/qmake/meta.cpp @@ -52,10 +52,7 @@ QMakeMetaInfo::readLib(const QString &meta_file) bool ret = false; if(!meta_file.isNull()) { - if (meta_file.endsWith(Option::libtool_ext)) { - if((ret=readLibtoolFile(meta_file))) - meta_type = "libtool"; - } else if(meta_file.endsWith(Option::prl_ext)) { + if (meta_file.endsWith(Option::prl_ext)) { QMakeProject proj; if (!proj.read(Option::normalizePath(meta_file), QMakeEvaluator::LoadProOnly)) return false; @@ -77,7 +74,7 @@ QString QMakeMetaInfo::findLib(const QString &lib) { QString ret; - QString extns[] = { Option::prl_ext, /*Option::libtool_ext,*/ QString() }; + QString extns[] = { Option::prl_ext, QString() }; for(int extn = 0; !extns[extn].isNull(); extn++) { if(lib.endsWith(extns[extn])) ret = QFile::exists(lib) ? lib : QString(); @@ -98,72 +95,4 @@ QMakeMetaInfo::findLib(const QString &lib) return ret; } - -bool -QMakeMetaInfo::readLibtoolFile(const QString &f) -{ - /* I can just run the .la through the .pro parser since they are compatible.. */ - QMakeProject proj; - QString nf = Option::normalizePath(f); - if (!proj.read(nf, QMakeEvaluator::LoadProOnly)) - return false; - QString dirf = nf.section(QLatin1Char('/'), 0, -2); - if(dirf == nf) - dirf = ""; - else if(!dirf.isEmpty() && !dirf.endsWith(Option::output_dir)) - dirf += QLatin1Char('/'); - const ProValueMap &v = proj.variables(); - for (ProValueMap::ConstIterator it = v.begin(); it != v.end(); ++it) { - ProStringList lst = it.value(); - if(lst.count() == 1 && (lst.first().startsWith("'") || lst.first().startsWith("\"")) && - lst.first().endsWith(QString(lst.first().at(0)))) - lst = ProStringList(lst.first().mid(1, lst.first().length() - 2)); - if(!vars.contains("QMAKE_PRL_TARGET") && - (it.key() == "dlname" || it.key() == "library_names" || it.key() == "old_library")) { - ProString dir = v["libdir"].first(); - if ((dir.startsWith('\'') || dir.startsWith('"')) && dir.endsWith(dir.at(0))) - dir = dir.mid(1, dir.length() - 2); - dir = dir.trimmed(); - if(!dir.isEmpty() && !dir.endsWith(QLatin1Char('/'))) - dir += QLatin1Char('/'); - if(lst.count() == 1) - lst = ProStringList(lst.first().toQString().split(" ")); - for (ProStringList::Iterator lst_it = lst.begin(); lst_it != lst.end(); ++lst_it) { - bool found = false; - QString dirs[] = { "", dir.toQString(), dirf, dirf + ".libs/", "(term)" }; - for(int i = 0; !found && dirs[i] != "(term)"; i++) { - if(QFile::exists(dirs[i] + (*lst_it))) { - QString targ = dirs[i] + (*lst_it); - if(QDir::isRelativePath(targ)) - targ.prepend(qmake_getpwd() + QLatin1Char('/')); - vars["QMAKE_PRL_TARGET"] << targ; - found = true; - } - } - if(found) - break; - } - } else if(it.key() == "dependency_libs") { - if(lst.count() == 1) { - ProString dep = lst.first(); - if ((dep.startsWith('\'') || dep.startsWith('"')) && dep.endsWith(dep.at(0))) - dep = dep.mid(1, dep.length() - 2); - lst = ProStringList(dep.trimmed().toQString().split(" ")); - } - for (ProStringList::Iterator lit = lst.begin(); lit != lst.end(); ++lit) { - if((*lit).startsWith("-R")) { - if(!conf->isEmpty("QMAKE_LFLAGS_RPATH")) - (*lit) = conf->first("QMAKE_LFLAGS_RPATH") + (*lit).mid(2); - } - } - ProStringList &prlLibs = vars["QMAKE_PRL_LIBS"]; - for (const ProString &s : qAsConst(lst)) { - prlLibs.removeAll(s); - prlLibs.append(s); - } - } - } - return true; -} - QT_END_NAMESPACE diff --git a/qmake/meta.h b/qmake/meta.h index 98f16b5fc3..456635a9a9 100644 --- a/qmake/meta.h +++ b/qmake/meta.h @@ -41,7 +41,6 @@ class QMakeProject; class QMakeMetaInfo { - bool readLibtoolFile(const QString &f); QMakeProject *conf; ProValueMap vars; QString meta_type; |