#include "juci.h" #include "config.h" #include "directories.h" #include "menu.h" #include "notebook.h" #include "terminal.h" #include "window.h" #ifndef _WIN32 #include #endif int Application::on_command_line(const Glib::RefPtr &cmd) { Glib::set_prgname("juci"); Glib::OptionContext ctx("[PATH ...]"); Glib::OptionGroup gtk_group(gtk_get_option_group(true)); ctx.add_group(gtk_group); int argc; char **argv = cmd->get_arguments(argc); ctx.parse(argc, argv); if(argc >= 2) { boost::system::error_code current_path_ec; auto current_path = boost::filesystem::current_path(current_path_ec); if(current_path_ec) errors.emplace_back("Error: could not find current path\n"); for(int c = 1; c < argc; c++) { boost::filesystem::path path(argv[c]); if(path.is_relative() && !current_path_ec) path = current_path / path; if(boost::filesystem::exists(path)) { if(boost::filesystem::is_regular_file(path)) files.emplace_back(path, 0); else if(boost::filesystem::is_directory(path)) directories.emplace_back(path); } //Open new file if parent path exists else { if(path.is_absolute() && boost::filesystem::is_directory(path.parent_path())) files.emplace_back(path, 0); else errors.emplace_back("Error: could not create " + path.string() + ".\n"); } } } activate(); return 0; } void Application::on_activate() { std::vector> file_offsets; std::string current_file; Window::get().load_session(directories, files, file_offsets, current_file, directories.empty() && files.empty()); Window::get().add_widgets(); add_window(Window::get()); Window::get().show(); bool first_directory = true; for(auto &directory : directories) { if(first_directory) { Directories::get().open(directory); first_directory = false; } else { std::string files_in_directory; for(auto it = files.begin(); it != files.end();) { if(it->first.generic_string().compare(0, directory.generic_string().size() + 1, directory.generic_string() + '/') == 0) { files_in_directory += " " + it->first.string(); it = files.erase(it); } else it++; } std::thread another_juci_app([directory, files_in_directory]() { Terminal::get().async_print("Executing: juci " + directory.string() + files_in_directory + "\n"); Terminal::get().process("juci " + directory.string() + files_in_directory, "", false); }); another_juci_app.detach(); } } for(size_t i = 0; i < files.size(); ++i) { Notebook::get().open(files[i].first, files[i].second); if(i < file_offsets.size()) { if(auto view = Notebook::get().get_current_view()) { view->place_cursor_at_line_offset(file_offsets[i].first, file_offsets[i].second); view->hide_tooltips(); } } } for(auto &error : errors) Terminal::get().print(error, true); if(!current_file.empty()) { Notebook::get().open(current_file); if(auto view = Notebook::get().get_current_view()) { auto iter = view->get_buffer()->get_insert()->get_iter(); // To update cursor history view->place_cursor_at_line_offset(iter.get_line(), iter.get_line_offset()); view->hide_tooltips(); } } while(Gtk::Main::events_pending()) Gtk::Main::iteration(false); for(auto view : Notebook::get().get_views()) view->scroll_to(view->get_buffer()->get_insert(), 0.0, 1.0, 0.5); } void Application::on_startup() { Gtk::Application::on_startup(); Menu::get().build(); if(!Menu::get().juci_menu || !Menu::get().window_menu) { std::cerr << "Menu not found." << std::endl; } else { set_app_menu(Menu::get().juci_menu); set_menubar(Menu::get().window_menu); } } Application::Application() : Gtk::Application("no.sout.juci", Gio::APPLICATION_NON_UNIQUE | Gio::APPLICATION_HANDLES_COMMAND_LINE) { Glib::set_application_name("juCi++"); //Gtk::MessageDialog without buttons caused text to be selected, this prevents that Gtk::Settings::get_default()->property_gtk_label_select_on_focus() = false; } int main(int argc, char *argv[]) { #ifndef _WIN32 signal(SIGPIPE, SIG_IGN); // Do not terminate application when writing to a process fails #endif return Application().run(argc, argv); }