X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=clients%2Fgtk2%2Fmakegdesc;fp=clients%2Fgtk2%2Fmakegdesc;h=0000000000000000000000000000000000000000;hb=e35e7757af650b09aa4364a9ce0444c5dbde8dee;hp=bc4088c0972fab83c15baf69d365a163361c94b2;hpb=932e94ad10f3449f36b3ca92025c8e8c8ab59aa9;p=doldaconnect.git diff --git a/clients/gtk2/makegdesc b/clients/gtk2/makegdesc deleted file mode 100755 index bc4088c..0000000 --- a/clients/gtk2/makegdesc +++ /dev/null @@ -1,424 +0,0 @@ -#!/usr/bin/perl - -$tempvar = 0; - -sub printwidgets -{ - my($widget, $sl, $p, $sig, $cb, $data, $pf, $cpf, $mod, $key, @delayedlines); - $sl = $_[1]; - $p = " " . (" " x $sl); - $cpf = $_[2]; - @delayedlines = (); - foreach $widget (@{$_[0]}) - { - if($widget->{"type"} eq "wnd") - { - print "${p}stack[$sl] = gtk_window_new(GTK_WINDOW_TOPLEVEL);\n"; - if($options{"hasaccels"}) { - print "${p}gtk_window_add_accel_group(GTK_WINDOW(stack[$sl]), accel_group);\n"; - } - if($widget->{"title"}) { - print "${p}gtk_window_set_title(GTK_WINDOW(stack[$sl]), \"" . $widget->{"title"} . "\");\n"; - } - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_container_add(GTK_CONTAINER(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} =~ /[hv]box/) { - print "${p}stack[$sl] = gtk_" . $widget->{"type"} . "_new("; - print $widget->{"homo"}?"TRUE, ":"FALSE, "; - print $widget->{"spacing"} || "0"; - print ");\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_box_pack_start(GTK_BOX(stack[" . ($sl - 1) . "]), stack[$sl], "; - print (($widget->{"expand"} || $widget->{"parent"}->{"dexpand"})?"TRUE, ":"FALSE, "); - print (($widget->{"fill"} || $widget->{"parent"}->{"dfill"})?"TRUE, ":"FALSE, "); - print $widget->{"pad"} || "0"; - print ");\n"; - } - } elsif($widget->{"type"} eq "table") { - print "${p}stack[$sl] = gtk_table_new(" . $widget->{"rows"} . ", " . $widget->{"cols"}; - print ", " . (($widget->{"homo"} eq "TRUE")?"TRUE":"FALSE"); - print ");\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_table_attach(GTK_TABLE(stack[" . ($sl - 1) . "]), stack[$sl]"; - print ", " . $widget->{"tx"}; - print ", " . ($widget->{"tx"} + (defined($widget->{"tw"})?$widget->{"tw"}:1)); - print ", " . $widget->{"ty"}; - print ", " . ($widget->{"ty"} + (defined($widget->{"th"})?$widget->{"th"}:1)); - if($widget->{"fill"} eq "y") { - $widget->{"fillx"} = "y"; - $widget->{"filly"} = "y"; - } - if($widget->{"shrink"} eq "y") { - $widget->{"shrinkx"} = "y"; - $widget->{"shrinky"} = "y"; - } - if($widget->{"expand"} eq "y") { - $widget->{"expandx"} = "y"; - $widget->{"expandy"} = "y"; - } - print ", 0"; - print " | GTK_FILL" if $widget->{"fillx"} eq "y"; - print " | GTK_SHRINK" if $widget->{"shrinkx"} eq "y"; - print " | GTK_EXPAND" if $widget->{"expandx"} eq "y"; - print ", 0"; - print " | GTK_FILL" if $widget->{"filly"} eq "y"; - print " | GTK_SHRINK" if $widget->{"shrinky"} eq "y"; - print " | GTK_EXPAND" if $widget->{"expandy"} eq "y"; - print ", " . (defined($widget->{"padx"})?$widget->{"padx"}:"0"); - print ", " . (defined($widget->{"pady"})?$widget->{"pady"}:"0"); - print ");\n"; - } - } elsif($widget->{"type"} eq "btn") { - $widget->{"label"} || die("Can't have button without label\n"); - print "${p}stack[$sl] = gtk_button_new_with_mnemonic(_(\"" . $widget->{"label"} . "\"));\n"; - } elsif($widget->{"type"} eq "chk") { - $widget->{"label"} || die("Can't have check button without label\n"); - print "${p}stack[$sl] = gtk_check_button_new_with_mnemonic(_(\"" . $widget->{"label"} . "\"));\n"; - } elsif($widget->{"type"} eq "sbtn") { - $widget->{"stock"} || die("Can't have button without stock\n"); - print "${p}stack[$sl] = gtk_button_new_from_stock(GTK_STOCK_" . $widget->{"stock"} . ");\n"; - } elsif($widget->{"type"} eq "simg") { - $widget->{"stock"} || die("Can't have image without stock\n"); - $widget->{"size"} || die("Can't have image without size\n"); - print "${p}stack[$sl] = gtk_image_new_from_stock(GTK_STOCK_" . $widget->{"stock"} . ", GTK_ICON_SIZE_" . $widget->{"size"} . ");\n"; - } elsif($widget->{"type"} eq "lbl") { - $widget->{"label"} || die("Can't have label without label\n"); - print "${p}stack[$sl] = gtk_label_new(_(\"" . $widget->{"label"} . "\"));\n"; - } elsif($widget->{"type"} eq "mlbl") { - $widget->{"label"} || die("Can't have label without label\n"); - print "${p}stack[$sl] = gtk_label_new_with_mnemonic(_(\"" . $widget->{"label"} . "\"));\n"; - if(defined($widget->{"mwidget"})) - { - if($widget->{"var"} ne "y") { - $widget->{"var"} = "l"; - } - if(!defined($widget->{"name"})) { - $widget->{"name"} = "temp" . $tempvar++; - } - $str = "gtk_label_set_mnemonic_widget(GTK_LABEL("; - if($widget->{"var"} eq "y") { - $str .= $options{"prefix"}; - } - $str .= $widget->{"name"}; - $str .= "), " . $options{"prefix"} . $widget->{"mwidget"} . ");"; - push @delayedlines, ($str); - } - } elsif($widget->{"type"} eq "text") { - print "${p}stack[$sl] = gtk_entry_new();\n"; - if($widget->{"default"}) { - print "${p}gtk_entry_set_text(GTK_ENTRY(stack[$sl]), \"" . $widget->{"default"} . "\");\n"; - } - } elsif($widget->{"type"} eq "menubar") { - print "${p}stack[$sl] = gtk_menu_bar_new();\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_menu_shell_append(GTK_MENU_SHELL(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} eq "menuitem") { - print "${p}stack[$sl] = gtk_menu_item_new_with_mnemonic(_(\"" . $widget->{"label"} . "\"));\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_menu_item_set_submenu(GTK_MENU_ITEM(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} eq "smenuitem") { - print "${p}stack[$sl] = gtk_image_menu_item_new_from_stock(GTK_STOCK_" . $widget->{"stock"} . ", accel_group);\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_menu_item_set_submenu(GTK_MENU_ITEM(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} eq "menusep") { - print "${p}stack[$sl] = gtk_separator_menu_item_new();\n"; - } elsif($widget->{"type"} eq "menu") { - print "${p}stack[$sl] = gtk_menu_new();\n"; - if($options{"hasaccels"}) { - print "${p}gtk_menu_set_accel_group(GTK_MENU(stack[$sl]), accel_group);\n"; - } - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_menu_shell_append(GTK_MENU_SHELL(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - }; - $widget->{"noshow"} = 1; - } elsif($widget->{"type"} =~ /^[hv]paned$/) { - print "${p}stack[$sl] = gtk_" . $widget->{"type"} . "_new();\n"; - $widget->{"cur"} = 1; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_paned_pack" . ($widget->{"parent"}->{"cur"}) . "(GTK_PANED(stack[" . ($sl - 1) . "]), stack[$sl]"; - print ", " . ((index($widget->{"parent"}->{"resize"}, $widget->{"parent"}->{"cur"}) < 0)?"FALSE":"TRUE"); - print ", " . ((index($widget->{"parent"}->{"shrink"}, $widget->{"parent"}->{"cur"}) < 0)?"FALSE":"TRUE"); - print ");\n"; - $widget->{"parent"}->{"cur"}++; - } - } elsif($widget->{"type"} eq "notebook") { - print "${p}stack[$sl] = gtk_notebook_new();\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_notebook_append_page(GTK_NOTEBOOK(stack[" . ($sl - 1) . "]), stack[$sl]"; - print ", gtk_label_new_with_mnemonic(_(\"" . $widget->{"nblabel"} . "\"))"; - print ");\n"; - } - } elsif($widget->{"type"} eq "sw") { - print "${p}stack[$sl] = gtk_scrolled_window_new(NULL, NULL);\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_container_add(GTK_CONTAINER(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} eq "frame") { - print "${p}stack[$sl] = gtk_frame_new(_(\"" . $widget->{"label"} . "\"));\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_container_add(GTK_CONTAINER(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} eq "exp") { - print "${p}stack[$sl] = gtk_expander_new_with_mnemonic(_(\"" . $widget->{"label"} . "\"));\n"; - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_container_add(GTK_CONTAINER(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; - } - } elsif($widget->{"type"} eq "treeview") { - print "${p}stack[$sl] = gtk_tree_view_new();\n"; - if(defined($widget->{"hvis"})) { - print "${p}gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(stack[$sl]), " . $widget->{"hvis"} . ");\n"; - } - if(defined($widget->{"rules"})) { - print "${p}gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(stack[$sl]), " . $widget->{"rules"} . ");\n"; - } - if(defined($widget->{"searchcol"})) { - print "${p}gtk_tree_view_set_search_column(GTK_TREE_VIEW(stack[$sl]), " . $widget->{"searchcol"} . ");\n"; - print "${p}gtk_tree_view_set_enable_search(GTK_TREE_VIEW(stack[$sl]), TRUE);\n"; - } - $pf = sub - { - my($widget, $p, $sl) = @_; - print "${p}gtk_tree_view_append_column(GTK_TREE_VIEW(stack[" . ($sl - 1) . "]), column);\n"; - if($widget->{"expander"} eq "y") { - print "${p}gtk_tree_view_set_expander_column(GTK_TREE_VIEW(stack[" . ($sl - 1) . "]), column);\n"; - } - } - } elsif($widget->{"type"} eq "tvcol") { - if(!defined($widget->{"subwidgets"})) - { - print "${p}column = gtk_tree_view_column_new_with_attributes("; - print "_(\"" . $widget->{"title"} . "\")"; - print ", gtk_cell_renderer_text_new()"; - if(defined($widget->{"text"})) { - print ", \"text\", " . $widget->{"text"}; - } - print ", NULL);\n"; - } else { - print "${p}column = gtk_tree_view_column_new();\n"; - print "${p}gtk_tree_view_column_set_title(column, _(\"" . $widget->{"title"} . "\"));\n"; - } - if(defined($widget->{"sortcol"})) { - print "${p}gtk_tree_view_column_set_sort_column_id(column, " . $widget->{"sortcol"} . ");\n"; - } - if(defined($widget->{"resizable"})) { - print "${p}gtk_tree_view_column_set_resizable(column, " . $widget->{"resizable"} . ");\n"; - } - $widget->{"noshow"} = 1; - $pf = sub - { - } - } elsif($widget->{"type"} eq "textrend") { - print "${p}renderer = gtk_cell_renderer_text_new();\n"; - print "${p}gtk_tree_view_column_pack_start(column, renderer, " . (defined($widget->{"expand"})?$widget->{"expand"}:"TRUE") . ");\n"; - if(defined($widget->{"text"})) { - print "${p}gtk_tree_view_column_add_attribute(column, renderer, \"text\", " . $widget->{"text"} . ");\n"; - } - if(defined($widget->{"func"})) { - print "${p}gtk_tree_view_column_set_cell_data_func(column, renderer, " . $widget->{"func"} . ", " . ($widget->{"funcdata"} || "NULL") . ", NULL);\n"; - } - $widget->{"noshow"} = 1; - } elsif($widget->{"type"} eq "custrend") { - print "${p}renderer = GTK_CELL_RENDERER(" . $widget->{"newfunc"} . "());\n"; - print "${p}gtk_tree_view_column_pack_start(column, renderer, " . (defined($widget->{"expand"})?$widget->{"expand"}:"FALSE") . ");\n"; - foreach $attr (keys %{$widget}) - { - if($attr =~ /attr\((\S+)\)/) - { - print "${p}gtk_tree_view_column_add_attribute(column, renderer, \"" . $1 . "\", " . $widget->{$attr} . ");\n"; - } - } - $widget->{"noshow"} = 1; - } elsif($widget->{"type"} eq "pixbufrend") { - print "${p}renderer = gtk_cell_renderer_pixbuf_new();\n"; - print "${p}gtk_tree_view_column_pack_start(column, renderer, FALSE);\n"; - if(defined($widget->{"stock_id"})) { - print "${p}gtk_tree_view_column_add_attribute(column, renderer, \"stock_id\", " . $widget->{"stock_id"} . ");\n"; - } - $widget->{"noshow"} = 1; - } elsif($widget->{"type"} eq "textview") { - print "${p}stack[$sl] = gtk_text_view_new();\n"; - if(defined($widget->{"editable"})) { - print "${p}gtk_text_view_set_editable(GTK_TEXT_VIEW(stack[$sl]), " . $widget->{"editable"} . ");\n"; - } - } elsif($widget->{"type"} eq "pbar") { - print "${p}stack[$sl] = gtk_progress_bar_new();\n"; - } elsif($widget->{"type"} eq "hr") { - print "${p}stack[$sl] = gtk_hseparator_new();\n"; - } elsif($widget->{"type"} eq "sbar") { - print "${p}stack[$sl] = gtk_statusbar_new();\n"; - if($widget->{"grip"} eq "n") { - print "${p}gtk_statusbar_set_has_resize_grip(GTK_STATUSBAR(stack[$sl]), FALSE);\n"; - } - } else { - print STDERR "Unknown widget: " . $widget->{"type"} ."\n"; - } - if($widget->{"sensitive"}) { - print "${p}gtk_widget_set_sensitive(stack[$sl], " . $widget->{"sensitive"} . ");\n"; - } - if($widget->{"var"} eq "y") { - print $p . $options{"prefix"} . $widget->{"name"} . " = stack[$sl];\n"; - } - if($widget->{"var"} eq "l") { - print $p . "GtkWidget *" . $widget->{"name"} . " = stack[$sl];\n"; - } - if($widget->{"sig"}) - { - while($widget->{"sig"} =~ /\G([\w_]+),?/g) { - print "${p}g_signal_connect(G_OBJECT(stack[$sl]), \"$1\", G_CALLBACK(cb_" . $options{"prefix"} . $widget->{"name"} . "_" . $1 . "), (gpointer)NULL);\n"; - } - } - if($widget->{"accel"}) - { - $mod = ""; - while($widget->{"accel"} =~ /\G(\w+)\+/gc) - { - $mod .= " | " if($mod); - $mod = $mod . "GDK_" . $1 . "_MASK"; - } - $mod || ($mod = "0"); - $widget->{"accel"} =~ /\G(\w+)/g; - $key = $1; - print "${p}gtk_widget_add_accelerator(stack[$sl], \"activate\", accel_group, GDK_$key, $mod, GTK_ACCEL_VISIBLE);\n"; - } - foreach $attr (keys %{$widget}) - { - if($attr =~ /^sig\((\S+)\)/) - { - $sig = $1; - if($widget->{$attr} =~ /([^,]*),(.*)/) - { - $cb = $1; - $data = $2; - } else { - $cb = $widget->{$attr}; - $data = "NULL"; - } - print "${p}g_signal_connect(G_OBJECT(stack[$sl]), \"$1\", G_CALLBACK($cb), (gpointer)$data);\n"; - } - } - if($widget->{"subwidgets"}) - { - print "$p\n"; - printwidgets($widget->{"subwidgets"}, $sl + 1, $pf); - } - if($sl > 0) - { - &$cpf($widget, $p, $sl); - if(!$widget->{"noshow"}) { - print "${p}gtk_widget_show(stack[$sl]);\n"; - } - } - print "$p\n"; - } - foreach $line (@delayedlines) - { - print $p . $line . "\n"; - } -} - -sub printvars -{ - my($widget); - foreach $widget (@{$_[0]}) - { - if($widget->{"var"}) - { - print "GtkWidget *" . $options{"prefix"} . $widget->{"name"} .";\n"; - } - printvars($widget->{"subwidgets"}) if($widget->{"subwidgets"}); - } -} - -sub dequote -{ - my($text); - ($text) = @_; - $text =~ s/([^\\]|^)\"/$1/g; - $text =~ s/\\(.)/$1/g; - return $text; -} - -$rootwidgets = []; -@estack = ($rootwidgets); -@wstack = (); -$curwidget = 0; -$maxstack = 1; - -while(<>) -{ - chomp; - s/(^|\s+)\#.*$//; - s/^\s*//; - if(/^;\s*(\w+)\s*:\s*(\w.*)/) - { - $options{$1} = $2; - } elsif(/^([:\$])\s*(\w+)/g) { - $curwidget = {"type" => $2}; - push @{$estack[0]}, $curwidget; - if((scalar @wstack) > 0) { - $curwidget->{"parent"} = $wstack[0]; - } - if($1 eq ":") - { - unshift @estack, ($curwidget->{"subwidgets"} = []); - unshift @wstack, $curwidget; - } - $maxstack = (scalar @estack) if((scalar @estack) > $maxstack); - while(/\G\s*(\S+)\s*:\s*((\w+|\"([^\\\"]+|\\.)*([^\\]|)\"|\\.)+)/g) - { - $curwidget->{$1} = dequote($2); - } - } elsif(/^%\s*(\S+)\s*:\s*((\w+|\"([^\\\"]+|\\.)*([^\\]|)\"|\\.)+)/) { - $curwidget || die("No current widget\n"); - $curwidget->{$1} = dequote($2); - } elsif(/^end/) { - shift @estack; - shift @wstack; - $curwidget = $wstack[0] if((scalar @wstack) > 0); - } elsif(!$_) { - } else { - print STDERR "Invalid construct: $_\n"; - } -} - -printvars $rootwidgets; -print "\n"; -print "GtkWidget *create_" . $options{"prefix"} . "wnd(void)\n"; -print "{\n"; -print " GtkWidget *stack[$maxstack];\n"; -print " GtkAccelGroup *accel_group;\n" if $options{"hasaccels"}; -print " GtkTreeViewColumn *column;\n" if $options{"hascolumns"}; -print " GtkCellRenderer *renderer;\n" if $options{"hasrenderers"}; -print " \n"; -print " accel_group = gtk_accel_group_new();\n" if $options{"hasaccels"}; -printwidgets $rootwidgets, 0; -print " return(stack[0]);\n"; -print "}\n";