aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJon Trowbridge <trow@src.gnome.org>2001-10-27 06:17:23 +0800
committerJon Trowbridge <trow@src.gnome.org>2001-10-27 06:17:23 +0800
commitd2cc21d95e7a95e3cc19c9d0d0b9367deab358f1 (patch)
treee78ad1ac820acd50b1132a97eca73f8593b4fd93
parentc26da3acf537953d00a77099528775ac3b95a005 (diff)
downloadgsoc2013-evolution-d2cc21d95e7a95e3cc19c9d0d0b9367deab358f1.tar.gz
gsoc2013-evolution-d2cc21d95e7a95e3cc19c9d0d0b9367deab358f1.tar.zst
gsoc2013-evolution-d2cc21d95e7a95e3cc19c9d0d0b9367deab358f1.zip
Wombat: Be afraid. Be VERY afraid.
svn path=/trunk/; revision=14174
-rw-r--r--tools/Makefile.am5
-rw-r--r--tools/evolution-addressbook-abuse.c120
2 files changed, 125 insertions, 0 deletions
diff --git a/tools/Makefile.am b/tools/Makefile.am
index eee5a29499..d4e442cb10 100644
--- a/tools/Makefile.am
+++ b/tools/Makefile.am
@@ -1,5 +1,7 @@
bin_SCRIPTS = killev evolution-move-tasks evolution-addressbook-clean
+
bin_PROGRAMS = evolution-addressbook-import evolution-addressbook-export
+noinst_PROGRAMS = evolution-addressbook-abuse
INCLUDES = \
-DG_LOG_DOMAIN=\"evolution-tools\" \
@@ -30,6 +32,9 @@ evolution_addressbook_import_LDADD = \
evolution_addressbook_export_LDADD = \
$(evolution_addressbook_import_LDADD)
+evolution_addressbook_abuse_LDADD = \
+ $(evolution_addressbook_import_LDADD)
+
CLEANFILES = evolution-addressbook-clean
diff --git a/tools/evolution-addressbook-abuse.c b/tools/evolution-addressbook-abuse.c
new file mode 100644
index 0000000000..67cfd746d7
--- /dev/null
+++ b/tools/evolution-addressbook-abuse.c
@@ -0,0 +1,120 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+
+#include <config.h>
+
+#include <liboaf/liboaf.h>
+#include <bonobo/bonobo-main.h>
+#include <backend/ebook/e-book-util.h>
+#include <gnome.h>
+
+static int cards_to_add = 1000;
+static int cards_added = 0;
+
+static gchar *
+make_random_string (void)
+{
+ const gchar *elements = " abcdefghijklmnopqrstuvwxyz1234567890 ABCDEFGHIJKLMNOPQRSTUVWXYZ";
+ gint len = strlen (elements);
+ gint i, N = 5 + (random () % 10);
+ gchar *str = g_malloc (N+1);
+
+ for (i = 0; i < N; ++i) {
+ str[i] = elements[random () % len];
+ }
+ str[i] = '\0';
+
+ return str;
+}
+
+static gchar *
+make_random_vcard (void)
+{
+ gchar *fa = make_random_string ();
+ gchar *name = make_random_string ();
+ gchar *email = make_random_string ();
+ gchar *org = make_random_string ();
+
+ gchar *vcard;
+
+ vcard = g_strdup_printf ("BEGIN:VCARD\n"
+ "X-EVOLUTION-FILE-AS:%s\n"
+ "N:%s\n"
+ "EMAIL;INTERNET:%s\n"
+ "ORG:%s\n"
+ "END:VCARD",
+ fa, name, email, org);
+ g_free (fa);
+ g_free (name);
+ g_free (email);
+ g_free (org);
+
+ return vcard;
+}
+
+/* ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** */
+
+static void
+add_cb (EBook *book, EBookStatus status, const char *id, gpointer closure)
+{
+ switch (status) {
+ case E_BOOK_STATUS_SUCCESS:
+ ++cards_added;
+ g_message ("succesful add! (%d of %d)", cards_added, cards_to_add);
+ if (cards_to_add == cards_added)
+ gtk_exit (0);
+ break;
+ default:
+ g_message ("something went wrong...");
+ gtk_exit (status);
+ break;
+ }
+}
+
+static void
+use_addressbook (EBook *book, gpointer closure)
+{
+ gint i;
+
+ if (book == NULL)
+ g_error (_("Error loading default addressbook."));
+
+ for (i = 0; i < cards_to_add; ++i) {
+ gchar *vcard = make_random_vcard ();
+ ECard *card = e_card_new (vcard);
+ e_book_add_card (book, card, add_cb, NULL);
+ g_free (vcard);
+ gtk_object_unref (GTK_OBJECT (card));
+ }
+
+ gtk_exit (0);
+}
+
+int
+main (int argc, char *argv[])
+{
+ char *filename = NULL;
+
+ struct poptOption options[] = {
+ { "input-file", '\0', POPT_ARG_STRING, &filename, 0, N_("Input File"), NULL },
+ { NULL, '\0', POPT_ARG_INCLUDE_TABLE, &oaf_popt_options, 0, NULL, NULL },
+ POPT_AUTOHELP
+ { NULL, '\0', 0, NULL, 0, NULL, NULL }
+ };
+
+ bindtextdomain (PACKAGE, EVOLUTION_LOCALEDIR);
+ textdomain (PACKAGE);
+
+ gnome_init_with_popt_table ("evolution-addressbook-clean", "0.0",
+ argc, argv, options, 0, NULL);
+
+ oaf_init (argc, argv);
+
+ if (bonobo_init (CORBA_OBJECT_NIL, CORBA_OBJECT_NIL, CORBA_OBJECT_NIL) == FALSE)
+ g_error (_("Could not initialize Bonobo"));
+
+ e_book_use_local_address_book (use_addressbook, NULL);
+
+ bonobo_main ();
+
+ return 0;
+}