implemented some stuff to find a good blocksize to use for copy/move.
* implemented some stuff to find a good blocksize to use for copy/move. Actually i'm not really happy with it, because probing seems suboptimal, but it's better than nothing. As soon as i have some time i should do some research on the subject to find a better solution.
This commit is contained in:
parent
6fe6128628
commit
b539a10ddc
|
@ -1,3 +1,11 @@
|
|||
2006-08-08 Bart Hakvoort <hakvoort@cvs.gnome.org>
|
||||
|
||||
* implemented some stuff to find a good blocksize to use for
|
||||
copy/move. Actually i'm not really happy with it, because probing
|
||||
seems suboptimal, but it's better than nothing. As soon as i have
|
||||
some time i should do some research on the subject to find a better
|
||||
solution.
|
||||
|
||||
2006-08-01 Bart Hakvoort <hakvoort@cvs.gnome.org>
|
||||
|
||||
* include/Win_GParted.h,
|
||||
|
|
|
@ -30,11 +30,8 @@ public:
|
|||
void Set_Data( const Partition & selected_partition, const Partition & copied_partition );
|
||||
|
||||
Partition Get_New_Partition() ;
|
||||
Sector get_block_size() ;
|
||||
|
||||
private:
|
||||
Gtk::HBox hbox_block_size ;
|
||||
Gtk::SpinButton spinbutton_block_size ;
|
||||
};
|
||||
|
||||
}//GParted
|
||||
|
|
|
@ -117,18 +117,38 @@ private:
|
|||
bool copy( const Partition & partition_src,
|
||||
Partition & partition_dest,
|
||||
Sector min_size,
|
||||
Sector block_size,
|
||||
std::vector<OperationDetail> & operation_details ) ;
|
||||
bool copy_filesystem( const Partition & partition_src,
|
||||
const Partition & partition_dest,
|
||||
std::vector<OperationDetail> & operation_details,
|
||||
Sector block_size ) ;
|
||||
std::vector<OperationDetail> & operation_details ) ;
|
||||
|
||||
bool check_repair( const Partition & partition, std::vector<OperationDetail> & operation_details ) ;
|
||||
|
||||
bool set_partition_type( const Partition & partition,
|
||||
std::vector<OperationDetail> & operation_details ) ;
|
||||
|
||||
enum CopyType
|
||||
{
|
||||
START_TO_END = 0,
|
||||
END_TO_START = 1
|
||||
} ;
|
||||
bool find_optimal_blocksize( const Partition & partition_old,
|
||||
const Partition & partition_new,
|
||||
CopyType copytype,
|
||||
Sector & optimal_blocksize,
|
||||
Sector & offset,
|
||||
std::vector<OperationDetail> & operation_details ) ;
|
||||
|
||||
bool copy_blocks( const Glib::ustring & src_device,
|
||||
const Glib::ustring & dst_device,
|
||||
Sector src_start,
|
||||
Sector dst_start,
|
||||
Sector blocksize,
|
||||
Sector sectors,
|
||||
std::vector<OperationDetail> & operation_details,
|
||||
CopyType copytype,
|
||||
bool show_progress = true ) ;
|
||||
|
||||
bool copy_block( PedDevice * lp_device_src,
|
||||
PedDevice * lp_device_dst,
|
||||
Sector offset_src,
|
||||
|
@ -167,6 +187,7 @@ private:
|
|||
std::map< Glib::ustring, Glib::ustring >::iterator iter ;
|
||||
std::map< Glib::ustring, std::vector<Glib::ustring> >::iterator iter_mp ;
|
||||
|
||||
|
||||
//disabling automount stuff
|
||||
bool DISABLE_AUTOMOUNT ;
|
||||
std::map<Glib::ustring, Glib::ustring> disabled_automount_devices ;
|
||||
|
|
|
@ -29,13 +29,11 @@ public:
|
|||
OperationCopy( const Device & device,
|
||||
const Partition & partition_orig,
|
||||
const Partition & partition_new,
|
||||
const Partition & partition_copied,
|
||||
Sector block_size ) ;
|
||||
const Partition & partition_copied ) ;
|
||||
|
||||
void apply_to_visual( std::vector<Partition> & partitions ) ;
|
||||
|
||||
Partition partition_copied ;
|
||||
Sector block_size ;
|
||||
|
||||
private:
|
||||
void create_description() ;
|
||||
|
|
|
@ -88,18 +88,6 @@ void Dialog_Partition_Copy::Set_Data( const Partition & selected_partition, cons
|
|||
Utils::round( Utils::sector_to_unit( fs .MIN, GParted::UNIT_MIB ) ),
|
||||
Utils::round( Utils::sector_to_unit( fs .MAX, GParted::UNIT_MIB ) ) ) ;
|
||||
|
||||
|
||||
//allow the user to set the size of the blocks which will be copied at once
|
||||
hbox_block_size .set_spacing( 10 ) ;
|
||||
this ->get_vbox() ->pack_start( hbox_block_size ) ;
|
||||
hbox_block_size .pack_start( * Utils::mk_label( _("Blocksize (sectors):") ), Gtk::PACK_SHRINK ) ;
|
||||
|
||||
spinbutton_block_size .set_numeric( true ) ;
|
||||
spinbutton_block_size .set_increments( 1, 10 ) ;
|
||||
spinbutton_block_size .set_range( 1, MEBIBYTE ) ;
|
||||
spinbutton_block_size .set_value( 32 ) ;
|
||||
hbox_block_size .pack_start( spinbutton_block_size, Gtk::PACK_SHRINK ) ;
|
||||
|
||||
//set global selected_partition (see Dialog_Base_Partition::Get_New_Partition )
|
||||
this ->selected_partition = copied_partition ;
|
||||
this ->selected_partition .device_path = selected_partition .device_path ;
|
||||
|
@ -120,9 +108,5 @@ Partition Dialog_Partition_Copy::Get_New_Partition()
|
|||
|
||||
return selected_partition ;
|
||||
}
|
||||
Sector Dialog_Partition_Copy::get_block_size()
|
||||
{
|
||||
return spinbutton_block_size .get_value_as_int() ;
|
||||
}
|
||||
|
||||
} //GParted
|
||||
|
|
|
@ -61,7 +61,7 @@ void Dialog_Partition_Resize_Move::Set_Data( const Partition & selected_partitio
|
|||
|
||||
void Dialog_Partition_Resize_Move::Resize_Move_Normal( const std::vector<Partition> & partitions )
|
||||
{
|
||||
//little bit of paranoia ;)
|
||||
//little bit of paranoia ;)//FIXME: partition with STAT_NEW should not be restricted ;)
|
||||
if ( selected_partition .sectors_used == -1 )
|
||||
fs .shrink = GParted::FS::NONE ;
|
||||
|
||||
|
|
|
@ -209,7 +209,8 @@ void Dialog_Progress::on_signal_show()
|
|||
{
|
||||
update_operation_details( treerow, operations[ t ] ->operation_detail ) ;
|
||||
if ( operations[ t ] ->operation_detail .sub_details .size() > 0 )
|
||||
label_current_sub .set_markup(
|
||||
label_current_sub .set_markup(//FIXME: move this to update_operation_details and
|
||||
//show every sub that has STATUS_EXECUTE...
|
||||
"<i>" +
|
||||
operations[ t ] ->operation_detail .sub_details .back() .get_description() +
|
||||
"</i>\n" ) ;
|
||||
|
|
|
@ -349,7 +349,6 @@ bool GParted_Core::apply_operation_to_disk( Operation * operation )
|
|||
succes = copy( static_cast<OperationCopy*>( operation ) ->partition_copied,
|
||||
operation ->partition_new,
|
||||
static_cast<OperationCopy*>( operation ) ->partition_copied .get_length(),
|
||||
static_cast<OperationCopy*>( operation ) ->block_size,
|
||||
operation ->operation_detail .sub_details ) ;
|
||||
break ;
|
||||
}
|
||||
|
@ -1221,127 +1220,19 @@ bool GParted_Core::move_filesystem_using_gparted( const Partition & partition_ol
|
|||
{
|
||||
operation_details .push_back( OperationDetail( _("using internal algorithm"), STATUS_NONE ) ) ;
|
||||
|
||||
bool succes = false ;
|
||||
if ( open_device_and_disk( partition_old .device_path ) )
|
||||
{
|
||||
Glib::ustring error_message ;
|
||||
if ( ped_device_open( lp_device ) )
|
||||
{
|
||||
ped_device_sync( lp_device ) ;
|
||||
CopyType copytype = partition_new .sector_start < partition_old .sector_start ? START_TO_END : END_TO_START ;
|
||||
Sector optimal_blocksize, offset ;
|
||||
|
||||
//add an empty sub which we will constantly update in the loop
|
||||
operation_details .push_back( OperationDetail( "", STATUS_NONE ) ) ;
|
||||
|
||||
Sector blocksize = 32; //FIXME: write an algorithm to determine the optimal blocksize
|
||||
Sector t ;
|
||||
if ( partition_new .sector_start < partition_old .sector_start ) //move to the left
|
||||
{
|
||||
Sector rest_sectors = partition_old .get_length() % blocksize ;
|
||||
for ( t = 0 ; t < partition_old .get_length() - rest_sectors ; t+=blocksize )
|
||||
{
|
||||
if ( ! copy_block( lp_device,
|
||||
lp_device,
|
||||
partition_old .sector_start +t,
|
||||
partition_new .sector_start +t,
|
||||
blocksize,
|
||||
error_message ) )
|
||||
break ;
|
||||
|
||||
if ( t % (blocksize * 100) == 0 )
|
||||
{
|
||||
operation_details .back() .progress_text =
|
||||
String::ucompose( _("%1 of %2 moved"),
|
||||
Utils::format_size( t +blocksize ),
|
||||
Utils::format_size( partition_old .get_length() ) ) ;
|
||||
|
||||
operation_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 moved"),
|
||||
t +blocksize,
|
||||
partition_old .get_length() ),
|
||||
FONT_ITALIC ) ;
|
||||
|
||||
operation_details .back() .fraction =
|
||||
t / static_cast<double>( partition_old .get_length() ) ;
|
||||
}
|
||||
}
|
||||
|
||||
if ( rest_sectors > 0 &&
|
||||
partition_old .get_length() -t == rest_sectors &&
|
||||
copy_block( lp_device,
|
||||
lp_device,
|
||||
partition_old .sector_start +t,
|
||||
partition_new .sector_start +t,
|
||||
rest_sectors,
|
||||
error_message ) )
|
||||
t += rest_sectors ;
|
||||
}
|
||||
else //move to the right..
|
||||
{//FIXME: moving to the right still appears slower than moving to the left...
|
||||
//most likely this has something to do with the fact we're reading from right to left, i guess the
|
||||
//headers of the disk have to move more.. (check this with the parted people)
|
||||
//since reading from RTL is only needed in case of overlap we could check for this...
|
||||
Sector rest_sectors = partition_old .get_length() % blocksize ;
|
||||
for ( t = 0 ; t < partition_old .get_length() - rest_sectors ; t+=blocksize )
|
||||
{
|
||||
if ( ! copy_block( lp_device,
|
||||
lp_device,
|
||||
partition_old .sector_end +1 -blocksize -t,
|
||||
partition_new .sector_end +1 -blocksize -t,
|
||||
blocksize,
|
||||
error_message ) )
|
||||
break ;
|
||||
|
||||
if ( t % (blocksize * 100) == 0 )
|
||||
{
|
||||
operation_details .back() .progress_text =
|
||||
String::ucompose( _("%1 of %2 moved"),
|
||||
Utils::format_size( t +blocksize ),
|
||||
Utils::format_size( partition_old .get_length() ) ) ;
|
||||
|
||||
operation_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 moved"),
|
||||
t +blocksize,
|
||||
partition_old .get_length() ),
|
||||
FONT_ITALIC ) ;
|
||||
|
||||
operation_details .back() .fraction =
|
||||
t / static_cast<double>( partition_old .get_length() ) ;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
if ( rest_sectors > 0 &&
|
||||
partition_old .get_length() -t == rest_sectors &&
|
||||
copy_block( lp_device,
|
||||
lp_device,
|
||||
partition_old .sector_start,
|
||||
partition_new .sector_start,
|
||||
rest_sectors,
|
||||
error_message ) )
|
||||
t += rest_sectors ;
|
||||
}
|
||||
|
||||
//final description
|
||||
operation_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 moved"), t, partition_old .get_length() ), FONT_ITALIC ) ;
|
||||
|
||||
//reset fraction to -1 to make room for a new one (or a pulsebar)
|
||||
operation_details .back() .fraction = -1 ;
|
||||
|
||||
if ( t == partition_old .get_length() )
|
||||
succes = true ;
|
||||
else
|
||||
{
|
||||
if ( ! error_message .empty() )
|
||||
operation_details .push_back(
|
||||
OperationDetail( error_message, STATUS_NONE, FONT_ITALIC ) ) ;
|
||||
}
|
||||
}
|
||||
|
||||
close_device_and_disk() ;
|
||||
}
|
||||
|
||||
return succes ;
|
||||
return find_optimal_blocksize( partition_old, partition_new, copytype, optimal_blocksize, offset, operation_details )
|
||||
&&
|
||||
copy_blocks( partition_old .device_path,
|
||||
partition_new .device_path,
|
||||
partition_old .sector_start + offset,
|
||||
partition_new .sector_start + offset,
|
||||
optimal_blocksize,
|
||||
partition_old .get_length() - offset,
|
||||
operation_details,
|
||||
copytype ) ;
|
||||
}
|
||||
|
||||
bool GParted_Core::resize_move_filesystem_using_libparted( const Partition & partition_old,
|
||||
|
@ -1636,7 +1527,6 @@ bool GParted_Core::maximize_filesystem( const Partition & partition,
|
|||
bool GParted_Core::copy( const Partition & partition_src,
|
||||
Partition & partition_dest,
|
||||
Sector min_size,
|
||||
Sector block_size,
|
||||
std::vector<OperationDetail> & operation_details )
|
||||
{
|
||||
if ( check_repair( partition_src, operation_details ) )
|
||||
|
@ -1658,8 +1548,7 @@ bool GParted_Core::copy( const Partition & partition_src,
|
|||
case GParted::FS::GPARTED :
|
||||
succes = copy_filesystem( partition_src,
|
||||
partition_dest,
|
||||
operation_details .back() .sub_details,
|
||||
block_size ) ;
|
||||
operation_details .back() .sub_details ) ;
|
||||
break ;
|
||||
|
||||
case GParted::FS::LIBPARTED :
|
||||
|
@ -1691,107 +1580,26 @@ bool GParted_Core::copy( const Partition & partition_src,
|
|||
}
|
||||
|
||||
bool GParted_Core::copy_filesystem( const Partition & partition_src,
|
||||
const Partition & partition_dest,
|
||||
std::vector<OperationDetail> & operation_details,
|
||||
Sector blocksize )
|
||||
const Partition & partition_dst,
|
||||
std::vector<OperationDetail> & operation_details )
|
||||
{
|
||||
operation_details .push_back( OperationDetail(
|
||||
String::ucompose( _("Use a blocksize of %1 (%2 sectors)"), Utils::format_size( blocksize ), blocksize ),
|
||||
STATUS_NONE,
|
||||
FONT_ITALIC ) ) ;
|
||||
Sector optimal_blocksize, offset ;
|
||||
|
||||
bool succes = false ;
|
||||
PedDevice *lp_device_src, *lp_device_dest ;
|
||||
|
||||
lp_device_src = ped_device_get( partition_src .device_path .c_str() );
|
||||
|
||||
if ( partition_src .device_path != partition_dest .device_path )
|
||||
lp_device_dest = ped_device_get( partition_dest .device_path .c_str() );
|
||||
else
|
||||
lp_device_dest = lp_device_src ;
|
||||
|
||||
if ( lp_device_src && lp_device_dest && ped_device_open( lp_device_src ) && ped_device_open( lp_device_dest ) )
|
||||
{
|
||||
ped_device_sync( lp_device_dest ) ;
|
||||
|
||||
//add an empty sub which we will constantly update in the loop
|
||||
operation_details .push_back( OperationDetail( "", STATUS_NONE ) ) ;
|
||||
|
||||
Glib::ustring error_message ;
|
||||
Sector t ;
|
||||
Sector rest_sectors = partition_src .get_length() % blocksize ;
|
||||
for ( t = 0 ; t < partition_src .get_length() - rest_sectors ; t+=blocksize )
|
||||
{
|
||||
if ( ! copy_block( lp_device_src,
|
||||
lp_device_dest,
|
||||
partition_src .sector_start + t,
|
||||
partition_dest .sector_start + t,
|
||||
blocksize,
|
||||
error_message ) )
|
||||
break ;
|
||||
|
||||
if ( t % ( blocksize * 100 ) == 0 )
|
||||
{
|
||||
operation_details .back() .progress_text =
|
||||
String::ucompose( _("%1 of %2 copied"),
|
||||
Utils::format_size( t +blocksize ),
|
||||
Utils::format_size( partition_src .get_length() ) ) ;
|
||||
|
||||
operation_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 moved"),
|
||||
t +blocksize,
|
||||
partition_src .get_length() ),
|
||||
FONT_ITALIC ) ;
|
||||
|
||||
operation_details .back() .fraction =
|
||||
t / static_cast<double>( partition_src .get_length() ) ;
|
||||
}
|
||||
}
|
||||
|
||||
if ( rest_sectors > 0 &&
|
||||
partition_src .get_length() -t == rest_sectors &&
|
||||
copy_block( lp_device_src,
|
||||
lp_device_dest,
|
||||
partition_src .sector_start +t,
|
||||
partition_dest .sector_start +t,
|
||||
rest_sectors,
|
||||
error_message ) )
|
||||
t += rest_sectors ;
|
||||
|
||||
|
||||
//final description
|
||||
operation_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 copied"), t, partition_src .get_length() ), FONT_ITALIC ) ;
|
||||
|
||||
//reset fraction to -1 to make room for a new one (or a pulsebar)
|
||||
operation_details .back() .fraction = -1 ;
|
||||
|
||||
if ( t == partition_src .get_length() )
|
||||
succes = true ;
|
||||
else
|
||||
{
|
||||
if ( ! error_message .empty() )
|
||||
operation_details .push_back(
|
||||
OperationDetail( error_message, STATUS_NONE, FONT_ITALIC ) ) ;
|
||||
}
|
||||
|
||||
//close the devices..
|
||||
ped_device_close( lp_device_src ) ;
|
||||
|
||||
if ( partition_src .device_path != partition_dest .device_path )
|
||||
ped_device_close( lp_device_dest ) ;
|
||||
|
||||
//detroy the devices..
|
||||
ped_device_destroy( lp_device_src ) ;
|
||||
|
||||
if ( partition_src .device_path != partition_dest .device_path )
|
||||
ped_device_destroy( lp_device_dest ) ;
|
||||
}
|
||||
else
|
||||
operation_details .push_back(
|
||||
OperationDetail( _("An error occurred while opening the devices"), STATUS_NONE ) ) ;
|
||||
|
||||
return succes ;
|
||||
return find_optimal_blocksize( partition_src,
|
||||
partition_dst,
|
||||
START_TO_END,
|
||||
optimal_blocksize,
|
||||
offset,
|
||||
operation_details )
|
||||
&&
|
||||
copy_blocks( partition_src .device_path,
|
||||
partition_dst .device_path,
|
||||
partition_src .sector_start + offset,
|
||||
partition_dst .sector_start + offset,
|
||||
optimal_blocksize,
|
||||
partition_src .get_length() - offset,
|
||||
operation_details,
|
||||
START_TO_END ) ;
|
||||
}
|
||||
|
||||
bool GParted_Core::check_repair( const Partition & partition, std::vector<OperationDetail> & operation_details )
|
||||
|
@ -1863,6 +1671,207 @@ bool GParted_Core::set_partition_type( const Partition & partition,
|
|||
return return_value ;
|
||||
}
|
||||
|
||||
bool GParted_Core::find_optimal_blocksize( const Partition & partition_old,
|
||||
const Partition & partition_new,
|
||||
CopyType copytype,
|
||||
Sector & optimal_blocksize,
|
||||
Sector & offset,
|
||||
std::vector<OperationDetail> & operation_details )
|
||||
{//FIXME, this probing is actually quite clumsy and suboptimal..
|
||||
//find out if there is a better way to determine a (close to) optimal blocksize...
|
||||
bool succes = true ;
|
||||
|
||||
optimal_blocksize = 32 ;//sensible default?
|
||||
offset = 0 ;
|
||||
|
||||
if ( partition_old .get_length() > 100000 )
|
||||
{
|
||||
operation_details .push_back( OperationDetail( _("finding optimal blocksize"), STATUS_NONE ) ) ;
|
||||
|
||||
std::clock_t clockticks_start, smallest_ticks = -1 ;
|
||||
|
||||
std::vector<Sector> blocksizes ;
|
||||
blocksizes .push_back( 1 ) ;
|
||||
blocksizes .push_back( 32 ) ;
|
||||
blocksizes .push_back( 128 ) ;
|
||||
blocksizes .push_back( 256 ) ;
|
||||
blocksizes .push_back( 512 ) ;
|
||||
|
||||
for ( unsigned int t = 0 ; t < blocksizes .size() && succes ; t++ )
|
||||
{
|
||||
clockticks_start = std::clock() ;
|
||||
|
||||
succes = copy_blocks( partition_old .device_path,
|
||||
partition_new .device_path,
|
||||
partition_old .sector_start + offset,
|
||||
partition_new .sector_start + offset,
|
||||
blocksizes[ t ],
|
||||
20000,
|
||||
operation_details .back() .sub_details,
|
||||
copytype,
|
||||
false ) ;
|
||||
|
||||
if ( (std::clock() - clockticks_start) < smallest_ticks || smallest_ticks == -1 )
|
||||
{
|
||||
smallest_ticks = std::clock() - clockticks_start ;
|
||||
optimal_blocksize = blocksizes[ t ] ;
|
||||
}
|
||||
|
||||
operation_details .back() .sub_details .back() .sub_details .push_back( OperationDetail(
|
||||
String::ucompose( _("%1 clockticks"), std::clock() - clockticks_start ),
|
||||
STATUS_NONE,
|
||||
FONT_ITALIC ) ) ;
|
||||
|
||||
offset += 20000 ;
|
||||
}
|
||||
|
||||
operation_details .back() .sub_details .push_back( OperationDetail(
|
||||
String::ucompose( _("optimal blocksize is %1 sectors (%2)"),
|
||||
optimal_blocksize,
|
||||
Utils::format_size( optimal_blocksize ) ) ,
|
||||
STATUS_NONE ) ) ;
|
||||
}
|
||||
|
||||
return succes ;
|
||||
}
|
||||
|
||||
bool GParted_Core::copy_blocks( const Glib::ustring & src_device,
|
||||
const Glib::ustring & dst_device,
|
||||
Sector src_start,
|
||||
Sector dst_start,
|
||||
Sector blocksize,
|
||||
Sector sectors,
|
||||
std::vector<OperationDetail> & operation_details,
|
||||
CopyType copytype,
|
||||
bool show_progress )
|
||||
{
|
||||
operation_details .push_back( OperationDetail(
|
||||
String::ucompose( _("copy %1 sectors using a blocksize of %2 sectors"), sectors, blocksize ), STATUS_NONE ) ) ;
|
||||
|
||||
bool succes = false ;
|
||||
PedDevice *lp_device_src, *lp_device_dst ;
|
||||
|
||||
lp_device_src = ped_device_get( src_device .c_str() );
|
||||
|
||||
if ( src_device != dst_device )
|
||||
lp_device_dst = ped_device_get( dst_device .c_str() );
|
||||
else
|
||||
lp_device_dst = lp_device_src ;
|
||||
|
||||
Glib::ustring error_message ;
|
||||
if ( lp_device_src && lp_device_dst && ped_device_open( lp_device_src ) && ped_device_open( lp_device_dst ) )
|
||||
{
|
||||
ped_device_sync( lp_device_dst ) ;
|
||||
//add an empty sub which we will constantly update in the loop
|
||||
operation_details .back() .sub_details .push_back( OperationDetail( "", STATUS_NONE ) ) ;
|
||||
|
||||
Sector t ;
|
||||
if ( copytype == START_TO_END )
|
||||
{
|
||||
Sector rest_sectors = sectors % blocksize ;
|
||||
for ( t = 0 ; t < sectors - rest_sectors ; t+=blocksize )
|
||||
{
|
||||
if ( ! copy_block( lp_device_src,
|
||||
lp_device_dst,
|
||||
src_start +t,
|
||||
dst_start +t,
|
||||
blocksize,
|
||||
error_message ) )
|
||||
break ;
|
||||
//FIXME: the stuff in the if-block should get its own function and should display remaining time.
|
||||
if ( show_progress && t % (blocksize * 100) == 0 )
|
||||
{
|
||||
operation_details .back() .sub_details .back() .progress_text =
|
||||
String::ucompose( _("%1 of %2 copied"),
|
||||
Utils::format_size( t +blocksize ),
|
||||
Utils::format_size( sectors ) ) ;
|
||||
|
||||
operation_details .back() .sub_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 copied"), t +blocksize, sectors ), FONT_ITALIC ) ;
|
||||
|
||||
operation_details .back() .sub_details .back() .fraction =
|
||||
t / static_cast<double>( sectors ) ;
|
||||
}
|
||||
}
|
||||
|
||||
if ( rest_sectors > 0 &&
|
||||
sectors -t == rest_sectors &&
|
||||
copy_block( lp_device_src,
|
||||
lp_device_dst,
|
||||
src_start +t,
|
||||
dst_start +t,
|
||||
rest_sectors,
|
||||
error_message ) )
|
||||
t += rest_sectors ;
|
||||
}
|
||||
else if ( copytype == END_TO_START )
|
||||
{
|
||||
Sector rest_sectors = sectors % blocksize ;
|
||||
for ( t = 0 ; t < sectors - rest_sectors ; t+=blocksize )
|
||||
{
|
||||
if ( ! copy_block( lp_device_src,
|
||||
lp_device_dst,
|
||||
src_start + sectors -blocksize -t,
|
||||
dst_start + sectors -blocksize -t,
|
||||
blocksize,
|
||||
error_message ) )
|
||||
break ;
|
||||
|
||||
if ( show_progress && t % (blocksize * 100) == 0 )
|
||||
{
|
||||
operation_details .back() .sub_details .back() .progress_text =
|
||||
String::ucompose( _("%1 of %2 copied"),
|
||||
Utils::format_size( t +blocksize ),
|
||||
Utils::format_size( sectors ) ) ;
|
||||
|
||||
operation_details .back() .sub_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 copied"), t +blocksize, sectors ), FONT_ITALIC ) ;
|
||||
|
||||
operation_details .back() .sub_details .back() .fraction =
|
||||
t / static_cast<double>( sectors ) ;
|
||||
}
|
||||
}
|
||||
|
||||
if ( rest_sectors > 0 &&
|
||||
sectors -t == rest_sectors &&
|
||||
copy_block( lp_device_src,
|
||||
lp_device_dst,
|
||||
src_start,
|
||||
dst_start,
|
||||
rest_sectors,
|
||||
error_message ) )
|
||||
t += rest_sectors ;
|
||||
}
|
||||
|
||||
|
||||
//final description
|
||||
operation_details .back() .sub_details .back() .set_description(
|
||||
String::ucompose( _("%1 of %2 copied"), t, sectors ), FONT_ITALIC ) ;
|
||||
|
||||
//reset fraction to -1 to make room for a new one (or a pulsebar)
|
||||
operation_details .back() .sub_details .back() .fraction = -1 ;
|
||||
|
||||
if ( t == sectors )
|
||||
succes = true ;
|
||||
|
||||
if ( ! succes && ! error_message .empty() )
|
||||
operation_details .back() .sub_details .push_back(
|
||||
OperationDetail( error_message, STATUS_NONE, FONT_ITALIC ) ) ;
|
||||
|
||||
//close and destroy the devices..
|
||||
ped_device_close( lp_device_src ) ;
|
||||
ped_device_destroy( lp_device_src ) ;
|
||||
|
||||
if ( src_device != dst_device )
|
||||
{
|
||||
ped_device_close( lp_device_dst ) ;
|
||||
ped_device_destroy( lp_device_dst ) ;
|
||||
}
|
||||
}
|
||||
|
||||
return succes ;
|
||||
}
|
||||
|
||||
bool GParted_Core::copy_block( PedDevice * lp_device_src,
|
||||
PedDevice * lp_device_dst,
|
||||
Sector offset_src,
|
||||
|
|
|
@ -23,8 +23,7 @@ namespace GParted
|
|||
OperationCopy::OperationCopy( const Device & device,
|
||||
const Partition & partition_orig,
|
||||
const Partition & partition_new,
|
||||
const Partition & partition_copied,
|
||||
Sector block_size )
|
||||
const Partition & partition_copied )
|
||||
{
|
||||
type = OPERATION_COPY ;
|
||||
|
||||
|
@ -32,7 +31,6 @@ OperationCopy::OperationCopy( const Device & device,
|
|||
this ->partition_original = partition_orig ;
|
||||
this ->partition_new = partition_new ;
|
||||
this ->partition_copied = partition_copied ;
|
||||
this ->block_size = block_size ;
|
||||
|
||||
this ->partition_new .add_path(
|
||||
String::ucompose( _("copy of %1"), this ->partition_copied .get_path() ), true ) ;
|
||||
|
|
|
@ -1274,8 +1274,7 @@ void Win_GParted::activate_paste()
|
|||
Operation * operation = new OperationCopy( devices[ current_device ],
|
||||
selected_partition,
|
||||
dialog .Get_New_Partition(),
|
||||
copied_partition,
|
||||
dialog .get_block_size() ) ;
|
||||
copied_partition ) ;
|
||||
operation ->icon = render_icon( Gtk::Stock::COPY, Gtk::ICON_SIZE_MENU );
|
||||
|
||||
Add_Operation( operation ) ;
|
||||
|
@ -1291,15 +1290,10 @@ void Win_GParted::activate_paste()
|
|||
partition_new .set_used( copied_partition .sectors_used ) ;
|
||||
partition_new .messages .clear() ;
|
||||
|
||||
//FIXME: in this case there's no window presented to the user, so he cannot choose the blocksize
|
||||
//i guess this means we have to present a window with the choice (maybe the copydialog, with everything
|
||||
//except the blocksize disabled?
|
||||
//bleh, this will be fixed as soon as the algorith to determine the optimal blocksize is in place
|
||||
Operation * operation = new OperationCopy( devices[ current_device ],
|
||||
selected_partition,
|
||||
partition_new,
|
||||
copied_partition,
|
||||
32 ) ;
|
||||
copied_partition ) ;
|
||||
operation ->icon = render_icon( Gtk::Stock::COPY, Gtk::ICON_SIZE_MENU );
|
||||
|
||||
Add_Operation( operation ) ;
|
||||
|
|
Loading…
Reference in New Issue