Adding support for detecting linux_raid_member file system.
This commit is contained in:
parent
3fd221f794
commit
2298d08c41
|
@ -16,6 +16,7 @@ set(FS_SRC
|
||||||
fs/hpfs.cpp
|
fs/hpfs.cpp
|
||||||
fs/iso9660.cpp
|
fs/iso9660.cpp
|
||||||
fs/jfs.cpp
|
fs/jfs.cpp
|
||||||
|
fs/linuxraidmember.cpp
|
||||||
fs/linuxswap.cpp
|
fs/linuxswap.cpp
|
||||||
fs/luks.cpp
|
fs/luks.cpp
|
||||||
fs/luks2.cpp
|
fs/luks2.cpp
|
||||||
|
@ -51,6 +52,7 @@ set(FS_LIB_HDRS
|
||||||
fs/hpfs.h
|
fs/hpfs.h
|
||||||
fs/iso9660.h
|
fs/iso9660.h
|
||||||
fs/jfs.h
|
fs/jfs.h
|
||||||
|
fs/linuxraidmember.h
|
||||||
fs/linuxswap.h
|
fs/linuxswap.h
|
||||||
fs/luks.h
|
fs/luks.h
|
||||||
fs/luks2.h
|
fs/luks2.h
|
||||||
|
|
|
@ -68,7 +68,8 @@ const std::vector<QColor> FileSystem::defaultColorCode =
|
||||||
QColor( 170,120,255 ), // udf
|
QColor( 170,120,255 ), // udf
|
||||||
QColor( 177,82,69 ), // iso9660
|
QColor( 177,82,69 ), // iso9660
|
||||||
QColor( 223,39,104 ), // luks2
|
QColor( 223,39,104 ), // luks2
|
||||||
QColor( 204,179,255 ) // fat12
|
QColor( 204,179,255 ), // fat12
|
||||||
|
QColor( 255,100,100 ) // linux_raid_member
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -445,7 +446,8 @@ static const KLocalizedString* typeNames()
|
||||||
kxi18nc("@item filesystem name", "udf"),
|
kxi18nc("@item filesystem name", "udf"),
|
||||||
kxi18nc("@item filesystem name", "iso9660"),
|
kxi18nc("@item filesystem name", "iso9660"),
|
||||||
kxi18nc("@item filesystem name", "luks2"),
|
kxi18nc("@item filesystem name", "luks2"),
|
||||||
kxi18nc("@item filesystem name", "fat12")
|
kxi18nc("@item filesystem name", "fat12"),
|
||||||
|
kxi18nc("@item filesystem name", "linux_raid_member"),
|
||||||
};
|
};
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
|
|
|
@ -91,6 +91,7 @@ public:
|
||||||
Iso9660,
|
Iso9660,
|
||||||
Luks2,
|
Luks2,
|
||||||
Fat12,
|
Fat12,
|
||||||
|
LinuxRaidMember,
|
||||||
|
|
||||||
__lastType
|
__lastType
|
||||||
};
|
};
|
||||||
|
|
|
@ -34,6 +34,7 @@
|
||||||
#include "fs/hpfs.h"
|
#include "fs/hpfs.h"
|
||||||
#include "fs/iso9660.h"
|
#include "fs/iso9660.h"
|
||||||
#include "fs/jfs.h"
|
#include "fs/jfs.h"
|
||||||
|
#include "fs/linuxraidmember.h"
|
||||||
#include "fs/linuxswap.h"
|
#include "fs/linuxswap.h"
|
||||||
#include "fs/luks.h"
|
#include "fs/luks.h"
|
||||||
#include "fs/luks2.h"
|
#include "fs/luks2.h"
|
||||||
|
@ -76,6 +77,7 @@ void FileSystemFactory::init()
|
||||||
m_FileSystems.insert(FileSystem::Type::Hpfs, new FS::hpfs(-1, -1, -1, QString()));
|
m_FileSystems.insert(FileSystem::Type::Hpfs, new FS::hpfs(-1, -1, -1, QString()));
|
||||||
m_FileSystems.insert(FileSystem::Type::Iso9660, new FS::iso9660(-1, -1, -1, QString()));
|
m_FileSystems.insert(FileSystem::Type::Iso9660, new FS::iso9660(-1, -1, -1, QString()));
|
||||||
m_FileSystems.insert(FileSystem::Type::Jfs, new FS::jfs(-1, -1, -1, QString()));
|
m_FileSystems.insert(FileSystem::Type::Jfs, new FS::jfs(-1, -1, -1, QString()));
|
||||||
|
m_FileSystems.insert(FileSystem::Type::LinuxRaidMember, new FS::linuxraidmember(-1, -1, -1, QString()));
|
||||||
m_FileSystems.insert(FileSystem::Type::LinuxSwap, new FS::linuxswap(-1, -1, -1, QString()));
|
m_FileSystems.insert(FileSystem::Type::LinuxSwap, new FS::linuxswap(-1, -1, -1, QString()));
|
||||||
m_FileSystems.insert(FileSystem::Type::Luks, new FS::luks(-1, -1, -1, QString()));
|
m_FileSystems.insert(FileSystem::Type::Luks, new FS::luks(-1, -1, -1, QString()));
|
||||||
m_FileSystems.insert(FileSystem::Type::Luks2, new FS::luks2(-1, -1, -1, QString()));
|
m_FileSystems.insert(FileSystem::Type::Luks2, new FS::luks2(-1, -1, -1, QString()));
|
||||||
|
@ -111,36 +113,37 @@ FileSystem* FileSystemFactory::create(FileSystem::Type t, qint64 firstsector, qi
|
||||||
FileSystem* fs = nullptr;
|
FileSystem* fs = nullptr;
|
||||||
|
|
||||||
switch (t) {
|
switch (t) {
|
||||||
case FileSystem::Type::Btrfs: fs = new FS::btrfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Btrfs: fs = new FS::btrfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Exfat: fs = new FS::exfat(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Exfat: fs = new FS::exfat(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Ext2: fs = new FS::ext2(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Ext2: fs = new FS::ext2(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Ext3: fs = new FS::ext3(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Ext3: fs = new FS::ext3(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Ext4: fs = new FS::ext4(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Ext4: fs = new FS::ext4(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Extended: fs = new FS::extended(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Extended: fs = new FS::extended(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::F2fs: fs = new FS::f2fs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::F2fs: fs = new FS::f2fs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Fat12: fs = new FS::fat12(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Fat12: fs = new FS::fat12(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Fat16: fs = new FS::fat16(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Fat16: fs = new FS::fat16(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Fat32: fs = new FS::fat32(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Fat32: fs = new FS::fat32(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Hfs: fs = new FS::hfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Hfs: fs = new FS::hfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::HfsPlus: fs = new FS::hfsplus(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::HfsPlus: fs = new FS::hfsplus(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Hpfs: fs = new FS::hpfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Hpfs: fs = new FS::hpfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Iso9660: fs = new FS::iso9660(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Iso9660: fs = new FS::iso9660(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Jfs: fs = new FS::jfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Jfs: fs = new FS::jfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::LinuxSwap: fs = new FS::linuxswap(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::LinuxRaidMember: fs = new FS::linuxraidmember(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Luks: fs = new FS::luks(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::LinuxSwap: fs = new FS::linuxswap(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Luks2: fs = new FS::luks2(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Luks: fs = new FS::luks(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Lvm2_PV: fs = new FS::lvm2_pv(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Luks2: fs = new FS::luks2(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Nilfs2: fs = new FS::nilfs2(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Lvm2_PV: fs = new FS::lvm2_pv(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Ntfs: fs = new FS::ntfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Nilfs2: fs = new FS::nilfs2(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Ocfs2: fs = new FS::ocfs2(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Ntfs: fs = new FS::ntfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::ReiserFS: fs = new FS::reiserfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Ocfs2: fs = new FS::ocfs2(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Reiser4: fs = new FS::reiser4(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::ReiserFS: fs = new FS::reiserfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Udf: fs = new FS::udf(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Reiser4: fs = new FS::reiser4(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Ufs: fs = new FS::ufs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Udf: fs = new FS::udf(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Unformatted: fs = new FS::unformatted(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Ufs: fs = new FS::ufs(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Unknown: fs = new FS::unknown(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Unformatted: fs = new FS::unformatted(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Xfs: fs = new FS::xfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Unknown: fs = new FS::unknown(firstsector, lastsector, sectorsused, label); break;
|
||||||
case FileSystem::Type::Zfs: fs = new FS::zfs(firstsector, lastsector, sectorsused, label); break;
|
case FileSystem::Type::Xfs: fs = new FS::xfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
|
case FileSystem::Type::Zfs: fs = new FS::zfs(firstsector, lastsector, sectorsused, label); break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
/*************************************************************************
|
||||||
|
* Copyright (C) 2018 by Caio Carvalho <caiojcarvalho@gmail.com> *
|
||||||
|
* *
|
||||||
|
* This program is free software; you can redistribute it and/or *
|
||||||
|
* modify it under the terms of the GNU General Public License as *
|
||||||
|
* published by the Free Software Foundation; either version 3 of *
|
||||||
|
* the License, or (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* You should have received a copy of the GNU General Public License *
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.*
|
||||||
|
*************************************************************************/
|
||||||
|
|
||||||
|
#include "fs/linuxraidmember.h"
|
||||||
|
|
||||||
|
namespace FS
|
||||||
|
{
|
||||||
|
|
||||||
|
linuxraidmember::linuxraidmember(qint64 firstsector, qint64 lastsector, qint64 sectorsused, const QString& label) :
|
||||||
|
FileSystem(firstsector, lastsector, sectorsused, label, FileSystem::Type::LinuxRaidMember)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
/*************************************************************************
|
||||||
|
* Copyright (C) 2018 by Caio Carvalho <caiojcarvalho@gmail.com> *
|
||||||
|
* *
|
||||||
|
* This program is free software; you can redistribute it and/or *
|
||||||
|
* modify it under the terms of the GNU General Public License as *
|
||||||
|
* published by the Free Software Foundation; either version 3 of *
|
||||||
|
* the License, or (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* You should have received a copy of the GNU General Public License *
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.*
|
||||||
|
*************************************************************************/
|
||||||
|
|
||||||
|
#ifndef LINUXRAIDMEMBER_H
|
||||||
|
#define LINUXRAIDMEMBER_H
|
||||||
|
|
||||||
|
#include "util/libpartitionmanagerexport.h"
|
||||||
|
|
||||||
|
#include "fs/filesystem.h"
|
||||||
|
|
||||||
|
class Report;
|
||||||
|
|
||||||
|
class QString;
|
||||||
|
|
||||||
|
namespace FS
|
||||||
|
{
|
||||||
|
/** A linux_raid_member file system.
|
||||||
|
@author Caio Carvalho <caiojcarvalho@gmail.com>
|
||||||
|
*/
|
||||||
|
class LIBKPMCORE_EXPORT linuxraidmember : public FileSystem
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
linuxraidmember(qint64 firstsector, qint64 lastsector, qint64 sectorsused, const QString& label);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // LINUXRAIDMEMBER_H
|
|
@ -415,6 +415,7 @@ FileSystem::Type SfdiskBackend::detectFileSystem(const QString& partitionPath)
|
||||||
else if (s == QStringLiteral("f2fs")) rval = FileSystem::Type::F2fs;
|
else if (s == QStringLiteral("f2fs")) rval = FileSystem::Type::F2fs;
|
||||||
else if (s == QStringLiteral("udf")) rval = FileSystem::Type::Udf;
|
else if (s == QStringLiteral("udf")) rval = FileSystem::Type::Udf;
|
||||||
else if (s == QStringLiteral("iso9660")) rval = FileSystem::Type::Iso9660;
|
else if (s == QStringLiteral("iso9660")) rval = FileSystem::Type::Iso9660;
|
||||||
|
else if (s == QStringLiteral("linux_raid_member")) rval = FileSystem::Type::LinuxRaidMember;
|
||||||
else
|
else
|
||||||
qWarning() << "unknown file system type " << s << " on " << partitionPath;
|
qWarning() << "unknown file system type " << s << " on " << partitionPath;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue