X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=radiant%2Fdialog.h;h=78efa830ee541861c87063bba78054b84fa0d2ab;hb=5c0f69d022c1de9859f64663d2a3c0c3b59c1a36;hp=f4ce16673e7f7f8ffbe4fac55acfa87567587e54;hpb=c001d05fb1dc902a725dbf50df82e88a1a526a21;p=xonotic%2Fnetradiant.git diff --git a/radiant/dialog.h b/radiant/dialog.h index f4ce1667..78efa830 100644 --- a/radiant/dialog.h +++ b/radiant/dialog.h @@ -24,164 +24,162 @@ #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(); + void Create(); -template -class CallbackDialogData; + void Destroy(); -typedef std::list DialogDataList; + ui::Window GetWidget() { + return m_window; + } -class Dialog -{ -ui::Window m_window; -DialogDataList m_data; -public: -ModalDialog m_modal; -ui::Window m_parent; + const ui::Window GetWidget() const { + return m_window; + } -Dialog(); -virtual ~Dialog(); + ui::CheckButton addCheckBox(ui::VBox vbox, const char *name, const char *flag, Property const &cb); -/*! - start modal dialog box - you need to use AddModalButton to select eIDOK eIDCANCEL buttons - */ -EMessageBoxReturn DoModal(); -void EndModal( EMessageBoxReturn code ); -virtual ui::Window 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(); -ui::Window GetWidget(){ - return m_window; -} -const ui::Window GetWidget() const { - return m_window; -} - -ui::CheckButton addCheckBox( ui::Widget vbox, const char* name, const char* flag, const BoolImportCallback& importCallback, const BoolExportCallback& exportCallback ); -ui::CheckButton addCheckBox( ui::Widget vbox, const char* name, const char* flag, bool& data ); -void addCombo( ui::Widget vbox, const char* name, StringArrayRange values, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void addCombo( ui::Widget vbox, const char* name, int& data, StringArrayRange values ); -void addSlider( ui::Widget 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::Widget vbox, const char* name, StringArrayRange names, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void addRadio( ui::Widget vbox, const char* name, int& data, StringArrayRange names ); -void addRadioIcons( ui::Widget vbox, const char* name, StringArrayRange icons, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void addRadioIcons( ui::Widget vbox, const char* name, int& data, StringArrayRange icons ); -ui::Widget addIntEntry( ui::Widget vbox, const char* name, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -ui::Widget addEntry( ui::Widget vbox, const char* name, int& data ){ - return addIntEntry( vbox, name, IntImportCaller( data ), IntExportCaller( data ) ); -} -ui::Widget addSizeEntry( ui::Widget vbox, const char* name, const SizeImportCallback& importCallback, const SizeExportCallback& exportCallback ); -ui::Widget addEntry( ui::Widget vbox, const char* name, std::size_t& data ){ - return addSizeEntry( vbox, name, SizeImportCaller( data ), SizeExportCaller( data ) ); -} -ui::Widget addFloatEntry( ui::Widget vbox, const char* name, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); -ui::Widget addEntry( ui::Widget vbox, const char* name, float& data ){ - return addFloatEntry( vbox, name, FloatImportCaller( data ), FloatExportCaller( data ) ); -} -ui::Widget addPathEntry( ui::Widget vbox, const char* name, bool browse_directory, const StringImportCallback& importCallback, const StringExportCallback& exportCallback ); -ui::Widget addPathEntry( ui::Widget vbox, const char* name, CopiedString& data, bool directory ); -ui::SpinButton addSpinner( ui::Widget vbox, const char* name, int& data, double value, double lower, double upper ); -ui::SpinButton addSpinner( ui::Widget vbox, const char* name, double value, double lower, double upper, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -ui::SpinButton addSpinner( ui::Widget vbox, const char* name, double value, double lower, double upper, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); + 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( struct _GtkToggleButton& object, const BoolImportCallback& importCallback, const BoolExportCallback& exportCallback ); -void AddIntRadioData( struct _GtkRadioButton& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddTextEntryData( struct _GtkEntry& object, const StringImportCallback& importCallback, const StringExportCallback& exportCallback ); -void AddIntEntryData( struct _GtkEntry& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddSizeEntryData( struct _GtkEntry& object, const SizeImportCallback& importCallback, const SizeExportCallback& exportCallback ); -void AddFloatEntryData( struct _GtkEntry& object, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); -void AddFloatSpinnerData( struct _GtkSpinButton& object, const FloatImportCallback& importCallback, const FloatExportCallback& exportCallback ); -void AddIntSpinnerData( struct _GtkSpinButton& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddIntAdjustmentData( struct _GtkAdjustment& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); -void AddIntComboData( struct _GtkComboBox& object, const IntImportCallback& importCallback, const IntExportCallback& exportCallback ); - -void AddDialogData( struct _GtkToggleButton& object, bool& data ); -void AddDialogData( struct _GtkRadioButton& object, int& data ); -void AddDialogData( struct _GtkEntry& object, CopiedString& data ); -void AddDialogData( struct _GtkEntry& object, int& data ); -void AddDialogData( struct _GtkEntry& object, std::size_t& data ); -void AddDialogData( struct _GtkEntry& object, float& data ); -void AddDialogData( struct _GtkSpinButton& object, float& data ); -void AddDialogData( struct _GtkSpinButton& object, int& data ); -void AddDialogData( struct _GtkAdjustment& object, int& data ); -void AddDialogData( struct _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