feat: implement opening a file to a new editor

merge-requests/8/head
Nefo Fortressia 2021-10-22 10:36:47 +07:00
parent 5a610f7be5
commit 78fd553104
1 changed files with 21 additions and 10 deletions

View File

@ -89,7 +89,7 @@ impl EchidnaEditorExt for EchidnaEditor {
// TODO: Somehow inserts self to this function. // TODO: Somehow inserts self to this function.
// This function sets the callback function as 'static, which for some reasons ban cloning self into it. Idk why. // This function sets the callback function as 'static, which for some reasons ban cloning self into it. Idk why.
dialog.connect_response(clone!(@weak window => dialog.connect_response(clone!( @weak app, @weak window, =>
move |dialog, response| { move |dialog, response| {
if response == ResponseType::Accept { if response == ResponseType::Accept {
@ -99,7 +99,8 @@ impl EchidnaEditorExt for EchidnaEditor {
match file_option { match file_option {
Some(file) => { Some(file) => {
dialog.destroy(); dialog.destroy();
Self::open_file(file);
Self::open_file(&notebook, file);
}, },
None => { None => {
@ -115,12 +116,11 @@ impl EchidnaEditorExt for EchidnaEditor {
fn open_file(notebook: &gtk::Notebook, file: gio::File){ fn open_file(notebook: &gtk::Notebook, file: gio::File){
let cancellable = Cancellable::new(); let cancellable = Cancellable::new();
let filepath = file.path(); let filepath = file.path().expect("No filepath");
let file_info_result = file.query_info( let file_info_result = file.query_info(
"*", "*",
gio::FileQueryInfoFlags::NONE, gio::FileQueryInfoFlags::NONE,
Some(&cancellable)); Some(&cancellable));
match file_info_result { match file_info_result {
Ok(info) => { Ok(info) => {
match info.content_type() { match info.content_type() {
@ -130,12 +130,23 @@ impl EchidnaEditorExt for EchidnaEditor {
let file_content = file.load_contents(Some(&content_cancellable)); let file_content = file.load_contents(Some(&content_cancellable));
match file_content { match file_content {
Ok(content) => { Ok(content) => {
let (int_vec, text_option) = content; let (int_vec, _text_option) = content;
println!("The int vector of {:?} is {:?}", filepath, int_vec); let language_manager = LanguageManager::new();
match text_option { let language = language_manager.guess_language(Some(&info.name().to_str().expect("Could not open the file because its name is not supported by Unicode.")), None);
Some(text) => println!("Opened {:?} and its content is:\n{}", filepath, text.as_str()),
None => println!("No value for {:?}.", filepath), let buffer = Buffer::new(None);
buffer.set_text(from_utf8(&int_vec).expect(format!("Could not parse the contents of {:?} as it's unsupported by UTF-8", filepath).as_str()));
match language {
Some(lang) => buffer.set_language(Some(&lang)),
None => {}
} }
let sourceview = View::with_buffer(&buffer);
notebook.prepend_page(&sourceview,
Some(&Label::new(Some(&info.name().to_str()
.expect("Could not parse file's name")))));
} }
Err(e) => println!("Could not open {:?} because:\n{:#?}", filepath, e), Err(e) => println!("Could not open {:?} because:\n{:#?}", filepath, e),
} }