Browse Source

Fully working linenumbers

merge-requests/365/head
oyvang 11 years ago
parent
commit
64508d0ee4
  1. 1
      juci/api.cc
  2. 2
      juci/juci.cc
  3. 95
      juci/notebook.cc
  4. 4
      juci/notebook.h

1
juci/api.cc

@ -1,4 +1,3 @@
#include "api.h" #include "api.h"
Menu::Controller* PluginApi::menu_; Menu::Controller* PluginApi::menu_;

2
juci/juci.cc

@ -1,11 +1,11 @@
#include "window.h" #include "window.h"
int main(int argc, char *argv[]) { int main(int argc, char *argv[]) {
Glib::RefPtr<Gtk::Application> app = Gtk::Application::create( Glib::RefPtr<Gtk::Application> app = Gtk::Application::create(
argc, argc,
argv, argv,
"no.sout.juci"); "no.sout.juci");
Window window; Window window;
//api::LoadPlugin("juci_api_test"); //api::LoadPlugin("juci_api_test");

95
juci/notebook.cc

@ -1,10 +1,12 @@
#include <thread>
#include "notebook.h" #include "notebook.h"
Notebook::Model::Model() { Notebook::Model::Model() {
cc_extension_ = ".cc"; cc_extension_ = ".cc";
h_extension_ = ".h"; h_extension_ = ".h";
scrollvalue_ = 20; scrollvalue_ = 50;
}; };
Notebook::View::View(){ Notebook::View::View(){
view_.pack_start(notebook_); view_.pack_start(notebook_);
@ -95,13 +97,6 @@ Notebook::Controller::Controller(Keybindings::Controller& keybindings) {
Search(false); Search(false);
}); });
text_vec_.back()->view().
signal_scroll_event().connect(sigc::mem_fun(
this,
&Notebook::Controller::
scroll_event_callback));
}//Constructor }//Constructor
@ -116,19 +111,14 @@ bool Notebook::Controller::scroll_event_callback(GdkEventScroll* scroll_event) {
get_vscrollbar()->get_adjustment(); get_vscrollbar()->get_adjustment();
if ( direction_y != 0 ) { if ( direction_y != 0 ) {
int dir_val = direction_y==-1?-model_.scrollvalue_:+model_.scrollvalue_; int dir_val = direction_y==-1?-model_.scrollvalue_:+model_.scrollvalue_;
adj->set_value(adj->get_value()+dir_val); adj->set_value(adj->get_value()+dir_val);
text_vec_.at(page)->view().set_vadjustment(adj); text_vec_.at(page)->view().set_vadjustment(adj);
linenumbers_vec_.at(page)->view().set_vadjustment(adj); linenumbers_vec_.at(page)->view().set_vadjustment(adj);
} }
if ( direction_x != 0 ) {
int dir_val = direction_x==-1?-model_.scrollvalue_:+model_.scrollvalue_;
adj->set_value(adj->get_value()+dir_val);
text_vec_.at(page)->view().set_hadjustment(adj);
}
return true; return true;
} }
Notebook::Controller::~Controller() { Notebook::Controller::~Controller() {
for (auto &i : text_vec_) delete i; for (auto &i : text_vec_) delete i;
for (auto &i : linenumbers_vec_) delete i; for (auto &i : linenumbers_vec_) delete i;
@ -144,9 +134,9 @@ Gtk::Box& Notebook::Controller::entry_view() {
return entry_.view(); return entry_.view();
} }
void Notebook::Controller::OnNewPage(std::string name) { void Notebook::Controller::OnNewPage(std::string name) {
OnCreatePage(); OnCreatePage();
std::cout << "oppretta pages" << std::endl; std::cout << "oppretta pages" << std::endl;
text_vec_.back()->OnNewEmptyFile(); text_vec_.back()->OnNewEmptyFile();
Notebook().append_page(*editor_vec_.back(), name); Notebook().append_page(*editor_vec_.back(), name);
@ -163,21 +153,19 @@ void Notebook::Controller::OnOpenFile(std::string path) {
Notebook().show_all_children(); Notebook().show_all_children();
Notebook().set_current_page(Pages()-1); Notebook().set_current_page(Pages()-1);
Notebook().set_focus_child(text_vec_.back()->view()); Notebook().set_focus_child(text_vec_.back()->view());
lines = Buffer(linenumbers_vec_.back())->get_text();
OnBufferChange(); OnBufferChange();
} }
void Notebook::Controller::OnCreatePage(){ void Notebook::Controller::OnCreatePage(){
text_vec_.push_back(new Source::Controller); text_vec_.push_back(new Source::Controller);
std::string temp = "TEXT ";
temp += text_vec_.size();
text_vec_.back()->view().set_name(temp);
linenumbers_vec_.push_back(new Source::Controller); linenumbers_vec_.push_back(new Source::Controller);
scrolledline_vec_.push_back(new Gtk::ScrolledWindow()); scrolledline_vec_.push_back(new Gtk::ScrolledWindow());
scrolledtext_vec_.push_back(new Gtk::ScrolledWindow()); scrolledtext_vec_.push_back(new Gtk::ScrolledWindow());
editor_vec_.push_back(new Gtk::HBox()); editor_vec_.push_back(new Gtk::HBox());
scrolledtext_vec_.back()->add(text_vec_.back()->view()); scrolledtext_vec_.back()->add(text_vec_.back()->view());
scrolledline_vec_.back()->add(linenumbers_vec_.back()->view()); scrolledline_vec_.back()->add(linenumbers_vec_.back()->view());
linenumbers_vec_.back()->view().get_buffer()->set_text("1 \n"); linenumbers_vec_.back()->view().get_buffer()->set_text("1 ");
linenumbers_vec_.back()->view().override_color(Gdk::RGBA("Black")); linenumbers_vec_.back()->view().override_color(Gdk::RGBA("Black"));
linenumbers_vec_.back()-> linenumbers_vec_.back()->
view().set_justification(Gtk::Justification::JUSTIFY_RIGHT); view().set_justification(Gtk::Justification::JUSTIFY_RIGHT);
@ -186,6 +174,7 @@ void Notebook::Controller::OnCreatePage(){
linenumbers_vec_.back()->view().set_sensitive(false); linenumbers_vec_.back()->view().set_sensitive(false);
editor_vec_.back()->pack_start(*scrolledline_vec_.back(),false,false); editor_vec_.back()->pack_start(*scrolledline_vec_.back(),false,false);
editor_vec_.back()->pack_start(*scrolledtext_vec_.back(), true, true); editor_vec_.back()->pack_start(*scrolledtext_vec_.back(), true, true);
BufferChangeHandler(text_vec_.back()->view().get_buffer()); BufferChangeHandler(text_vec_.back()->view().get_buffer());
} }
@ -267,7 +256,7 @@ void Notebook::Controller::Search(bool forward){
if ( !forward ) { if ( !forward ) {
if ( search_match_start_ == 0 || if ( search_match_start_ == 0 ||
search_match_start_.get_line_offset() == 0) { search_match_start_.get_line_offset() == 0) {
search_match_start_= Buffer(text_vec_.at(CurrentPage()))->end(); search_match_start_= Buffer(text_vec_.at(CurrentPage()))->end();
} }
search_match_start_. search_match_start_.
@ -288,42 +277,35 @@ void Notebook::Controller::Search(bool forward){
search_match_end_); search_match_end_);
} }
} }
void Notebook::Controller::OnBufferChange() { void Notebook::Controller::OnBufferChange() {
int page = CurrentPage(); int page = CurrentPage();
int line_nr = Buffer(text_vec_.at(page))->get_line_count(); int text_nr = Buffer(text_vec_.at(page))->get_line_count();
int line_nr = Buffer(linenumbers_vec_.at(page))->get_line_count();
Glib::RefPtr while (line_nr < text_nr ){
<Gtk::TextBuffer::Mark> mark = Gtk::TextBuffer::Mark::create(); line_nr++;
Glib::RefPtr Buffer(linenumbers_vec_.at(page))->
<Gtk::TextBuffer::Mark> mark_lines = Gtk::TextBuffer::Mark::create(); insert(Buffer(linenumbers_vec_.at(page))->end(),
"\n"+std::to_string(line_nr)+" ");
if(Buffer(text_vec_.at(page))->get_insert()->get_iter().starts_line() && }
Buffer(text_vec_.at(page))->get_insert()->get_iter().get_line() == while (line_nr > text_nr ){
Buffer(text_vec_.at(page))->end().get_line()) { Gtk::TextIter iter = Buffer(linenumbers_vec_.at(page))->get_iter_at_line(line_nr);
std::string lines ="1 "; iter.backward_char();
for ( int it = 2; it <= line_nr; ++it ) { line_nr--;
lines.append("\n"+ std::to_string(it)+" "); Buffer(linenumbers_vec_.at(page))->
} erase(iter,
Buffer(linenumbers_vec_.at(page))->set_text(lines); Buffer(linenumbers_vec_.at(page))->end());
}
Buffer(text_vec_.at(page))-> if(Buffer(text_vec_.at(page))->get_insert()->get_iter().starts_line() &&
add_mark( Buffer(text_vec_.at(page))->get_insert()->get_iter().get_line() ==
mark, Buffer(text_vec_.at(page))->end().get_line()) {
Buffer(text_vec_.at(page))->end());
Buffer(linenumbers_vec_.at(page))-> GdkEventScroll* scroll = new GdkEventScroll;
add_mark( scroll->delta_y = 1.0;
mark_lines, scroll->delta_x = 0.0;
Buffer(linenumbers_vec_.at(page))->end()); scroll_event_callback(scroll);
delete scroll;
text_vec_.at(page)->view().scroll_to(mark); }
linenumbers_vec_.at(page)->view().scroll_to(mark_lines);
}else{
Buffer(text_vec_.at(page))->
add_mark(
mark,
Buffer(text_vec_.at(page))->
get_insert()->get_iter());
}
} }
@ -354,3 +336,4 @@ void Notebook::Controller::BufferChangeHandler(Glib::RefPtr<Gtk::TextBuffer>
OnBufferChange(); OnBufferChange();
}); });
} }

4
juci/notebook.h

@ -65,10 +65,14 @@ namespace Notebook {
Gtk::TextIter search_match_end_; Gtk::TextIter search_match_end_;
Gtk::TextIter search_match_start_; Gtk::TextIter search_match_start_;
Glib::RefPtr<Gtk::Clipboard> refClipboard_; Glib::RefPtr<Gtk::Clipboard> refClipboard_;
std::string
lines="1 ";
}; // class controller }; // class controller
} // namespace Notebook } // namespace Notebook
#endif // JUCI_NOTEBOOK_H_ #endif // JUCI_NOTEBOOK_H_

Loading…
Cancel
Save