--- krusader-2.3.0-beta1.orig/krArc/krarc.cpp	2010-12-26 00:37:52.000000000 +0200
+++ krusader-2.3.0-beta1/krArc/krarc.cpp	2011-01-03 00:53:16.836670713 +0200
@@ -423,7 +423,7 @@
         if (mt)
             emit mimeType(mt->name());
         proc << getCmd << getPath(arcFile->url());
-        if (arcType != "gzip" && arcType != "bzip2" && arcType != "lzma") proc << localeEncodedString(file);
+        if (arcType != "gzip" && arcType != "bzip2" && arcType != "lzma" && arcType != "xz") proc << localeEncodedString(file);
         connect(&proc, SIGNAL(newOutputData(KProcess *, QByteArray &)),
                 this, SLOT(receivedData(KProcess *, QByteArray &)));
         proc.setMerge(false);
@@ -440,7 +440,7 @@
     proc.waitForFinished();
 
     if (!extArcReady && !decompressToFile) {
-        if (proc.exitStatus() != QProcess::NormalExit || !checkStatus(proc.exitCode()) || (arcType != "bzip2" && arcType != "lzma" && expectedSize != decompressedLen)) {
+        if (proc.exitStatus() != QProcess::NormalExit || !checkStatus(proc.exitCode()) || (arcType != "bzip2" && arcType != "lzma" && arcType != "xz" && expectedSize != decompressedLen)) {
             if (encrypted && tries) {
                 invalidatePassword();
                 get(url, tries - 1);
@@ -827,6 +827,8 @@
         arcType = "gzip";
     else if (arcType == "tlz")
         arcType = "lzma";
+    else if (arcType == "txz")
+        arcType = "xz";
 
     if (arcType.isEmpty()) {
         arcType = arcFile->mimetype();
@@ -861,7 +863,7 @@
         return false;
     }
 
-    if (arcType != "bzip2" && arcType != "lzma") {
+    if (arcType != "bzip2" && arcType != "lzma" && arcType != "xz") {
         if (arcType == "rpm") {
             proc << listCmd << arcPath;
             proc.setStandardOutputFile(temp.fileName());
@@ -896,7 +898,7 @@
 
     root->append(entry);
 
-    if (arcType == "bzip2" || arcType == "lzma") {
+    if (arcType == "bzip2" || arcType == "lzma" || arcType == "xz") {
         KRDEBUG("Got me here...");
         parseLine(0, "");
         return true;
@@ -1207,6 +1209,14 @@
         mode = arcFile->mode();
         size = arcFile->size();
     }
+    if (arcType == "xz") {
+        fullName = arcFile->name();
+        if (fullName.endsWith(QLatin1String("xz"))) {
+            fullName.truncate(fullName.length() - 3);
+        }
+        mode = arcFile->mode();
+        size = arcFile->size();
+    }
     if (arcType == "bzip2") {
         // There is no way to list bzip2 files, so we take our information from
         // the archive itself...
@@ -1460,6 +1470,13 @@
         copyCmd = QStringList();
         delCmd  = QStringList();
         putCmd  = QStringList();
+    } else if (arcType == "xz") {
+        cmd     = fullPathName("xz");
+        listCmd << fullPathName("xz");
+        getCmd  << fullPathName("xz") << "-dc";
+        copyCmd = QStringList();
+        delCmd  = QStringList();
+        putCmd  = QStringList();
     } else if (arcType == "arj") {
         cmd     = fullPathName("arj");
         listCmd << fullPathName("arj") << "v" << "-y" << "-v";
@@ -1544,7 +1561,7 @@
         return exitCode == 0 || exitCode == 1;
     else if (arcType == "ace" || arcType == "bzip2" || arcType == "lha" || arcType == "rpm" || arcType == "arj")
         return exitCode == 0;
-    else if (arcType == "gzip" || arcType == "lzma")
+    else if (arcType == "gzip" || arcType == "lzma" || arcType == "xz")
         return exitCode == 0 || exitCode == 2;
     else
         return exitCode == 0;
@@ -1566,7 +1583,8 @@
         {"bzip2", 0, "\x42\x5a\x68\x39\x31" },
         {"gzip", 0, "\x1f\x8b"},
         {"deb",  0, "!<arch>\ndebian-binary   " },
-        {"7z",   0, "7z\xbc\xaf\x27\x1c" }
+        {"7z",   0, "7z\xbc\xaf\x27\x1c" }/*,
+        {"xz",   0, "\xfd\x37\x7a\x58\x5a\x00"}*/
     };
     static int autoDetectElems = sizeof(autoDetectParams) / sizeof(AutoDetectParams);
 
@@ -1714,6 +1732,14 @@
         return "lzma";
     }
 
+    if (fileName.endsWith(QLatin1String(".tar.xz")) ||
+            fileName.endsWith(QLatin1String(".txz"))) {
+        return "txz";
+    }
+    if (fileName.endsWith(QLatin1String(".xz"))) {
+        return "xz";
+    }
+    
     return QString();
 }

--- krusader-2.3.0-beta1.orig/krusader/Dialogs/packgui.cpp	2010-12-26 00:37:50.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Dialogs/packgui.cpp	2011-01-03 00:55:05.843337380 +0200
@@ -68,6 +68,7 @@
     if (PS("tar") && PS("gzip")) typeData->addItem("tar.gz");
     if (PS("tar") && PS("bzip2")) typeData->addItem("tar.bz2");
     if (PS("tar") && PS("lzma")) typeData->addItem("tar.lzma");
+    if (PS("tar") && PS("xz")) typeData->addItem("tar.xz");
     if (PS("zip")) typeData->addItem("zip");
     if (PS("rar")) typeData->addItem("rar");
     if (PS("lha")) typeData->addItem("lha");

--- krusader-2.3.0-beta1.orig/krusader/Konfigurator/kgarchives.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Konfigurator/kgarchives.cpp	2011-01-03 00:57:00.326670713 +0200
@@ -62,6 +62,7 @@
     {{"Archives", "Do Tar",   _DoTar,   i18n("Tar"),   false,  ""},
         {"Archives", "Do GZip",  _DoGZip,  i18n("GZip"),  false,  ""},
         {"Archives", "Do LZMA",  _DoLZMA,  i18n("LZMA"),  false,  ""},
+        {"Archives", "Do XZ",    _DoXZ,    i18n("XZ"),    false,  ""},
         {"Archives", "Do BZip2", _DoBZip2, i18n("BZip2"), false,  ""},
         {"Archives", "Do UnZip", _DoUnZip, i18n("Zip"),   false,  ""},
         {"Archives", "Do UnRar", _DoUnRar, i18n("Rar"),   false,  ""},
@@ -73,7 +74,7 @@
         {"Archives", "Do 7z",    _Do7z,    i18n("7zip"),  false,  ""}
     };
 
-    cbs = createCheckBoxGroup(3, 0, packers, 12, generalGrp);
+    cbs = createCheckBoxGroup(3, 0, packers, 13, generalGrp);
     generalGrid->addWidget(cbs, 1, 0);
 
     addLabel(generalGrid, 2, 0, i18n("The archives that are \"grayed out\" were unavailable on your\n"
@@ -148,6 +149,7 @@
     cbs->find("Do GZip")->setEnabled(PS("gzip"));
     cbs->find("Do BZip2")->setEnabled(PS("bzip2"));
     cbs->find("Do LZMA")->setEnabled(PS("lzma"));
+    cbs->find("Do XZ")->setEnabled(PS("xz"));
     cbs->find("Do UnZip")->setEnabled(PS("unzip"));
     cbs->find("Do Lha")->setEnabled(PS("lha"));
     cbs->find("Do RPM")->setEnabled(PS("rpm") || PS("cpio"));

--- krusader-2.3.0-beta1.orig/krusader/Konfigurator/kgdependencies.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Konfigurator/kgdependencies.cpp	2011-01-03 00:57:30.006670714 +0200
@@ -100,6 +100,7 @@
     addApplication("unrar", archGrid1, 12, packers_tab, PAGE_PACKERS);
     addApplication("unzip", archGrid1, 13, packers_tab, PAGE_PACKERS);
     addApplication("zip",   archGrid1, 14, packers_tab, PAGE_PACKERS);
+    addApplication("xz",    archGrid1, 15, packers_tab, PAGE_PACKERS);
 
     //  ---------------------------- CHECKSUM TAB -------------------------------------
     QWidget *checksum_tab = new QWidget(tabWidget);

--- krusader-2.3.0-beta1.orig/krusader/Konfigurator/kggeneral.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Konfigurator/kggeneral.cpp	2011-01-03 00:58:39.056670713 +0200
@@ -193,6 +193,7 @@
     defaultAtomicExtensions += ".tar.gz";
     defaultAtomicExtensions += ".tar.bz2";
     defaultAtomicExtensions += ".tar.lzma";
+    defaultAtomicExtensions += ".tar.xz";
     defaultAtomicExtensions += ".moc.cpp";
 
     listBox = createListBox("Look&Feel", "Atomic Extensions",

--- krusader-2.3.0-beta1.orig/krusader/Konfigurator/kgprotocols.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Konfigurator/kgprotocols.cpp	2011-01-03 01:00:49.756670713 +0200
@@ -51,12 +51,14 @@
         "application/x-gzip,application/x-jar,"
         "application/x-lha,application/x-lha-compressed,"
         "application/x-rar,application/x-rar-compressed,"
+        "application/x-xz,"
         "application/x-rpm,application/zip,"
         "application/x-zip,application/x-zip-compressed";
 QString KgProtocols::defaultTarMimes   = "application/x-tar,application/x-tarz,"
         "application/x-bzip-compressed-tar,"
         "application/x-compressed-tar,"
-        "application/x-tbz,application/x-tgz";
+        "application/x-tbz,application/x-tgz,"
+        "application/x-xz-compressed-tar";
 
 KgProtocols::KgProtocols(bool first, QWidget* parent) :
         KonfiguratorPage(first, parent)

--- krusader-2.3.0-beta1.orig/krusader/Konfigurator/krresulttable.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Konfigurator/krresulttable.cpp	2011-01-03 01:02:42.460004046 +0200
@@ -102,6 +102,7 @@
     Archiver* gzip  = new Archiver("gzip",  "http://www.gnu.org",      PS("gzip"),  true,  true);
     Archiver* bzip2 = new Archiver("bzip2", "http://www.gnu.org",      PS("bzip2"), true,  true);
     Archiver* lzma  = new Archiver("lzma",  "http://tukaani.org/lzma", PS("lzma"),  true,  true);
+    Archiver* xz    = new Archiver("xz",    "http://tukaani.org/xz",   PS("xz"),    true,  true);
     Archiver* lha   = new Archiver("lha",   "http://www.gnu.org",      PS("lha"),   true,  true);
     Archiver* zip   = new Archiver("zip",   "http://www.info-zip.org", PS("zip"),   true,  false);
     Archiver* unzip = new Archiver("unzip", "http://www.info-zip.org", PS("unzip"), false, true);
@@ -139,6 +140,7 @@
     addRow(gzip, _grid);
     addRow(bzip2, _grid);
     addRow(lzma, _grid);
+    addRow(xz, _grid);
     addRow(lha, _grid);
     addRow(zip, _grid);
     addRow(unzip, _grid);
@@ -155,6 +157,7 @@
     delete gzip;
     delete bzip2;
     delete lzma;
+    delete xz;
     delete lha;
     delete zip;
     delete unzip;

--- krusader-2.3.0-beta1.orig/krusader/Panel/krview.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/Panel/krview.cpp	2011-01-03 01:03:53.033337380 +0200
@@ -367,6 +367,7 @@
     defaultAtomicExtensions += ".tar.gz";
     defaultAtomicExtensions += ".tar.bz2";
     defaultAtomicExtensions += ".tar.lzma";
+    defaultAtomicExtensions += ".tar.xz";
     defaultAtomicExtensions += ".moc.cpp";
     QStringList atomicExtensions = grpSvr.readEntry("Atomic Extensions", defaultAtomicExtensions);
     for (QStringList::iterator i = atomicExtensions.begin(); i != atomicExtensions.end();) {

--- krusader-2.3.0-beta1.orig/krusader/VFS/krarchandler.cpp	2010-12-26 00:37:51.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/VFS/krarchandler.cpp	2011-01-03 01:14:58.190004047 +0200
@@ -85,7 +85,7 @@
 };
 #endif
 
-static QStringList arcProtocols = QString("tar;bzip;bzip2;lzma;gzip;krarc;zip").split(';');
+static QStringList arcProtocols = QString("tar;bzip;bzip2;lzma;xz;gzip;krarc;zip").split(';');
 
 KWallet::Wallet * KRarcHandler::wallet = 0;
 
@@ -98,6 +98,7 @@
     if (KrServices::cmdExist("gzip")) packers.append("gzip");
     if (KrServices::cmdExist("bzip2")) packers.append("bzip2");
     if (KrServices::cmdExist("lzma")) packers.append("lzma");
+    if (KrServices::cmdExist("xz")) packers.append("xz");
     if (KrServices::cmdExist("unzip")) packers.append("unzip");
     if (KrServices::cmdExist("zip")) packers.append("zip");
     if (KrServices::cmdExist("lha")) packers.append("lha");
@@ -134,6 +135,8 @@
         return true;
     else if (type == "-tlz" && lst.contains("tar"))
         return true;
+    else if (type == "-txz" && lst.contains("tar"))
+        return true;
     else if (type == "tarz" && lst.contains("tar"))
         return true;
     else if (type == "gzip" && lst.contains("gzip"))
@@ -142,6 +145,8 @@
         return true;
     else if (type == "lzma" && lst.contains("lzma"))
         return true;
+    else if (type == "-xz" && lst.contains("xz"))
+        return true;
     else if (type == "-lha" && lst.contains("lha"))
         return true;
     else if (type == "-ace" && lst.contains("unace"))
@@ -173,6 +178,7 @@
             (type == "-tar" && group.readEntry("Do Tar" , _DoTar)) ||
             (type == "-tbz" && group.readEntry("Do BZip2", _DoBZip2)) ||
             (type == "-tlz" && group.readEntry("Do LZMA", _DoLZMA)) ||
+            (type == "-txz" && group.readEntry("Do XZ", _DoXZ)) ||
             (type == "gzip" && group.readEntry("Do GZip" , _DoGZip)) ||
             (type == "zip2" && group.readEntry("Do BZip2", _DoBZip2)) ||
             (type == "-zip" && group.readEntry("Do UnZip", _DoUnZip)) ||
@@ -198,7 +204,7 @@
     if (!arcSupported(type)) return 0;
 
     // bzip an gzip archive contains only one file
-    if (type == "zip2" || type == "gzip" || type == "lzma") return 1L;
+    if (type == "zip2" || type == "gzip" || type == "lzma" || type == "-xz") return 1L;
 
     // set the right lister to do the job
     QStringList lister;
@@ -209,6 +215,7 @@
     else if (type == "tarz") lister << KrServices::fullPathName("tar") << "-tvzf";
     else if (type == "-tbz") lister << KrServices::fullPathName("tar") << "-tjvf";
     else if (type == "-tlz") lister << KrServices::fullPathName("tar") << "--lzma" << "-tvf";
+    else if (type == "-txz") lister << KrServices::fullPathName("tar") << "--xz" << "-tvf";
     else if (type == "-lha") lister << KrServices::fullPathName("lha") << "l";
     else if (type == "-rar") lister << KrServices::fullPathName(KrServices::cmdExist("rar") ? "rar" : "unrar") << "l" << "-v";
     else if (type == "-ace") lister << KrServices::fullPathName("unace") << "l";
@@ -293,9 +300,11 @@
     else if (type == "tarz") packer << KrServices::fullPathName("tar") << "-xvzf";
     else if (type == "-tbz") packer << KrServices::fullPathName("tar") << "-xjvf";
     else if (type == "-tlz") packer << KrServices::fullPathName("tar") << "--lzma" << "-xvf";
+    else if (type == "-txz") packer << KrServices::fullPathName("tar") << "--xz" << "-xvf";
     else if (type == "gzip") packer << KrServices::fullPathName("gzip") << "-cd";
     else if (type == "zip2") packer << KrServices::fullPathName("bzip2") << "-cdk";
     else if (type == "lzma") packer << KrServices::fullPathName("lzma") << "-cdk";
+    else if (type == "-xz")  packer << KrServices::fullPathName("xz") << "-cdk";
     else if (type == "-lha") packer << KrServices::fullPathName("lha") << "xf";
     else if (type == "-rar") packer << KrServices::fullPathName(KrServices::cmdExist("rar") ? "rar" : "unrar") << "-y" << "x";
     else if (type == "-ace") packer << KrServices::fullPathName("unace") << "x";
@@ -351,7 +360,7 @@
     // unpack the files
     KrLinecountingProcess proc;
     proc << packer << archive;
-    if (type == "zip2" || type == "gzip" || type == "lzma") {
+    if (type == "zip2" || type == "gzip" || type == "lzma" || type == "-xz") {
         QString arcname = archive.mid(archive.lastIndexOf("/") + 1);
         if (arcname.contains(".")) arcname = arcname.left(arcname.lastIndexOf("."));
         proc.setStandardOutputFile(dest + '/' + arcname);
@@ -407,9 +416,11 @@
     else if (type == "tarz") packer << KrServices::fullPathName("tar") << "-tvzf";
     else if (type == "-tbz") packer << KrServices::fullPathName("tar") << "-tjvf";
     else if (type == "-tlz") packer << KrServices::fullPathName("tar") << "--lzma" << "-tvf";
+    else if (type == "-txz") packer << KrServices::fullPathName("tar") << "--xz" << "-tvf";
     else if (type == "gzip") packer << KrServices::fullPathName("gzip") << "-tv";
     else if (type == "zip2") packer << KrServices::fullPathName("bzip2") << "-tv";
     else if (type == "lzma") packer << KrServices::fullPathName("lzma") << "-tv";
+    else if (type == "-xz")  packer << KrServices::fullPathName("xz") << "-tv";
     else if (type == "-rar") packer << KrServices::fullPathName(KrServices::cmdExist("rar") ? "rar" : "unrar") << "t";
     else if (type == "-ace") packer << KrServices::fullPathName("unace") << "t";
     else if (type == "-lha") packer << KrServices::fullPathName("lha") << "t";
@@ -474,6 +485,8 @@
         packer << KrServices::fullPathName("tar") << "-cvjf"; type = "-tbz";
     } else if (type == "tar.lzma") {
         packer << KrServices::fullPathName("tar") << "--lzma" << "-cvf"; type = "-tlz";
+    } else if (type == "tar.xz") {
+        packer << KrServices::fullPathName("tar") << "--xz" << "-cvf"; type = "-txz";
     } else if (type == "rar") {
         packer << KrServices::fullPathName("rar") << "-r" << "a"; type = "-rar";
     } else if (type == "lha") {
@@ -673,6 +687,10 @@
         result = "-7z";
     }
 
+    if (result.endsWith(QLatin1String("-xz"))) {
+        result = "-xz";
+    }
+
     return result.right(4);
 }
 
@@ -683,9 +701,9 @@
         return exitCode == 0 || exitCode == 1;
     else if (type == "-ace" || type == "zip2" || type == "-lha" || type == "-rpm" || type == "cpio" ||
              type == "-tar" || type == "tarz" || type == "-tbz" || type == "-tgz" || type == "-arj" ||
-             type == "-deb" || type == "-tlz")
+             type == "-deb" || type == "-tlz" || type == "-txz")
         return exitCode == 0;
-    else if (type == "gzip" || type == "lzma")
+    else if (type == "gzip" || type == "lzma" || type == "-xz")
         return exitCode == 0 || exitCode == 2;
     else
         return exitCode == 0;
@@ -707,7 +725,8 @@
         {"bzip2", 0, "\x42\x5a\x68\x39\x31" },
         {"gzip", 0, "\x1f\x8b"},
         {"deb",  0, "!<arch>\ndebian-binary   " },
-        {"7z",   0, "7z\xbc\xaf\x27\x1c" }
+        {"7z",   0, "7z\xbc\xaf\x27\x1c" }/*,
+        {"xz",   0, "\xfd\x37\x7a\x58\x5a\x00"}*/
     };
     static int autoDetectElems = sizeof(autoDetectParams) / sizeof(AutoDetectParams);
 
@@ -839,6 +858,14 @@
         return "lzma";
     }
 
+    if (fileName.endsWith(QLatin1String(".tar.xz")) ||
+            fileName.endsWith(QLatin1String(".txz"))) {
+        return "txz";
+    }
+    if (fileName.endsWith(QLatin1String(".xz"))) {
+        return "xz";
+    }
+
     return QString();
 }
 
--- krusader-2.3.0-beta1.orig/krusader/defaults.h	2010-12-26 00:37:52.000000000 +0200
+++ krusader-2.3.0-beta1/krusader/defaults.h	2011-01-03 01:15:46.816670713 +0200
@@ -181,6 +181,8 @@
 #define _DoBZip2       true
 // Do LZMA ///////////
 #define _DoLZMA       true
+// Do XZ ///////////
+#define _DoXZ         true
 // Do Rar /////////////
 #define _DoRar         true
 // Do UnRar ///////////