Студопедия
Случайная страница | ТОМ-1 | ТОМ-2 | ТОМ-3
АрхитектураБиологияГеографияДругоеИностранные языки
ИнформатикаИсторияКультураЛитератураМатематика
МедицинаМеханикаОбразованиеОхрана трудаПедагогика
ПолитикаПравоПрограммированиеПсихологияРелигия
СоциологияСпортСтроительствоФизикаФилософия
ФинансыХимияЭкологияЭкономикаЭлектроника

Приложение 3.

Формат файла конфигурации | Формат файла проверки | Загрузка файла конфигурации | Тестовый пример |


Читайте также:
  1. Аэродромы. Приложение 14 к Конвенции о междунардной
  2. Аэродромы. Приложение 14 к Конвенции о междунардной гражданской авиациии (ИКАО).
  3. Заявка подается на сайте по форме. См. приложение
  4. ЗОЛОТО (приложение к книге)
  5. Книга Тюрем Клипот и Тюремных Гениев с приложением их Сигилл и Имен
  6. Национальное приложение для стандарта ЕN 1996-1-1
  7. ПРИЛОЖЕНИЕ * СЛУЧАЙ С ПОСЕЛКОМ ЗАПОЛЯРНЫЙ 1 страница

#include <string>

#include <vector>

#include <algorithm>

 

#ifdef __MWERKS__

# define FL_DLL

#endif

 

#include <FL/Fl.H>

#include <FL/Fl_Group.H>

#include <FL/Fl_Double_Window.H>

#include <FL/fl_ask.H>

#include <FL/Fl_Native_File_Chooser.H>

#include <FL/Fl_Menu_Bar.H>

#include <FL/Fl_Input.H>

#include <FL/Fl_Button.H>

#include <FL/Fl_Return_Button.H>

#include <FL/Fl_Text_Buffer.H>

#include <FL/Fl_Text_Editor.H>

#include <FL/filename.H>

 

#include <libxml/parser.h>

#include <libxml/tree.h>

#include <libxml/xmlschemas.h>

#include <libxml/xmlerror.h>

 

using namespace std;

 

int changed = 0;

char filename[FL_PATH_MAX] = "";

char title[FL_PATH_MAX];

Fl_Text_Buffer *textbuf = 0;

 

 

// Syntax highlighting stuff...

#define TS 14 // default editor textsize

Fl_Text_Buffer *stylebuf = 0;

Fl_Text_Display::Style_Table_Entry styletable[7]; // Style table

std::vector <std::string> code_keywords;

std::vector <std::string> code_types;

std::vector <std::string>::iterator it;

std::vector <std::string>::iterator it1;

 

xmlChar *uri;

xmlChar *color;

xmlChar *font;

int i(0);

 

Fl_Text_Display::Style_Table_Entry stylebuftemp;

 

int is_valid(const xmlDocPtr doc, const char *schema_filename)

{

xmlDocPtr schema_doc = xmlReadFile(schema_filename, NULL, XML_PARSE_NONET);

if (schema_doc == NULL) {

fl_alert("The schema cannot be loaded or is not well-formed");

return -1;

}

xmlSchemaParserCtxtPtr parser_ctxt = xmlSchemaNewDocParserCtxt(schema_doc);

if (parser_ctxt == NULL) {

fl_alert("Unable to create a parser context for the schema", "Ok");

xmlFreeDoc(schema_doc);

return -2;

}

xmlSchemaPtr schema = xmlSchemaParse(parser_ctxt);

if (schema == NULL) {

fl_alert("the schema itself is not valid", "Ok");

xmlSchemaFreeParserCtxt(parser_ctxt);

xmlFreeDoc(schema_doc);

return -3;

}

xmlSchemaValidCtxtPtr valid_ctxt = xmlSchemaNewValidCtxt(schema);

if (valid_ctxt == NULL) {

fl_alert("unable to create a validation context for the schema", "Ok");

xmlSchemaFree(schema);

xmlSchemaFreeParserCtxt(parser_ctxt);

xmlFreeDoc(schema_doc);

return -4;

}

int is_valid = (xmlSchemaValidateDoc(valid_ctxt, doc) == 0);

xmlSchemaFreeValidCtxt(valid_ctxt);

xmlSchemaFree(schema);

xmlSchemaFreeParserCtxt(parser_ctxt);

xmlFreeDoc(schema_doc);

return is_valid? 1: 0;

}

 

