diff --git a/juci/CMakeLists.txt b/juci/CMakeLists.txt index bddf3ef..9f93102 100644 --- a/juci/CMakeLists.txt +++ b/juci/CMakeLists.txt @@ -4,7 +4,7 @@ set(module juci_to_python_api) project (${project_name}) -set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++14") +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_CURRENT_LIST_DIR}/cmake/Modules/") INCLUDE(FindPkgConfig) diff --git a/juci/cmake/Modules/FindTestlcl.cmake b/juci/cmake/Modules/FindTestlcl.cmake index c28720f..55f7aca 100644 --- a/juci/cmake/Modules/FindTestlcl.cmake +++ b/juci/cmake/Modules/FindTestlcl.cmake @@ -10,11 +10,11 @@ find_package(PkgConfig) find_path(LCL_INCLUDE_DIR headers/TranslationUnit.h - HINTS "/home/forgie/code/libclangpp/" + HINTS "/home/gm/bachelor/lib/" ) find_library(LCL_LIBRARY NAMES testlcl - HINTS "/home/forgie/code/libclangpp/lib") + HINTS "/home/gm/bachelor/lib/lib/") set(LCL_LIBRARIES ${LCL_LIBRARY} ) set(LCL_INCLUDE_DIRS ${LCL_INCLUDE_DIR} ) diff --git a/juci/entry.cc b/juci/entry.cc index 147dd5a..7be5861 100644 --- a/juci/entry.cc +++ b/juci/entry.cc @@ -5,10 +5,13 @@ Entry::Model::Model() : prev_("Prev"){ std::cout<<"Model Entry"<add(Gtk::Action::create("FileNewCC", "New cc file"), Gtk::AccelKey("c"), [this]() { + isnewfile = true; OnFileNewCCFile(); }); keybindings.action_group_menu()->add(Gtk::Action::create("FileNewH", "New h file"), Gtk::AccelKey("h"), [this]() { + isnewfile = true; OnFileNewHeaderFile(); }); keybindings.action_group_menu()->add(Gtk::Action::create("WindowCloseTab", @@ -50,6 +53,8 @@ Notebook::Controller::Controller(Keybindings::Controller& keybindings){ keybindings.action_group_menu()->add(Gtk::Action::create("EditFind", Gtk::Stock::FIND), [this]() { + isnewfile = false; + OnEditSearch(); //TODO(Oyvang, Zalox, Forgi)Create function OnEditFind(); }); keybindings.action_group_menu()->add(Gtk::Action::create("EditCopy", @@ -69,7 +74,11 @@ Notebook::Controller::Controller(Keybindings::Controller& keybindings){ }); entry_.view_.entry().signal_activate().connect( [this]() { - OnNewPage(entry_.view_.entry().get_text()); + if(isnewfile){ + OnNewPage(entry_.text()); + }else{ + Search(); + } entry_.OnHideEntries(); }); }//Constructor @@ -132,17 +141,54 @@ void Notebook::Controller::OnEditCut() { } } -void Notebook::Controller::OnOpenFile(std::string filename) { +void Notebook::Controller::OnOpenFile(std::string path) { scrolledwindow_vec_.push_back(new Gtk::ScrolledWindow()); source_vec_.push_back(new Source::Controller); scrolledwindow_vec_.back()->add(source_vec_.back()->view()); - source_vec_.back()->OnOpenFile(filename); - view_.notebook().append_page(*scrolledwindow_vec_.back(), filename); + source_vec_.back()->OnOpenFile(path); + unsigned pos = path.find_last_of("/\\"); + view_.notebook().append_page(*scrolledwindow_vec_.back(), path.substr(pos+1)); view_.notebook().show_all_children(); view_.notebook().set_focus_child(*scrolledwindow_vec_.back()); view_.notebook().set_current_page(view_.notebook().get_n_pages()-1); } +std::string Notebook::Controller::GetCursorWord(){ + int page = view_.notebook().get_current_page(); + std::string word; + Gtk::TextIter start,end; + start=source_vec_.at(page)->view().get_buffer()->begin(); + end=source_vec_.at(page)->view().get_buffer()->end(); + // if(!source_vec_.at(page)->view().get_buffer()->get_selection_bounds(start, + // end)){ + start=source_vec_.at(page)->view().get_buffer()->get_insert()->get_iter(); + end=source_vec_.at(page)->view().get_buffer()->get_insert()->get_iter(); + if(!end.ends_line()) { + while(!end.ends_word()){ + end.forward_char(); + } + } + if(!start.starts_line()) { + while(!start.starts_word()){ + start.backward_char(); + } + } + word = source_vec_.at(page)->view().get_buffer()->get_text(start,end); + + //TODO(Oyvang)fix selected text + return word; +} +void Notebook::Controller::OnEditSearch(){ + entry_.OnShowSearch(GetCursorWord()); + +} + +void Notebook::Controller::Search(){ + std::string search_word; + search_word = entry_.text(); + //TODO(oyvang) create seacrh function + std::cout<<"funka"< source_vec_; std::vector scrolledwindow_vec_; Glib::RefPtr refClipboard; std::list listTargets; + std::string GetCursorWord(); void OnFileNewEmptyfile(); void OnFileNewCCFile(); void OnFileNewHeaderFile(); void OnEditCopy(); void OnEditPaste(); void OnEditCut(); + void OnEditSearch(); + void Search(); + private: + bool isnewfile; + }; // class controller } // namespace Notebook