diff options
author | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2014-10-07 12:03:35 -0500 |
---|---|---|
committer | Slávek Banko <slavek.banko@axis.cz> | 2017-07-22 15:56:42 +0200 |
commit | 099aa9f3624379b5390f1db63b57fcbac4d8a721 (patch) | |
tree | e4fc235c1af55cceb67242fcb201ecaa7e8efc30 /kio | |
parent | 562d0b76429bccfbf4a66e509632063d99e18147 (diff) | |
download | tdelibs-099aa9f3624379b5390f1db63b57fcbac4d8a721.tar.gz tdelibs-099aa9f3624379b5390f1db63b57fcbac4d8a721.zip |
Fix libmime database load once and for all
This relates to Bug 656
(cherry picked from commit e5f898219af927c9bac3aa9b0c9e9473a52dde15)
Diffstat (limited to 'kio')
-rw-r--r-- | kio/kio/kmimemagic.cpp | 44 |
1 files changed, 31 insertions, 13 deletions
diff --git a/kio/kio/kmimemagic.cpp b/kio/kio/kmimemagic.cpp index 362dd3d45..4127e3451 100644 --- a/kio/kio/kmimemagic.cpp +++ b/kio/kio/kmimemagic.cpp @@ -19,6 +19,7 @@ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ + #include "kmimemagic.h" #include <kdebug.h> #include <kapplication.h> @@ -31,6 +32,10 @@ #include <magic.h> +// Taken from file/file.h +// Keep in sync with that header! +#define FILE_LOAD 0 + static void process(struct config_rec* conf, const TQString &); KMimeMagic* KMimeMagic::s_pSelf; @@ -63,8 +68,6 @@ void KMimeMagic::initStatic() { #include <tqregexp.h> #include <tqstring.h> -#define HOWMANY 4000 /* big enough to recognize most WWW files, and skip GPL-headers */ - #define MIME_INODE_DIR "inode/directory" #define MIME_INODE_CDEV "inode/chardevice" #define MIME_INODE_BDEV "inode/blockdevice" @@ -88,7 +91,7 @@ class KMimeMagicUtimeConf { public: KMimeMagicUtimeConf() { tmpDirs << TQString::fromLatin1("/tmp"); // default value - + // The trick is that we also don't want the user to override globally set // directories. So we have to misuse KStandardDirs :} TQStringList confDirs = KGlobal::dirs()->resourceDirs( "config" ); @@ -121,7 +124,7 @@ class KMimeMagicUtimeConf { } #endif } - + bool restoreAccessTime( const TQString & file ) const { TQString dir = file.left( file.findRev( '/' ) ); bool res = tmpDirs.contains( dir ); @@ -150,6 +153,7 @@ struct config_rec { int accuracy; magic_t magic; + TQStringList databases; KMimeMagicUtimeConf * utimeConf; }; @@ -158,7 +162,13 @@ struct config_rec { * apprentice - load configuration from the magic file. */ int KMimeMagic::apprentice( const TQString& magicfile ) { - return magic_load(conf->magic, magicfile.latin1()); + TQString maindatabase = magicfile; + if (maindatabase == "") { + maindatabase = magic_getpath(0, FILE_LOAD); + } + conf->databases.clear(); + conf->databases.append(maindatabase); + return magic_load(conf->magic, conf->databases[0].latin1()); } /* @@ -239,10 +249,19 @@ KMimeMagic::~KMimeMagic() { } bool KMimeMagic::mergeConfig(const TQString & _configfile) { - if (magic_load(conf->magic, _configfile.latin1()) == 0) { - return true; + conf->databases.append(_configfile); + TQString merged_databases = conf->databases.join(":"); + int magicvers = magic_version(); + if ((magicvers < 512) || (magicvers >= 518)) { + if (magic_load(conf->magic, merged_databases.latin1()) == 0) { + return true; + } + else { + return false; + } } else { + kdWarning(7018) << "KMimeMagic::mergeConfig disabled due to buggy libmagic version " << magicvers << endl; return false; } } @@ -251,7 +270,7 @@ void KMimeMagic::setFollowLinks( bool _enable ) { conf->followLinks = _enable; } -KMimeMagicResult *KMimeMagic::findBufferType(const TQByteArray &array) { +KMimeMagicResult *KMimeMagic::findBufferType(const TQByteArray &array) { conf->resultBuf = TQString::null; if ( !magicResult ) { magicResult = new KMimeMagicResult(); @@ -327,22 +346,21 @@ KMimeMagicResult* KMimeMagic::findFileType(const TQString & fn) { kdDebug(7018) << "KMimeMagic::findFileType " << fn << endl; #endif conf->resultBuf = TQString::null; - + if ( !magicResult ) { magicResult = new KMimeMagicResult(); } magicResult->setInvalid(); conf->accuracy = 100; - + if ( !conf->utimeConf ) { conf->utimeConf = new KMimeMagicUtimeConf(); } - + /* process it based on the file contents */ process(conf, fn ); - + /* if we have any results, put them in the request structure */ - //finishResult(); magicResult->setMimeType(conf->resultBuf.stripWhiteSpace()); magicResult->setAccuracy(conf->accuracy); refineResult(magicResult, fn); |