unsigned int XMLValue2FLColor(const xmlChar* XMLvalue)

{

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_BLACK")))

{

return FL_BLACK;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_GREEN")))

{

return FL_GREEN;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_DARK_GREEN")))

{

return FL_DARK_GREEN;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_BLUE")))

{

return FL_BLUE;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_DARK_BLUE")))

{

return FL_DARK_BLUE;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_RED")))

{

return FL_RED;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_DARK_RED")))

{

return FL_DARK_RED;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_MAGENTA")))

{

return FL_MAGENTA;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_DARK_MAGENTA")))

{

return FL_DARK_MAGENTA;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_CYAN")))

{

return FL_CYAN;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_DARK_CYAN")))

{

return FL_DARK_CYAN;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_YELLOW")))

{

return FL_YELLOW;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_DARK_YELLOW")))

{

return FL_DARK_YELLOW;

}

}

 

int XMLValue2FLfont(const xmlChar* XMLvalue)

{

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_COURIER")))

{

return FL_COURIER;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_COURIER_BOLD")))

{

return FL_COURIER_BOLD;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_COURIER_ITALIC")))

{

return FL_COURIER_ITALIC;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_COURIER_BOLD_ITALIC")))

{

return FL_COURIER_BOLD_ITALIC;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_HELVETICA")))

{

return FL_HELVETICA;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_HELVETICA_BOLD")))

{

return FL_HELVETICA_BOLD;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_HELVETICA_ITALIC")))

{

return FL_HELVETICA_ITALIC;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_HELVETICA_BOLD_ITALIC")))

{

return FL_HELVETICA_BOLD_ITALIC;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_TIMES")))

{

return FL_TIMES;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_TIMES_BOLD")))

{

return FL_TIMES_BOLD;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_TIMES_ITALIC")))

{

return FL_TIMES_ITALIC;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_TIMES_BOLD_ITALIC")))

{

return FL_TIMES_BOLD_ITALIC;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_SCREEN")))

{

return FL_SCREEN;

}

if((!xmlStrcmp(XMLvalue, (const xmlChar *)"FL_SCREEN_BOLD")))

{

return FL_SCREEN_BOLD;

}

}

 

void parseStyles(xmlDocPtr doc, xmlNodePtr cur, const char *name)

{

while(cur!= NULL)

{

uri = xmlGetProp(cur, (const xmlChar *)"name");

if((!xmlStrcmp(uri, (const xmlChar *) "Plain")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[0] = stylebuftemp;

}

if((!xmlStrcmp(uri, (const xmlChar *) "Line Comments")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[1] = stylebuftemp;

}

if((!xmlStrcmp(uri, (const xmlChar *) "Block Comments")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[2] = stylebuftemp;

}

if((!xmlStrcmp(uri, (const xmlChar *) "Strings")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[3] = stylebuftemp;

}

if((!xmlStrcmp(uri, (const xmlChar *) "Directives")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[4] = stylebuftemp;

}

if((!xmlStrcmp(uri, (const xmlChar *) "Types")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[5] = stylebuftemp;

}

if((!xmlStrcmp(uri, (const xmlChar *) "Keywords")))

{

color = xmlGetProp(cur, (const xmlChar *)"color");

font = xmlGetProp(cur, (const xmlChar *)"font");

stylebuftemp.color = XMLValue2FLColor(color);

stylebuftemp.font = XMLValue2FLfont(font);

stylebuftemp.size = TS;

styletable[6] = stylebuftemp;

}

cur = cur->next;

}

}

 

void parseNodes(xmlDocPtr doc, xmlNodePtr cur, char *curNode)

{

xmlChar *key;

int exit(0);

cur = cur->xmlChildrenNode;

while(cur!= NULL)

{

if((!xmlStrcmp(cur->name, (const xmlChar *) curNode)))

{

if((!xmlStrcmp(cur->name, (const xmlChar *) "entry")))

{

parseStyles(doc, cur, "Plain");

parseStyles(doc, cur, "Line Comments");

parseStyles(doc, cur, "Block Comments");

parseStyles(doc, cur, "Strings");

parseStyles(doc, cur, "Directives");

parseStyles(doc, cur, "Types");

parseStyles(doc, cur, "Keywords");

return;

}else

{

key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);

if(strcmp(curNode, "type") == 0)

{

code_types.push_back((const char *) key);

}else

{

code_keywords.push_back((const char *) key);

}

xmlFree(key);

}

}

cur = cur->next;

}

return;

}

 

void parseXMLDoc(xmlDocPtr doc, char *nodeName, char *curNode)

{

xmlNodePtr cur;

cur = xmlDocGetRootElement(doc);

cur = cur->xmlChildrenNode;

while (cur!= NULL)

{

if ((!xmlStrcmp(cur->name, (const xmlChar *) nodeName)))

{

parseNodes(doc, cur, curNode);

}

cur = cur->next;

}

}

 

void loadHighlightingData()

{

xmlDocPtr doc1;

const char * filename = "config.xml";

doc1 = xmlReadFile(filename, NULL, XML_PARSE_NONET);

if(is_valid(doc1, "schema.xsd") == 1)

{

int i = 0;

xmlDocPtr xmldoc = NULL;

xmlChar *uri;

if((xmldoc = xmlReadFile(filename, NULL, 0)) == NULL) return;

xmlNodePtr cur = xmlDocGetRootElement(xmldoc);

parseXMLDoc(xmldoc, "style", "entry");

parseXMLDoc(xmldoc, "keywords", "keyword");

parseXMLDoc(xmldoc, "types", "type");

xmlFree(uri);

xmlFree(color);

xmlFree(font);

}else

{

//error in XML

xmlErrorPtr XMLError;

XMLError = xmlGetLastError();

fl_alert(XMLError->message);

}

}

 

//

// 'style_parse()' - Parse text and produce style data.

//

 

void

style_parse(const char *text,

char *style,

int length) {

char current;

int col;

int last;

char buf[255],

*bufptr;

const char *temp;

 

// Style letters:

//

// A - Plain

// B - Line comments

// C - Block comments

// D - Strings

// E - Directives

// F - Types

// G - Keywords

 

for (current = *style, col = 0, last = 0; length > 0; length --, text ++) {

if (current == 'B' || current == 'F' || current == 'G') current = 'A';

if (current == 'A') {

// Check for directives, comments, strings, and keywords...

if (col == 0 && *text == '#') {

// Set style to directive

current = 'E';

} else if (strncmp(text, "//", 2) == 0) {

current = 'B';

for (; length > 0 && *text!= '\n'; length --, text ++) *style++ = 'B';

 

if (length == 0) break;

} else if (strncmp(text, "/*", 2) == 0) {

current = 'C';

} else if (strncmp(text, "\\\"", 2) == 0) {

// Quoted quote...

*style++ = current;

*style++ = current;

text ++;

length --;

col += 2;

continue;

} else if (*text == '\"') {

current = 'D';

} else if (!last && (islower((*text)&255) || *text == '_')) {

// Might be a keyword...

for (temp = text, bufptr = buf;

(islower((*temp)&255) || *temp == '_') && bufptr < (buf + sizeof(buf) - 1);

*bufptr++ = *temp++);

 

if (!islower((*temp)&255) && *temp!= '_') {

*bufptr = '\0';

 

bufptr = buf;

 

it = find(code_types.begin(), code_types.end(), bufptr);

it1 = find(code_keywords.begin(), code_keywords.end(), bufptr);

if(it!= code_types.end())

{

while (text < temp) {

*style++ = 'F';

text ++;

length --;

col ++;

}

 

text --;

length ++;

last = 1;

continue;

} else if(it1!= code_keywords.end())

{

while (text < temp) {

*style++ = 'G';

text ++;

length --;

col ++;

}

 

text --;

length ++;

last = 1;

continue;

}

}

}

} else if (current == 'C' && strncmp(text, "*/", 2) == 0) {

// Close a C comment...

*style++ = current;

*style++ = current;

text ++;

length --;

current = 'A';

col += 2;

continue;

} else if (current == 'D') {

// Continuing in string...

if (strncmp(text, "\\\"", 2) == 0) {

// Quoted end quote...

*style++ = current;

*style++ = current;

text ++;

length --;

col += 2;

continue;

} else if (*text == '\"') {

// End quote...

*style++ = current;

col ++;

current = 'A';

continue;

}

}

 

// Copy style info...

if (current == 'A' && (*text == '{' || *text == '}')) *style++ = 'G';

else *style++ = current;

col ++;

 

last = isalnum((*text)&255) || *text == '_' || *text == '.';

 

if (*text == '\n') {

// Reset column and possibly reset the style

col = 0;

if (current == 'B' || current == 'E') current = 'A';

}

}

}

 

 

//

// 'style_init()' - Initialize the style buffer...

//

 

void

style_init(void) {

char *style = new char[textbuf->length() + 1];

char *text = textbuf->text();

 

memset(style, 'A', textbuf->length());

style[textbuf->length()] = '\0';

 

if (!stylebuf) stylebuf = new Fl_Text_Buffer(textbuf->length());

 

style_parse(text, style, textbuf->length());

 

stylebuf->text(style);

delete[] style;

free(text);

}

 

 

//

// 'style_unfinished_cb()' - Update unfinished styles.

//

 

void

style_unfinished_cb(int, void*) {

}

 

 

//

// 'style_update()' - Update the style buffer...

//

 

void

style_update(int pos, // I - Position of update

int nInserted, // I - Number of inserted chars

int nDeleted, // I - Number of deleted chars

int /*nRestyled*/, // I - Number of restyled chars

const char * /*deletedText*/,// I - Text that was deleted

void *cbArg) { // I - Callback data

int start, // Start of text

end; // End of text

char last, // Last style on line

*style, // Style data

*text; // Text data

 

 

// If this is just a selection change, just unselect the style buffer...

if (nInserted == 0 && nDeleted == 0) {

stylebuf->unselect();

return;

}

 

// Track changes in the text buffer...

if (nInserted > 0) {

// Insert characters into the style buffer...

style = new char[nInserted + 1];

memset(style, 'A', nInserted);

style[nInserted] = '\0';

 

stylebuf->replace(pos, pos + nDeleted, style);

delete[] style;

} else {

// Just delete characters in the style buffer...

stylebuf->remove(pos, pos + nDeleted);

}

 

// Select the area that was just updated to avoid unnecessary

// callbacks...

stylebuf->select(pos, pos + nInserted - nDeleted);

 

// Re-parse the changed region; we do this by parsing from the

// beginning of the previous line of the changed region to the end of

// the line of the changed region... Then we check the last

// style character and keep updating if we have a multi-line

// comment character...

start = textbuf->line_start(pos);

// if (start > 0) start = textbuf->line_start(start - 1);

end = textbuf->line_end(pos + nInserted);

text = textbuf->text_range(start, end);

style = stylebuf->text_range(start, end);

if (start==end)

last = 0;

else

last = style[end - start - 1];

 

// printf("start = %d, end = %d, text = \"%s\", style = \"%s\", last='%c'...\n",

// start, end, text, style, last);

 

style_parse(text, style, end - start);

 

// printf("new style = \"%s\", new last='%c'...\n",

// style, style[end - start - 1]);

 

stylebuf->replace(start, end, style);

((Fl_Text_Editor *)cbArg)->redisplay_range(start, end);

 

if (start==end || last!= style[end - start - 1]) {

// printf("Recalculate the rest of the buffer style\n");

// Either the user deleted some text, or the last character

// on the line changed styles, so reparse the

// remainder of the buffer...

free(text);

free(style);

 

end = textbuf->length();

text = textbuf->text_range(start, end);

style = stylebuf->text_range(start, end);

 

style_parse(text, style, end - start);

 

stylebuf->replace(start, end, style);

((Fl_Text_Editor *)cbArg)->redisplay_range(start, end);

}

 

free(text);

free(style);

}

 

 

// Editor window functions and class...

void save_cb();

void saveas_cb();

void find2_cb(Fl_Widget*, void*);

void replall_cb(Fl_Widget*, void*);

void replace2_cb(Fl_Widget*, void*);

void replcan_cb(Fl_Widget*, void*);

 

class EditorWindow: public Fl_Double_Window {

public:

EditorWindow(int w, int h, const char* t);

~EditorWindow();

 

Fl_Window *replace_dlg;

Fl_Input *replace_find;

Fl_Input *replace_with;

Fl_Button *replace_all;

Fl_Return_Button *replace_next;

Fl_Button *replace_cancel;

 

Fl_Text_Editor *editor;

char search[256];

};

 

EditorWindow::EditorWindow(int w, int h, const char* t): Fl_Double_Window(w, h, t) {

replace_dlg = new Fl_Window(300, 105, "Replace");

replace_find = new Fl_Input(80, 10, 210, 25, "Find:");

replace_find->align(FL_ALIGN_LEFT);

 

replace_with = new Fl_Input(80, 40, 210, 25, "Replace:");

replace_with->align(FL_ALIGN_LEFT);

 

replace_all = new Fl_Button(10, 70, 90, 25, "Replace All");

replace_all->callback((Fl_Callback *)replall_cb, this);

 

replace_next = new Fl_Return_Button(105, 70, 120, 25, "Replace Next");

replace_next->callback((Fl_Callback *)replace2_cb, this);

 

replace_cancel = new Fl_Button(230, 70, 60, 25, "Cancel");

replace_cancel->callback((Fl_Callback *)replcan_cb, this);

replace_dlg->end();

replace_dlg->set_non_modal();

editor = 0;

*search = (char)0;

loadHighlightingData();

}

 

EditorWindow::~EditorWindow() {

delete replace_dlg;

}

 

int check_save(void) {

if (!changed) return 1;

 

int r = fl_choice("The current file has not been saved.\n"

"Would you like to save it now?",

"Cancel", "Save", "Don't Save");

 

if (r == 1) {

save_cb(); // Save the file...

return!changed;

}

 

return (r == 2)? 1: 0;

}

 

int loading = 0;

void load_file(const char *newfile, int ipos) {

loading = 1;

int insert = (ipos!= -1);

changed = insert;

if (!insert) strcpy(filename, "");

int r;

if (!insert) r = textbuf->loadfile(newfile);

else r = textbuf->insertfile(newfile, ipos);

//changed = changed || textbuf->input_file_was_transcoded;

if (r)

fl_alert("Error reading from file \'%s\':\n%s.", newfile, strerror(errno));

else

if (!insert) strcpy(filename, newfile);

loading = 0;

textbuf->call_modify_callbacks();

}

 

void save_file(const char *newfile) {

if (textbuf->savefile(newfile))

fl_alert("Error writing to file \'%s\':\n%s.", newfile, strerror(errno));

else

strcpy(filename, newfile);

changed = 0;

textbuf->call_modify_callbacks();

}

 

void copy_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

Fl_Text_Editor::kf_copy(0, e->editor);

}

 

void cut_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

Fl_Text_Editor::kf_cut(0, e->editor);

}

 

void delete_cb(Fl_Widget*, void*) {

textbuf->remove_selection();

}

 

void find_cb(Fl_Widget* w, void* v) {

EditorWindow* e = (EditorWindow*)v;

const char *val;

 

val = fl_input("Search String:", e->search);

if (val!= NULL) {

// User entered a string - go find it!

strcpy(e->search, val);

find2_cb(w, v);

}

}

 

void find2_cb(Fl_Widget* w, void* v) {

EditorWindow* e = (EditorWindow*)v;

if (e->search[0] == '\0') {

// Search string is blank; get a new one...

find_cb(w, v);

return;

}

 

int pos = e->editor->insert_position();

int found = textbuf->search_forward(pos, e->search, &pos);

if (found) {

// Found a match; select and update the position...

textbuf->select(pos, pos+strlen(e->search));

e->editor->insert_position(pos+strlen(e->search));

e->editor->show_insert_position();

}

else fl_alert("No occurrences of \'%s\' found!", e->search);

}

 

void set_title(Fl_Window* w) {

if (filename[0] == '\0') strcpy(title, "Untitled");

else {

char *slash;

slash = strrchr(filename, '/');

#ifdef WIN32

if (slash == NULL) slash = strrchr(filename, '\\');

#endif

if (slash!= NULL) strcpy(title, slash + 1);

else strcpy(title, filename);

}

 

if (changed) strcat(title, " (modified)");

 

w->label(title);

}

 

void changed_cb(int, int nInserted, int nDeleted,int, const char*, void* v) {

if ((nInserted || nDeleted) &&!loading) changed = 1;

EditorWindow *w = (EditorWindow *)v;

set_title(w);

if (loading) w->editor->show_insert_position();

}

 

void new_cb(Fl_Widget*, void*) {

if (!check_save()) return;

 

filename[0] = '\0';

textbuf->select(0, textbuf->length());

textbuf->remove_selection();

changed = 0;

textbuf->call_modify_callbacks();

}

 

void open_cb(Fl_Widget*, void*) {

if (!check_save()) return;

Fl_Native_File_Chooser fnfc;

fnfc.title("Open file");

fnfc.type(Fl_Native_File_Chooser::BROWSE_FILE);

if (fnfc.show()) return;

load_file(fnfc.filename(), -1);

 

}

 

void insert_cb(Fl_Widget*, void *v) {

Fl_Native_File_Chooser fnfc;

fnfc.title("Insert file");

fnfc.type(Fl_Native_File_Chooser::BROWSE_FILE);

if (fnfc.show()) return;

EditorWindow *w = (EditorWindow *)v;

load_file(fnfc.filename(), w->editor->insert_position());

}

 

void paste_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

Fl_Text_Editor::kf_paste(0, e->editor);

}

 

int num_windows = 0;

 

void close_cb(Fl_Widget*, void* v) {

EditorWindow* w = (EditorWindow*)v;

 

if (num_windows == 1) {

if (!check_save())

return;

}

 

w->hide();

w->editor->buffer(0);

textbuf->remove_modify_callback(style_update, w->editor);

textbuf->remove_modify_callback(changed_cb, w);

Fl::delete_widget(w);

 

num_windows--;

if (!num_windows) exit(0);

}

 

void quit_cb(Fl_Widget*, void*) {

if (changed &&!check_save())

return;

 

exit(0);

}

 

void replace_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

e->replace_dlg->show();

}

 

void replace2_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

const char *find = e->replace_find->value();

const char *replace = e->replace_with->value();

 

if (find[0] == '\0') {

// Search string is blank; get a new one...

e->replace_dlg->show();

return;

}

 

e->replace_dlg->hide();

 

int pos = e->editor->insert_position();

int found = textbuf->search_forward(pos, find, &pos);

 

if (found) {

// Found a match; update the position and replace text...

textbuf->select(pos, pos+strlen(find));

textbuf->remove_selection();

textbuf->insert(pos, replace);

textbuf->select(pos, pos+strlen(replace));

e->editor->insert_position(pos+strlen(replace));

e->editor->show_insert_position();

}

else fl_alert("No occurrences of \'%s\' found!", find);

}

 

void replall_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

const char *find = e->replace_find->value();

const char *replace = e->replace_with->value();

 

find = e->replace_find->value();

if (find[0] == '\0') {

// Search string is blank; get a new one...

e->replace_dlg->show();

return;

}

 

e->replace_dlg->hide();

 

e->editor->insert_position(0);

int times = 0;

 

// Loop through the whole string

for (int found = 1; found;) {

int pos = e->editor->insert_position();

found = textbuf->search_forward(pos, find, &pos);

 

if (found) {

// Found a match; update the position and replace text...

textbuf->select(pos, pos+strlen(find));

textbuf->remove_selection();

textbuf->insert(pos, replace);

e->editor->insert_position(pos+strlen(replace));

e->editor->show_insert_position();

times++;

}

}

 

if (times) fl_message("Replaced %d occurrences.", times);

else fl_alert("No occurrences of \'%s\' found!", find);

}

 

void replcan_cb(Fl_Widget*, void* v) {

EditorWindow* e = (EditorWindow*)v;

e->replace_dlg->hide();

}

 

void save_cb() {

if (filename[0] == '\0') {

// No filename - get one!

saveas_cb();

return;

}

else save_file(filename);

}

 

void saveas_cb() {

Fl_Native_File_Chooser fnfc;

fnfc.title("Save File As?");

fnfc.type(Fl_Native_File_Chooser::BROWSE_SAVE_FILE);

if (fnfc.show()) return;

save_file(fnfc.filename());

}

 

Fl_Window* new_view();

 

void view_cb(Fl_Widget*, void*) {

Fl_Window* w = new_view();

w->show();

}

 

Fl_Menu_Item menuitems[] = {

{ "&File", 0, 0, 0, FL_SUBMENU },

{ "&New File", 0, (Fl_Callback *)new_cb },

{ "&Open File...", FL_COMMAND + 'o', (Fl_Callback *)open_cb },

{ "&Insert File...", FL_COMMAND + 'i', (Fl_Callback *)insert_cb, 0, FL_MENU_DIVIDER },

{ "&Save File", FL_COMMAND + 's', (Fl_Callback *)save_cb },

{ "Save File &As...", FL_COMMAND + FL_SHIFT + 's', (Fl_Callback *)saveas_cb, 0, FL_MENU_DIVIDER },

{ "New &View", FL_ALT + 'v', (Fl_Callback *)view_cb, 0 },

{ "&Close View", FL_COMMAND + 'w', (Fl_Callback *)close_cb, 0, FL_MENU_DIVIDER },

{ "E&xit", FL_COMMAND + 'q', (Fl_Callback *)quit_cb, 0 },

{ 0 },

 

{ "&Edit", 0, 0, 0, FL_SUBMENU },

{ "Cu&t", FL_COMMAND + 'x', (Fl_Callback *)cut_cb },

{ "&Copy", FL_COMMAND + 'c', (Fl_Callback *)copy_cb },

{ "&Paste", FL_COMMAND + 'v', (Fl_Callback *)paste_cb },

{ "&Delete", 0, (Fl_Callback *)delete_cb },

{ 0 },

 

{ "&Search", 0, 0, 0, FL_SUBMENU },

{ "&Find...", FL_COMMAND + 'f', (Fl_Callback *)find_cb },

{ "F&ind Again", FL_COMMAND + 'g', find2_cb },

{ "&Replace...", FL_COMMAND + 'r', replace_cb },

{ "Re&place Again", FL_COMMAND + 't', replace2_cb },

{ 0 },

 

{ 0 }

};

 

Fl_Window* new_view() {

EditorWindow* w = new EditorWindow(660, 400, title);

w->begin();

Fl_Menu_Bar* m = new Fl_Menu_Bar(0, 0, 660, 30);

m->copy(menuitems, w);

w->editor = new Fl_Text_Editor(0, 30, 660, 370);

w->editor->textfont(FL_COURIER);

w->editor->textsize(TS);

w->editor->buffer(textbuf);

w->editor->highlight_data(stylebuf, styletable,

sizeof(styletable) / sizeof(styletable[0]),

'A', style_unfinished_cb, 0);

textbuf->text();

style_init();

w->end();

w->resizable(w->editor);

w->callback((Fl_Callback *)close_cb, w);

 

textbuf->add_modify_callback(style_update, w->editor);

textbuf->add_modify_callback(changed_cb, w);

textbuf->call_modify_callbacks();

num_windows++;

return w;

}

 

int main(int argc, char **argv) {

LIBXML_TEST_VERSION;

textbuf = new Fl_Text_Buffer;

style_init();

 

Fl_Window* window = new_view();

 

window->show(1, argv);

 

if (argc > 1) load_file(argv[1], -1);

 

return Fl::run();

}


Дата добавления: 2015-11-04; просмотров: 54 | Нарушение авторских прав


<== предыдущая страница | следующая страница ==>
Приложение 2.| Обнаружение знаний в базах данных

mybiblioteka.su - 2015-2024 год. (0.173 сек.)