X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=libs%2Fgtkutil%2Fdialog.cpp;h=59f5c5d9328161c359f4f37836eb38778c0fd7dd;hb=e4287c28bb2dafedc81c66e63951d947cfbeb225;hp=0f95e9ae0f66df515c5fe8b2045b497faf3db953;hpb=203343b01a7ad87cb3d136689c9936ff5bc23c01;p=xonotic%2Fnetradiant.git diff --git a/libs/gtkutil/dialog.cpp b/libs/gtkutil/dialog.cpp index 0f95e9ae..59f5c5d9 100644 --- a/libs/gtkutil/dialog.cpp +++ b/libs/gtkutil/dialog.cpp @@ -1,23 +1,23 @@ /* -Copyright (C) 2001-2006, William Joseph. -All Rights Reserved. + Copyright (C) 2001-2006, William Joseph. + All Rights Reserved. -This file is part of GtkRadiant. + This file is part of GtkRadiant. -GtkRadiant is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 2 of the License, or -(at your option) any later version. + GtkRadiant is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. -GtkRadiant is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. + GtkRadiant is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. -You should have received a copy of the GNU General Public License -along with GtkRadiant; if not, write to the Free Software -Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA -*/ + You should have received a copy of the GNU General Public License + along with GtkRadiant; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ #include "dialog.h" @@ -35,269 +35,242 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #include "button.h" #include "window.h" -GtkVBox* create_dialog_vbox(int spacing, int border) -{ - GtkVBox* vbox = GTK_VBOX(gtk_vbox_new(FALSE, spacing)); - gtk_widget_show(GTK_WIDGET(vbox)); - gtk_container_set_border_width(GTK_CONTAINER(vbox), border); - return vbox; +GtkVBox* create_dialog_vbox( int spacing, int border ){ + GtkVBox* vbox = GTK_VBOX( gtk_vbox_new( FALSE, spacing ) ); + gtk_widget_show( GTK_WIDGET( vbox ) ); + gtk_container_set_border_width( GTK_CONTAINER( vbox ), border ); + return vbox; } -GtkHBox* create_dialog_hbox(int spacing, int border) -{ - GtkHBox* hbox = GTK_HBOX(gtk_hbox_new(FALSE, spacing)); - gtk_widget_show(GTK_WIDGET(hbox)); - gtk_container_set_border_width(GTK_CONTAINER(hbox), border); - return hbox; +GtkHBox* create_dialog_hbox( int spacing, int border ){ + GtkHBox* hbox = GTK_HBOX( gtk_hbox_new( FALSE, spacing ) ); + gtk_widget_show( GTK_WIDGET( hbox ) ); + gtk_container_set_border_width( GTK_CONTAINER( hbox ), border ); + return hbox; } -GtkFrame* create_dialog_frame(const char* label, GtkShadowType shadow) -{ - GtkFrame* frame = GTK_FRAME(gtk_frame_new(label)); - gtk_widget_show(GTK_WIDGET(frame)); - gtk_frame_set_shadow_type(frame, shadow); - return frame; +GtkFrame* create_dialog_frame( const char* label, GtkShadowType shadow ){ + GtkFrame* frame = GTK_FRAME( gtk_frame_new( label ) ); + gtk_widget_show( GTK_WIDGET( frame ) ); + gtk_frame_set_shadow_type( frame, shadow ); + return frame; } -GtkTable* create_dialog_table(unsigned int rows, unsigned int columns, unsigned int row_spacing, unsigned int col_spacing, int border) -{ - GtkTable* table = GTK_TABLE(gtk_table_new(rows, columns, FALSE)); - gtk_widget_show(GTK_WIDGET(table)); - gtk_table_set_row_spacings(table, row_spacing); - gtk_table_set_col_spacings(table, col_spacing); - gtk_container_set_border_width(GTK_CONTAINER(table), border); - return table; +GtkTable* create_dialog_table( unsigned int rows, unsigned int columns, unsigned int row_spacing, unsigned int col_spacing, int border ){ + GtkTable* table = GTK_TABLE( gtk_table_new( rows, columns, FALSE ) ); + gtk_widget_show( GTK_WIDGET( table ) ); + gtk_table_set_row_spacings( table, row_spacing ); + gtk_table_set_col_spacings( table, col_spacing ); + gtk_container_set_border_width( GTK_CONTAINER( table ), border ); + return table; } -GtkButton* create_dialog_button(const char* label, GCallback func, gpointer data) -{ - GtkButton* button = GTK_BUTTON(gtk_button_new_with_label(label)); - gtk_widget_set_size_request(GTK_WIDGET(button), 64, -1); - gtk_widget_show(GTK_WIDGET(button)); - g_signal_connect(G_OBJECT(button), "clicked", func, data); - return button; +GtkButton* create_dialog_button( const char* label, GCallback func, gpointer data ){ + GtkButton* button = GTK_BUTTON( gtk_button_new_with_label( label ) ); + gtk_widget_set_size_request( GTK_WIDGET( button ), 64, -1 ); + gtk_widget_show( GTK_WIDGET( button ) ); + g_signal_connect( G_OBJECT( button ), "clicked", func, data ); + return button; } -GtkWindow* create_dialog_window(GtkWindow* parent, const char* title, GCallback func, gpointer data, int default_w, int default_h) -{ - GtkWindow* window = create_floating_window(title, parent); - gtk_window_set_default_size(window, default_w, default_h); - gtk_window_set_position(window, GTK_WIN_POS_CENTER_ON_PARENT); - g_signal_connect(G_OBJECT(window), "delete_event", func, data); +GtkWindow* create_dialog_window( GtkWindow* parent, const char* title, GCallback func, gpointer data, int default_w, int default_h ){ + GtkWindow* window = create_floating_window( title, parent ); + gtk_window_set_default_size( window, default_w, default_h ); + gtk_window_set_position( window, GTK_WIN_POS_CENTER_ON_PARENT ); + g_signal_connect( G_OBJECT( window ), "delete_event", func, data ); - return window; + return window; } -gboolean modal_dialog_button_clicked(GtkWidget *widget, ModalDialogButton* button) -{ - button->m_dialog.loop = false; - button->m_dialog.ret = button->m_value; - return TRUE; +gboolean modal_dialog_button_clicked( GtkWidget *widget, ModalDialogButton* button ){ + button->m_dialog.loop = false; + button->m_dialog.ret = button->m_value; + return TRUE; } -gboolean modal_dialog_delete(GtkWidget *widget, GdkEvent* event, ModalDialog* dialog) -{ - dialog->loop = 0; - dialog->ret = eIDCANCEL; - return TRUE; +gboolean modal_dialog_delete( GtkWidget *widget, GdkEvent* event, ModalDialog* dialog ){ + dialog->loop = 0; + dialog->ret = eIDCANCEL; + return TRUE; } -EMessageBoxReturn modal_dialog_show(GtkWindow* window, ModalDialog& dialog) -{ - gtk_grab_add(GTK_WIDGET(window)); - gtk_widget_show(GTK_WIDGET(window)); +EMessageBoxReturn modal_dialog_show( GtkWindow* window, ModalDialog& dialog ){ + gtk_grab_add( GTK_WIDGET( window ) ); + gtk_widget_show( GTK_WIDGET( window ) ); - dialog.loop = true; - while(dialog.loop) - { - gtk_main_iteration(); - } + dialog.loop = true; + while ( dialog.loop ) + { + gtk_main_iteration(); + } - gtk_widget_hide(GTK_WIDGET(window)); - gtk_grab_remove(GTK_WIDGET(window)); + gtk_widget_hide( GTK_WIDGET( window ) ); + gtk_grab_remove( GTK_WIDGET( window ) ); - return dialog.ret; + return dialog.ret; } -GtkButton* create_modal_dialog_button(const char* label, ModalDialogButton& button) -{ - return create_dialog_button(label, G_CALLBACK(modal_dialog_button_clicked), &button); +GtkButton* create_modal_dialog_button( const char* label, ModalDialogButton& button ){ + return create_dialog_button( label, G_CALLBACK( modal_dialog_button_clicked ), &button ); } -GtkWindow* create_modal_dialog_window(GtkWindow* parent, const char* title, ModalDialog& dialog, int default_w, int default_h) -{ - return create_dialog_window(parent, title, G_CALLBACK(modal_dialog_delete), &dialog, default_w, default_h); +GtkWindow* create_modal_dialog_window( GtkWindow* parent, const char* title, ModalDialog& dialog, int default_w, int default_h ){ + return create_dialog_window( parent, title, G_CALLBACK( modal_dialog_delete ), &dialog, default_w, default_h ); } -GtkWindow* create_fixedsize_modal_dialog_window(GtkWindow* parent, const char* title, ModalDialog& dialog, int width, int height) -{ - GtkWindow* window = create_modal_dialog_window(parent, title, dialog, width, height); +GtkWindow* create_fixedsize_modal_dialog_window( GtkWindow* parent, const char* title, ModalDialog& dialog, int width, int height ){ + GtkWindow* window = create_modal_dialog_window( parent, title, dialog, width, height ); - gtk_window_set_resizable(window, FALSE); - gtk_window_set_modal(window, TRUE); - gtk_window_set_position(window, GTK_WIN_POS_CENTER); + gtk_window_set_resizable( window, FALSE ); + gtk_window_set_modal( window, TRUE ); + gtk_window_set_position( window, GTK_WIN_POS_CENTER ); - window_remove_minmax(window); + window_remove_minmax( window ); - //gtk_widget_set_size_request(GTK_WIDGET(window), width, height); - //gtk_window_set_default_size(window, width, height); - //gtk_window_resize(window, width, height); - //GdkGeometry geometry = { width, height, -1, -1, width, height, -1, -1, -1, -1, GDK_GRAVITY_STATIC, }; - //gtk_window_set_geometry_hints(window, GTK_WIDGET(window), &geometry, (GdkWindowHints)(GDK_HINT_POS|GDK_HINT_MIN_SIZE|GDK_HINT_BASE_SIZE)); + //gtk_widget_set_size_request(GTK_WIDGET(window), width, height); + //gtk_window_set_default_size(window, width, height); + //gtk_window_resize(window, width, height); + //GdkGeometry geometry = { width, height, -1, -1, width, height, -1, -1, -1, -1, GDK_GRAVITY_STATIC, }; + //gtk_window_set_geometry_hints(window, GTK_WIDGET(window), &geometry, (GdkWindowHints)(GDK_HINT_POS|GDK_HINT_MIN_SIZE|GDK_HINT_BASE_SIZE)); - return window; + return window; } -gboolean dialog_button_ok(GtkWidget *widget, ModalDialog* data) -{ - data->loop = false; - data->ret = eIDOK; - return TRUE; +gboolean dialog_button_ok( GtkWidget *widget, ModalDialog* data ){ + data->loop = false; + data->ret = eIDOK; + return TRUE; } -gboolean dialog_button_cancel(GtkWidget *widget, ModalDialog* data) -{ - data->loop = false; - data->ret = eIDCANCEL; - return TRUE; +gboolean dialog_button_cancel( GtkWidget *widget, ModalDialog* data ){ + data->loop = false; + data->ret = eIDCANCEL; + return TRUE; } -gboolean dialog_button_yes(GtkWidget *widget, ModalDialog* data) -{ - data->loop = false; - data->ret = eIDYES; - return TRUE; +gboolean dialog_button_yes( GtkWidget *widget, ModalDialog* data ){ + data->loop = false; + data->ret = eIDYES; + return TRUE; } -gboolean dialog_button_no(GtkWidget *widget, ModalDialog* data) -{ - data->loop = false; - data->ret = eIDNO; - return TRUE; +gboolean dialog_button_no( GtkWidget *widget, ModalDialog* data ){ + data->loop = false; + data->ret = eIDNO; + return TRUE; } -gboolean dialog_delete_callback(GtkWidget *widget, GdkEventAny* event, ModalDialog* data) -{ - gtk_widget_hide(widget); - data->loop = false; - return TRUE; +gboolean dialog_delete_callback( GtkWidget *widget, GdkEventAny* event, ModalDialog* data ){ + gtk_widget_hide( widget ); + data->loop = false; + return TRUE; } -GtkWindow* create_simple_modal_dialog_window(const char* title, ModalDialog& dialog, GtkWidget* contents) -{ - GtkWindow* window = create_fixedsize_modal_dialog_window(0, title, dialog); +GtkWindow* create_simple_modal_dialog_window( const char* title, ModalDialog& dialog, GtkWidget* contents ){ + GtkWindow* window = create_fixedsize_modal_dialog_window( 0, title, dialog ); - GtkVBox* vbox1 = create_dialog_vbox(8, 4); - gtk_container_add(GTK_CONTAINER(window), GTK_WIDGET(vbox1)); + GtkVBox* vbox1 = create_dialog_vbox( 8, 4 ); + gtk_container_add( GTK_CONTAINER( window ), GTK_WIDGET( vbox1 ) ); - gtk_container_add(GTK_CONTAINER(vbox1), contents); + gtk_container_add( GTK_CONTAINER( vbox1 ), contents ); - GtkAlignment* alignment = GTK_ALIGNMENT(gtk_alignment_new(0.5, 0.0, 0.0, 0.0)); - gtk_widget_show(GTK_WIDGET(alignment)); - gtk_box_pack_start(GTK_BOX(vbox1), GTK_WIDGET(alignment), FALSE, FALSE, 0); + GtkAlignment* alignment = GTK_ALIGNMENT( gtk_alignment_new( 0.5, 0.0, 0.0, 0.0 ) ); + gtk_widget_show( GTK_WIDGET( alignment ) ); + gtk_box_pack_start( GTK_BOX( vbox1 ), GTK_WIDGET( alignment ), FALSE, FALSE, 0 ); - GtkButton* button = create_dialog_button("OK", G_CALLBACK(dialog_button_ok), &dialog); - gtk_container_add(GTK_CONTAINER(alignment), GTK_WIDGET(button)); + GtkButton* button = create_dialog_button( "OK", G_CALLBACK( dialog_button_ok ), &dialog ); + gtk_container_add( GTK_CONTAINER( alignment ), GTK_WIDGET( button ) ); - return window; + return window; } -RadioHBox RadioHBox_new(StringArrayRange names) -{ - GtkHBox* hbox = GTK_HBOX(gtk_hbox_new(TRUE, 4)); - gtk_widget_show(GTK_WIDGET(hbox)); +RadioHBox RadioHBox_new( StringArrayRange names ){ + GtkHBox* hbox = GTK_HBOX( gtk_hbox_new( TRUE, 4 ) ); + gtk_widget_show( GTK_WIDGET( hbox ) ); - GSList* group = 0; - GtkRadioButton* radio = 0; - for(StringArrayRange::Iterator i = names.first; i != names.last; ++i) - { - radio = GTK_RADIO_BUTTON(gtk_radio_button_new_with_label(group, *i)); - gtk_widget_show(GTK_WIDGET(radio)); - gtk_box_pack_start(GTK_BOX(hbox), GTK_WIDGET(radio), FALSE, FALSE, 0); + GSList* group = 0; + GtkRadioButton* radio = 0; + for ( StringArrayRange::Iterator i = names.first; i != names.last; ++i ) + { + radio = GTK_RADIO_BUTTON( gtk_radio_button_new_with_label( group, *i ) ); + gtk_widget_show( GTK_WIDGET( radio ) ); + gtk_box_pack_start( GTK_BOX( hbox ), GTK_WIDGET( radio ), FALSE, FALSE, 0 ); - group = gtk_radio_button_get_group(radio); - } + group = gtk_radio_button_get_group( radio ); + } - return RadioHBox(hbox, radio); + return RadioHBox( hbox, radio ); } -PathEntry PathEntry_new() -{ - GtkFrame* frame = GTK_FRAME(gtk_frame_new(NULL)); - gtk_widget_show(GTK_WIDGET(frame)); - gtk_frame_set_shadow_type(frame, GTK_SHADOW_IN); +PathEntry PathEntry_new(){ + GtkFrame* frame = GTK_FRAME( gtk_frame_new( NULL ) ); + gtk_widget_show( GTK_WIDGET( frame ) ); + gtk_frame_set_shadow_type( frame, GTK_SHADOW_IN ); - // path entry - GtkHBox* hbox = GTK_HBOX(gtk_hbox_new(FALSE, 0)); - gtk_widget_show(GTK_WIDGET(hbox)); + // path entry + GtkHBox* hbox = GTK_HBOX( gtk_hbox_new( FALSE, 0 ) ); + gtk_widget_show( GTK_WIDGET( hbox ) ); - GtkEntry* entry = GTK_ENTRY(gtk_entry_new()); - gtk_entry_set_has_frame(entry, FALSE); - gtk_widget_show(GTK_WIDGET(entry)); - gtk_box_pack_start(GTK_BOX(hbox), GTK_WIDGET(entry), TRUE, TRUE, 0); + GtkEntry* entry = GTK_ENTRY( gtk_entry_new() ); + gtk_entry_set_has_frame( entry, FALSE ); + gtk_widget_show( GTK_WIDGET( entry ) ); + gtk_box_pack_start( GTK_BOX( hbox ), GTK_WIDGET( entry ), TRUE, TRUE, 0 ); - // browse button - GtkButton* button = GTK_BUTTON(gtk_button_new()); - button_set_icon(button, "ellipsis.bmp"); - gtk_widget_show(GTK_WIDGET(button)); - gtk_box_pack_end(GTK_BOX(hbox), GTK_WIDGET(button), FALSE, FALSE, 0); + // browse button + GtkButton* button = GTK_BUTTON( gtk_button_new() ); + button_set_icon( button, "ellipsis.bmp" ); + gtk_widget_show( GTK_WIDGET( button ) ); + gtk_box_pack_end( GTK_BOX( hbox ), GTK_WIDGET( button ), FALSE, FALSE, 0 ); - gtk_container_add(GTK_CONTAINER(frame), GTK_WIDGET(hbox)); + gtk_container_add( GTK_CONTAINER( frame ), GTK_WIDGET( hbox ) ); - return PathEntry(frame, entry, button); + return PathEntry( frame, entry, button ); } -void PathEntry_setPath(PathEntry& self, const char* path) -{ - gtk_entry_set_text(self.m_entry, path); +void PathEntry_setPath( PathEntry& self, const char* path ){ + gtk_entry_set_text( self.m_entry, path ); } typedef ReferenceCaller1 PathEntrySetPathCaller; -void BrowsedPathEntry_clicked(GtkWidget* widget, BrowsedPathEntry* self) -{ - self->m_browse(PathEntrySetPathCaller(self->m_entry)); +void BrowsedPathEntry_clicked( GtkWidget* widget, BrowsedPathEntry* self ){ + self->m_browse( PathEntrySetPathCaller( self->m_entry ) ); } -BrowsedPathEntry::BrowsedPathEntry(const BrowseCallback& browse) : - m_entry(PathEntry_new()), - m_browse(browse) -{ - g_signal_connect(G_OBJECT(m_entry.m_button), "clicked", G_CALLBACK(BrowsedPathEntry_clicked), this); +BrowsedPathEntry::BrowsedPathEntry( const BrowseCallback& browse ) : + m_entry( PathEntry_new() ), + m_browse( browse ){ + g_signal_connect( G_OBJECT( m_entry.m_button ), "clicked", G_CALLBACK( BrowsedPathEntry_clicked ), this ); } -GtkLabel* DialogLabel_new(const char* name) -{ - GtkLabel* label = GTK_LABEL(gtk_label_new(name)); - gtk_widget_show(GTK_WIDGET(label)); - gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5); - gtk_label_set_justify(label, GTK_JUSTIFY_LEFT); +GtkLabel* DialogLabel_new( const char* name ){ + GtkLabel* label = GTK_LABEL( gtk_label_new( name ) ); + gtk_widget_show( GTK_WIDGET( label ) ); + gtk_misc_set_alignment( GTK_MISC( label ), 1, 0.5 ); + gtk_label_set_justify( label, GTK_JUSTIFY_LEFT ); - return label; + return label; } -GtkTable* DialogRow_new(const char* name, GtkWidget* widget) -{ - GtkTable* table = GTK_TABLE(gtk_table_new(1, 3, TRUE)); - gtk_widget_show(GTK_WIDGET(table)); +GtkTable* DialogRow_new( const char* name, GtkWidget* widget ){ + GtkTable* table = GTK_TABLE( gtk_table_new( 1, 3, TRUE ) ); + gtk_widget_show( GTK_WIDGET( table ) ); - gtk_table_set_col_spacings(table, 4); - gtk_table_set_row_spacings(table, 0); + gtk_table_set_col_spacings( table, 4 ); + gtk_table_set_row_spacings( table, 0 ); - gtk_table_attach(table, GTK_WIDGET(DialogLabel_new(name)), 0, 1, 0, 1, - (GtkAttachOptions) (GTK_EXPAND|GTK_FILL), - (GtkAttachOptions) (0), 0, 0); + gtk_table_attach( table, GTK_WIDGET( DialogLabel_new( name ) ), 0, 1, 0, 1, + (GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ), + (GtkAttachOptions) ( 0 ), 0, 0 ); - gtk_table_attach(table, widget, 1, 3, 0, 1, - (GtkAttachOptions) (GTK_EXPAND|GTK_FILL), - (GtkAttachOptions) (0), 0, 0); + gtk_table_attach( table, widget, 1, 3, 0, 1, + (GtkAttachOptions) ( GTK_EXPAND | GTK_FILL ), + (GtkAttachOptions) ( 0 ), 0, 0 ); - return table; + return table; } -void DialogVBox_packRow(GtkVBox* vbox, GtkWidget* row) -{ - gtk_box_pack_start(GTK_BOX(vbox), row, FALSE, FALSE, 0); +void DialogVBox_packRow( GtkVBox* vbox, GtkWidget* row ){ + gtk_box_pack_start( GTK_BOX( vbox ), row, FALSE, FALSE, 0 ); } -