X-Git-Url: http://git.xonotic.org/?a=blobdiff_plain;f=radiant%2Fdialog.h;h=dac38d9b84be984f7e6f5fe7539c9defb5718546;hb=d8d29a543f2928c2aef158b1c90b92d031826a8b;hp=2a0454ebad33afe1d3208a7edeff3d5411383d39;hpb=e4287c28bb2dafedc81c66e63951d947cfbeb225;p=xonotic%2Fnetradiant.git diff --git a/radiant/dialog.h b/radiant/dialog.h index 2a0454eb..dac38d9b 100644 --- a/radiant/dialog.h +++ b/radiant/dialog.h @@ -23,171 +23,167 @@ #define INCLUDED_DIALOG_H #include +#include +#include "property.h" +#include "generic/callback.h" #include "gtkutil/dialog.h" #include "generic/callback.h" #include "string/string.h" -template -class ReferenceCaller1; +struct DLG_DATA +{ + virtual ~DLG_DATA() = default; + virtual void release() = 0; + virtual void importData() const = 0; + virtual void exportData() const = 0; +}; -inline void BoolImport( bool& self, bool value ){ - self = value; -} -typedef ReferenceCaller1 BoolImportCaller; -inline void BoolExport( bool& self, const BoolImportCallback& importCallback ){ - importCallback( self ); -} -typedef ReferenceCaller1 BoolExportCaller; +template +class CallbackDialogData; +typedef std::list DialogDataList; -inline void IntImport( int& self, int value ){ - self = value; -} -typedef ReferenceCaller1 IntImportCaller; +class Dialog { + ui::Window m_window; + DialogDataList m_data; +public: + ModalDialog m_modal; + ui::Window m_parent; -inline void IntExport( int& self, const IntImportCallback& importCallback ){ - importCallback( self ); -} -typedef ReferenceCaller1 IntExportCaller; + Dialog(); + virtual ~Dialog(); -inline void SizeImport( std::size_t& self, std::size_t value ){ - self = value; -} -typedef ReferenceCaller1 SizeImportCaller; +/*! + start modal dialog box + you need to use AddModalButton to select eIDOK eIDCANCEL buttons + */ + EMessageBoxReturn DoModal(); -inline void SizeExport( std::size_t& self, const SizeImportCallback& importCallback ){ - importCallback( self ); -} -typedef ReferenceCaller1 SizeExportCaller; + void EndModal(EMessageBoxReturn code); + virtual ui::Window BuildDialog() = 0; -inline void FloatImport( float& self, float value ){ - self = value; -} -typedef ReferenceCaller1 FloatImportCaller; + virtual void exportData(); -inline void FloatExport( float& self, const FloatImportCallback& importCallback ){ - importCallback( self ); -} -typedef ReferenceCaller1 FloatExportCaller; + virtual void importData(); + virtual void PreModal() {}; -inline void StringImport( CopiedString& self, const char* value ){ - self = value; -} -typedef ReferenceCaller1 StringImportCaller; -inline void StringExport( CopiedString& self, const StringImportCallback& importCallback ){ - importCallback( self.c_str() ); -} -typedef ReferenceCaller1 StringExportCaller; + virtual void PostModal(EMessageBoxReturn code) {}; + virtual void ShowDlg(); -struct DLG_DATA -{ - virtual void release() = 0; - virtual void importData() const = 0; - virtual void exportData() const = 0; -}; + virtual void HideDlg(); -typedef struct _GtkWindow GtkWindow; -typedef struct _GtkToggleButton GtkToggleButton; -typedef struct _GtkRadioButton GtkRadioButton; -typedef struct _GtkSpinButton GtkSpinButton; -typedef struct _GtkComboBox GtkComboBox; -typedef struct _GtkEntry GtkEntry; -typedef struct _GtkAdjustment GtkAdjustment; + void Create(); -template -class CallbackDialogData; + void Destroy(); -typedef std::list DialogDataList; + ui::Window GetWidget() { + return m_window; + } -class Dialog -{ -GtkWindow* m_window; -DialogDataList m_data; -public: -ModalDialog m_modal; -GtkWindow* m_parent; + const ui::Window GetWidget() const { + return m_window; + } -Dialog(); -virtual ~Dialog(); + ui::VBox addSpacer(ui::VBox vbox, int size); -/*! - start modal dialog box - you need to use AddModalButton to select eIDOK eIDCANCEL buttons - */ -EMessageBoxReturn DoModal(); -void EndModal( EMessageBoxReturn code ); -virtual GtkWindow* BuildDialog() = 0; -virtual void exportData(); -virtual void importData(); -virtual void PreModal() { }; -virtual void PostModal( EMessageBoxReturn code ) { }; -virtual void ShowDlg(); -virtual void HideDlg(); -void Create(); -void Destroy(); -GtkWindow* GetWidget(){ - return m_window; -} -const GtkWindow* GetWidget() const { - return m_window; -} - -GtkWidget* addCheckBox( GtkWidget* vbox, const char* name, const char* flag, const BoolImportCallback& importCallback, const BoolExportCallback& exportCallback ); -GtkWidget* addCheckBox( GtkWidget* vbox, const char* name, const char* flag, bool& data ); -void addCombo( GtkWidget* vbox, const char* name, StringArrayRange values, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void addCombo( GtkWidget* vbox, const char* name, int& data, StringArrayRange values ); -void addSlider( GtkWidget* vbox, const char* name, int& data, gboolean draw_value, const char* low, const char* high, double value, double lower, double upper, double step_increment, double page_increment ); -void addRadio( GtkWidget* vbox, const char* name, StringArrayRange names, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void addRadio( GtkWidget* vbox, const char* name, int& data, StringArrayRange names ); -void addRadioIcons( GtkWidget* vbox, const char* name, StringArrayRange icons, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void addRadioIcons( GtkWidget* vbox, const char* name, int& data, StringArrayRange icons ); -GtkWidget* addIntEntry( GtkWidget* vbox, const char* name, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -GtkWidget* addEntry( GtkWidget* vbox, const char* name, int& data ){ - return addIntEntry( vbox, name, IntImportCaller( data ), IntExportCaller( data ) ); -} -GtkWidget* addSizeEntry( GtkWidget* vbox, const char* name, const SizeImportCallback& importCallback, const SizeExportCallback& exportCallback ); -GtkWidget* addEntry( GtkWidget* vbox, const char* name, std::size_t& data ){ - return addSizeEntry( vbox, name, SizeImportCaller( data ), SizeExportCaller( data ) ); -} -GtkWidget* addFloatEntry( GtkWidget* vbox, const char* name, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); -GtkWidget* addEntry( GtkWidget* vbox, const char* name, float& data ){ - return addFloatEntry( vbox, name, FloatImportCaller( data ), FloatExportCaller( data ) ); -} -GtkWidget* addPathEntry( GtkWidget* vbox, const char* name, bool browse_directory, const StringImportCallback& importCallback, const StringExportCallback& exportCallback ); -GtkWidget* addPathEntry( GtkWidget* vbox, const char* name, CopiedString& data, bool directory ); -GtkWidget* addSpinner( GtkWidget* vbox, const char* name, int& data, double value, double lower, double upper ); -GtkWidget* addSpinner( GtkWidget* vbox, const char* name, double value, double lower, double upper, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -GtkWidget* addSpinner( GtkWidget* vbox, const char* name, double value, double lower, double upper, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); + ui::Label addLabel(ui::VBox vbox, const char *name, const char *text); + + ui::CheckButton addCheckBox(ui::VBox vbox, const char *name, const char *flag, Property const &cb); + + ui::CheckButton addCheckBox(ui::VBox vbox, const char *name, const char *flag, bool &data); + + void addCombo(ui::VBox vbox, const char *name, StringArrayRange values, Property const &cb); + + void addCombo(ui::VBox vbox, const char *name, int &data, StringArrayRange values); + + void addSlider(ui::VBox vbox, const char *name, int &data, gboolean draw_value, const char *low, const char *high, + double value, double lower, double upper, double step_increment, double page_increment); + + void addRadio(ui::VBox vbox, const char *name, StringArrayRange names, Property const &cb); + + void addRadio(ui::VBox vbox, const char *name, int &data, StringArrayRange names); + + void addRadioIcons(ui::VBox vbox, const char *name, StringArrayRange icons, Property const &cb); + + void addRadioIcons(ui::VBox vbox, const char *name, int &data, StringArrayRange icons); + + ui::Widget addIntEntry(ui::VBox vbox, const char *name, Property const &cb); + + ui::Widget addEntry(ui::VBox vbox, const char *name, int &data) { + return addIntEntry(vbox, name, make_property(data)); + } + + ui::Widget addSizeEntry(ui::VBox vbox, const char *name, Property const &cb); + + ui::Widget addEntry(ui::VBox vbox, const char *name, std::size_t &data) { + return addSizeEntry(vbox, name, make_property(data)); + } + + ui::Widget addFloatEntry(ui::VBox vbox, const char *name, Property const &cb); + + ui::Widget addEntry(ui::VBox vbox, const char *name, float &data) { + return addFloatEntry(vbox, name, make_property(data)); + } + + ui::Widget addPathEntry(ui::VBox vbox, const char *name, bool browse_directory, Property const &cb); + + ui::Widget addPathEntry(ui::VBox vbox, const char *name, CopiedString &data, bool directory); + + ui::SpinButton addSpinner(ui::VBox vbox, const char *name, int &data, double value, double lower, double upper); + + ui::SpinButton + addSpinner(ui::VBox vbox, const char *name, double value, double lower, double upper, Property const &cb); + + ui::SpinButton + addSpinner(ui::VBox vbox, const char *name, double value, double lower, double upper, Property const &cb); protected: -void AddBoolToggleData( GtkToggleButton& object, const BoolImportCallback& importCallback, const BoolExportCallback& exportCallback ); -void AddIntRadioData( GtkRadioButton& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddTextEntryData( GtkEntry& object, const StringImportCallback& importCallback, const StringExportCallback& exportCallback ); -void AddIntEntryData( GtkEntry& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddSizeEntryData( GtkEntry& object, const SizeImportCallback& importCallback, const SizeExportCallback& exportCallback ); -void AddFloatEntryData( GtkEntry& object, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); -void AddFloatSpinnerData( GtkSpinButton& object, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); -void AddIntSpinnerData( GtkSpinButton& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddIntAdjustmentData( GtkAdjustment& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddIntComboData( GtkComboBox& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); - -void AddDialogData( GtkToggleButton& object, bool& data ); -void AddDialogData( GtkRadioButton& object, int& data ); -void AddDialogData( GtkEntry& object, CopiedString& data ); -void AddDialogData( GtkEntry& object, int& data ); -void AddDialogData( GtkEntry& object, std::size_t& data ); -void AddDialogData( GtkEntry& object, float& data ); -void AddDialogData( GtkSpinButton& object, float& data ); -void AddDialogData( GtkSpinButton& object, int& data ); -void AddDialogData( GtkAdjustment& object, int& data ); -void AddDialogData( GtkComboBox& object, int& data ); + void AddBoolToggleData(ui::ToggleButton object, Property const &cb); + + void AddIntRadioData(ui::RadioButton object, Property const &cb); + + void AddTextEntryData(ui::Entry object, Property const &cb); + + void AddIntEntryData(ui::Entry object, Property const &cb); + + void AddSizeEntryData(ui::Entry object, Property const &cb); + + void AddFloatEntryData(ui::Entry object, Property const &cb); + + void AddFloatSpinnerData(ui::SpinButton object, Property const &cb); + + void AddIntSpinnerData(ui::SpinButton object, Property const &cb); + + void AddIntAdjustmentData(ui::Adjustment object, Property const &cb); + + void AddIntComboData(ui::ComboBox object, Property const &cb); + + void AddDialogData(ui::ToggleButton object, bool &data); + + void AddDialogData(ui::RadioButton object, int &data); + + void AddDialogData(ui::Entry object, CopiedString &data); + + void AddDialogData(ui::Entry object, int &data); + + void AddDialogData(ui::Entry object, std::size_t &data); + + void AddDialogData(ui::Entry object, float &data); + + void AddDialogData(ui::SpinButton object, float &data); + + void AddDialogData(ui::SpinButton object, int &data); + + void AddDialogData(ui::Adjustment object, int &data); + + void AddDialogData(ui::ComboBox object, int &data); }; #endif