summaryrefslogtreecommitdiffstats
path: root/mmc_updater/src/UpdateDialogGtk.h
diff options
context:
space:
mode:
authorAndrew <forkk@forkk.net>2013-12-09 12:04:05 -0600
committerAndrew <forkk@forkk.net>2013-12-09 12:04:05 -0600
commit7f52bed9e3f559adcbcf3f3c1c7ac2251964db8c (patch)
tree52097b57dc7d18ec4e35ef3a8e554af2d91545e8 /mmc_updater/src/UpdateDialogGtk.h
parent9410dd042ea62224fa3e0eb3b525abbdf0c316ee (diff)
parent220e07aef4a34dca9f31ae0c5bb994e5c594125d (diff)
downloadMultiMC-7f52bed9e3f559adcbcf3f3c1c7ac2251964db8c.tar
MultiMC-7f52bed9e3f559adcbcf3f3c1c7ac2251964db8c.tar.gz
MultiMC-7f52bed9e3f559adcbcf3f3c1c7ac2251964db8c.tar.lz
MultiMC-7f52bed9e3f559adcbcf3f3c1c7ac2251964db8c.tar.xz
MultiMC-7f52bed9e3f559adcbcf3f3c1c7ac2251964db8c.zip
Merge branch 'feature_updater' into develop
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();
+}
+
+