X-Git-Url: http://git.xonotic.org/?a=blobdiff_plain;f=libs%2Fgtkutil%2Fdialog.cpp;h=9024e2871012c293135588fd65972b0b094377ab;hb=9dfae1c9b270ee369c6362903a9205b30751b95f;hp=fddf060e670712667dd6077967797604454059e7;hpb=0203ac024e9396ebc180d9721da40b90b7c33dc6;p=xonotic%2Fnetradiant.git diff --git a/libs/gtkutil/dialog.cpp b/libs/gtkutil/dialog.cpp index fddf060e..9024e287 100644 --- a/libs/gtkutil/dialog.cpp +++ b/libs/gtkutil/dialog.cpp @@ -26,238 +26,268 @@ #include "button.h" #include "window.h" -ui::VBox create_dialog_vbox( int spacing, int border ){ - auto vbox = ui::VBox( FALSE, spacing ); - vbox.show(); - gtk_container_set_border_width( GTK_CONTAINER( vbox ), border ); - return vbox; +ui::VBox create_dialog_vbox(int spacing, int border) +{ + auto vbox = ui::VBox(FALSE, spacing); + vbox.show(); + gtk_container_set_border_width(GTK_CONTAINER(vbox), border); + return vbox; } -ui::HBox create_dialog_hbox( int spacing, int border ){ - auto hbox = ui::HBox( FALSE, spacing ); - hbox.show(); - gtk_container_set_border_width( GTK_CONTAINER( hbox ), border ); - return hbox; +ui::HBox create_dialog_hbox(int spacing, int border) +{ + auto hbox = ui::HBox(FALSE, spacing); + hbox.show(); + gtk_container_set_border_width(GTK_CONTAINER(hbox), border); + return hbox; } -ui::Frame create_dialog_frame( const char* label, ui::Shadow shadow ){ - auto frame = ui::Frame( label ); - frame.show(); - gtk_frame_set_shadow_type( frame, (GtkShadowType) shadow ); - return frame; +ui::Frame create_dialog_frame(const char *label, ui::Shadow shadow) +{ + auto frame = ui::Frame(label); + frame.show(); + gtk_frame_set_shadow_type(frame, (GtkShadowType) shadow); + return frame; } -ui::Table create_dialog_table( unsigned int rows, unsigned int columns, unsigned int row_spacing, unsigned int col_spacing, int border ){ - auto table = ui::Table( rows, columns, FALSE ); - table.show(); - 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; +ui::Table +create_dialog_table(unsigned int rows, unsigned int columns, unsigned int row_spacing, unsigned int col_spacing, + int border) +{ + auto table = ui::Table(rows, columns, FALSE); + table.show(); + 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; } -ui::Button create_dialog_button( const char* label, GCallback func, gpointer data ){ - auto button = ui::Button( label ); - button.dimensions(64, -1); - button.show(); - button.connect( "clicked", func, data ); - return button; +ui::Button create_dialog_button(const char *label, GCallback func, gpointer data) +{ + auto button = ui::Button(label); + button.dimensions(64, -1); + button.show(); + button.connect("clicked", func, data); + return button; } -ui::Window create_dialog_window( ui::Window parent, const char* title, GCallback func, gpointer data, int default_w, int default_h ){ - ui::Window 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 ); - window.connect( "delete_event", func, data ); +ui::Window +create_dialog_window(ui::Window parent, const char *title, GCallback func, gpointer data, int default_w, int default_h) +{ + ui::Window 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); + window.connect("delete_event", func, data); - return window; + return window; } -gboolean modal_dialog_button_clicked( ui::Widget widget, ModalDialogButton* button ){ - button->m_dialog.loop = false; - button->m_dialog.ret = button->m_value; - return TRUE; +gboolean modal_dialog_button_clicked(ui::Widget widget, ModalDialogButton *button) +{ + button->m_dialog.loop = false; + button->m_dialog.ret = button->m_value; + return TRUE; } -gboolean modal_dialog_delete( ui::Widget widget, GdkEvent* event, ModalDialog* dialog ){ - dialog->loop = 0; - dialog->ret = eIDCANCEL; - return TRUE; +gboolean modal_dialog_delete(ui::Widget widget, GdkEvent *event, ModalDialog *dialog) +{ + dialog->loop = 0; + dialog->ret = eIDCANCEL; + return TRUE; } -EMessageBoxReturn modal_dialog_show( ui::Window window, ModalDialog& dialog ){ - gtk_grab_add( window ); - window.show(); +EMessageBoxReturn modal_dialog_show(ui::Window window, ModalDialog &dialog) +{ + gtk_grab_add(window); + window.show(); - dialog.loop = true; - while ( dialog.loop ) - { - gtk_main_iteration(); - } + dialog.loop = true; + while (dialog.loop) { + gtk_main_iteration(); + } - window.hide(); - gtk_grab_remove( window ); + window.hide(); + gtk_grab_remove(window); - return dialog.ret; + return dialog.ret; } -ui::Button create_modal_dialog_button( const char* label, ModalDialogButton& button ){ - return create_dialog_button( label, G_CALLBACK( modal_dialog_button_clicked ), &button ); +ui::Button create_modal_dialog_button(const char *label, ModalDialogButton &button) +{ + return create_dialog_button(label, G_CALLBACK(modal_dialog_button_clicked), &button); } -ui::Window create_modal_dialog_window( ui::Window 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 ); +ui::Window +create_modal_dialog_window(ui::Window 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); } -ui::Window create_fixedsize_modal_dialog_window( ui::Window parent, const char* title, ModalDialog& dialog, int width, int height ){ - auto window = create_modal_dialog_window( parent, title, dialog, width, height ); +ui::Window +create_fixedsize_modal_dialog_window(ui::Window parent, const char *title, ModalDialog &dialog, int width, int height) +{ + auto 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); - //window.dimensions(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, window, &geometry, (GdkWindowHints)(GDK_HINT_POS|GDK_HINT_MIN_SIZE|GDK_HINT_BASE_SIZE)); + //window.dimensions(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, window, &geometry, (GdkWindowHints)(GDK_HINT_POS|GDK_HINT_MIN_SIZE|GDK_HINT_BASE_SIZE)); - return window; + return window; } -gboolean dialog_button_ok( ui::Widget widget, ModalDialog* data ){ - data->loop = false; - data->ret = eIDOK; - return TRUE; +gboolean dialog_button_ok(ui::Widget widget, ModalDialog *data) +{ + data->loop = false; + data->ret = eIDOK; + return TRUE; } -gboolean dialog_button_cancel( ui::Widget widget, ModalDialog* data ){ - data->loop = false; - data->ret = eIDCANCEL; - return TRUE; +gboolean dialog_button_cancel(ui::Widget widget, ModalDialog *data) +{ + data->loop = false; + data->ret = eIDCANCEL; + return TRUE; } -gboolean dialog_button_yes( ui::Widget widget, ModalDialog* data ){ - data->loop = false; - data->ret = eIDYES; - return TRUE; +gboolean dialog_button_yes(ui::Widget widget, ModalDialog *data) +{ + data->loop = false; + data->ret = eIDYES; + return TRUE; } -gboolean dialog_button_no( ui::Widget widget, ModalDialog* data ){ - data->loop = false; - data->ret = eIDNO; - return TRUE; +gboolean dialog_button_no(ui::Widget widget, ModalDialog *data) +{ + data->loop = false; + data->ret = eIDNO; + return TRUE; } -gboolean dialog_delete_callback( ui::Widget widget, GdkEventAny* event, ModalDialog* data ){ - widget.hide(); - data->loop = false; - return TRUE; +gboolean dialog_delete_callback(ui::Widget widget, GdkEventAny *event, ModalDialog *data) +{ + widget.hide(); + data->loop = false; + return TRUE; } -ui::Window create_simple_modal_dialog_window( const char* title, ModalDialog& dialog, ui::Widget contents ){ - ui::Window window = create_fixedsize_modal_dialog_window(ui::Window{ui::null}, title, dialog ); +ui::Window create_simple_modal_dialog_window(const char *title, ModalDialog &dialog, ui::Widget contents) +{ + ui::Window window = create_fixedsize_modal_dialog_window(ui::Window{ui::null}, title, dialog); - auto vbox1 = create_dialog_vbox( 8, 4 ); - window.add(vbox1); + auto vbox1 = create_dialog_vbox(8, 4); + window.add(vbox1); - vbox1.add(contents); + vbox1.add(contents); - ui::Alignment alignment = ui::Alignment( 0.5, 0.0, 0.0, 0.0 ); - alignment.show(); - vbox1.pack_start( alignment, FALSE, FALSE, 0 ); + ui::Alignment alignment = ui::Alignment(0.5, 0.0, 0.0, 0.0); + alignment.show(); + vbox1.pack_start(alignment, FALSE, FALSE, 0); - auto button = create_dialog_button( "OK", G_CALLBACK( dialog_button_ok ), &dialog ); - alignment.add(button); + auto button = create_dialog_button("OK", G_CALLBACK(dialog_button_ok), &dialog); + alignment.add(button); - return window; + return window; } -RadioHBox RadioHBox_new( StringArrayRange names ){ - auto hbox = ui::HBox( TRUE, 4 ); - hbox.show(); +RadioHBox RadioHBox_new(StringArrayRange names) +{ + auto hbox = ui::HBox(TRUE, 4); + hbox.show(); - GSList* group = 0; - auto radio = ui::RadioButton(ui::null); - for ( StringArrayRange::Iterator i = names.first; i != names.last; ++i ) - { - radio = ui::RadioButton::from( gtk_radio_button_new_with_label( group, *i ) ); - radio.show(); - hbox.pack_start( radio, FALSE, FALSE, 0 ); + GSList *group = 0; + auto radio = ui::RadioButton(ui::null); + for (StringArrayRange::Iterator i = names.first; i != names.last; ++i) { + radio = ui::RadioButton::from(gtk_radio_button_new_with_label(group, *i)); + radio.show(); + hbox.pack_start(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(){ - auto frame = ui::Frame(); - frame.show(); - gtk_frame_set_shadow_type( frame, GTK_SHADOW_IN ); +PathEntry PathEntry_new() +{ + auto frame = ui::Frame(); + frame.show(); + gtk_frame_set_shadow_type(frame, GTK_SHADOW_IN); - // path entry - auto hbox = ui::HBox( FALSE, 0 ); - hbox.show(); + // path entry + auto hbox = ui::HBox(FALSE, 0); + hbox.show(); - auto entry = ui::Entry(ui::New); - gtk_entry_set_has_frame( entry, FALSE ); - entry.show(); - hbox.pack_start( entry, TRUE, TRUE, 0 ); + auto entry = ui::Entry(ui::New); + gtk_entry_set_has_frame(entry, FALSE); + entry.show(); + hbox.pack_start(entry, TRUE, TRUE, 0); - // browse button - auto button = ui::Button(ui::New); - button_set_icon( button, "ellipsis.bmp" ); - button.show(); - hbox.pack_end(button, FALSE, FALSE, 0); + // browse button + auto button = ui::Button(ui::New); + button_set_icon(button, "ellipsis.bmp"); + button.show(); + hbox.pack_end(button, FALSE, FALSE, 0); - frame.add(hbox); + frame.add(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 ReferenceCaller PathEntrySetPathCaller; -void BrowsedPathEntry_clicked( ui::Widget widget, BrowsedPathEntry* self ){ - self->m_browse( PathEntrySetPathCaller( self->m_entry ) ); +typedef ReferenceCaller PathEntrySetPathCaller; + +void BrowsedPathEntry_clicked(ui::Widget widget, BrowsedPathEntry *self) +{ + self->m_browse(PathEntrySetPathCaller(self->m_entry)); } -BrowsedPathEntry::BrowsedPathEntry( const BrowseCallback& browse ) : - m_entry( PathEntry_new() ), - m_browse( browse ){ - m_entry.m_button.connect( "clicked", G_CALLBACK( BrowsedPathEntry_clicked ), this ); +BrowsedPathEntry::BrowsedPathEntry(const BrowseCallback &browse) : + m_entry(PathEntry_new()), + m_browse(browse) +{ + m_entry.m_button.connect("clicked", G_CALLBACK(BrowsedPathEntry_clicked), this); } -ui::Label DialogLabel_new( const char* name ){ - auto label = ui::Label( name ); - label.show(); - gtk_misc_set_alignment( GTK_MISC( label ), 1, 0.5 ); - gtk_label_set_justify( label, GTK_JUSTIFY_LEFT ); +ui::Label DialogLabel_new(const char *name) +{ + auto label = ui::Label(name); + label.show(); + gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5); + gtk_label_set_justify(label, GTK_JUSTIFY_LEFT); - return label; + return label; } -ui::Table DialogRow_new( const char* name, ui::Widget widget ){ - auto table = ui::Table( 1, 3, TRUE ); - table.show(); +ui::Table DialogRow_new(const char *name, ui::Widget widget) +{ + auto table = ui::Table(1, 3, TRUE); + table.show(); - 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); table.attach(DialogLabel_new(name), {0, 1, 0, 1}, {GTK_EXPAND | GTK_FILL, 0}); table.attach(widget, {1, 3, 0, 1}, {GTK_EXPAND | GTK_FILL, 0}); - return table; + return table; } -void DialogVBox_packRow( ui::Box vbox, ui::Widget row ){ - vbox.pack_start( row, FALSE, FALSE, 0 ); +void DialogVBox_packRow(ui::Box vbox, ui::Widget row) +{ + vbox.pack_start(row, FALSE, FALSE, 0); }