static void array_place_text(int x, int y) { int i, j, delta_x, delta_y, start_x, start_y; int nx, ny; F_text *save_text; elastic_movetext(); /* erase last lengths if appres.showlengths is true */ erase_lengths(); tail(&objects, &object_tails); save_text = new_t; if ((!cur_numxcopies) && (!cur_numycopies)) { place_text(x, y); } else { delta_x = cur_x - fix_x; delta_y = cur_y - fix_y; start_x = cur_x - delta_x; start_y = cur_y - delta_y; if ((cur_numxcopies < 2) && (cur_numycopies < 2)) { /* special cases */ if (cur_numxcopies > 0) { place_text_x(start_x+delta_x, start_y); new_t = copy_text(cur_t); } if (cur_numycopies > 0) { place_text_x(start_x, start_y+delta_y); new_t = copy_text(cur_t); } } else { nx = cur_numxcopies; if (nx == 0) nx++; ny = cur_numycopies; if (ny == 0) ny++; for (i = 0, x = start_x; i < nx; i++, x+=delta_x) { for (j = 0, y = start_y; j < ny; j++, y+=delta_y) { if (i || j ) { place_text_x(x, y); new_t = copy_text(cur_t); } } } } } /* put all new texts in the saved objects structure for undo */ saved_objects.texts = save_text; set_action_object(F_ADD, O_ALL_OBJECT); /* turn back on all relevant markers */ update_markers(new_objmask); }
static void load_database_config(mxml_node_t* current, config_DB* config) { if (current == NULL) { fprintf(stderr, "missing config item 'database'\n"); exit(1); } copy_text("database", current, "host", &config->host); copy_text("database", current, "user", &config->user); copy_text("database", current, "passwd", &config->passwd); copy_text("database", current, "dbname", &config->dbname); copy_int("database", current, "port", &config->port); }
static void copy_int(const char* path, mxml_node_t* current, const char* name, int* dst) { char* buffer; copy_text(path, current, name, &buffer); *dst = atoi(buffer); free(buffer); }
static void load_reader_config(mxml_node_t* current, config_Reader* config) { if (current == NULL) { fprintf(stderr, "missing config item 'reader'\n"); exit(1); } copy_text("reader", current, "device", &config->device); copy_int("reader", current, "numberofAntennas", &config->numberofAntennas); copy_int("reader", current, "timeout", &config->timeout); }
void LineEdit::menu_option(int p_option) { switch(p_option) { case MENU_CUT: { if (editable) { cut_text(); } } break; case MENU_COPY: { copy_text(); } break; case MENU_PASTE: { if (editable) { paste_text(); } } break; case MENU_CLEAR: { if (editable) { clear(); } } break; case MENU_SELECT_ALL: { select_all(); } break; case MENU_UNDO: { undo(); } break; } }
/*Copia de onde o arquivo fonte começar a apontar até o fim dele para aonde output apontar*/ void copy_adjust_text (FILE *src, FILE *output, int fator_correcao) { int c; while (!feof(src)){ fscanf(src, "%d", &c); fprintf (output, "%d ", c); /*Ao chegar no stop, copia toda a seção de dados igualzinha*/ if (c == STOP_CODE) { copy_text (src, output); continue; } /*Se for um copy, pega um argumento extra*/ if (c == COPY_CODE) { fscanf(src, "%d", &c); fprintf (output, "%d ", c+fator_correcao); } /*Se for qualquer instrução != STOP peque 1 argumento (copy está pegando o segundo)*/ fscanf(src, "%d", &c); fprintf (output, "%d ", c+fator_correcao); } }
int id_copy(ID *id, ID **newid, int test) { if(!test) *newid= NULL; /* conventions: * - make shallow copy, only this ID block * - id.us of the new ID is set to 1 */ switch(GS(id->name)) { case ID_SCE: return 0; /* can't be copied from here */ case ID_LI: return 0; /* can't be copied from here */ case ID_OB: if(!test) *newid= (ID*)copy_object((Object*)id); return 1; case ID_ME: if(!test) *newid= (ID*)copy_mesh((Mesh*)id); return 1; case ID_CU: if(!test) *newid= (ID*)copy_curve((Curve*)id); return 1; case ID_MB: if(!test) *newid= (ID*)copy_mball((MetaBall*)id); return 1; case ID_MA: if(!test) *newid= (ID*)copy_material((Material*)id); return 1; case ID_TE: if(!test) *newid= (ID*)copy_texture((Tex*)id); return 1; case ID_IM: if(!test) *newid= (ID*)copy_image((Image*)id); return 1; case ID_LT: if(!test) *newid= (ID*)copy_lattice((Lattice*)id); return 1; case ID_LA: if(!test) *newid= (ID*)copy_lamp((Lamp*)id); return 1; case ID_SPK: if(!test) *newid= (ID*)copy_speaker((Speaker*)id); return 1; case ID_CA: if(!test) *newid= (ID*)copy_camera((Camera*)id); return 1; case ID_IP: return 0; /* deprecated */ case ID_KE: if(!test) *newid= (ID*)copy_key((Key*)id); return 1; case ID_WO: if(!test) *newid= (ID*)copy_world((World*)id); return 1; case ID_SCR: return 0; /* can't be copied from here */ case ID_VF: return 0; /* not implemented */ case ID_TXT: if(!test) *newid= (ID*)copy_text((Text*)id); return 1; case ID_SCRIPT: return 0; /* deprecated */ case ID_SO: return 0; /* not implemented */ case ID_GR: if(!test) *newid= (ID*)copy_group((Group*)id); return 1; case ID_AR: if(!test) *newid= (ID*)copy_armature((bArmature*)id); return 1; case ID_AC: if(!test) *newid= (ID*)copy_action((bAction*)id); return 1; case ID_NT: if(!test) *newid= (ID*)ntreeCopyTree((bNodeTree*)id); return 1; case ID_BR: if(!test) *newid= (ID*)copy_brush((Brush*)id); return 1; case ID_PA: if(!test) *newid= (ID*)psys_copy_settings((ParticleSettings*)id); return 1; case ID_WM: return 0; /* can't be copied from here */ case ID_GD: return 0; /* not implemented */ } return 0; }
LRESULT CALLBACK App::subclass_wndproc_new(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam){ //odnalezienie kontrolki Control* kontrolka = NULL; for(unsigned int i=0; i<Controls::geti()->controls.size(); i++){ if(Controls::geti()->controls.at(i)->handle == hwnd){ kontrolka = Controls::geti()->controls.at(i); break; } } if(kontrolka==NULL){ IO::geti()->error("Subclassing: Nie znaleziono kontrolki o podanym uchwycie"); return 0; } string nazwa = kontrolka->name; //globalne skróty klawiszowe if(message == WM_KEYDOWN){ if(wParam==VK_F1||wParam==VK_F2||wParam==VK_F3||wParam==VK_F5||wParam==VK_F6||wParam==VK_F7||wParam==VK_F8||wParam==VK_F9||wParam==VK_F10||wParam==VK_F11){ CallWindowProc(windowProc, hwnd, message, wParam, lParam); //przekazanie wy¿ej do mainwindow return 0; //przechwycenie } //wyjœcie z fullscreena if(wParam==VK_ESCAPE && Config::geti()->fullscreen_on){ CallWindowProc(windowProc, hwnd, message, wParam, lParam); //przekazanie wy¿ej do mainwindow return 0; //przechwycenie } //ctrl if(is_control_pressed()){ if(wParam=='S'||wParam=='F'||wParam=='N'||wParam=='B'||wParam==VK_ADD||wParam==VK_SUBTRACT||wParam==VK_LEFT||wParam==VK_RIGHT||wParam=='0'||wParam==VK_NUMPAD0||wParam==VK_OEM_3){ CallWindowProc(windowProc, hwnd, message, wParam, lParam); //przekazanie wy¿ej do mainwindow return 0; //przechwycenie } } } if(message == WM_SYSKEYDOWN){ if(wParam==VK_F10){ //zamiana WM_SYSKEYDOWN na WM_KEYDOWN subclass_wndproc_new(hwnd, WM_KEYDOWN, wParam, lParam); return 0; } } //globalne przechwycenie wygaszacza if(message == WM_SYSCOMMAND){ if(wParam == SC_SCREENSAVE){ CallWindowProc(windowProc, hwnd, message, wParam, lParam); //przekazanie wy¿ej do mainwindow return 0; //przechwycenie } } //nowe procedury kontrolek if(nazwa=="filename_edit"){ switch(message){ case WM_CHAR:{ if(wParam==VK_ESCAPE){ Controls::geti()->set_focus("editor"); return 0; }else if(wParam==VK_RETURN){ if(!Config::geti()->cmd_show){ cmd_switch(1); } Controls::geti()->set_focus("cmd"); Controls::geti()->select_all("cmd"); return 0; } }break; } } if(nazwa=="cmd"){ switch(message){ case WM_CHAR:{ if(wParam==VK_ESCAPE){ Controls::geti()->set_focus("editor"); return 0; }else if(wParam==VK_RETURN){ exec_cmd(); return 0; //przechwycenie } }break; case WM_KEYDOWN:{ if(wParam==VK_UP){ Controls::geti()->set_text("cmd", last_cmd); SendMessage(Controls::geti()->find("cmd"), EM_SETSEL, last_cmd.length(), last_cmd.length()); return 0; } if(wParam==VK_DOWN){ Controls::geti()->set_text("cmd", ""); return 0; } }break; } } if(nazwa=="editor"){ //edytor switch(message){ case WM_SYSKEYDOWN:{ if(wParam>='1' && wParam<='9'){ //zamiana WM_SYSKEYDOWN na WM_KEYDOWN subclass_wndproc_new(hwnd, WM_KEYDOWN, wParam, lParam); return 0; } }break; case WM_KEYDOWN:{ if(is_control_pressed()){ //ctrl if(wParam=='C'){ copy_text(); return 0; }else if(wParam=='A'){ select_all(); return 0; }else if(wParam=='Z'){ undo->revert(); return 0; }else if(wParam=='R'){ refresh_text(); return 0; }else if(wParam=='T'){ quick_replace(); return 0; }else if(wParam=='Q'){ usun_akordy(); return 0; }else if(wParam=='W'){ save_pattern(); return 0; }else if(wParam=='E'){ insert_pattern(); return 0; }else if(wParam=='D'){ dodaj_nawias(); return 0; }else if(wParam>='1' && wParam<='9'){ zapisz_tekst(wParam-'1'+1); return 0; } }else if(is_alt_pressed()){ //alt if(wParam>='1' && wParam<='9'){ wstaw_tekst(wParam-'1'+1); return 0; } } }break; case WM_CHAR:{ //dla ka¿dego znaku (bez controla) if(!is_control_pressed()){ undo->save(); } //undo->save(); if(wParam == ']'){ string add_text = "]"; SendMessage(Controls::geti()->find("editor"), EM_REPLACESEL, 0, (LPARAM)add_text.c_str()); //wstawienie znaku refresh_text(); //odœwie¿enie tekstu //zmiana koloru po nawiasie na kolor tekstu CHARFORMAT cf_text; cf_text.cbSize = sizeof(cf_text); SendMessage(Controls::geti()->find("editor"), EM_GETCHARFORMAT, SCF_DEFAULT, (LPARAM)&cf_text); //kolor tekstu + brak pogrubienia cf_text.dwMask = CFM_COLOR | CFM_BOLD; cf_text.crTextColor = RGB(Config::i()->color_text[0], Config::i()->color_text[1], Config::i()->color_text[2]); cf_text.dwEffects = 0; SendMessage(Controls::geti()->find("editor"), EM_SETCHARFORMAT, SCF_SELECTION, (LPARAM)&cf_text); return 0; } }break; case WM_MOUSEWHEEL:{ int zdelta = GET_WHEEL_DELTA_WPARAM(wParam); if(LOWORD(wParam)==MK_CONTROL){ //z controlem //zmiana czcionki if(zdelta>=0){ change_font_size(+1); }else{ change_font_size(-1); } return 0; }else{ //scrollowanie edytora int scroll_step = Config::geti()->editor_fontsize + 2; if(zdelta>=0){ change_scroll(-scroll_step); }else{ change_scroll(+scroll_step); } return 0; } }break; } } if(nazwa=="find_edit"){ //szukany ci¹g znaków switch(message){ case WM_SETFOCUS:{ if(Controls::i()->get_text("find_edit")==Config::i()->find_edit_placeholder){ Controls::i()->set_text("find_edit", ""); } IO::geti()->echo("(Wpisz szukany ci¹g znaków, Enter - szukaj)"); }break; case WM_KILLFOCUS:{ if(Controls::i()->get_text("find_edit").length()==0){ Controls::i()->set_text("find_edit", Config::i()->find_edit_placeholder); } }break; case WM_CHAR:{ if(wParam==VK_RETURN){ znajdz(); return 0; } if(wParam==VK_TAB){ Controls::geti()->set_focus("replace_edit"); return 0; } }break; } } if(nazwa=="replace_edit"){ //tekst do zamiany switch(message){ case WM_SETFOCUS:{ if(Controls::i()->get_text("replace_edit")==Config::i()->replace_edit_placeholder){ Controls::i()->set_text("replace_edit", ""); } IO::geti()->echo("(Wpisz tekst do zamiany, Enter - zamieñ w zaznaczeniu lub ca³ym pliku)"); }break; case WM_KILLFOCUS:{ if(Controls::i()->get_text("replace_edit").length()==0){ Controls::i()->set_text("replace_edit", Config::i()->replace_edit_placeholder); } }break; case WM_CHAR:{ if(wParam==VK_RETURN){ zamien(); return 0; } if(wParam==VK_TAB){ Controls::geti()->set_focus("find_edit"); return 0; } }break; } } if(nazwa=="autoscroll_interval"){ //autoscroll_interval switch(message){ case WM_SETFOCUS:{ IO::geti()->echo("(Czas miêdzy kolejnymi przebiegami autoscrolla - wyra¿ony w milisekundach)"); }break; case WM_CHAR:{ if(wParam==VK_RETURN){ autoscroll_nowait(0); return 0; } }break; } } if(nazwa=="autoscroll_wait"){ //autoscroll_wait switch(message){ case WM_SETFOCUS:{ IO::geti()->echo("(Czas opóŸnienia przed autoscrollem - wyra¿ony w sekundach)"); }break; case WM_CHAR:{ if(wParam==VK_RETURN){ autoscroll_on(); return 0; } }break; } } return CallWindowProc(kontrolka->wndproc_old, hwnd, message, wParam, lParam); }
int main (int argc, char *argv[]) { FILE *input1, *input2, *saida, *output; DEFINITION_TABLE_CELL *aux, *head; int fator_corretivo; if (argc < 4) { printf ("Faltam argumentos para o programa.\n"); return 0; } /*Abre os arquivos de entrada de dados, independente da terminaçao .o*/ input1 = open_sourcefile(argv[1]); input2 = open_sourcefile(argv[2]); output = open_targetfile(argv[3]); saida = fopen(TEMPORARY_FILE, "w+"); /*Se algum arquivo não abrir, temos um problema*/ if (input1 == NULL || input2 == NULL || output == NULL || saida == NULL){ printf ("Não foi possivel aprir algum arguivo.\n"); return 0; } /*Apaga possíveis espaços no fim do arquivo que me dão uma dor de cabeça enorme*/ apaga_trailing_space(input1); apaga_trailing_space(input2); /*Calcula o fator corretivo para deslocar o segundo arquivo*/ fator_corretivo = code_size(input1); if (debug1) printf ("Fator corretivo: %d\n", fator_corretivo); /*Se os arquivos forem independentes*/ if (precisa_ligar(input1) && (precisa_ligar(input2))) { /*Monta a primeira parte da tabela de definições */ head = monta_def_table(input1, input2, fator_corretivo); /*Comentário para acompanhar a tabela de definições 1*/ if (debug1) { printf ("\nTABELA DE DEFINICOES\n"); for (aux = head; aux != NULL; aux = aux->prox) printf ("ROTULO: '%s'\t'END: '%d'\n", aux->rotulo, aux->end); } /*COPIAR O CODIGO 1*/ goto_code(input1); copy_text(input1, saida); /*COPIA COM FATOR DE CORREÇÃO O CÓDIGO 2*/ goto_code(input2); copy_adjust_text (input2, saida, fator_corretivo); /*ESCREVE NO ARQUIVO TEMPORÁRIO, REMOVE O ' ' NO FIM QUE CAUSA PROBLEMAS*/ fclose(saida); saida = fopen(TEMPORARY_FILE, "r+"); apaga_trailing_space(saida); /*AGORA TENHO QUE AJUSTAR AS REFERÊNCIAS CRUZADAS*/ referencias_cruzadas(input1, input2, saida, output, head, fator_corretivo); } apaga_trailing_space(output); fclose(input1); fclose(input2); fclose(saida); fclose(output); remove(TEMPORARY_FILE); return 0; }
void LineEdit::_input_event(InputEvent p_event) { switch(p_event.type) { case InputEvent::MOUSE_BUTTON: { const InputEventMouseButton &b = p_event.mouse_button; if (b.pressed && b.button_index==BUTTON_RIGHT) { menu->set_pos(get_global_transform().xform(get_local_mouse_pos())); menu->set_size(Vector2(1,1)); menu->popup(); grab_focus(); return; } if (b.button_index!=BUTTON_LEFT) break; _reset_caret_blink_timer(); if (b.pressed) { shift_selection_check_pre(b.mod.shift); set_cursor_at_pixel_pos(b.x); if (b.mod.shift) { selection_fill_at_cursor(); selection.creating=true; } else { if (b.doubleclick) { selection.enabled=true; selection.begin=0; selection.end=text.length(); selection.doubleclick=true; } selection.drag_attempt=false; if ((cursor_pos<selection.begin) || (cursor_pos>selection.end) || !selection.enabled) { selection_clear(); selection.cursor_start=cursor_pos; selection.creating=true; } else if (selection.enabled) { selection.drag_attempt=true; } } // if (!editable) // non_editable_clicked_signal.call(); update(); } else { if ( (!selection.creating) && (!selection.doubleclick)) { selection_clear(); } selection.creating=false; selection.doubleclick=false; if (OS::get_singleton()->has_virtual_keyboard()) OS::get_singleton()->show_virtual_keyboard(text,get_global_rect()); } update(); } break; case InputEvent::MOUSE_MOTION: { const InputEventMouseMotion& m=p_event.mouse_motion; if (m.button_mask&BUTTON_LEFT) { if (selection.creating) { set_cursor_at_pixel_pos(m.x); selection_fill_at_cursor(); } } } break; case InputEvent::KEY: { const InputEventKey &k =p_event.key; if (!k.pressed) return; unsigned int code = k.scancode; if (k.mod.command) { bool handled=true; switch (code) { case (KEY_X): { // CUT if(editable) { cut_text(); } } break; case (KEY_C): { // COPY copy_text(); } break; case (KEY_V): { // PASTE if(editable) { paste_text(); } } break; case (KEY_Z): { // Simple One level undo if(editable) { undo(); } } break; case (KEY_U): { // Delete from start to cursor if(editable) { selection_clear(); undo_text = text; text = text.substr(cursor_pos,text.length()-cursor_pos); Ref<Font> font = get_font("font"); cached_width = 0; if (font != NULL) { for (int i = 0; i < text.length(); i++) cached_width += font->get_char_size(text[i]).width; } set_cursor_pos(0); _text_changed(); } } break; case (KEY_Y): { // PASTE (Yank for unix users) if(editable) { paste_text(); } } break; case (KEY_K): { // Delete from cursor_pos to end if(editable) { selection_clear(); undo_text = text; text = text.substr(0,cursor_pos); _text_changed(); } } break; case (KEY_A): { //Select All select(); } break; default: { handled=false; } } if (handled) { accept_event(); return; } } _reset_caret_blink_timer(); if (!k.mod.meta) { bool handled=true; switch (code) { case KEY_ENTER: case KEY_RETURN: { emit_signal( "text_entered",text ); if (OS::get_singleton()->has_virtual_keyboard()) OS::get_singleton()->hide_virtual_keyboard(); return; } break; case KEY_BACKSPACE: { if (!editable) break; if (selection.enabled) { undo_text=text; selection_delete(); break; } #ifdef APPLE_STYLE_KEYS if (k.mod.alt) { #else if (k.mod.alt) { handled=false; break; } else if (k.mod.command) { #endif int cc=cursor_pos; bool prev_char=false; while (cc>0) { bool ischar=_is_text_char(text[cc-1]); if (prev_char && !ischar) break; prev_char=ischar; cc--; } delete_text(cc, cursor_pos); set_cursor_pos(cc); } else { undo_text=text; delete_char(); } } break; case KEY_KP_4: { if (k.unicode != 0) { handled = false; break; } // numlock disabled. fallthrough to key_left } case KEY_LEFT: { #ifndef APPLE_STYLE_KEYS if (!k.mod.alt) #endif shift_selection_check_pre(k.mod.shift); #ifdef APPLE_STYLE_KEYS if (k.mod.command) { set_cursor_pos(0); } else if (k.mod.alt) { #else if (k.mod.alt) { handled=false; break; } else if (k.mod.command) { #endif bool prev_char=false; int cc=cursor_pos; while (cc>0) { bool ischar=_is_text_char(text[cc-1]); if (prev_char && !ischar) break; prev_char=ischar; cc--; } set_cursor_pos(cc); } else { set_cursor_pos(get_cursor_pos()-1); } shift_selection_check_post(k.mod.shift); } break; case KEY_KP_6: { if (k.unicode != 0) { handled = false; break; } // numlock disabled. fallthrough to key_right } case KEY_RIGHT: { shift_selection_check_pre(k.mod.shift); #ifdef APPLE_STYLE_KEYS if (k.mod.command) { set_cursor_pos(text.length()); } else if (k.mod.alt) { #else if (k.mod.alt) { handled=false; break; } else if (k.mod.command) { #endif bool prev_char=false; int cc=cursor_pos; while (cc<text.length()) { bool ischar=_is_text_char(text[cc]); if (prev_char && !ischar) break; prev_char=ischar; cc++; } set_cursor_pos(cc); } else { set_cursor_pos(get_cursor_pos()+1); } shift_selection_check_post(k.mod.shift); } break; case KEY_DELETE: { if (!editable) break; if (k.mod.shift && !k.mod.command && !k.mod.alt) { cut_text(); break; } if (selection.enabled) { undo_text=text; selection_delete(); break; } int text_len = text.length(); if (cursor_pos==text_len) break; // nothing to do #ifdef APPLE_STYLE_KEYS if (k.mod.alt) { #else if (k.mod.alt) { handled=false; break; } else if (k.mod.command) { #endif int cc=cursor_pos; bool prev_char=false; while (cc<text.length()) { bool ischar=_is_text_char(text[cc]); if (prev_char && !ischar) break; prev_char=ischar; cc++; } delete_text(cursor_pos,cc); } else { undo_text=text; set_cursor_pos(cursor_pos+1); delete_char(); } } break; case KEY_KP_7: { if (k.unicode != 0) { handled = false; break; } // numlock disabled. fallthrough to key_home } case KEY_HOME: { shift_selection_check_pre(k.mod.shift); set_cursor_pos(0); shift_selection_check_post(k.mod.shift); } break; case KEY_KP_1: { if (k.unicode != 0) { handled = false; break; } // numlock disabled. fallthrough to key_end } case KEY_END: { shift_selection_check_pre(k.mod.shift); set_cursor_pos(text.length()); shift_selection_check_post(k.mod.shift); } break; default: { handled=false; } break; } if (handled) { accept_event(); } else if (!k.mod.alt && !k.mod.command) { if (k.unicode>=32 && k.scancode!=KEY_DELETE) { if (editable) { selection_delete(); CharType ucodestr[2]= {(CharType)k.unicode,0}; append_at_cursor(ucodestr); _text_changed(); accept_event(); } } else { return; } } update(); } return; } break; } } void LineEdit::set_align(Align p_align) { ERR_FAIL_INDEX(p_align, 4); align = p_align; update(); } LineEdit::Align LineEdit::get_align() const { return align; } Variant LineEdit::get_drag_data(const Point2& p_point) { if (selection.drag_attempt && selection.enabled) { String t = text.substr(selection.begin, selection.end - selection.begin); Label *l = memnew( Label ); l->set_text(t); set_drag_preview(l); return t; } return Variant(); } bool LineEdit::can_drop_data(const Point2& p_point,const Variant& p_data) const { return p_data.get_type()==Variant::STRING; } void LineEdit::drop_data(const Point2& p_point,const Variant& p_data) { if (p_data.get_type()==Variant::STRING) { set_cursor_at_pixel_pos(p_point.x); int selected = selection.end - selection.begin; Ref<Font> font = get_font("font"); if (font != NULL) { for (int i = selection.begin; i < selection.end; i++) cached_width -= font->get_char_size(text[i]).width; } text.erase(selection.begin, selected); append_at_cursor(p_data); selection.begin = cursor_pos-selected; selection.end = cursor_pos; } } void LineEdit::_notification(int p_what) { switch(p_what) { #ifdef TOOLS_ENABLED case NOTIFICATION_ENTER_TREE: { if (get_tree()->is_editor_hint()) { cursor_set_blink_enabled(EDITOR_DEF("text_editor/caret_blink", false)); cursor_set_blink_speed(EDITOR_DEF("text_editor/caret_blink_speed", 0.65)); if (!EditorSettings::get_singleton()->is_connected("settings_changed",this,"_editor_settings_changed")) { EditorSettings::get_singleton()->connect("settings_changed",this,"_editor_settings_changed"); } } } break; #endif case NOTIFICATION_RESIZED: { set_cursor_pos( get_cursor_pos() ); } break; case MainLoop::NOTIFICATION_WM_FOCUS_IN: { window_has_focus = true; draw_caret = true; update(); } break; case MainLoop::NOTIFICATION_WM_FOCUS_OUT: { window_has_focus = false; draw_caret = false; update(); } break; case NOTIFICATION_DRAW: { if ((!has_focus() && !menu->has_focus()) || !window_has_focus) { draw_caret = false; } int width,height; Size2 size=get_size(); width=size.width; height=size.height; RID ci = get_canvas_item(); Ref<StyleBox> style = get_stylebox("normal"); if (!is_editable()) style=get_stylebox("read_only"); Ref<Font> font=get_font("font"); style->draw( ci, Rect2( Point2(), size ) ); if (has_focus()) { get_stylebox("focus")->draw( ci, Rect2( Point2(), size ) ); } int x_ofs=0; switch (align) { case ALIGN_FILL: case ALIGN_LEFT: { x_ofs=style->get_offset().x; } break; case ALIGN_CENTER: { x_ofs=int(size.width-(cached_width))/2; } break; case ALIGN_RIGHT: { x_ofs=int(size.width-style->get_offset().x-(cached_width)); } break; } int ofs_max=width-style->get_minimum_size().width; int char_ofs=window_pos; int y_area=height-style->get_minimum_size().height; int y_ofs=style->get_offset().y; int font_ascent=font->get_ascent(); Color selection_color=get_color("selection_color"); Color font_color=get_color("font_color"); Color font_color_selected=get_color("font_color_selected"); Color cursor_color=get_color("cursor_color"); const String& t = text.empty() ? placeholder : text; // draw placeholder color if(text.empty()) font_color.a *= placeholder_alpha; int caret_height = font->get_height() > y_area ? y_area : font->get_height(); while(true) { //end of string, break! if (char_ofs>=t.length()) break; CharType cchar=pass?'*':t[char_ofs]; CharType next=pass?'*':t[char_ofs+1]; int char_width=font->get_char_size( cchar,next ).width; // end of widget, break! if ((x_ofs + char_width) > ofs_max) break; bool selected=selection.enabled && char_ofs>=selection.begin && char_ofs<selection.end; if (selected) VisualServer::get_singleton()->canvas_item_add_rect(ci, Rect2(Point2(x_ofs, y_ofs), Size2(char_width, caret_height)), selection_color); font->draw_char(ci, Point2(x_ofs, y_ofs + font_ascent), cchar, next, selected ? font_color_selected : font_color); if (char_ofs==cursor_pos && draw_caret) { VisualServer::get_singleton()->canvas_item_add_rect(ci, Rect2( Point2( x_ofs , y_ofs ), Size2( 1, caret_height ) ), cursor_color ); } x_ofs+=char_width; char_ofs++; } if (char_ofs==cursor_pos && draw_caret) {//may be at the end VisualServer::get_singleton()->canvas_item_add_rect(ci, Rect2( Point2( x_ofs , y_ofs ), Size2( 1, caret_height ) ), cursor_color ); } } break; case NOTIFICATION_FOCUS_ENTER: { if (!caret_blink_enabled) { draw_caret = true; } if (OS::get_singleton()->has_virtual_keyboard()) OS::get_singleton()->show_virtual_keyboard(text,get_global_rect()); } break; case NOTIFICATION_FOCUS_EXIT: { if (OS::get_singleton()->has_virtual_keyboard()) OS::get_singleton()->hide_virtual_keyboard(); } break; } } void LineEdit::copy_text() { if(selection.enabled) { OS::get_singleton()->set_clipboard(text.substr(selection.begin, selection.end - selection.begin)); } } void LineEdit::cut_text() { if(selection.enabled) { undo_text = text; OS::get_singleton()->set_clipboard(text.substr(selection.begin, selection.end - selection.begin)); selection_delete(); } } void LineEdit::paste_text() { String paste_buffer = OS::get_singleton()->get_clipboard(); if(paste_buffer != "") { if(selection.enabled) selection_delete(); append_at_cursor(paste_buffer); _text_changed(); } } void LineEdit::undo() { int old_cursor_pos = cursor_pos; text = undo_text; Ref<Font> font = get_font("font"); cached_width = 0; for (int i = 0; i<text.length(); i++) cached_width += font->get_char_size(text[i]).width; if(old_cursor_pos > text.length()) { set_cursor_pos(text.length()); } else { set_cursor_pos(old_cursor_pos); } _text_changed(); }