summaryrefslogtreecommitdiffstats
path: root/mmc_updater/src/UpdateDialogGtk.h
diff options
context:
space:
mode:
authorPetr Mrázek <peterix@gmail.com>2013-12-02 00:55:24 +0100
committerPetr Mrázek <peterix@gmail.com>2013-12-02 00:55:24 +0100
commit6aa9bd0f77dcb5128167fae62e32aa5252fe85c6 (patch)
tree632994a61888929af9289927d338bd19a2b3f32c /mmc_updater/src/UpdateDialogGtk.h
parent613699b3626aea750093ab7eaaeccaa28c0e87c6 (diff)
downloadMultiMC-6aa9bd0f77dcb5128167fae62e32aa5252fe85c6.tar
MultiMC-6aa9bd0f77dcb5128167fae62e32aa5252fe85c6.tar.gz
MultiMC-6aa9bd0f77dcb5128167fae62e32aa5252fe85c6.tar.lz
MultiMC-6aa9bd0f77dcb5128167fae62e32aa5252fe85c6.tar.xz
MultiMC-6aa9bd0f77dcb5128167fae62e32aa5252fe85c6.zip
Renew the updater branch
Now with some actual consensus on what the updater will do!
Diffstat (limited to 'mmc_updater/src/UpdateDialogGtk.h')
-rw-r--r--mmc_updater/src/UpdateDialogGtk.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/mmc_updater/src/UpdateDialogGtk.h b/mmc_updater/src/UpdateDialogGtk.h
new file mode 100644
index 00000000..70e29c78
--- /dev/null
+++ b/mmc_updater/src/UpdateDialogGtk.h
@@ -0,0 +1,42 @@
+#pragma once
+
+#include "UpdateDialog.h"
+#include "UpdateMessage.h"
+#include "UpdateObserver.h"
+
+#include <gtk/gtk.h>
+
+class UpdateDialogGtk : public UpdateDialog
+{
+ public:
+ UpdateDialogGtk();
+
+ // implements UpdateDialog
+ virtual void init(int argc, char** argv);
+ virtual void exec();
+ virtual void quit();
+
+ // observer callbacks - these may be called
+ // from a background thread
+ virtual void updateError(const std::string& errorMessage);
+ virtual void updateProgress(int percentage);
+ virtual void updateFinished();
+
+ private:
+ static void finish(GtkWidget* widget, gpointer dialog);
+ static gboolean notify(void* message);
+
+ GtkWidget* m_window;
+ GtkWidget* m_progressLabel;
+ GtkWidget* m_finishButton;
+ GtkWidget* m_progressBar;
+ bool m_hadError;
+};
+
+// helper functions which allow the GTK dialog to be loaded dynamically
+// at runtime and used only if the GTK libraries are actually present
+extern "C" {
+ UpdateDialogGtk* update_dialog_gtk_new();
+}
+
+