diff options
author | Slávek Banko <[email protected]> | 2013-11-17 02:08:00 +0100 |
---|---|---|
committer | Slávek Banko <[email protected]> | 2013-11-17 02:10:14 +0100 |
commit | 7a8b0da20f90349c9e989a86ad58f347910e0cf2 (patch) | |
tree | d924e4135e1367b479dbb5de2df290fd3658458b | |
parent | c244bac1537175f6219fa778a13acfedeaf8b304 (diff) | |
download | tdebase-7a8b0da20f90349c9e989a86ad58f347910e0cf2.tar.gz tdebase-7a8b0da20f90349c9e989a86ad58f347910e0cf2.zip |
Allow mount options specific to filesystem in tdehw storage backend
This relates to Bug 1708
-rw-r--r-- | tdeioslave/media/mediamanager/tdehardwarebackend.cpp | 46 |
1 files changed, 30 insertions, 16 deletions
diff --git a/tdeioslave/media/mediamanager/tdehardwarebackend.cpp b/tdeioslave/media/mediamanager/tdehardwarebackend.cpp index dd61ac9a5..b306a7bfe 100644 --- a/tdeioslave/media/mediamanager/tdehardwarebackend.cpp +++ b/tdeioslave/media/mediamanager/tdehardwarebackend.cpp @@ -894,8 +894,7 @@ TQStringList TDEBackend::mountoptions(const TQString &name) TQStringList result; // Allow only those options which are valid for the given device - // pmount only allows a subset of options, and those are given in the map below - // FIXME + // FIXME: Is there a better way to determine options by the file system? TQMap<TQString,bool> valids; valids["ro"] = true; //valids["quiet"] = false; @@ -903,11 +902,34 @@ TQStringList TDEBackend::mountoptions(const TQString &name) //valids["uid"] = false; valids["utf8"] = true; //valids["shortname"] = false; - valids["locale"] = true; + //valids["locale"] = false; valids["sync"] = true; valids["noatime"] = true; //valids["data"] = false; + if ((sdevice->fileSystemName().endsWith("fat")) + || (sdevice->fileSystemName().endsWith("dos")) + ) { + valids["shortname"] = true; + } + if ((sdevice->fileSystemName() == "ext3") + || (sdevice->fileSystemName() == "ext4") + ) { + valids["data"] = true; + } + if (sdevice->fileSystemName().startsWith("ext")) { + valids.remove("utf8"); + } + if (sdevice->fileSystemName() == "ntfs-3g") { + valids["locale"] = true; + } + if (sdevice->fileSystemName() == "iso9660") { + valids.remove("ro"); + valids.remove("quiet"); + valids.remove("sync"); + valids.remove("noatime"); + } + TQString drive_udi = driveUDIFromDeviceUID(medium->id()); TDEConfig config("mediamanagerrc"); @@ -953,17 +975,13 @@ TQStringList TDEBackend::mountoptions(const TQString &name) if (valids.contains("ro")) { value = config.readBoolEntry("ro", false); tmp = TQString("ro=%1").arg(value ? "true" : "false"); - if (sdevice->fileSystemName() != "iso9660") { - result << tmp; - } + result << tmp; } if (valids.contains("quiet")) { value = config.readBoolEntry("quiet", false); tmp = TQString("quiet=%1").arg(value ? "true" : "false"); - if (sdevice->fileSystemName() != "iso9660") { - result << tmp; - } + result << tmp; } if (valids.contains("flush")) { @@ -1001,7 +1019,7 @@ TQStringList TDEBackend::mountoptions(const TQString &name) } // pass our locale to the ntfs-3g driver so it can translate local characters - if (valids.contains("locale") && (sdevice->fileSystemName() == "ntfs-3g")) { + if (valids.contains("locale")) { // have to obtain LC_CTYPE as returned by the `locale` command // check in the same order as `locale` does char *cType; @@ -1013,17 +1031,13 @@ TQStringList TDEBackend::mountoptions(const TQString &name) if (valids.contains("sync")) { value = config.readBoolEntry("sync", ( valids.contains("flush") && !sdevice->fileSystemName().endsWith("fat") ) && removable); tmp = TQString("sync=%1").arg(value ? "true" : "false"); - if (sdevice->fileSystemName() != "iso9660") { - result << tmp; - } + result << tmp; } if (valids.contains("noatime")) { value = config.readBoolEntry("atime", !sdevice->fileSystemName().endsWith("fat")); tmp = TQString("atime=%1").arg(value ? "true" : "false"); - if (sdevice->fileSystemName() != "iso9660") { - result << tmp; - } + result << tmp; } TQString mount_point; |