X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=common%2Fmakegdesc;h=b61ed758aa6abb0a81a2fad9b9de1cced28009e8;hb=dbdb91fa4abf642a9699b1381abf8bcbb05b202c;hp=5ffcf09243ca3726ea53a4bf96ebed5d664ff31f;hpb=bf9a1919dcda8d86b95a294e9a609587339848e4;p=doldaconnect.git diff --git a/common/makegdesc b/common/makegdesc index 5ffcf09..b61ed75 100755 --- a/common/makegdesc +++ b/common/makegdesc @@ -1,5 +1,10 @@ #!/usr/bin/perl +use Getopt::Long; +use IO::File; + +GetOptions(\%args, "h=s") || exit 1; + $tempvar = 0; sub printwidgets @@ -58,6 +63,16 @@ sub printwidgets print $widget->{"pad"} || "0"; print ");\n"; } + } elsif($widget->{"type"} =~ /([hv])btnbox/) { + print "${p}stack[$sl] = gtk_" . $1 . "button_box_new();\n"; + if(defined($widget->{"layout"})) { + print "${p}gtk_button_box_set_layout(GTK_BUTTON_BOX(stack[$sl]), GTK_BUTTONBOX_" . $widget->{"layout"} . ");\n"; + } + $pf = sub + { + my($widget, $p, $sl) = @_; + print "${p}gtk_container_add(GTK_CONTAINER(stack[" . ($sl - 1) . "]), stack[$sl]);\n"; + } } elsif($widget->{"type"} eq "table") { print "${p}stack[$sl] = gtk_table_new(" . $widget->{"rows"} . ", " . $widget->{"cols"}; print ", " . (($widget->{"homo"} eq "TRUE")?"TRUE":"FALSE"); @@ -114,6 +129,9 @@ sub printwidgets $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 "xpmimg") { + $widget->{"data"} || die("Can't have XPM image without data\n"); + print "${p}stack[$sl] = gtk_image_new_from_pixbuf(gdk_pixbuf_new_from_xpm_data((const char **)" . $widget->{"data"} . "));\n"; } elsif($widget->{"type"} eq "lbl") { $widget->{"label"} || $widget->{"markup"} || die("Can't have label without label\n"); if($widget->{"label"}) { @@ -197,6 +215,9 @@ sub printwidgets } } elsif($widget->{"type"} eq "notebook") { print "${p}stack[$sl] = gtk_notebook_new();\n"; + if(defined($widget->{"pos"})) { + print "${p}gtk_notebook_set_tab_pos(GTK_NOTEBOOK(stack[$sl]), GTK_POS_" . $widget->{"pos"} . ");\n"; + } $pf = sub { my($widget, $p, $sl) = @_; @@ -310,6 +331,16 @@ sub printwidgets 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 "progrend") { + print "${p}renderer = gtk_cell_renderer_progress_new();\n"; + print "${p}gtk_tree_view_column_pack_start(column, renderer, " . (defined($widget->{"expand"})?$widget->{"expand"}:"FALSE") . ");\n"; + if(defined($widget->{"value"})) { + print "${p}gtk_tree_view_column_add_attribute(column, renderer, \"value\", " . $widget->{"value"} . ");\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"; @@ -397,7 +428,7 @@ sub printwidgets $cb = $widget->{$attr}; $data = "NULL"; } - print "${p}g_signal_connect(G_OBJECT(stack[$sl]), \"$1\", G_CALLBACK($cb), (gpointer)$data);\n"; + print "${p}g_signal_connect(G_OBJECT(stack[$sl]), \"$sig\", G_CALLBACK($cb), (gpointer)$data);\n"; } } if($widget->{"subwidgets"}) @@ -420,6 +451,20 @@ sub printwidgets } } +sub printheader +{ + my($widget, $handle); + $handle = $_[1]; + foreach $widget (@{$_[0]}) + { + if($widget->{"var"}) + { + $handle->print("extern GtkWidget *" . $options{"prefix"} . $widget->{"name"} .";\n"); + } + printheader($widget->{"subwidgets"}, $handle) if($widget->{"subwidgets"}); + } +} + sub printvars { my($widget); @@ -485,6 +530,14 @@ while(<>) } } +if($args{"h"}) +{ + $hfile = IO::File->new($args{"h"}, "w") || die; + $hfile->print("GtkWidget *create_" . $options{"prefix"} . "wnd(void);\n"); + printheader $rootwidgets, $hfile; + $hfile->close(); +} + printvars $rootwidgets; print "\n"; print "GtkWidget *create_" . $options{"prefix"} . "wnd(void)\n";