source: tags/arb_5.0/AWT/AWT_tables.cxx

Last change on this file was 5942, checked in by westram, 15 years ago
  • added AW_window::activate (activates window using show() and sending _NET_ACTIVE_WINDOW to WM)
  • use activate in
    • standard popups (all menu/button popups using AW_POPUP)
    • special popup functions that don't bind window to menu/button
    • small requesters (aw_input, aw_question, …)
    • in popup-functions of information windows. But not if info-window is minimized and user just selects a new result in search window.
    • popup message window on each new message
  • no-exit-shells now popdown when X-Button is pressed (e.g. MESSAGE BOX)
  • fixed several special popup functions
  • renamed AW_window::get_show() → is_shown()
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 18.9 KB
Line 
1#include <stdio.h>
2#include <stdlib.h>
3#include <unistd.h>
4#include <time.h>
5#include <string.h>
6// #include <malloc.h>
7#include <memory.h>
8
9#include <arbdb.h>
10#include <arbdbt.h>
11#include <aw_root.hxx>
12#include <aw_device.hxx>
13#include <aw_window.hxx>
14#include <aw_awars.hxx>
15#include <aw_global.hxx>
16#include "awt.hxx"
17#include "awtlocal.hxx"
18#include "awt_sel_boxes.hxx"
19
20
21void ad_table_field_reorder_cb(AW_window *aws,awt_table *awtt) {
22    GB_begin_transaction(awtt->gb_main);
23    char *source = aws->get_root()->awar(awtt->awar_field_reorder_source)->read_string();
24    char *dest =   aws->get_root()->awar(awtt->awar_field_reorder_dest)  ->read_string();
25    GB_ERROR warning = 0;
26    GBDATA *gb_table = GBT_open_table(awtt->gb_main, awtt->table_name,GB_TRUE);
27    if (!gb_table){
28        aw_message(GBS_global_string("Table '%s' does not exist",awtt->table_name));
29        return;
30    }
31    GBDATA *gb_source = GBT_find_table_field(gb_table,source);
32    GBDATA *gb_dest = GBT_find_table_field(gb_table,dest);
33    if (!gb_source|| !gb_dest){
34        aw_message("Please select two valid fields");
35    }
36    else if (gb_source && gb_dest && (gb_dest !=gb_source) ) {
37        GBDATA *gb_fields = GB_get_father(gb_source);
38        int     nitems    = 0;
39        GBDATA *gb_cnt;
40
41        for (gb_cnt  = GB_child(gb_fields); gb_cnt; gb_cnt = GB_nextChild(gb_cnt)) {
42            nitems++;
43        }
44       
45        GBDATA **new_order = new GBDATA *[nitems];
46        nitems             = 0;
47        for (gb_cnt  = GB_child(gb_fields); gb_cnt; gb_cnt = GB_nextChild(gb_cnt)) {
48            if (gb_cnt == gb_source) continue;
49            new_order[nitems++] = gb_cnt;
50            if (gb_cnt == gb_dest) {
51                new_order[nitems++] = gb_source;
52            }
53        }
54        warning = GB_resort_data_base(awtt->gb_main,new_order,nitems);
55        delete [] new_order;
56    }
57   
58    delete source;
59    delete dest;
60    GB_commit_transaction(awtt->gb_main);
61}
62
63AW_window *create_ad_table_field_reorder_window(AW_root *root,awt_table *awtt)
64{
65    AW_window_simple *aws = new AW_window_simple;
66    aws->init( root, "REORDER_FIELDS", "REORDER FIELDS");
67    aws->load_xfig("ad_kreo.fig");
68
69    aws->callback( (AW_CB0)AW_POPDOWN);
70    aws->at("close");
71    aws->create_button("CLOSE","CLOSE","C");
72
73    aws->callback( AW_POPUP_HELP,(AW_CL)"spaf_reorder.hlp");
74    aws->at("help");
75    aws->create_button("HELP","HELP","H");
76
77    aws->at("doit");
78    aws->button_length(0);
79    aws->callback((AW_CB1)ad_table_field_reorder_cb,(AW_CL)awtt);
80    aws->help_text("spaf_reorder.hlp");
81    aws->create_button("MOVE_TO_NEW_POSITION", "MOVE  SELECTED LEFT  ITEM\nAFTER SELECTED RIGHT ITEM","P");
82
83    aws->at("source");
84    awt_create_selection_list_on_table_fields(awtt->gb_main,aws,awtt->table_name,awtt->awar_field_reorder_source);
85
86    aws->at("dest");
87    awt_create_selection_list_on_table_fields(awtt->gb_main,aws,awtt->table_name,awtt->awar_field_reorder_dest);
88
89    return (AW_window *)aws;
90}
91
92void awt_table_field_hide_cb(AW_window *aws, awt_table *awtt) {
93    GB_begin_transaction(awtt->gb_main);
94    GB_ERROR  error    = 0;
95    GBDATA   *gb_table = GBT_open_table(awtt->gb_main, awtt->table_name,GB_TRUE);
96
97    if (!gb_table){
98        error = GBS_global_string("Table '%s' does not exist",awtt->table_name);
99    }
100    else {
101        char   *source    = aws->get_root()->awar(awtt->awar_selected_field)->read_string();
102        GBDATA *gb_source = GBT_find_table_field(gb_table,source);
103
104        if (!gb_source) error = "Please select an item you want to delete";
105        else error            = GB_delete(gb_source);
106
107        free(source);
108    }
109    GB_end_transaction_show_error(awtt->gb_main, error, aw_message);
110}
111
112void awt_table_field_delete_cb(AW_window *aws, awt_table *awtt) {
113    GB_begin_transaction(awtt->gb_main);
114   
115    GB_ERROR  error    = 0;
116    GBDATA   *gb_table = GBT_open_table(awtt->gb_main, awtt->table_name,GB_TRUE);
117    if (!gb_table){
118        error = GBS_global_string("Table '%s' does not exist",awtt->table_name);
119    }
120    else {
121        char   *source    = aws->get_root()->awar(awtt->awar_selected_field)->read_string();
122        GBDATA *gb_source = GBT_find_table_field(gb_table,source);
123
124        if (!gb_source) error = "Please select an item you want to delete";
125        else error            = GB_delete(gb_source);
126
127        for (GBDATA *gb_table_entry = GBT_first_table_entry(gb_table);
128             gb_table_entry && !error;
129             gb_table_entry = GBT_next_table_entry(gb_table_entry))
130        {
131            GBDATA *gb_table_entry_field;
132            while (!error && (gb_table_entry_field = GB_search(gb_table_entry,source,GB_FIND))) {
133                error = GB_delete(gb_table_entry_field);
134            }
135        }
136        free(source);
137    }
138
139    GB_end_transaction_show_error(awtt->gb_main, error, aw_message);
140}
141
142
143void ad_table_field_create_cb(AW_window *aws,awt_table *awtt)   {
144    GB_push_transaction(awtt->gb_main);
145    char *name = aws->get_root()->awar(awtt->awar_field_new_name)->read_string();
146    GB_ERROR error = GB_check_key(name);
147    GB_ERROR error2 = GB_check_hkey(name);
148    if (error && !error2) {
149        aw_message("Warning: Your key contain a '/' character,\n"
150                   "    that means it is a hierarchical key");
151        error = 0;
152    }
153    GBDATA *gb_table = GBT_open_table(awtt->gb_main,awtt->table_name,GB_TRUE);
154    if (gb_table){
155        GB_TYPES type = (GB_TYPES)aws->get_root()->awar(awtt->awar_field_new_type)->read_int();
156        if(!error) {
157            GBDATA *gb_table_field = GBT_open_table_field(gb_table, name, type);
158            if (!gb_table_field) error = GB_await_error();
159        }
160    }
161    else {
162        error = GBS_global_string("Table '%s' does not exist",awtt->table_name);
163    }
164    aws->hide_or_notify(error);
165
166    free(name);
167    GB_pop_transaction(awtt->gb_main);
168}
169
170AW_window *create_ad_table_field_create_window(AW_root *root, awt_table *awtt){
171    static AW_window_simple *aws = new AW_window_simple;
172    aws->init( root, "CREATE_FIELD","CREATE A NEW FIELD");
173    aws->load_xfig("ad_fcrea.fig");
174
175    aws->callback( (AW_CB0)AW_POPDOWN);
176    aws->at("close");
177    aws->create_button("CLOSE","CLOSE","C");
178
179
180    aws->at("input");
181    aws->label("FIELD NAME");
182    aws->create_input_field(awtt->awar_field_new_name,15);
183
184    aws->at("type");
185    aws->create_toggle_field(awtt->awar_field_new_type,"FIELD TYPE","F");
186    aws->insert_toggle("Ascii Text","S",        (int)GB_STRING);
187    aws->insert_toggle("Link","L",          (int)GB_LINK);
188    aws->insert_toggle("Rounded Numerical","N", (int)GB_INT);
189    aws->insert_toggle("Numerical","R",     (int)GB_FLOAT);
190    aws->insert_toggle("MASK = 01 Text","0",    (int)GB_BITS);
191    aws->update_toggle_field();
192
193
194    aws->at("ok");
195    aws->callback((AW_CB1)ad_table_field_create_cb,(AW_CL)awtt);
196    aws->create_button("CREATE","CREATE","C");
197
198    return (AW_window *)aws;
199}
200
201awt_table::awt_table(GBDATA *igb_main, AW_root *awr,const char *itable_name){
202    gb_main = igb_main;
203    GB_transaction tscope(gb_main);
204    table_name = strdup(itable_name);
205    char *tname = GBS_string_2_key(table_name);
206    this->awar_field_reorder_source = GBS_global_string_copy(AWAR_TABLE_FIELD_REORDER_SOURCE_TEMPLATE,tname);
207    this->awar_field_reorder_dest = GBS_global_string_copy(AWAR_TABLE_FIELD_REORDER_DEST_TEMPLATE,tname);
208    this->awar_field_rem = GBS_global_string_copy(AWAR_TABLE_FIELD_REM_TEMPLATE,tname);
209    this->awar_field_new_name = GBS_global_string_copy(AWAR_TABLE_FIELD_NEW_NAME_TEMPLATE,tname);
210    this->awar_field_new_type = GBS_global_string_copy(AWAR_TABLE_FIELD_NEW_TYPE_TEMPLATE,tname);
211    this->awar_selected_field = GBS_global_string_copy(AWAR_TABLE_SELECTED_FIELD_TEMPLATE,tname);
212
213    awr->awar_string(awar_field_reorder_source,"");
214    awr->awar_string(awar_field_reorder_dest,"");
215    awr->awar_string(awar_field_new_name,"");
216    awr->awar_int(awar_field_new_type,GB_STRING);
217    awr->awar_string(awar_field_rem,"No comment");
218    awr->awar_string(awar_selected_field,"");
219
220    delete tname;
221}
222
223awt_table::~awt_table(){
224    delete table_name;
225    delete awar_field_reorder_source;
226    delete awar_field_reorder_dest;
227    delete awar_field_new_name;
228    delete awar_field_rem;
229    delete awar_selected_field;
230}
231
232void   awt_map_table_field_rem(AW_root *aw_root,awt_table *awtt){
233    GB_transaction tscope(awtt->gb_main);
234    GBDATA *gb_table = GBT_open_table(awtt->gb_main,awtt->table_name,GB_TRUE);
235    if (!gb_table){
236        aw_root->awar(awtt->awar_field_rem)->unmap();
237        return;
238    }
239    char *field_name  = aw_root->awar(awtt->awar_selected_field)->read_string();
240    GBDATA *gb_table_field = GBT_find_table_field(gb_table,field_name);
241    if (!gb_table_field){
242        delete field_name;
243        aw_root->awar(awtt->awar_field_rem)->unmap();
244        return;
245    }
246    GBDATA *gb_desc = GB_search(gb_table_field,"description",GB_STRING);
247    aw_root->awar(awtt->awar_field_rem)->map(gb_desc);
248}
249
250void create_ad_table_field_admin(AW_window *aww,GBDATA *gb_main,const char *tname){
251    static GB_HASH *table_to_win_hash = GBS_create_hash(256, GB_MIND_CASE);
252    AW_root        *aw_root           = aww->get_root();
253    char           *table_name;
254    if (tname){
255        table_name = strdup(tname);
256    }
257    else {
258        table_name = aw_root->awar(AWAR_TABLE_NAME)->read_string();
259    }
260
261    AW_window_simple *aws = (AW_window_simple *)GBS_read_hash(table_to_win_hash,table_name);
262    if (!aws) {
263        awt_table *awtt = new awt_table(gb_main,aw_root,table_name);
264        aws = new AW_window_simple;
265        const char *table_header = GBS_global_string("TABLE_ADMIN_%s",table_name);
266        aws->init( aw_root, table_header,table_header);
267
268        aws->load_xfig("ad_table_fields.fig");
269
270        aws->callback( AW_POPDOWN);
271        aws->at("close");
272        aws->create_button("CLOSE","CLOSE","C");
273
274        aws->callback( AW_POPUP_HELP,(AW_CL)"tableadm.hlp");
275        aws->at("help");
276        aws->create_button("HELP","HELP","H");
277
278        aws->at("table_name");
279        aws->create_button(table_name,table_name,"A");
280
281        aws->button_length(13);
282
283        aws->at("delete");
284        aws->callback((AW_CB1)awt_table_field_delete_cb,(AW_CL)awtt);
285        aws->create_button("DELETE","DELETE","D");
286
287        aws->at("hide");
288        aws->callback((AW_CB1)awt_table_field_hide_cb,(AW_CL)awtt);
289        aws->create_button("HIDE","HIDE","D");
290
291        aws->at("create");
292        aws->callback(AW_POPUP,(AW_CL)create_ad_table_field_create_window,(AW_CL)awtt);
293        aws->create_button("CREATE","CREATE","C");
294
295        aws->at("reorder");
296        aws->callback(AW_POPUP,(AW_CL)create_ad_table_field_reorder_window,(AW_CL)awtt);
297        aws->create_button("REORDER","REORDER","R");
298
299
300
301        //    aws->at("rename");
302        //    aws->callback(AW_POPUP,(AW_CL)create_table_field_rename_window,(AW_CL)awtt);
303        //    aws->create_button("RENAME","RENAME","R");
304
305        //    aws->at("copy");
306        //    aws->callback(AW_POPUP,(AW_CL)create_table_field_copy_window,(AW_CL)awtt);
307        //    aws->create_button("COPY","COPY","C");
308
309
310        aws->at("list");
311        awt_create_selection_list_on_table_fields(gb_main,(AW_window *)aws,table_name,awtt->awar_selected_field);
312
313        aws->at("rem");
314        aws->create_text_field(awtt->awar_field_rem);
315
316        awt_map_table_field_rem(aw_root,awtt);
317        aw_root->awar(awtt->awar_selected_field)->add_callback((AW_RCB1)awt_map_table_field_rem,(AW_CL)awtt);
318    }
319   
320    aws->activate();
321    free(table_name);
322}
323
324
325
326
327/***************************************************** TABLE ADMIN
328 ***********************************************/
329
330
331
332//#define AWAR_TABLE_IMPORT "tmp/ad_table/import_table"
333
334void table_vars_callback(AW_root *aw_root,GBDATA *gb_main)      // Map table vars to display objects
335{
336    GB_push_transaction(gb_main);
337    char *tablename = aw_root->awar(AWAR_TABLE_NAME)->read_string();
338    GBDATA *gb_table = GBT_open_table(gb_main,tablename,GB_TRUE);
339    if (!gb_table) {
340        aw_root->awar(AWAR_TABLE_REM)->unmap();
341    }else{
342        GBDATA *table_rem = GB_search(gb_table,"description",   GB_STRING);
343        aw_root->awar(AWAR_TABLE_REM)->map(table_rem);
344    }
345    char *fname = GBS_string_eval(tablename,"*=*1.table:table_*=*1",0);
346    aw_root->awar(AWAR_TABLE_EXPORT "/file_name")->write_string(fname); // create default file name
347    delete fname;
348    GB_pop_transaction(gb_main);
349    free(tablename);
350}
351
352
353
354void table_rename_cb(AW_window *aww,GBDATA *gb_main){
355    GB_ERROR  error  = 0;
356    char     *source = aww->get_root()->awar(AWAR_TABLE_NAME)->read_string();
357    char     *dest   = aww->get_root()->awar(AWAR_TABLE_DEST)->read_string();
358   
359    GB_begin_transaction(gb_main);
360    GBDATA *gb_table_dest = GBT_open_table(gb_main,dest,GB_TRUE);
361    if (gb_table_dest) {
362        error = "Table already exists";
363    }
364    else {
365        GBDATA *gb_table = GBT_open_table(gb_main,source,GB_TRUE);
366        if (gb_table){
367            GBDATA *gb_name = GB_search(gb_table,"name",GB_STRING);
368           
369            if (!gb_name) error = GB_await_error();
370            else error          = GB_write_string(gb_name,dest);
371        }
372    }
373    GB_end_transaction_show_error(gb_main, error, aw_message);
374
375    free(source);
376    free(dest);
377}
378
379void table_copy_cb(AW_window *aww,GBDATA *gb_main){
380    GB_ERROR  error  = 0;
381    char     *source = aww->get_root()->awar(AWAR_TABLE_NAME)->read_string();
382    char     *dest   = aww->get_root()->awar(AWAR_TABLE_DEST)->read_string();
383   
384    GB_begin_transaction(gb_main);
385    GBDATA *gb_table_dest = GBT_open_table(gb_main,dest,GB_TRUE);
386    if (gb_table_dest) {
387        error = "Table already exists";
388    }
389    else {
390        GBDATA *gb_table = GBT_open_table(gb_main,source,GB_TRUE);
391        if (gb_table){
392            GBDATA *gb_table_data = GB_entry(gb_main,"table_data");
393            gb_table_dest = GB_create_container(gb_table_data,"table");
394            error = GB_copy(gb_table_dest,gb_table);
395            if (!error){
396                GBDATA *gb_name = GB_search(gb_table_dest,"name",GB_STRING);
397                error = GB_write_string(gb_name,dest);
398            }
399        }
400    }
401    GB_end_transaction_show_error(gb_main, error, aw_message);
402
403    free(source);
404    free(dest);
405}
406void table_create_cb(AW_window *aww,GBDATA *gb_main){
407    char     *dest  = aww->get_root()->awar(AWAR_TABLE_DEST)->read_string();
408    GB_ERROR  error = GB_begin_transaction(gb_main);
409    if (!error) {
410        error = GB_check_key(dest);
411        if (!error){
412            GBDATA *gb_table     = GBT_open_table(gb_main,dest,GB_FALSE);
413            if (!gb_table) error = GB_await_error();
414        }
415    }
416    error = GB_end_transaction(gb_main, error);
417    aww->hide_or_notify(error);
418    free(dest);
419}
420
421AW_window *create_table_rename_window(AW_root *root,GBDATA *gb_main)
422{
423    AW_window_simple *aws = new AW_window_simple;
424    aws->init( root, "RENAME_TABLE","TABLE RENAME");
425    aws->load_xfig("ad_al_si.fig");
426
427    aws->callback( (AW_CB0)AW_POPDOWN);
428    aws->at("close");
429    aws->create_button("CLOSE","CLOSE","C");
430
431    aws->at("label");
432    aws->create_autosize_button(0,"Please enter the new name\nof the table");
433
434    aws->at("input");
435    aws->create_input_field(AWAR_TABLE_DEST,15);
436
437    aws->at("ok");
438    aws->callback((AW_CB1)table_rename_cb,(AW_CL)gb_main);
439    aws->create_button("GO","GO","G");
440
441    return (AW_window *)aws;
442}
443
444AW_window *create_table_copy_window(AW_root *root,GBDATA *gb_main)
445{
446    AW_window_simple *aws = new AW_window_simple;
447    aws->init( root, "COPY_TABLE", "TABLE COPY");
448    aws->load_xfig("ad_al_si.fig");
449
450    aws->callback( (AW_CB0)AW_POPDOWN);
451    aws->at("close");
452    aws->create_button("CLOSE","CLOSE","C");
453
454    aws->at("label");
455    aws->create_autosize_button(0,"Please enter the name\nof the new table");
456
457    aws->at("input");
458    aws->create_input_field(AWAR_TABLE_DEST,15);
459
460    aws->at("ok");
461    aws->callback((AW_CB1)table_copy_cb,(AW_CL)gb_main);
462    aws->create_button("GO","GO","G");
463
464    return (AW_window *)aws;
465}
466AW_window *create_table_create_window(AW_root *root,GBDATA *gb_main)
467{
468    AW_window_simple *aws = new AW_window_simple;
469    aws->init( root, "CREATE_TABLE", "TABLE CREATE");
470    aws->load_xfig("ad_al_si.fig");
471
472    aws->callback( (AW_CB0)AW_POPDOWN);
473    aws->at("close");
474    aws->create_button("CLOSE","CLOSE","C");
475
476    aws->at("label");
477    aws->create_autosize_button(0,"Please enter the name\nof the new table");
478
479    aws->at("input");
480    aws->create_input_field(AWAR_TABLE_DEST,15);
481
482    aws->at("ok");
483    aws->callback((AW_CB1)table_create_cb,(AW_CL)gb_main);
484    aws->create_button("GO","GO","G");
485
486    return (AW_window *)aws;
487}
488void awt_table_delete_cb(AW_window *aww,GBDATA *gb_main){
489    GB_ERROR  error  = 0;
490    char     *source = aww->get_root()->awar(AWAR_TABLE_NAME)->read_string();
491
492    GB_begin_transaction(gb_main);
493    GBDATA *gb_table = GBT_open_table(gb_main, source, GB_TRUE);
494    if (gb_table) {
495        error = GB_delete(gb_table);
496    }
497    else {
498        error = "Please select a table first";
499    }
500    GB_end_transaction_show_error(gb_main, error, aw_message);
501
502    free(source);
503}
504
505void create_tables_var(GBDATA *gb_main, AW_root *aw_root){
506    aw_root->awar_string( AWAR_TABLE_NAME );
507    aw_root->awar_string( AWAR_TABLE_DEST );
508    aw_root->awar_string( AWAR_TABLE_REM,"no rem" );
509   
510    aw_create_selection_box_awars(aw_root, AWAR_TABLE_EXPORT, "", "table", "tablefile");
511
512    aw_create_selection_box_awars(aw_root, AWAR_TABLE_IMPORT, "", "table", "tablefile");
513    aw_root->awar_string( AWAR_TABLE_IMPORT "/table_name", "table_"); //->set_srt( GBT_TABLE_AWAR_SRT);
514
515    aw_root->awar(AWAR_TABLE_NAME)->add_callback( (AW_RCB1)table_vars_callback,(AW_CL)gb_main);
516    table_vars_callback(aw_root,gb_main);
517}
518
519AW_window *AWT_create_tables_admin_window(AW_root *aw_root,GBDATA *gb_main)
520{
521    static AW_window_simple *aws = 0;
522
523    if (aws) return aws;
524    GB_transaction tscope(gb_main);
525    create_tables_var(gb_main,aw_root);
526
527    aws = new AW_window_simple;
528    aws->init( aw_root, "TABLE_ADMIN","TABLE ADMIN");
529    aws->load_xfig("ad_table_admin.fig");
530
531    aws->callback( AW_POPDOWN);
532    aws->at("close");
533    aws->create_button("CLOSE","CLOSE","C");
534
535    aws->callback( AW_POPUP_HELP,(AW_CL)"tableadm.hlp");
536    aws->at("help");
537    aws->create_button("HELP","HELP","H");
538
539    aws->button_length(13);
540
541    aws->at("delete");
542    aws->callback((AW_CB1)awt_table_delete_cb,(AW_CL)gb_main);
543    aws->create_button("DELETE","DELETE","D");
544
545    aws->at("rename");
546    aws->callback(AW_POPUP,(AW_CL)create_table_rename_window,(AW_CL)gb_main);
547    aws->create_button("RENAME","RENAME","R");
548
549    aws->at("copy");
550    aws->callback(AW_POPUP,(AW_CL)create_table_copy_window,(AW_CL)gb_main);
551    aws->create_button("COPY","COPY","C");
552
553    aws->at("cmp");
554    aws->callback(AW_POPUP,(AW_CL)create_table_create_window,(AW_CL)gb_main);
555    aws->create_button("CREATE","CREATE","C");
556
557    aws->at("export");
558    aws->callback((AW_CB)create_ad_table_field_admin,(AW_CL)gb_main,0);
559    aws->create_button("ADMIN","ADMIN","C");
560
561    aws->at("list");
562    awt_create_selection_list_on_tables(gb_main,(AW_window *)aws,AWAR_TABLE_NAME);
563
564    aws->at("rem");
565    aws->create_text_field(AWAR_TABLE_REM);
566
567    return (AW_window *)aws;
568}
Note: See TracBrowser for help on using the repository browser.