Added logic to radio buttons to select method of duplicate finder
This commit is contained in:
parent
26084a695a
commit
6f516223a5
|
@ -185,7 +185,7 @@ Author: Rafał Mikrut
|
|||
<property name="spacing">1</property>
|
||||
<property name="homogeneous">True</property>
|
||||
<child>
|
||||
<object class="GtkButton">
|
||||
<object class="GtkButton" id="buttons_add_included_directory">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="receives_default">True</property>
|
||||
|
@ -236,7 +236,7 @@ Author: Rafał Mikrut
|
|||
</packing>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkButton">
|
||||
<object class="GtkButton" id="buttons_remove_included_directory">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="receives_default">True</property>
|
||||
|
@ -350,7 +350,7 @@ Author: Rafał Mikrut
|
|||
<property name="spacing">1</property>
|
||||
<property name="homogeneous">True</property>
|
||||
<child>
|
||||
<object class="GtkButton">
|
||||
<object class="GtkButton" id="buttons_add_excluded_directory">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="receives_default">True</property>
|
||||
|
@ -401,7 +401,7 @@ Author: Rafał Mikrut
|
|||
</packing>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkButton">
|
||||
<object class="GtkButton" id="buttons_remove_excluded_directory">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="receives_default">True</property>
|
||||
|
@ -774,8 +774,8 @@ Author: Rafał Mikrut
|
|||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="receives_default">False</property>
|
||||
<property name="active">True</property>
|
||||
<property name="draw_indicator">True</property>
|
||||
<property name="group">radio_button_hash</property>
|
||||
</object>
|
||||
<packing>
|
||||
<property name="expand">False</property>
|
||||
|
@ -789,9 +789,8 @@ Author: Rafał Mikrut
|
|||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="receives_default">False</property>
|
||||
<property name="active">True</property>
|
||||
<property name="draw_indicator">True</property>
|
||||
<property name="group">radio_button_size</property>
|
||||
<property name="group">radio_button_hash</property>
|
||||
</object>
|
||||
<packing>
|
||||
<property name="expand">False</property>
|
||||
|
@ -807,7 +806,6 @@ Author: Rafał Mikrut
|
|||
<property name="receives_default">False</property>
|
||||
<property name="active">True</property>
|
||||
<property name="draw_indicator">True</property>
|
||||
<property name="group">radio_button_size</property>
|
||||
</object>
|
||||
<packing>
|
||||
<property name="expand">False</property>
|
||||
|
|
|
@ -83,6 +83,11 @@ fn main() {
|
|||
let buttons_delete: gtk::Button = builder.get_object("buttons_delete").unwrap();
|
||||
let buttons_save: gtk::Button = builder.get_object("buttons_save").unwrap();
|
||||
|
||||
// let buttons_add_included_directory : gtk::Button =builder.get_object("buttons_add_included_directory").unwrap();
|
||||
// let buttons_remove_included_directory: gtk::Button =builder.get_object("buttons_remove_included_directory").unwrap();
|
||||
// let buttons_add_excluded_directory: gtk::Button =builder.get_object("buttons_add_excluded_directory").unwrap();
|
||||
// let buttons_remove_excluded_directory: gtk::Button =builder.get_object("buttons_remove_excluded_directory").unwrap();
|
||||
|
||||
// Not used buttons for now
|
||||
buttons_stop.hide();
|
||||
buttons_resume.hide();
|
||||
|
@ -92,6 +97,11 @@ fn main() {
|
|||
//// Check Buttons
|
||||
let check_button_recursive: gtk::CheckButton = builder.get_object("check_button_recursive").unwrap();
|
||||
|
||||
//// Radio Buttons
|
||||
let radio_button_size: gtk::RadioButton = builder.get_object("radio_button_size").unwrap();
|
||||
let radio_button_hashmb: gtk::RadioButton = builder.get_object("radio_button_hashmb").unwrap();
|
||||
let radio_button_hash: gtk::RadioButton = builder.get_object("radio_button_hash").unwrap();
|
||||
|
||||
//// Notebooks
|
||||
let notebook_chooser_tool: gtk::Notebook = builder.get_object("notebook_chooser_tool").unwrap();
|
||||
let mut notebook_chooser_tool_children_names: Vec<String> = Vec::new();
|
||||
|
@ -275,8 +285,10 @@ fn main() {
|
|||
});
|
||||
}
|
||||
|
||||
// Connect Buttons
|
||||
//// Connect Buttons
|
||||
|
||||
// Down notepad
|
||||
{
|
||||
assert!(notebook_chooser_tool_children_names.contains(&"notebook_duplicate_finder_label".to_string()));
|
||||
assert!(notebook_chooser_tool_children_names.contains(&"scrolled_window_empty_folder_finder".to_string()));
|
||||
// Search button
|
||||
|
@ -291,10 +303,18 @@ fn main() {
|
|||
match notebook_chooser_tool_children_names.get(notebook_chooser_tool.get_current_page().unwrap() as usize).unwrap().as_str() {
|
||||
"notebook_duplicate_finder_label" => {
|
||||
// Find duplicates
|
||||
// TODO Change to proper value
|
||||
|
||||
let mut df = DuplicateFinder::new();
|
||||
let check_method = duplicate::CheckingMethod::Hash; // TODO
|
||||
let check_method;
|
||||
if radio_button_size.get_active() {
|
||||
check_method = duplicate::CheckingMethod::Size;
|
||||
} else if radio_button_hashmb.get_active() {
|
||||
check_method = duplicate::CheckingMethod::HashMB;
|
||||
} else if radio_button_hash.get_active() {
|
||||
check_method = duplicate::CheckingMethod::Hash;
|
||||
} else {
|
||||
panic!("No radio button is pressed");
|
||||
}
|
||||
{
|
||||
df.set_included_directory(get_string_from_list_store(&scrolled_window_included_directories));
|
||||
df.set_excluded_directory(get_string_from_list_store(&scrolled_window_excluded_directories));
|
||||
|
@ -305,7 +325,7 @@ fn main() {
|
|||
Ok(t) => t,
|
||||
Err(_) => 1024, // By default
|
||||
});
|
||||
df.set_check_method(check_method.clone()); // TODO
|
||||
df.set_check_method(check_method.clone());
|
||||
df.set_delete_method(duplicate::DeleteMethod::None);
|
||||
df.find_duplicates();
|
||||
}
|
||||
|
@ -383,20 +403,22 @@ fn main() {
|
|||
let btreemap = df.get_files_sorted_by_size();
|
||||
|
||||
for (size, vector) in btreemap.iter().rev() {
|
||||
let values: [&dyn ToValue; 3] = [
|
||||
let values: [&dyn ToValue; 4] = [
|
||||
&(vector.len().to_string() + " x " + size.to_string().as_str()),
|
||||
&("(".to_string() + ((vector.len() - 1) as u64 * *size as u64).to_string().as_str() + ")"),
|
||||
&"Bytes lost".to_string(),
|
||||
&(HEADER_ROW_COLOR.to_string()),
|
||||
];
|
||||
list_store.set(&list_store.append(), &col_indices, &values);
|
||||
for entry in vector {
|
||||
let path = &entry.path;
|
||||
let index = path.rfind('/').unwrap();
|
||||
|
||||
let values: [&dyn ToValue; 3] = [
|
||||
let values: [&dyn ToValue; 4] = [
|
||||
&(path[index + 1..].to_string()),
|
||||
&(path[..index].to_string()),
|
||||
&(NaiveDateTime::from_timestamp(entry.modified_date.duration_since(UNIX_EPOCH).expect("Invalid file date").as_secs() as i64, 0).to_string()),
|
||||
&(MAIN_ROW_COLOR.to_string()),
|
||||
];
|
||||
list_store.set(&list_store.append(), &col_indices, &values);
|
||||
}
|
||||
|
@ -554,6 +576,12 @@ fn main() {
|
|||
});
|
||||
}
|
||||
}
|
||||
// Upper Notepad
|
||||
{
|
||||
// Add excluded directory
|
||||
{}
|
||||
}
|
||||
}
|
||||
|
||||
// Quit the program when X in main window was clicked
|
||||
main_window.connect_delete_event(|_, _| {
|
||||
|
|
Loading…
Reference in a new issue