summaryrefslogtreecommitdiff
path: root/gtk2_ardour/nag.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2008-12-12 14:43:24 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2008-12-12 14:43:24 +0000
commitbc89fe0147c04b67141936d109c00dfd4d69cc4b (patch)
tree544ff450c40fe1f43853a8420228a26f27f1eafb /gtk2_ardour/nag.cc
parent30daaebaa2d90d6b0e8673143ccc3cacd7bd1753 (diff)
most of the 2.X->3.0 commit (up to rev 4299) except for gtk2_ardour/editor_canvas.cc; builds and runs and does a few specific things but expect it to be buggy for a while yet
git-svn-id: svn://localhost/ardour2/branches/3.0@4313 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/nag.cc')
-rw-r--r--gtk2_ardour/nag.cc206
1 files changed, 206 insertions, 0 deletions
diff --git a/gtk2_ardour/nag.cc b/gtk2_ardour/nag.cc
new file mode 100644
index 0000000000..ece3ac3e2a
--- /dev/null
+++ b/gtk2_ardour/nag.cc
@@ -0,0 +1,206 @@
+#include <fstream>
+#include <gtkmm/stock.h>
+
+#include <ardour/ardour.h>
+#include <ardour/filesystem_paths.h>
+
+#include "nag.h"
+#include "i18n.h"
+
+using namespace ARDOUR;
+using namespace std;
+using namespace Glib;
+using namespace Gtk;
+
+NagScreen::NagScreen (std::string context, bool maybe_sub)
+ : ArdourDialog (_("Support Ardour Development"), true)
+ , donate_button (button_group, _("I'd like to make a one-time donation"))
+ , subscribe_button (button_group, _("Tell me more about becoming a subscriber"))
+ , existing_button (button_group, _("I'm already a subscriber!"))
+ , next_time_button (button_group, _("Ask about this the next time I export"))
+ , never_again_button (button_group, _("Never ever ask me about this again"))
+{
+ if (maybe_sub) {
+ message.set_text (_("Congratulations on your session export.\n\n\
+It looks as if you may already be a subscriber. If so, thanks, and sorry\n\
+to bother you again about this - I'm working on improving our subscriber system\n\
+so that I don't have to keep annoying you with this message.\n\n\
+If you're not a subscriber, perhaps you might consider supporting my work\n\
+on Ardour with either a one-time donation or subscription. Nothing will \n\
+happen if you choose not to do so. However Ardour's continuing development\n\
+relies on a stable, sustainable income stream. Thanks for using Ardour!"));
+ } else {
+ message.set_text (_("Congratulations on your session export.\n\n\
+I hope you find Ardour a useful tool. I'd like to ask you to consider supporting\n\
+its development with either a one-time donation or subscription. Nothing\n\
+will happen if you choose not to do so. However Ardour's continuing development\n\
+relies on a stable, sustainable income stream. Thanks for using Ardour!"));
+ }
+
+ button_box.pack_start (donate_button);
+ button_box.pack_start (subscribe_button);
+ button_box.pack_start (existing_button);
+ button_box.pack_start (next_time_button);
+ button_box.pack_start (never_again_button);
+
+ get_vbox()->set_spacing (12);
+ get_vbox()->pack_start (message);
+ get_vbox()->pack_start (button_box);
+
+ set_border_width (12);
+ add_button (Stock::OK, RESPONSE_ACCEPT);
+}
+
+NagScreen::~NagScreen ()
+{
+}
+
+void
+NagScreen::nag ()
+{
+ show_all ();
+
+ int response = run ();
+
+ hide ();
+
+ switch (response) {
+ case RESPONSE_ACCEPT:
+ break;
+ default:
+ return;
+ }
+
+ if (donate_button.get_active()) {
+ offer_to_donate ();
+ } else if (subscribe_button.get_active()) {
+ offer_to_subscribe ();
+ } else if (never_again_button.get_active ()) {
+ mark_never_again ();
+ } else if (existing_button.get_active ()) {
+ mark_affirmed_subscriber ();
+ }
+}
+
+NagScreen*
+NagScreen::maybe_nag (std::string why)
+{
+ Glib::ustring path;
+ bool really_subscribed;
+ bool maybe_subscribed;
+
+ path = Glib::build_filename (user_config_directory().to_string(), ".nevernag");
+
+ if (Glib::file_test (path, Glib::FILE_TEST_EXISTS)) {
+ return 0;
+ }
+
+ maybe_subscribed = is_subscribed (really_subscribed);
+
+ if (really_subscribed) {
+ return 0;
+ }
+
+ return new NagScreen (why, maybe_subscribed);
+}
+
+void
+NagScreen::mark_never_again ()
+{
+ Glib::ustring path;
+
+ path = Glib::build_filename (user_config_directory().to_string(), ".nevernag");
+
+ ofstream nagfile (path.c_str());
+}
+
+void
+NagScreen::mark_subscriber ()
+{
+ Glib::ustring path;
+
+ path = Glib::build_filename (user_config_directory().to_string(), ".askedaboutsub");
+
+ ofstream subsfile (path.c_str());
+}
+
+void
+NagScreen::mark_affirmed_subscriber ()
+{
+ Glib::ustring path;
+
+ path = Glib::build_filename (user_config_directory().to_string(), ".isubscribe");
+
+ ofstream subsfile (path.c_str());
+}
+
+bool
+NagScreen::is_subscribed (bool& really)
+{
+ Glib::ustring path;
+
+ really = false;
+
+ /* what we'd really like here is a way to query paypal
+ for someone's subscription status. thats a bit complicated
+ so for now, just see if they ever told us they were
+ subscribed. we try to trust our users :)
+ */
+
+ path = Glib::build_filename (user_config_directory().to_string(), ".isubscribe");
+ if (file_test (path, FILE_TEST_EXISTS)) {
+ really = true;
+ return true;
+ }
+
+ path = Glib::build_filename (user_config_directory().to_string(), ".askedaboutsub");
+ if (file_test (path, FILE_TEST_EXISTS)) {
+ /* they never said they were subscribed but they
+ did once express an interest in it.
+ */
+ really = false;
+ return true;
+ }
+
+ return false;
+}
+
+void
+NagScreen::offer_to_donate ()
+{
+ const char* uri = "http://ardour.org/donate";
+
+ /* we don't care if it fails */
+
+ open_uri (uri);
+}
+
+void
+NagScreen::offer_to_subscribe ()
+{
+ const char* uri = "http://ardour.org/subscribe";
+
+ if (open_uri (uri)) {
+ mark_subscriber ();
+ }
+}
+
+bool
+NagScreen::open_uri (const char* uri)
+{
+#ifdef HAVE_GTK_OPEN_URI
+ GError* err;
+ return gtk_open_uri (0, uri, GDK_CURRENT_TIME, &err);
+#else
+#ifndef __APPLE__
+ std::string command = "xdg-open ";
+ command += uri;
+ spawn_command_line_async (command);
+
+ return true;
+#else
+ extern bool cocoa_open_url (const char*);
+ return cocoa_open_url (uri);
+#endif
+#endif
+}