FLUID: Adds text search to source, header, and project view

This commit is contained in:
Matthias Melcher 2023-10-24 16:14:25 +02:00
parent 238b3a1be4
commit 38b529c01b
3 changed files with 154 additions and 18 deletions

View File

@ -263,6 +263,77 @@ TextViewer *sv_strings=(TextViewer *)0;
TextViewer *sv_project=(TextViewer *)0; TextViewer *sv_project=(TextViewer *)0;
Fl_Button *sv_find_text_case=(Fl_Button *)0;
Fl_Input *sv_find_text=(Fl_Input *)0;
static void cb_sv_find_text(Fl_Input* o, void*) {
Fl_Text_Display *e = NULL;
if (sv_source->visible_r()) {
e = sv_source;
} else if (sv_header->visible_r()) {
e = sv_header;
} else if (sv_project->visible_r()) {
e = sv_project;
}
if (e) {
Fl_Text_Buffer *b = e->buffer();
int pos = e->insert_position();
int found = b->search_forward(pos, o->value(), &pos, sv_find_text_case->value());
if (found) {
b->select(pos, pos + (int)strlen(o->value()));
e->insert_position(pos);
e->show_insert_position();
}
}
}
static void cb_(Fl_Button*, void*) {
Fl_Text_Display *e = NULL;
if (sv_source->visible_r()) {
e = sv_source;
} else if (sv_header->visible_r()) {
e = sv_header;
} else if (sv_project->visible_r()) {
e = sv_project;
}
if (e) {
const char *needle = sv_find_text->value();
Fl_Text_Buffer *b = e->buffer();
int pos = e->insert_position()-1;
if (pos < 0) pos = b->length()-1;
int found = b->search_backward(pos, needle, &pos, sv_find_text_case->value());
if (found) {
b->select(pos, pos + (int)strlen(needle));
e->insert_position(pos);
e->show_insert_position();
}
}
}
static void cb_1(Fl_Button*, void*) {
Fl_Text_Display *e = NULL;
if (sv_source->visible_r()) {
e = sv_source;
} else if (sv_header->visible_r()) {
e = sv_header;
} else if (sv_project->visible_r()) {
e = sv_project;
}
if (e) {
const char *needle = sv_find_text->value();
Fl_Text_Buffer *b = e->buffer();
int pos = e->insert_position() + 1;
if (pos+1 >= b->length()) pos = 0;
int found = b->search_forward(pos, needle, &pos, sv_find_text_case->value());
if (found) {
b->select(pos, pos + (int)strlen(needle));
e->insert_position(pos);
e->show_insert_position();
}
}
}
static void cb_Reveal(Fl_Button*, void*) { static void cb_Reveal(Fl_Button*, void*) {
if (sourceview_panel && sourceview_panel->visible()) { if (sourceview_panel && sourceview_panel->visible()) {
Fl_Type *node = NULL; Fl_Type *node = NULL;
@ -311,7 +382,6 @@ Fl_Double_Window* make_sourceview() {
sv_tab->callback((Fl_Callback*)update_sourceview_position_cb); sv_tab->callback((Fl_Callback*)update_sourceview_position_cb);
{ Fl_Group* o = new Fl_Group(10, 35, 500, 415, "Source"); { Fl_Group* o = new Fl_Group(10, 35, 500, 415, "Source");
o->labelsize(13); o->labelsize(13);
o->hide();
{ CodeViewer* o = sv_source = new CodeViewer(10, 40, 500, 410); { CodeViewer* o = sv_source = new CodeViewer(10, 40, 500, 410);
sv_source->box(FL_DOWN_FRAME); sv_source->box(FL_DOWN_FRAME);
sv_source->color(FL_BACKGROUND2_COLOR); sv_source->color(FL_BACKGROUND2_COLOR);
@ -375,6 +445,7 @@ Fl_Double_Window* make_sourceview() {
} // Fl_Group* o } // Fl_Group* o
{ Fl_Group* o = new Fl_Group(10, 35, 500, 415, "Project"); { Fl_Group* o = new Fl_Group(10, 35, 500, 415, "Project");
o->labelsize(13); o->labelsize(13);
o->hide();
{ TextViewer* o = sv_project = new TextViewer(10, 40, 500, 410); { TextViewer* o = sv_project = new TextViewer(10, 40, 500, 410);
sv_project->box(FL_DOWN_FRAME); sv_project->box(FL_DOWN_FRAME);
sv_project->color(FL_BACKGROUND2_COLOR); sv_project->color(FL_BACKGROUND2_COLOR);
@ -397,23 +468,28 @@ Fl_Double_Window* make_sourceview() {
Fl_Group::current()->resizable(sv_tab); Fl_Group::current()->resizable(sv_tab);
} // Fl_Tabs* sv_tab } // Fl_Tabs* sv_tab
{ Fl_Group* o = new Fl_Group(10, 460, 500, 20); { Fl_Group* o = new Fl_Group(10, 460, 500, 20);
{ Fl_Button* o = new Fl_Button(244, 460, 25, 20, "aA"); { sv_find_text_case = new Fl_Button(244, 460, 25, 20, "aA");
o->labelsize(11); sv_find_text_case->type(1);
} // Fl_Button* o sv_find_text_case->labelsize(11);
} // Fl_Button* sv_find_text_case
{ sv_find_text = new Fl_Input(40, 460, 200, 20, "Find:");
sv_find_text->labelsize(11);
sv_find_text->textsize(11);
sv_find_text->callback((Fl_Callback*)cb_sv_find_text);
sv_find_text->when(FL_WHEN_RELEASE | FL_WHEN_ENTER_KEY_CHANGED);
} // Fl_Input* sv_find_text
{ Fl_Button* o = new Fl_Button(273, 460, 25, 20, "<<"); { Fl_Button* o = new Fl_Button(273, 460, 25, 20, "<<");
o->labelsize(11); o->labelsize(11);
o->callback((Fl_Callback*)cb_);
} // Fl_Button* o } // Fl_Button* o
{ Fl_Button* o = new Fl_Button(298, 460, 25, 20, ">>"); { Fl_Button* o = new Fl_Button(298, 460, 25, 20, ">>");
o->labelsize(11); o->labelsize(11);
o->callback((Fl_Callback*)cb_1);
} // Fl_Button* o } // Fl_Button* o
{ Fl_Button* o = new Fl_Button(327, 460, 61, 20, "Reveal"); { Fl_Button* o = new Fl_Button(327, 460, 61, 20, "Reveal");
o->labelsize(11); o->labelsize(11);
o->callback((Fl_Callback*)cb_Reveal); o->callback((Fl_Callback*)cb_Reveal);
} // Fl_Button* o } // Fl_Button* o
{ Fl_Input* o = new Fl_Input(40, 460, 200, 20, "Find:");
o->labelsize(11);
o->textsize(11);
} // Fl_Input* o
{ Fl_Box* o = new Fl_Box(490, 460, 20, 20); { Fl_Box* o = new Fl_Box(490, 460, 20, 20);
Fl_Group::current()->resizable(o); Fl_Group::current()->resizable(o);
} // Fl_Box* o } // Fl_Box* o

View File

@ -286,9 +286,9 @@ Function {make_sourceview()} {open
} { } {
Fl_Group {} { Fl_Group {} {
label Source open label Source open
xywh {10 35 500 415} labelsize 13 hide resizable xywh {10 35 500 415} labelsize 13 resizable
} { } {
Fl_Text_Editor sv_source { Fl_Text_Editor sv_source {selected
xywh {10 40 500 410} textfont 4 textsize 11 resizable xywh {10 40 500 410} textfont 4 textsize 11 resizable
code0 {\#include "CodeEditor.h"} code0 {\#include "CodeEditor.h"}
code1 {o->linenumber_width(60);} code1 {o->linenumber_width(60);}
@ -321,7 +321,7 @@ Function {make_sourceview()} {open
} }
Fl_Group {} { Fl_Group {} {
label Project open label Project open
xywh {10 35 500 415} labelsize 13 xywh {10 35 500 415} labelsize 13 hide
} { } {
Fl_Text_Display sv_project { Fl_Text_Display sv_project {
xywh {10 40 500 410} textfont 4 textsize 11 resizable xywh {10 40 500 410} textfont 4 textsize 11 resizable
@ -334,16 +334,78 @@ Function {make_sourceview()} {open
Fl_Group {} {open Fl_Group {} {open
xywh {10 460 500 20} xywh {10 460 500 20}
} { } {
Fl_Button {} { Fl_Button sv_find_text_case {
label aA label aA
xywh {244 460 25 20} labelsize 11 xywh {244 460 25 20} type Toggle labelsize 11
}
Fl_Input sv_find_text {
label {Find:}
callback {Fl_Text_Display *e = NULL;
if (sv_source->visible_r()) {
e = sv_source;
} else if (sv_header->visible_r()) {
e = sv_header;
} else if (sv_project->visible_r()) {
e = sv_project;
}
if (e) {
Fl_Text_Buffer *b = e->buffer();
int pos = e->insert_position();
int found = b->search_forward(pos, o->value(), &pos, sv_find_text_case->value());
if (found) {
b->select(pos, pos + (int)strlen(o->value()));
e->insert_position(pos);
e->show_insert_position();
}
}}
xywh {40 460 200 20} labelsize 11 when 15 textsize 11
} }
Fl_Button {} { Fl_Button {} {
label {<<} label {<<}
callback {Fl_Text_Display *e = NULL;
if (sv_source->visible_r()) {
e = sv_source;
} else if (sv_header->visible_r()) {
e = sv_header;
} else if (sv_project->visible_r()) {
e = sv_project;
}
if (e) {
const char *needle = sv_find_text->value();
Fl_Text_Buffer *b = e->buffer();
int pos = e->insert_position()-1;
if (pos < 0) pos = b->length()-1;
int found = b->search_backward(pos, needle, &pos, sv_find_text_case->value());
if (found) {
b->select(pos, pos + (int)strlen(needle));
e->insert_position(pos);
e->show_insert_position();
}
}}
xywh {273 460 25 20} labelsize 11 xywh {273 460 25 20} labelsize 11
} }
Fl_Button {} { Fl_Button {} {
label {>>} label {>>}
callback {Fl_Text_Display *e = NULL;
if (sv_source->visible_r()) {
e = sv_source;
} else if (sv_header->visible_r()) {
e = sv_header;
} else if (sv_project->visible_r()) {
e = sv_project;
}
if (e) {
const char *needle = sv_find_text->value();
Fl_Text_Buffer *b = e->buffer();
int pos = e->insert_position() + 1;
if (pos+1 >= b->length()) pos = 0;
int found = b->search_forward(pos, needle, &pos, sv_find_text_case->value());
if (found) {
b->select(pos, pos + (int)strlen(needle));
e->insert_position(pos);
e->show_insert_position();
}
}}
xywh {298 460 25 20} labelsize 11 xywh {298 460 25 20} labelsize 11
} }
Fl_Button {} { Fl_Button {} {
@ -362,13 +424,9 @@ Function {make_sourceview()} {open
if (Fl::event_clicks()==1) // double click if (Fl::event_clicks()==1) // double click
node->open(); node->open();
} }
}} selected }}
xywh {327 460 61 20} labelsize 11 xywh {327 460 61 20} labelsize 11
} }
Fl_Input {} {
label {Find:}
xywh {40 460 200 20} labelsize 11 textsize 11
}
Fl_Box {} { Fl_Box {} {
xywh {490 460 20 20} resizable xywh {490 460 20 20} resizable
} }

View File

@ -38,7 +38,9 @@ extern CodeViewer *sv_header;
extern TextViewer *sv_strings; extern TextViewer *sv_strings;
extern TextViewer *sv_project; extern TextViewer *sv_project;
#include <FL/Fl_Button.H> #include <FL/Fl_Button.H>
extern Fl_Button *sv_find_text_case;
#include <FL/Fl_Input.H> #include <FL/Fl_Input.H>
extern Fl_Input *sv_find_text;
#include <FL/Fl_Box.H> #include <FL/Fl_Box.H>
#include <FL/Fl_Light_Button.H> #include <FL/Fl_Light_Button.H>
extern Fl_Light_Button *sv_autorefresh; extern Fl_Light_Button *sv_autorefresh;