Enhance detection for ext3, fat16, fat32, linux-swap, and hfsplus
This change is in preparation for supporting sectors sizes > 512 bytes.
This commit is contained in:
parent
66355153fb
commit
6369e58bff
|
@ -1,4 +1,4 @@
|
||||||
/* Copyright (C) 2008, 2009 Curtis Gedak
|
/* Copyright (C) 2008, 2009, 2010 Curtis Gedak
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -86,12 +86,23 @@ Glib::ustring FS_Info::get_device_entry( const Glib::ustring & path )
|
||||||
Glib::ustring FS_Info::get_fs_type( const Glib::ustring & path )
|
Glib::ustring FS_Info::get_fs_type( const Glib::ustring & path )
|
||||||
{
|
{
|
||||||
Glib::ustring fs_type = "" ;
|
Glib::ustring fs_type = "" ;
|
||||||
|
Glib::ustring fs_sec_type = "" ;
|
||||||
|
|
||||||
//Retrieve the line containing the device path
|
//Retrieve the line containing the device path
|
||||||
Glib::ustring temp = get_device_entry( path ) ;
|
Glib::ustring dev_path_line = get_device_entry( path ) ;
|
||||||
|
|
||||||
//Retrieve TYPE
|
//Retrieve TYPE
|
||||||
fs_type = Utils::regexp_label( temp, "TYPE=\"([^\"]*)\"" ) ;
|
fs_type = Utils::regexp_label( dev_path_line, "[^_]TYPE=\"([^\"]*)\"" ) ;
|
||||||
|
fs_sec_type = Utils::regexp_label( dev_path_line, "SEC_TYPE=\"([^\"]*)\"" ) ;
|
||||||
|
|
||||||
|
//If vfat, decide whether fat16 or fat32
|
||||||
|
if ( fs_type == "vfat" )
|
||||||
|
{
|
||||||
|
if ( fs_sec_type == "msdos" )
|
||||||
|
fs_type = "fat16" ;
|
||||||
|
else
|
||||||
|
fs_type = "fat32" ;
|
||||||
|
}
|
||||||
|
|
||||||
if ( fs_type .empty() && vol_id_found )
|
if ( fs_type .empty() && vol_id_found )
|
||||||
{
|
{
|
||||||
|
|
|
@ -960,7 +960,8 @@ GParted::FILESYSTEM GParted_Core::get_filesystem()
|
||||||
fs_type == "linux-swap(v1)" ||
|
fs_type == "linux-swap(v1)" ||
|
||||||
fs_type == "linux-swap(new)" ||
|
fs_type == "linux-swap(new)" ||
|
||||||
fs_type == "linux-swap(v0)" ||
|
fs_type == "linux-swap(v0)" ||
|
||||||
fs_type == "linux-swap(old)" )
|
fs_type == "linux-swap(old)" ||
|
||||||
|
fs_type == "swap" )
|
||||||
return GParted::FS_LINUX_SWAP ;
|
return GParted::FS_LINUX_SWAP ;
|
||||||
else if ( fs_type == "fat16" )
|
else if ( fs_type == "fat16" )
|
||||||
return GParted::FS_FAT16 ;
|
return GParted::FS_FAT16 ;
|
||||||
|
@ -976,7 +977,8 @@ GParted::FILESYSTEM GParted_Core::get_filesystem()
|
||||||
return GParted::FS_JFS ;
|
return GParted::FS_JFS ;
|
||||||
else if ( fs_type == "hfs" )
|
else if ( fs_type == "hfs" )
|
||||||
return GParted::FS_HFS ;
|
return GParted::FS_HFS ;
|
||||||
else if ( fs_type == "hfs+" )
|
else if ( fs_type == "hfs+" ||
|
||||||
|
fs_type == "hfsplus" )
|
||||||
return GParted::FS_HFSPLUS ;
|
return GParted::FS_HFSPLUS ;
|
||||||
else if ( fs_type == "ufs" )
|
else if ( fs_type == "ufs" )
|
||||||
return GParted::FS_UFS ;
|
return GParted::FS_UFS ;
|
||||||
|
|
Loading…
Reference in New Issue