Browse Source

Fully working linenumbers

master
oyvang 11 years ago
parent
commit
64508d0ee4
  1. 1
      juci/api.cc
  2. 2
      juci/juci.cc
  3. 99
      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");

99
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_);
@ -94,13 +96,6 @@ Notebook::Controller::Controller(Keybindings::Controller& keybindings) {
[this]() { [this]() {
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() {
int page = CurrentPage();
int line_nr = Buffer(text_vec_.at(page))->get_line_count();
Glib::RefPtr
<Gtk::TextBuffer::Mark> mark = Gtk::TextBuffer::Mark::create();
Glib::RefPtr
<Gtk::TextBuffer::Mark> mark_lines = Gtk::TextBuffer::Mark::create();
if(Buffer(text_vec_.at(page))->get_insert()->get_iter().starts_line() && void Notebook::Controller::OnBufferChange() {
Buffer(text_vec_.at(page))->get_insert()->get_iter().get_line() == int page = CurrentPage();
Buffer(text_vec_.at(page))->end().get_line()) { int text_nr = Buffer(text_vec_.at(page))->get_line_count();
std::string lines ="1 "; int line_nr = Buffer(linenumbers_vec_.at(page))->get_line_count();
for ( int it = 2; it <= line_nr; ++it ) { while (line_nr < text_nr ){
lines.append("\n"+ std::to_string(it)+" "); line_nr++;
} Buffer(linenumbers_vec_.at(page))->
Buffer(linenumbers_vec_.at(page))->set_text(lines); insert(Buffer(linenumbers_vec_.at(page))->end(),
"\n"+std::to_string(line_nr)+" ");
Buffer(text_vec_.at(page))-> }
add_mark( while (line_nr > text_nr ){
mark, Gtk::TextIter iter = Buffer(linenumbers_vec_.at(page))->get_iter_at_line(line_nr);
Buffer(text_vec_.at(page))->end()); iter.backward_char();
Buffer(linenumbers_vec_.at(page))-> line_nr--;
add_mark( Buffer(linenumbers_vec_.at(page))->
mark_lines, erase(iter,
Buffer(linenumbers_vec_.at(page))->end()); Buffer(linenumbers_vec_.at(page))->end());
}
text_vec_.at(page)->view().scroll_to(mark); if(Buffer(text_vec_.at(page))->get_insert()->get_iter().starts_line() &&
linenumbers_vec_.at(page)->view().scroll_to(mark_lines); Buffer(text_vec_.at(page))->get_insert()->get_iter().get_line() ==
}else{ Buffer(text_vec_.at(page))->end().get_line()) {
Buffer(text_vec_.at(page))->
add_mark( GdkEventScroll* scroll = new GdkEventScroll;
mark, scroll->delta_y = 1.0;
Buffer(text_vec_.at(page))-> scroll->delta_x = 0.0;
get_insert()->get_iter()); scroll_event_callback(scroll);
} delete scroll;
}
} }
@ -350,7 +332,8 @@ Gtk::Notebook& Notebook::Controller::Notebook() {
void Notebook::Controller::BufferChangeHandler(Glib::RefPtr<Gtk::TextBuffer> void Notebook::Controller::BufferChangeHandler(Glib::RefPtr<Gtk::TextBuffer>
buffer) { buffer) {
buffer->signal_changed().connect( buffer->signal_changed().connect(
[this]() { [this]() {
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