From e2b90768ae2e19fe1a888c4a0ea9f5b31a973811 Mon Sep 17 00:00:00 2001 From: Oswald Buddenhagen Date: Mon, 9 Jul 2018 17:30:35 +0200 Subject: 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 --- qmake/meta.cpp | 75 ++-------------------------------------------------------- qmake/meta.h | 1 - 2 files changed, 2 insertions(+), 74 deletions(-) (limited to 'qmake') 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; -- cgit v1.2.3