mirror of
https://github.com/qbittorrent/qBittorrent
synced 2024-11-14 19:12:46 +01:00
1335 lines
28 KiB
Bash
Executable File
1335 lines
28 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Generated by qconf 1.2 ( http://delta.affinix.com/qconf/ )
|
|
#
|
|
|
|
show_usage() {
|
|
cat <<EOT
|
|
Usage: $0 [OPTION]...
|
|
|
|
This script creates necessary configuration files to build/install.
|
|
|
|
Main options:
|
|
--prefix=[path] Base path for build/install. Default: /usr/local
|
|
--bindir=[path] Directory for binaries. Default: PREFIX/bin
|
|
--datadir=[path] Directory for data. Default: PREFIX/share
|
|
--qtdir=[path] Directory where Qt is installed.
|
|
--verbose Show extra configure output.
|
|
--help This help text.
|
|
|
|
EOT
|
|
}
|
|
|
|
# which/make detection adapted from Qt
|
|
which_command() {
|
|
OLD_HOME=$HOME
|
|
HOME=/dev/null
|
|
export HOME
|
|
|
|
WHICH=`which which 2>/dev/null`
|
|
if echo $WHICH | grep 'shell built-in command' >/dev/null 2>&1; then
|
|
WHICH=which
|
|
elif [ -z "$WHICH" ]; then
|
|
if which which >/dev/null 2>&1; then
|
|
WHICH=which
|
|
else
|
|
for a in /usr/ucb /usr/bin /bin /usr/local/bin; do
|
|
if [ -x $a/which ]; then
|
|
WHICH=$a/which
|
|
break;
|
|
fi
|
|
done
|
|
fi
|
|
fi
|
|
|
|
if [ -z "$WHICH" ]; then
|
|
OLD_IFS=$IFS
|
|
IFS=:
|
|
for a in $PATH; do
|
|
if [ -x $a/$1 ]; then
|
|
echo "$a/$1"
|
|
IFS=$OLD_IFS
|
|
export IFS
|
|
HOME=$OLD_HOME
|
|
export HOME
|
|
return 0
|
|
fi
|
|
done
|
|
IFS=$OLD_IFS
|
|
export IFS
|
|
else
|
|
a=`"$WHICH" "$1" 2>/dev/null`
|
|
if [ ! -z "$a" -a -x "$a" ]; then
|
|
echo "$a"
|
|
HOME=$OLD_HOME
|
|
export HOME
|
|
return 0
|
|
fi
|
|
fi
|
|
HOME=$OLD_HOME
|
|
export HOME
|
|
return 1
|
|
}
|
|
WHICH=which_command
|
|
|
|
# find a make command
|
|
if [ -z "$MAKE" ]; then
|
|
MAKE=
|
|
for mk in gmake make; do
|
|
if $WHICH $mk >/dev/null 2>&1; then
|
|
MAKE=`$WHICH $mk`
|
|
break
|
|
fi
|
|
done
|
|
if [ -z "$MAKE" ]; then
|
|
echo "You don't seem to have 'make' or 'gmake' in your PATH."
|
|
echo "Cannot proceed."
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
show_qt_info() {
|
|
printf "Be sure you have a proper Qt 4.0 build environment set up. This means not\n"
|
|
printf "just Qt, but also a C++ compiler, a make tool, and any other packages\n"
|
|
printf "necessary for compiling C++ programs.\n"
|
|
printf "\n"
|
|
printf "If you are certain everything is installed, then it could be that Qt 4 is not\n"
|
|
printf "being recognized or that a different version of Qt is being detected by\n"
|
|
printf "mistake (for example, this could happen if \$QTDIR is pointing to a Qt 3\n"
|
|
printf "installation). At least one of the following conditions must be satisfied:\n"
|
|
printf "\n"
|
|
printf " 1) --qtdir is set to the location of Qt\n"
|
|
printf " 2) \$QTDIR is set to the location of Qt\n"
|
|
printf " 3) QtCore is in the pkg-config database\n"
|
|
printf " 4) qmake is in the \$PATH\n"
|
|
printf "\n"
|
|
printf "This script will use the first one it finds to be true, checked in the above\n"
|
|
printf "order. #3 and #4 are the recommended options. #1 and #2 are mainly for\n"
|
|
printf "overriding the system configuration.\n"
|
|
printf "\n"
|
|
}
|
|
|
|
while [ $# -gt 0 ]; do
|
|
optarg=`expr "x$1" : 'x[^=]*=\(.*\)'`
|
|
case "$1" in
|
|
--prefix=*)
|
|
PREFIX=$optarg
|
|
shift
|
|
;;
|
|
|
|
--bindir=*)
|
|
BINDIR=$optarg
|
|
shift
|
|
;;
|
|
|
|
--datadir=*)
|
|
DATADIR=$optarg
|
|
shift
|
|
;;
|
|
|
|
--qtdir=*)
|
|
EX_QTDIR=$optarg
|
|
shift
|
|
;;
|
|
|
|
--verbose)
|
|
QC_DEBUG="Y"
|
|
shift
|
|
;;
|
|
--help) show_usage; exit ;;
|
|
*) show_usage; exit ;;
|
|
esac
|
|
done
|
|
|
|
PREFIX=${PREFIX:-/usr/local}
|
|
BINDIR=${BINDIR:-$PREFIX/bin}
|
|
DATADIR=${DATADIR:-$PREFIX/share}
|
|
|
|
echo "Configuring qbittorrent ..."
|
|
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo
|
|
echo PREFIX=$PREFIX
|
|
echo BINDIR=$BINDIR
|
|
echo DATADIR=$DATADIR
|
|
echo EX_QTDIR=$EX_QTDIR
|
|
echo
|
|
fi
|
|
|
|
printf "Verifying Qt 4 build environment ... "
|
|
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo
|
|
fi
|
|
|
|
qm=""
|
|
|
|
# qt4 check: --qtdir
|
|
if [ -z "$qm" ]; then
|
|
qstr=$EX_QTDIR/bin/qmake
|
|
if [ -x "$qstr" ]; then
|
|
qm=$qstr
|
|
fi
|
|
fi
|
|
if [ -z "$qm" ] && [ "$QC_DEBUG" = "Y" ]; then
|
|
echo "Warning: qmake not found via --qtdir"
|
|
fi
|
|
|
|
# qt4 check: QTDIR
|
|
if [ -z "$qm" ]; then
|
|
qstr=$QTDIR/bin/qmake
|
|
if [ -x "$qstr" ]; then
|
|
qm=$qstr
|
|
fi
|
|
fi
|
|
if [ -z "$qm" ] && [ "$QC_DEBUG" = "Y" ]; then
|
|
echo "Warning: qmake not found via \$QTDIR"
|
|
fi
|
|
|
|
# qt4 check: pkg-config
|
|
if [ -z "$qm" ]; then
|
|
str=`pkg-config QtCore --variable=exec_prefix 2>/dev/null`
|
|
if [ ! -z "$str" ]; then
|
|
qstr=$str/bin/qmake
|
|
if [ -x "$qstr" ]; then
|
|
qm=$qstr
|
|
fi
|
|
fi
|
|
fi
|
|
if [ -z "$qm" ] && [ "$QC_DEBUG" = "Y" ]; then
|
|
echo "Warning: qmake not found via pkg-config"
|
|
fi
|
|
|
|
# qt4 check: PATH
|
|
if [ -z "$qm" ]; then
|
|
qstr=`$WHICH qmake 2>/dev/null`
|
|
if [ -x "$qstr" ]; then
|
|
qm=$qstr
|
|
fi
|
|
fi
|
|
if [ -z "$qm" ] && [ "$QC_DEBUG" = "Y" ]; then
|
|
echo "Warning: qmake not found via \$PATH"
|
|
fi
|
|
|
|
if [ -z "$qm" ]; then
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo " -> fail"
|
|
else
|
|
echo "fail"
|
|
fi
|
|
printf "\n"
|
|
printf "Reason: Unable to find the 'qmake' tool.\n"
|
|
printf "\n"
|
|
show_qt_info
|
|
exit 1;
|
|
fi
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo qmake found in $qm
|
|
fi
|
|
|
|
gen_files() {
|
|
cat >$1/modules.cpp <<EOT
|
|
#line 1 "qt41.qcm"
|
|
/*
|
|
-----BEGIN QCMOD-----
|
|
name: Qt >= 4.1
|
|
-----END QCMOD-----
|
|
*/
|
|
class qc_qt41 : public ConfObj
|
|
{
|
|
public:
|
|
qc_qt41(Conf *c) : ConfObj(c) {}
|
|
QString name() const { return "Qt >= 4.1"; }
|
|
QString shortname() const { return "qt41"; }
|
|
bool exec()
|
|
{
|
|
return(QT_VERSION >= 0x040100);
|
|
}
|
|
};
|
|
#line 1 "libtorrent.qcm"
|
|
/*
|
|
-----BEGIN QCMOD-----
|
|
name: libtorrent
|
|
-----END QCMOD-----
|
|
*/
|
|
class qc_libtorrent : public ConfObj
|
|
{
|
|
public:
|
|
qc_libtorrent(Conf *c) : ConfObj(c) {}
|
|
QString name() const { return "libtorrent >= 0.11"; }
|
|
QString shortname() const { return "libtorrent"; }
|
|
bool exec(){
|
|
QString s;
|
|
QStringList sl;
|
|
sl += "/usr/include";
|
|
sl += "/usr/local/include";
|
|
sl += "/sw/include";
|
|
if(!conf->findHeader("libtorrent/kademlia/node.hpp", sl, &s)) {
|
|
qWarning("libtorrent v0.11 includes not found!\nYou can download it at http://www.libtorrent.net");
|
|
return false;
|
|
}
|
|
conf->addIncludePath(s);
|
|
return true;
|
|
}
|
|
};
|
|
#line 1 "libboost.qcm"
|
|
/*
|
|
-----BEGIN QCMOD-----
|
|
name: libboost
|
|
-----END QCMOD-----
|
|
*/
|
|
class qc_libboost : public ConfObj
|
|
{
|
|
public:
|
|
qc_libboost(Conf *c) : ConfObj(c) {}
|
|
QString name() const { return "libboost"; }
|
|
QString shortname() const { return "libboost"; }
|
|
bool exec(){
|
|
QString s;
|
|
QStringList sl;
|
|
sl += "/usr/include";
|
|
sl += "/usr/local/include";
|
|
sl += "/sw/include";
|
|
if(!conf->findHeader("boost/format.hpp", sl, &s)) {
|
|
qWarning("libboost includes not found!");
|
|
return false;
|
|
}
|
|
conf->addIncludePath(s);
|
|
if(!conf->findHeader("boost/date_time/posix_time/posix_time.hpp", sl, &s)) {
|
|
qWarning("libboost-date-time includes not found!");
|
|
return false;
|
|
}
|
|
conf->addIncludePath(s);
|
|
if(!conf->findHeader("boost/filesystem/path.hpp", sl, &s)) {
|
|
qWarning("libboost-filesystem includes not found!");
|
|
return false;
|
|
}
|
|
if(!conf->findHeader("boost/thread.hpp", sl, &s)) {
|
|
qWarning("libboost-thread includes not found!");
|
|
return false;
|
|
}
|
|
conf->addIncludePath(s);
|
|
|
|
return true;
|
|
}
|
|
};
|
|
#line 1 "libcurl.qcm"
|
|
/*
|
|
-----BEGIN QCMOD-----
|
|
name: libcurl
|
|
-----END QCMOD-----
|
|
*/
|
|
class qc_libcurl : public ConfObj
|
|
{
|
|
public:
|
|
qc_libcurl(Conf *c) : ConfObj(c) {}
|
|
QString name() const { return "libcurl"; }
|
|
QString shortname() const { return "libcurl"; }
|
|
bool exec(){
|
|
QString s;
|
|
QStringList sl;
|
|
sl += "/usr/include";
|
|
sl += "/usr/local/include";
|
|
sl += "/sw/include";
|
|
if(!conf->findHeader("curl/curl.h", sl, &s)) {
|
|
qWarning("libcurl includes not found!\n");
|
|
return false;
|
|
}
|
|
conf->addIncludePath(s);
|
|
return true;
|
|
}
|
|
};
|
|
#line 1 "python.qcm"
|
|
/*
|
|
-----BEGIN QCMOD-----
|
|
name: python
|
|
-----END QCMOD-----
|
|
*/
|
|
class qc_python : public ConfObj
|
|
{
|
|
public:
|
|
qc_python(Conf *c) : ConfObj(c) {}
|
|
QString name() const { return "python >= 2.3"; }
|
|
QString shortname() const { return "python"; }
|
|
bool exec(){
|
|
int r = conf->doCommand("python testpython.py");
|
|
if(r == 0)
|
|
return true;
|
|
else
|
|
return false;
|
|
}
|
|
};
|
|
|
|
EOT
|
|
cat >$1/modules_new.cpp <<EOT
|
|
o = new qc_qt41(conf);
|
|
o->required = true;
|
|
o->disabled = false;
|
|
o = new qc_libtorrent(conf);
|
|
o->required = true;
|
|
o->disabled = false;
|
|
o = new qc_libboost(conf);
|
|
o->required = true;
|
|
o->disabled = false;
|
|
o = new qc_libcurl(conf);
|
|
o->required = true;
|
|
o->disabled = false;
|
|
o = new qc_python(conf);
|
|
o->required = true;
|
|
o->disabled = false;
|
|
|
|
EOT
|
|
cat >$1/conf4.h <<EOT
|
|
#ifndef QC_CONF4_H
|
|
#define QC_CONF4_H
|
|
|
|
#include <QtCore>
|
|
|
|
class Conf;
|
|
|
|
enum VersionMode { VersionMin, VersionExact, VersionMax, VersionAny };
|
|
|
|
// ConfObj
|
|
//
|
|
// Subclass ConfObj to create a new configuration module.
|
|
class ConfObj
|
|
{
|
|
public:
|
|
Conf *conf;
|
|
bool required;
|
|
bool disabled;
|
|
bool success;
|
|
|
|
ConfObj(Conf *c);
|
|
virtual ~ConfObj();
|
|
|
|
// long or descriptive name of what is being checked/performed
|
|
// example: "KDE >= 3.3"
|
|
virtual QString name() const = 0;
|
|
|
|
// short name
|
|
// example: "kde"
|
|
virtual QString shortname() const = 0;
|
|
|
|
// string to display during check
|
|
// default: "Checking for [name] ..."
|
|
virtual QString checkString() const;
|
|
|
|
// string to display after check
|
|
// default: "yes" or "no", based on result of exec()
|
|
virtual QString resultString() const;
|
|
|
|
// this is where the checking code goes
|
|
virtual bool exec() = 0;
|
|
};
|
|
|
|
// Conf
|
|
//
|
|
// Interact with this class from your ConfObj to perform detection
|
|
// operations and to output configuration parameters.
|
|
class Conf
|
|
{
|
|
public:
|
|
bool debug_enabled;
|
|
QString qmake_path;
|
|
QString maketool;
|
|
|
|
QString DEFINES;
|
|
QString INCLUDEPATH;
|
|
QString LIBS;
|
|
QString extra;
|
|
|
|
QList<ConfObj*> list;
|
|
QMap<QString,QString> vars;
|
|
|
|
Conf();
|
|
~Conf();
|
|
|
|
QString getenv(const QString &var);
|
|
QString qvar(const QString &s);
|
|
|
|
bool exec();
|
|
|
|
void debug(const QString &s);
|
|
|
|
QString expandIncludes(const QString &inc);
|
|
QString expandLibs(const QString &lib);
|
|
|
|
int doCommand(const QString &s, QByteArray *out = 0);
|
|
int doCommand(const QString &prog, const QStringList &args, QByteArray *out = 0);
|
|
|
|
bool doCompileAndLink(const QString &filedata, const QStringList &incs, const QString &libs, const QString &proextra, int *retcode = 0);
|
|
bool checkHeader(const QString &path, const QString &h);
|
|
bool findHeader(const QString &h, const QStringList &ext, QString *inc);
|
|
bool checkLibrary(const QString &path, const QString &name);
|
|
bool findLibrary(const QString &name, QString *lib);
|
|
QString findProgram(const QString &prog);
|
|
bool findSimpleLibrary(const QString &incvar, const QString &libvar, const QString &incname, const QString &libname, QString *incpath, QString *libs);
|
|
bool findFooConfig(const QString &path, QString *version, QStringList *incs, QString *libs, QString *otherflags);
|
|
bool findPkgConfig(const QString &name, VersionMode mode, const QString &req_version, QString *version, QStringList *incs, QString *libs, QString *otherflags);
|
|
|
|
void addDefine(const QString &str);
|
|
void addLib(const QString &str);
|
|
void addIncludePath(const QString &str);
|
|
void addExtra(const QString &str);
|
|
|
|
private:
|
|
bool first_debug;
|
|
|
|
friend class ConfObj;
|
|
void added(ConfObj *o);
|
|
};
|
|
|
|
#endif
|
|
|
|
EOT
|
|
cat >$1/conf4.cpp <<EOT
|
|
#include "conf4.h"
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
class MocTestObject : public QObject
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
MocTestObject() {}
|
|
};
|
|
|
|
QString qc_getenv(const QString &var)
|
|
{
|
|
char *p = ::getenv(var.toLatin1().data());
|
|
if(!p)
|
|
return QString();
|
|
return QString(p);
|
|
}
|
|
|
|
QStringList qc_pathlist()
|
|
{
|
|
QStringList list;
|
|
QString path = qc_getenv("PATH");
|
|
if(!path.isEmpty())
|
|
list = path.split(':', QString::SkipEmptyParts);
|
|
return list;
|
|
}
|
|
|
|
QString qc_findprogram(const QString &prog)
|
|
{
|
|
QString out;
|
|
QStringList list = qc_pathlist();
|
|
for(int n = 0; n < list.count(); ++n)
|
|
{
|
|
QFileInfo fi(list[n] + '/' + prog);
|
|
if(fi.exists() && fi.isExecutable())
|
|
{
|
|
out = fi.filePath();
|
|
break;
|
|
}
|
|
}
|
|
return out;
|
|
}
|
|
|
|
QString qc_findself(const QString &argv0)
|
|
{
|
|
if(argv0.contains('/'))
|
|
return argv0;
|
|
else
|
|
return qc_findprogram(argv0);
|
|
}
|
|
|
|
int qc_runcommand(const QString &command, QByteArray *out, bool showOutput)
|
|
{
|
|
QString fullcmd = command;
|
|
if(!showOutput)
|
|
fullcmd += " 2>/dev/null";
|
|
FILE *f = popen(fullcmd.toLatin1().data(), "r");
|
|
if(!f)
|
|
return -1;
|
|
if(out)
|
|
out->clear();
|
|
while(1)
|
|
{
|
|
char c = (char)fgetc(f);
|
|
if(feof(f))
|
|
break;
|
|
if(out)
|
|
out->append(c);
|
|
if(showOutput)
|
|
fputc(c, stdout);
|
|
}
|
|
int ret = pclose(f);
|
|
if(ret == -1)
|
|
return -1;
|
|
return ret;
|
|
}
|
|
|
|
int qc_runprogram(const QString &prog, const QStringList &args, QByteArray *out, bool showOutput)
|
|
{
|
|
QString fullcmd = prog;
|
|
QString argstr = args.join(" ");
|
|
if(!argstr.isEmpty())
|
|
fullcmd += QString(" ") + argstr;
|
|
return qc_runcommand(fullcmd, out, showOutput);
|
|
|
|
// TODO: use QProcess once it is fixed
|
|
/*
|
|
QProcess process;
|
|
if(showOutput)
|
|
process.setReadChannelMode(ForwardedChannels);
|
|
process.start(prog, args);
|
|
process.waitForFinished(-1);
|
|
return process.exitCode();
|
|
*/
|
|
}
|
|
|
|
void qc_splitcflags(const QString &cflags, QStringList *incs, QStringList *otherflags)
|
|
{
|
|
incs->clear();
|
|
otherflags->clear();
|
|
|
|
QStringList cflagsList = cflags.split(" ");
|
|
for(int n = 0; n < cflagsList.count(); ++n)
|
|
{
|
|
QString str = cflagsList[n];
|
|
if(str.startsWith("-I"))
|
|
{
|
|
// we want everything except the leading "-I"
|
|
incs->append(str.remove(0, 2));
|
|
}
|
|
else
|
|
{
|
|
// we want whatever is left
|
|
otherflags->append(str);
|
|
}
|
|
}
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
// ConfObj
|
|
//----------------------------------------------------------------------------
|
|
ConfObj::ConfObj(Conf *c)
|
|
{
|
|
conf = c;
|
|
conf->added(this);
|
|
required = false;
|
|
disabled = false;
|
|
success = false;
|
|
}
|
|
|
|
ConfObj::~ConfObj()
|
|
{
|
|
}
|
|
|
|
QString ConfObj::checkString() const
|
|
{
|
|
return QString("Checking for %1 ...").arg(name());
|
|
}
|
|
|
|
QString ConfObj::resultString() const
|
|
{
|
|
if(success)
|
|
return "yes";
|
|
else
|
|
return "no";
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
// qc_internal_pkgconfig
|
|
//----------------------------------------------------------------------------
|
|
class qc_internal_pkgconfig : public ConfObj
|
|
{
|
|
public:
|
|
QString pkgname, desc;
|
|
VersionMode mode;
|
|
QString req_ver;
|
|
|
|
qc_internal_pkgconfig(Conf *c, const QString &_name, const QString &_desc, VersionMode _mode, const QString &_req_ver) : ConfObj(c)
|
|
{
|
|
pkgname = _name;
|
|
desc = _desc;
|
|
mode = _mode;
|
|
req_ver = _req_ver;
|
|
}
|
|
|
|
QString name() const { return desc; }
|
|
QString shortname() const { return pkgname; }
|
|
|
|
bool exec()
|
|
{
|
|
QStringList incs;
|
|
QString version, libs, other;
|
|
if(!conf->findPkgConfig(pkgname, mode, req_ver, &version, &incs, &libs, &other))
|
|
return false;
|
|
|
|
for(int n = 0; n < incs.count(); ++n)
|
|
conf->addIncludePath(incs[n]);
|
|
if(!libs.isEmpty())
|
|
conf->addLib(libs);
|
|
//if(!other.isEmpty())
|
|
// conf->addExtra(QString("QMAKE_CFLAGS += %1\n").arg(other));
|
|
return true;
|
|
}
|
|
};
|
|
|
|
//----------------------------------------------------------------------------
|
|
// Conf
|
|
//----------------------------------------------------------------------------
|
|
Conf::Conf()
|
|
{
|
|
// TODO: no more vars?
|
|
//vars.insert("QMAKE_INCDIR_X11", new QString(X11_INC));
|
|
//vars.insert("QMAKE_LIBDIR_X11", new QString(X11_LIBDIR));
|
|
//vars.insert("QMAKE_LIBS_X11", new QString(X11_LIB));
|
|
//vars.insert("QMAKE_CC", CC);
|
|
|
|
debug_enabled = false;
|
|
}
|
|
|
|
Conf::~Conf()
|
|
{
|
|
qDeleteAll(list);
|
|
}
|
|
|
|
void Conf::added(ConfObj *o)
|
|
{
|
|
list.append(o);
|
|
}
|
|
|
|
QString Conf::getenv(const QString &var)
|
|
{
|
|
return qc_getenv(var);
|
|
}
|
|
|
|
void Conf::debug(const QString &s)
|
|
{
|
|
if(debug_enabled)
|
|
{
|
|
if(first_debug)
|
|
printf("\n");
|
|
first_debug = false;
|
|
printf(" * %s\n", qPrintable(s));
|
|
}
|
|
}
|
|
|
|
bool Conf::exec()
|
|
{
|
|
for(int n = 0; n < list.count(); ++n)
|
|
{
|
|
ConfObj *o = list[n];
|
|
|
|
// if this was a disabled-by-default option, check if it was enabled
|
|
if(o->disabled)
|
|
{
|
|
QString v = QString("QC_ENABLE_") + o->shortname();
|
|
if(getenv(v) != "Y")
|
|
continue;
|
|
}
|
|
// and the opposite?
|
|
else
|
|
{
|
|
QString v = QString("QC_DISABLE_") + o->shortname();
|
|
if(getenv(v) == "Y")
|
|
continue;
|
|
}
|
|
|
|
bool output = true;
|
|
QString check = o->checkString();
|
|
if(check.isEmpty())
|
|
output = false;
|
|
|
|
if(output)
|
|
{
|
|
printf("%s", check.toLatin1().data());
|
|
fflush(stdout);
|
|
}
|
|
|
|
first_debug = true;
|
|
bool ok = o->exec();
|
|
o->success = ok;
|
|
|
|
if(output)
|
|
{
|
|
QString result = o->resultString();
|
|
if(!first_debug)
|
|
printf(" -> %s\n", result.toLatin1().data());
|
|
else
|
|
printf(" %s\n", result.toLatin1().data());
|
|
}
|
|
|
|
if(!ok && o->required)
|
|
{
|
|
printf("\nError: need %s!\n", o->name().toLatin1().data());
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
QString Conf::qvar(const QString &s)
|
|
{
|
|
return vars.value(s);
|
|
}
|
|
|
|
QString Conf::expandIncludes(const QString &inc)
|
|
{
|
|
return QString("-I") + inc;
|
|
}
|
|
|
|
QString Conf::expandLibs(const QString &lib)
|
|
{
|
|
return QString("-L") + lib;
|
|
}
|
|
|
|
int Conf::doCommand(const QString &s, QByteArray *out)
|
|
{
|
|
debug(QString("[%1]").arg(s));
|
|
int r = qc_runcommand(s, out, debug_enabled);
|
|
debug(QString("returned: %1").arg(r));
|
|
return r;
|
|
}
|
|
|
|
int Conf::doCommand(const QString &prog, const QStringList &args, QByteArray *out)
|
|
{
|
|
QString fullcmd = prog;
|
|
QString argstr = args.join(" ");
|
|
if(!argstr.isEmpty())
|
|
fullcmd += QString(" ") + argstr;
|
|
debug(QString("[%1]").arg(fullcmd));
|
|
int r = qc_runprogram(prog, args, out, debug_enabled);
|
|
debug(QString("returned: %1").arg(r));
|
|
return r;
|
|
}
|
|
|
|
bool Conf::doCompileAndLink(const QString &filedata, const QStringList &incs, const QString &libs, const QString &proextra, int *retcode)
|
|
{
|
|
QDir tmp(".qconftemp");
|
|
if(!tmp.mkdir("atest"))
|
|
{
|
|
debug("unable to create atest dir");
|
|
return false;
|
|
}
|
|
QDir dir(tmp.filePath("atest"));
|
|
if(!dir.exists())
|
|
{
|
|
debug("atest dir does not exist");
|
|
return false;
|
|
}
|
|
|
|
QString fname = dir.filePath("atest.cpp");
|
|
QString out = "atest";
|
|
QFile f(fname);
|
|
if(!f.open(QFile::WriteOnly | QFile::Truncate))
|
|
{
|
|
debug("unable to open atest.cpp for writing");
|
|
return false;
|
|
}
|
|
if(f.write(filedata.toLatin1()) == -1)
|
|
{
|
|
debug("error writing to atest.cpp");
|
|
return false;
|
|
}
|
|
f.close();
|
|
|
|
debug(QString("Wrote atest.cpp:\n%1").arg(filedata));
|
|
|
|
QString pro = QString(
|
|
"CONFIG += console\n"
|
|
"CONFIG -= qt app_bundle\n"
|
|
"SOURCES += atest.cpp\n");
|
|
QString inc = incs.join(" ");
|
|
if(!inc.isEmpty())
|
|
pro += "INCLUDEPATH += " + inc + '\n';
|
|
if(!libs.isEmpty())
|
|
pro += "LIBS += " + libs + '\n';
|
|
pro += proextra;
|
|
|
|
fname = dir.filePath("atest.pro");
|
|
f.setFileName(fname);
|
|
if(!f.open(QFile::WriteOnly | QFile::Truncate))
|
|
{
|
|
debug("unable to open atest.pro for writing");
|
|
return false;
|
|
}
|
|
if(f.write(pro.toLatin1()) == -1)
|
|
{
|
|
debug("error writing to atest.pro");
|
|
return false;
|
|
}
|
|
f.close();
|
|
|
|
debug(QString("Wrote atest.pro:\n%1").arg(pro));
|
|
|
|
QString oldpath = QDir::currentPath();
|
|
QDir::setCurrent(dir.path());
|
|
|
|
bool ok = false;
|
|
int r = doCommand(qmake_path, QStringList() << "atest.pro");
|
|
if(r == 0)
|
|
{
|
|
r = doCommand(maketool, QStringList());
|
|
if(r == 0)
|
|
{
|
|
ok = true;
|
|
if(retcode)
|
|
*retcode = doCommand(QString("./") + out, QStringList());
|
|
}
|
|
r = doCommand(maketool, QStringList() << "distclean");
|
|
if(r != 0)
|
|
debug("error during atest distclean");
|
|
}
|
|
|
|
QDir::setCurrent(oldpath);
|
|
|
|
// cleanup
|
|
dir.remove("atest.pro");
|
|
dir.remove("atest.cpp");
|
|
tmp.rmdir("atest");
|
|
|
|
if(!ok)
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
bool Conf::checkHeader(const QString &path, const QString &h)
|
|
{
|
|
QFileInfo fi(path + '/' + h);
|
|
if(fi.exists())
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
bool Conf::findHeader(const QString &h, const QStringList &ext, QString *inc)
|
|
{
|
|
if(checkHeader("/usr/include", h))
|
|
{
|
|
*inc = "";
|
|
return true;
|
|
}
|
|
QStringList dirs;
|
|
dirs += "/usr/local/include";
|
|
dirs += ext;
|
|
for(QStringList::ConstIterator it = dirs.begin(); it != dirs.end(); ++it)
|
|
{
|
|
if(checkHeader(*it, h))
|
|
{
|
|
*inc = *it;
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool Conf::checkLibrary(const QString &path, const QString &name)
|
|
{
|
|
QString str =
|
|
//"#include <stdio.h>\n"
|
|
"int main()\n"
|
|
"{\n"
|
|
//" printf(\"library checker running\\\\n\");\n"
|
|
" return 0;\n"
|
|
"}\n";
|
|
|
|
QString libs;
|
|
if(!path.isEmpty())
|
|
libs += QString("-L") + path + ' ';
|
|
libs += QString("-l") + name;
|
|
if(!doCompileAndLink(str, QStringList(), libs, QString()))
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
bool Conf::findLibrary(const QString &name, QString *lib)
|
|
{
|
|
if(checkLibrary("", name))
|
|
{
|
|
*lib = "";
|
|
return true;
|
|
}
|
|
if(checkLibrary("/usr/local/lib", name))
|
|
{
|
|
*lib = "/usr/local/lib";
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
QString Conf::findProgram(const QString &prog)
|
|
{
|
|
return qc_findprogram(prog);
|
|
}
|
|
|
|
bool Conf::findSimpleLibrary(const QString &incvar, const QString &libvar, const QString &incname, const QString &libname, QString *incpath, QString *libs)
|
|
{
|
|
QString inc, lib;
|
|
QString s;
|
|
|
|
s = getenv(incvar);
|
|
if(!s.isEmpty()) {
|
|
if(!checkHeader(s, incname))
|
|
return false;
|
|
inc = s;
|
|
}
|
|
else {
|
|
if(!findHeader(incname, QStringList(), &s))
|
|
return false;
|
|
inc = s;
|
|
}
|
|
|
|
s = getenv(libvar);
|
|
if(!s.isEmpty()) {
|
|
if(!checkLibrary(s, libname))
|
|
return false;
|
|
lib = s;
|
|
}
|
|
else {
|
|
if(!findLibrary(libname, &s))
|
|
return false;
|
|
lib = s;
|
|
}
|
|
|
|
QString lib_out;
|
|
if(!lib.isEmpty())
|
|
lib_out += QString("-L") + s;
|
|
lib_out += QString("-l") + libname;
|
|
|
|
*incpath = inc;
|
|
*libs = lib_out;
|
|
return true;
|
|
}
|
|
|
|
bool Conf::findFooConfig(const QString &path, QString *version, QStringList *incs, QString *libs, QString *otherflags)
|
|
{
|
|
QStringList args;
|
|
QByteArray out;
|
|
int ret;
|
|
|
|
args += "--version";
|
|
ret = doCommand(path, args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
QString version_out = QString::fromLatin1(out).trimmed();
|
|
|
|
args.clear();
|
|
args += "--libs";
|
|
ret = doCommand(path, args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
QString libs_out = QString::fromLatin1(out).trimmed();
|
|
|
|
args.clear();
|
|
args += "--cflags";
|
|
ret = doCommand(path, args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
QString cflags = QString::fromLatin1(out).trimmed();
|
|
|
|
QStringList incs_out, otherflags_out;
|
|
qc_splitcflags(cflags, &incs_out, &otherflags_out);
|
|
|
|
*version = version_out;
|
|
*incs = incs_out;
|
|
*libs = libs_out;
|
|
*otherflags = otherflags_out.join(" ");
|
|
return true;
|
|
}
|
|
|
|
bool Conf::findPkgConfig(const QString &name, VersionMode mode, const QString &req_version, QString *version, QStringList *incs, QString *libs, QString *otherflags)
|
|
{
|
|
QStringList args;
|
|
QByteArray out;
|
|
int ret;
|
|
|
|
args += name;
|
|
args += "--exists";
|
|
ret = doCommand("pkg-config", args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
if(mode != VersionAny)
|
|
{
|
|
args.clear();
|
|
args += name;
|
|
if(mode == VersionMin)
|
|
args += QString("--atleast-version=%1").arg(req_version);
|
|
else if(mode == VersionMax)
|
|
args += QString("--max-version=%1").arg(req_version);
|
|
else
|
|
args += QString("--exact-version=%1").arg(req_version);
|
|
ret = doCommand("pkg-config", args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
}
|
|
|
|
args.clear();
|
|
args += name;
|
|
args += "--modversion";
|
|
ret = doCommand("pkg-config", args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
QString version_out = QString::fromLatin1(out).trimmed();
|
|
|
|
args.clear();
|
|
args += name;
|
|
args += "--libs";
|
|
ret = doCommand("pkg-config", args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
QString libs_out = QString::fromLatin1(out).trimmed();
|
|
|
|
args.clear();
|
|
args += name;
|
|
args += "--cflags";
|
|
ret = doCommand("pkg-config", args, &out);
|
|
if(ret != 0)
|
|
return false;
|
|
|
|
QString cflags = QString::fromLatin1(out).trimmed();
|
|
|
|
QStringList incs_out, otherflags_out;
|
|
qc_splitcflags(cflags, &incs_out, &otherflags_out);
|
|
|
|
*version = version_out;
|
|
*incs = incs_out;
|
|
*libs = libs_out;
|
|
*otherflags = otherflags_out.join(" ");
|
|
return true;
|
|
}
|
|
|
|
void Conf::addDefine(const QString &str)
|
|
{
|
|
if(DEFINES.isEmpty())
|
|
DEFINES = str;
|
|
else
|
|
DEFINES += QString(" ") + str;
|
|
debug(QString("DEFINES += %1").arg(str));
|
|
}
|
|
|
|
void Conf::addLib(const QString &str)
|
|
{
|
|
if(LIBS.isEmpty())
|
|
LIBS = str;
|
|
else
|
|
LIBS += QString(" ") + str;
|
|
debug(QString("LIBS += %1").arg(str));
|
|
}
|
|
|
|
void Conf::addIncludePath(const QString &str)
|
|
{
|
|
if(INCLUDEPATH.isEmpty())
|
|
INCLUDEPATH = str;
|
|
else
|
|
INCLUDEPATH += QString(" ") + str;
|
|
debug(QString("INCLUDEPATH += %1").arg(str));
|
|
}
|
|
|
|
void Conf::addExtra(const QString &str)
|
|
{
|
|
extra += str + '\n';
|
|
debug(QString("extra += %1").arg(str));
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
// main
|
|
//----------------------------------------------------------------------------
|
|
#include "conf4.moc"
|
|
|
|
#ifdef HAVE_MODULES
|
|
# include"modules.cpp"
|
|
#endif
|
|
|
|
int main()
|
|
{
|
|
Conf *conf = new Conf;
|
|
ConfObj *o;
|
|
o = 0;
|
|
#ifdef HAVE_MODULES
|
|
# include"modules_new.cpp"
|
|
#endif
|
|
|
|
conf->debug_enabled = (qc_getenv("QC_DEBUG") == "Y") ? true: false;
|
|
if(conf->debug_enabled)
|
|
printf(" -> ok\n");
|
|
else
|
|
printf("ok\n");
|
|
|
|
QString confCommand = qc_getenv("QC_COMMAND");
|
|
QString proName = qc_getenv("QC_PROFILE");
|
|
conf->qmake_path = qc_getenv("QC_QMAKE");
|
|
conf->maketool = qc_getenv("QC_MAKETOOL");
|
|
|
|
if(conf->debug_enabled)
|
|
printf("conf command: [%s]\n", qPrintable(confCommand));
|
|
|
|
QString confPath = qc_findself(confCommand);
|
|
if(confPath.isEmpty())
|
|
{
|
|
printf("Error: cannot find myself; rerun with an absolute path\n");
|
|
return 1;
|
|
}
|
|
|
|
QString srcdir = QFileInfo(confPath).absolutePath();
|
|
QString builddir = QDir::current().absolutePath();
|
|
QString proPath = QDir(srcdir).filePath(proName);
|
|
|
|
if(conf->debug_enabled)
|
|
{
|
|
printf("conf path: [%s]\n", qPrintable(confPath));
|
|
printf("srcdir: [%s]\n", qPrintable(srcdir));
|
|
printf("builddir: [%s]\n", qPrintable(builddir));
|
|
printf("profile: [%s]\n", qPrintable(proPath));
|
|
printf("qmake path: [%s]\n", qPrintable(conf->qmake_path));
|
|
printf("make tool: [%s]\n", qPrintable(conf->maketool));
|
|
printf("\n");
|
|
}
|
|
|
|
bool success = false;
|
|
if(conf->exec())
|
|
{
|
|
QFile f("conf.pri");
|
|
if(!f.open(QFile::WriteOnly | QFile::Truncate))
|
|
{
|
|
printf("Error writing %s\n", qPrintable(f.fileName()));
|
|
return 1;
|
|
}
|
|
|
|
QString str;
|
|
str += "# qconf\n\n";
|
|
|
|
QString var;
|
|
var = qc_getenv("PREFIX");
|
|
if(!var.isEmpty())
|
|
str += QString("PREFIX = %1\n").arg(var);
|
|
var = qc_getenv("BINDIR");
|
|
if(!var.isEmpty())
|
|
str += QString("BINDIR = %1\n").arg(var);
|
|
var = qc_getenv("LIBDIR");
|
|
if(!var.isEmpty())
|
|
str += QString("LIBDIR = %1\n").arg(var);
|
|
var = qc_getenv("DATADIR");
|
|
if(!var.isEmpty())
|
|
str += QString("DATADIR = %1\n").arg(var);
|
|
str += '\n';
|
|
|
|
if(qc_getenv("QC_STATIC") == "Y")
|
|
str += "CONFIG += staticlib\n";
|
|
|
|
// TODO: don't need this?
|
|
//str += "QT_PATH_PLUGINS = " + QString(qInstallPathPlugins()) + '\n';
|
|
|
|
if(!conf->DEFINES.isEmpty())
|
|
str += "DEFINES += " + conf->DEFINES + '\n';
|
|
if(!conf->INCLUDEPATH.isEmpty())
|
|
str += "INCLUDEPATH += " + conf->INCLUDEPATH + '\n';
|
|
if(!conf->LIBS.isEmpty())
|
|
str += "LIBS += " + conf->LIBS + '\n';
|
|
if(!conf->extra.isEmpty())
|
|
str += conf->extra;
|
|
str += '\n';
|
|
|
|
QByteArray cs = str.toLatin1();
|
|
f.write(cs);
|
|
f.close();
|
|
success = true;
|
|
}
|
|
QString qmake_path = conf->qmake_path;
|
|
delete conf;
|
|
|
|
if(!success)
|
|
return 1;
|
|
|
|
// run qmake on the project file
|
|
int ret = qc_runprogram(qmake_path, QStringList() << proPath, 0, true);
|
|
if(ret != 0)
|
|
return 1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
EOT
|
|
cat >$1/conf4.pro <<EOT
|
|
CONFIG += console
|
|
CONFIG -= app_bundle
|
|
QT -= gui
|
|
TARGET = conf
|
|
|
|
HEADERS += conf4.h
|
|
SOURCES += conf4.cpp
|
|
|
|
|
|
DEFINES += HAVE_MODULES
|
|
|
|
EOT
|
|
}
|
|
|
|
export PREFIX
|
|
export BINDIR
|
|
export DATADIR
|
|
export EX_QTDIR
|
|
export QC_DEBUG
|
|
rm -rf .qconftemp
|
|
(
|
|
mkdir .qconftemp
|
|
gen_files .qconftemp
|
|
cd .qconftemp
|
|
$qm conf4.pro >/dev/null
|
|
$MAKE clean >/dev/null 2>&1
|
|
$MAKE >../conf.log 2>&1
|
|
)
|
|
|
|
if [ "$?" != "0" ]; then
|
|
rm -rf .qconftemp
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo " -> fail"
|
|
else
|
|
echo "fail"
|
|
fi
|
|
printf "\n"
|
|
printf "Reason: There was an error compiling 'conf'. See conf.log for details.\n"
|
|
printf "\n"
|
|
show_qt_info
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo "conf.log:"
|
|
cat conf.log
|
|
fi
|
|
exit 1;
|
|
fi
|
|
|
|
QC_COMMAND=$0
|
|
export QC_COMMAND
|
|
QC_PROFILE=qbittorrent.pro
|
|
export QC_PROFILE
|
|
QC_QMAKE=$qm
|
|
export QC_QMAKE
|
|
QC_MAKETOOL=$MAKE
|
|
export QC_MAKETOOL
|
|
.qconftemp/conf
|
|
ret="$?"
|
|
if [ "$ret" = "1" ]; then
|
|
rm -rf .qconftemp
|
|
echo
|
|
exit 1;
|
|
else
|
|
if [ "$ret" != "0" ]; then
|
|
rm -rf .qconftemp
|
|
if [ "$QC_DEBUG" = "Y" ]; then
|
|
echo " -> fail"
|
|
else
|
|
echo "fail"
|
|
fi
|
|
echo
|
|
echo "Reason: Unexpected error launching 'conf'"
|
|
echo
|
|
exit 1;
|
|
fi
|
|
fi
|
|
rm -rf .qconftemp
|
|
|
|
echo
|
|
echo "Good, your configure finished. Now run $MAKE."
|
|
echo
|