diff options
author | Jon Trowbridge <trow@src.gnome.org> | 2001-10-27 06:17:23 +0800 |
---|---|---|
committer | Jon Trowbridge <trow@src.gnome.org> | 2001-10-27 06:17:23 +0800 |
commit | d2cc21d95e7a95e3cc19c9d0d0b9367deab358f1 (patch) | |
tree | e78ad1ac820acd50b1132a97eca73f8593b4fd93 | |
parent | c26da3acf537953d00a77099528775ac3b95a005 (diff) | |
download | gsoc2013-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.am | 5 | ||||
-rw-r--r-- | tools/evolution-addressbook-abuse.c | 120 |
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; +} |