aboutsummaryrefslogtreecommitdiffstats
path: root/camel/camel-internet-address.c
diff options
context:
space:
mode:
Diffstat (limited to 'camel/camel-internet-address.c')
-rw-r--r--camel/camel-internet-address.c551
1 files changed, 0 insertions, 551 deletions
diff --git a/camel/camel-internet-address.c b/camel/camel-internet-address.c
deleted file mode 100644
index 6a82393d8d..0000000000
--- a/camel/camel-internet-address.c
+++ /dev/null
@@ -1,551 +0,0 @@
-/*
- * Copyright (C) 2000 Ximian Inc.
- *
- * Authors: Michael Zucchi <notzed@ximian.com>
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of version 2 of the GNU General Public
- * License as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public
- * License along with this program; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#include <stdio.h>
-#include <string.h>
-
-#include "camel-mime-utils.h"
-#include "camel-internet-address.h"
-
-#define d(x)
-
-static int internet_decode (CamelAddress *, const char *raw);
-static char * internet_encode (CamelAddress *);
-static int internet_unformat (CamelAddress *, const char *raw);
-static char * internet_format (CamelAddress *);
-static int internet_cat (CamelAddress *dest, const CamelAddress *source);
-static void internet_remove (CamelAddress *, int index);
-
-static void camel_internet_address_class_init (CamelInternetAddressClass *klass);
-static void camel_internet_address_init (CamelInternetAddress *obj);
-
-static CamelAddressClass *camel_internet_address_parent;
-
-struct _address {
- char *name;
- char *address;
-};
-
-static void
-camel_internet_address_class_init(CamelInternetAddressClass *klass)
-{
- CamelAddressClass *address = (CamelAddressClass *) klass;
-
- camel_internet_address_parent = CAMEL_ADDRESS_CLASS(camel_type_get_global_classfuncs(camel_address_get_type()));
-
- address->decode = internet_decode;
- address->encode = internet_encode;
- address->unformat = internet_unformat;
- address->format = internet_format;
- address->remove = internet_remove;
- address->cat = internet_cat;
-}
-
-static void
-camel_internet_address_init(CamelInternetAddress *obj)
-{
-}
-
-CamelType
-camel_internet_address_get_type(void)
-{
- static CamelType type = CAMEL_INVALID_TYPE;
-
- if (type == CAMEL_INVALID_TYPE) {
- type = camel_type_register(camel_address_get_type(), "CamelInternetAddress",
- sizeof (CamelInternetAddress),
- sizeof (CamelInternetAddressClass),
- (CamelObjectClassInitFunc) camel_internet_address_class_init,
- NULL,
- (CamelObjectInitFunc) camel_internet_address_init,
- NULL);
- }
-
- return type;
-}
-
-static int
-internet_decode (CamelAddress *a, const char *raw)
-{
- struct _camel_header_address *ha, *n;
- int count = a->addresses->len;
-
- /* Should probably use its own decoder or something */
- ha = camel_header_address_decode(raw, NULL);
- if (ha) {
- n = ha;
- while (n) {
- if (n->type == HEADER_ADDRESS_NAME) {
- camel_internet_address_add((CamelInternetAddress *)a, n->name, n->v.addr);
- } else if (n->type == HEADER_ADDRESS_GROUP) {
- struct _camel_header_address *g = n->v.members;
- while (g) {
- if (g->type == HEADER_ADDRESS_NAME)
- camel_internet_address_add((CamelInternetAddress *)a, g->name, g->v.addr);
- /* otherwise, it's an error, infact */
- g = g->next;
- }
- }
- n = n->next;
- }
- camel_header_address_list_clear(&ha);
- }
-
- return a->addresses->len - count;
-}
-
-static char *
-internet_encode (CamelAddress *a)
-{
- int i;
- GString *out;
- char *ret;
- int len = 6; /* "From: ", assume longer of the address headers */
-
- if (a->addresses->len == 0)
- return NULL;
-
- out = g_string_new("");
-
- for (i = 0;i < a->addresses->len; i++) {
- struct _address *addr = g_ptr_array_index(a->addresses, i);
- char *enc;
-
- if (i != 0)
- g_string_append(out, ", ");
-
- enc = camel_internet_address_encode_address(&len, addr->name, addr->address);
- g_string_append(out, enc);
- g_free(enc);
- }
-
- ret = out->str;
- g_string_free(out, FALSE);
-
- return ret;
-}
-
-static int
-internet_unformat(CamelAddress *a, const char *raw)
-{
- char *buffer, *p, *name, *addr;
- int c;
- int count = a->addresses->len;
-
- if (raw == NULL)
- return 0;
-
- d(printf("unformatting address: %s\n", raw));
-
- /* we copy, so we can modify as we go */
- buffer = g_strdup(raw);
-
- /* this can be simpler than decode, since there are much fewer rules */
- p = buffer;
- name = NULL;
- addr = p;
- do {
- c = (unsigned char)*p++;
- switch (c) {
- /* removes quotes, they should only be around the total name anyway */
- case '"':
- p[-1] = ' ';
- while (*p)
- if (*p == '"') {
- *p++ = ' ';
- break;
- } else {
- p++;
- }
- break;
- case '<':
- if (name == NULL)
- name = addr;
- addr = p;
- addr[-1] = 0;
- while (*p && *p != '>')
- p++;
- if (*p == 0)
- break;
- p++;
- /* falls through */
- case ',':
- p[-1] = 0;
- /* falls through */
- case 0:
- if (name)
- name = g_strstrip(name);
- addr = g_strstrip(addr);
- if (addr[0]) {
- d(printf("found address: '%s' <%s>\n", name, addr));
- camel_internet_address_add((CamelInternetAddress *)a, name, addr);
- }
- name = NULL;
- addr = p;
- break;
- }
- } while (c);
-
- g_free(buffer);
-
- return a->addresses->len - count;
-}
-
-static char *
-internet_format (CamelAddress *a)
-{
- int i;
- GString *out;
- char *ret;
-
- if (a->addresses->len == 0)
- return NULL;
-
- out = g_string_new("");
-
- for (i = 0;i < a->addresses->len; i++) {
- struct _address *addr = g_ptr_array_index(a->addresses, i);
- char *enc;
-
- if (i != 0)
- g_string_append(out, ", ");
-
- enc = camel_internet_address_format_address(addr->name, addr->address);
- g_string_append(out, enc);
- g_free(enc);
- }
-
- ret = out->str;
- g_string_free(out, FALSE);
-
- return ret;
-}
-
-static int
-internet_cat (CamelAddress *dest, const CamelAddress *source)
-{
- int i;
-
- g_assert(CAMEL_IS_INTERNET_ADDRESS(source));
-
- for (i=0;i<source->addresses->len;i++) {
- struct _address *addr = g_ptr_array_index(source->addresses, i);
- camel_internet_address_add((CamelInternetAddress *)dest, addr->name, addr->address);
- }
-
- return i;
-}
-
-static void
-internet_remove (CamelAddress *a, int index)
-{
- struct _address *addr;
-
- if (index < 0 || index >= a->addresses->len)
- return;
-
- addr = g_ptr_array_index(a->addresses, index);
- g_free(addr->name);
- g_free(addr->address);
- g_free(addr);
- g_ptr_array_remove_index(a->addresses, index);
-}
-
-/**
- * camel_internet_address_new:
- *
- * Create a new CamelInternetAddress object.
- *
- * Return value: A new CamelInternetAddress object.
- **/
-CamelInternetAddress *
-camel_internet_address_new (void)
-{
- CamelInternetAddress *new = CAMEL_INTERNET_ADDRESS(camel_object_new(camel_internet_address_get_type()));
- return new;
-}
-
-/**
- * camel_internet_address_add:
- * @a: internet address object
- * @name:
- * @address:
- *
- * Add a new internet address to the address object.
- *
- * Return value: Index of added entry.
- **/
-int
-camel_internet_address_add (CamelInternetAddress *a, const char *name, const char *address)
-{
- struct _address *new;
- int index;
-
- g_assert(CAMEL_IS_INTERNET_ADDRESS(a));
-
- new = g_malloc(sizeof(*new));
- new->name = g_strdup(name);
- new->address = g_strdup(address);
- index = ((CamelAddress *)a)->addresses->len;
- g_ptr_array_add(((CamelAddress *)a)->addresses, new);
-
- return index;
-}
-
-/**
- * camel_internet_address_get:
- * @a: internet address object
- * @index: address's array index
- * @namep: Holder for the returned name, or NULL, if not required.
- * @addressp: Holder for the returned address, or NULL, if not required.
- *
- * Get the address at @index.
- *
- * Return value: TRUE if such an address exists, or FALSE otherwise.
- **/
-gboolean
-camel_internet_address_get (const CamelInternetAddress *a, int index, const char **namep, const char **addressp)
-{
- struct _address *addr;
-
- g_assert(CAMEL_IS_INTERNET_ADDRESS(a));
-
- if (index < 0 || index >= ((CamelAddress *)a)->addresses->len)
- return FALSE;
-
- addr = g_ptr_array_index( ((CamelAddress *)a)->addresses, index);
- if (namep)
- *namep = addr->name;
- if (addressp)
- *addressp = addr->address;
- return TRUE;
-}
-
-/**
- * camel_internet_address_find_name:
- * @a:
- * @name:
- * @addressp: Holder for address part, or NULL, if not required.
- *
- * Find address by real name.
- *
- * Return value: The index of the address matching the name, or -1
- * if no match was found.
- **/
-int
-camel_internet_address_find_name(CamelInternetAddress *a, const char *name, const char **addressp)
-{
- struct _address *addr;
- int i, len;
-
- g_assert(CAMEL_IS_INTERNET_ADDRESS(a));
-
- len = ((CamelAddress *)a)->addresses->len;
- for (i=0;i<len;i++) {
- addr = g_ptr_array_index( ((CamelAddress *)a)->addresses, i );
- if (!strcmp(addr->name, name)) {
- if (addressp)
- *addressp = addr->address;
- return i;
- }
- }
- return -1;
-}
-
-/**
- * camel_internet_address_find_address:
- * @a:
- * @address:
- * @namep: Return for the matching name, or NULL, if not required.
- *
- * Find an address by address.
- *
- * Return value: The index of the address, or -1 if not found.
- **/
-int
-camel_internet_address_find_address(CamelInternetAddress *a, const char *address, const char **namep)
-{
- struct _address *addr;
- int i, len;
-
- g_assert(CAMEL_IS_INTERNET_ADDRESS(a));
-
- len = ((CamelAddress *)a)->addresses->len;
- for (i=0;i<len;i++) {
- addr = g_ptr_array_index( ((CamelAddress *)a)->addresses, i );
- if (!strcmp(addr->address, address)) {
- if (namep)
- *namep = addr->name;
- return i;
- }
- }
- return -1;
-}
-
-static void
-cia_encode_addrspec(GString *out, const char *addr)
-{
- const char *at, *p;
-
- at = strchr(addr, '@');
- if (at == NULL)
- goto append;
-
- p = addr;
- while (p < at) {
- char c = *p++;
-
- /* strictly by rfc, we should split local parts on dots.
- however i think 2822 changes this, and not many clients grok it, so
- just quote the whole local part if need be */
- if (!(camel_mime_is_atom(c) || c=='.')) {
- g_string_append_c(out, '"');
-
- p = addr;
- while (p < at) {
- c = *p++;
- if (c == '"' || c == '\\')
- g_string_append_c(out, '\\');
- g_string_append_c(out, c);
- }
- g_string_append_c(out, '"');
- g_string_append(out, p);
-
- return;
- }
- }
-
-append:
- g_string_append(out, addr);
-}
-
-/**
- * camel_internet_address_encode_address:
- * @len: The encoded length so far, of this line
- * @name:
- * @addr:
- *
- * Encode a single address ready for internet usage. Header folding
- * as per rfc 822 is also performed, based on the length *@inlen. If @inlen
- * is NULL, then no folding will occur.
- *
- * Return value: The encoded address.
- **/
-char *
-camel_internet_address_encode_address(int *inlen, const char *real, const char *addr)
-{
- char *name = camel_header_encode_phrase(real);
- char *ret = NULL;
- int len = 0;
- GString *out = g_string_new("");
-
- g_assert(addr);
-
- if (inlen != NULL)
- len = *inlen;
-
- if (name && name[0]) {
- if (inlen != NULL && (strlen(name) + len) > CAMEL_FOLD_SIZE) {
- char *folded = camel_header_address_fold(name, len);
- char *last;
- g_string_append(out, folded);
- g_free(folded);
- last = strrchr(out->str, '\n');
- if (last)
- len = last-(out->str+out->len);
- else
- len = out->len;
- } else {
- g_string_append(out, name);
- len += strlen(name);
- }
- }
-
- /* NOTE: Strictly speaking, we could and should split the
- * internal address up if we need to, on atom or specials
- * boundaries - however, to aid interoperability with mailers
- * that will probably not handle this case, we will just move
- * the whole address to its own line. */
- if (inlen != NULL && (strlen(addr) + len) > CAMEL_FOLD_SIZE) {
- g_string_append(out, "\n\t");
- len = 1;
- }
-
- len -= out->len;
-
- if (name && name[0])
- g_string_append_printf(out, " <");
- cia_encode_addrspec(out, addr);
- if (name && name[0])
- g_string_append_printf(out, ">");
-
- len += out->len;
-
- if (inlen != NULL)
- *inlen = len;
-
- g_free(name);
-
- ret = out->str;
- g_string_free(out, FALSE);
-
- return ret;
-}
-
-/**
- * camel_internet_address_format_address:
- * @name: A name, quotes may be stripped from it.
- * @addr: Assumes a valid rfc822 email address.
- *
- * Function to format a single address, suitable for display.
- *
- * Return value:
- **/
-char *
-camel_internet_address_format_address(const char *name, const char *addr)
-{
- char *ret = NULL;
-
- g_assert(addr);
-
- if (name && name[0]) {
- const char *p = name;
- char *o, c;
-
- while ((c = *p++)) {
- if (c == '\"' || c == ',') {
- o = ret = g_malloc(strlen(name)+3+strlen(addr)+3 + 1);
- p = name;
- *o++ = '\"';
- while ((c = *p++))
- if (c != '\"')
- *o++ = c;
- *o++ = '\"';
- sprintf(o, " <%s>", addr);
- d(printf("encoded '%s' => '%s'\n", name, ret));
- return ret;
- }
- }
- ret = g_strdup_printf("%s <%s>", name, addr);
- } else
- ret = g_strdup(addr);
-
- return ret;
-}
n>1-0/+28 * Add AQBANKING option, fixes broken/incorrect dependency on openhbci.lawrance2005-06-082-4/+14 * Add aqbanking 1.0.11, online banking interface and financial datalawrance2005-06-085-0/+175 * Upgrade to 0.5.7.thierry2005-06-073-9/+9 * change the libtool version to use from 1.3 to 1.5oliver2005-06-023-11/+17 * Update to 0.10.tobez2005-05-242-3/+3 * Chase update of openhbcilawrance2005-05-171-1/+2 * Update to 0.9.17.2lawrance2005-05-175-36/+33 * Oops... Add new Spanish, Italian, Dutch, Polish and Romanian translations.thierry2005-05-151-2/+12 * Upgrade to 0.5.6.thierry2005-05-153-10/+9 * Relinquish maintainership back to ports@. Hopefully someone will give gnucashmarcus2005-05-122-2/+2 * Correct a typo in the previous commit, and use the right version libdb41.marcus2005-05-122-2/+2 * Fix the build with db41.marcus2005-05-122-4/+2 * Add JAVA_EXTRACT option that makes sure that java is available atlioux2005-05-111-0/+1 * Remove BROKEN status since the port is indeed fetchablelioux2005-05-091-2/+0 * BROKEN on 4.x: Does not compilekris2005-05-071-1/+7 * BROKEN: Unfetchablekris2005-05-071-0/+2 * - Add xtrader [1]ahze2005-04-175-0/+68 * s/ENV/SETENV/mi2005-04-161-1/+1 * At Kris's request, back out the MACHINE_ARCH spelling correction untilobrien2005-04-124-4/+4 * Assist getting more ports working on AMD64 by obeying theobrien2005-04-114-4/+4 * Update to 3.15erwin2005-04-042-3/+3 * - Update to 0.32leeym2005-04-042-4/+4 * Update to 0.5.1.alioux2005-04-042-3/+4 * o Add patch forgotten when port was updated to 0.5alphalioux2005-03-301-0/+13 * Update to 0.5alpha; thus, fixing BROKEN statuslioux2005-03-282-5/+15 * BROKEN on ia64 and alpha: Does not compilekris2005-03-271-1/+7 * Bump PORTREVISION to chase the glib20 shared lib version change.marcus2005-03-126-5/+6 * Update to 0.09mat2005-03-093-3/+4 * - Update to 3.3.flz2005-03-033-8/+15 * - Update to 3.3.flz2005-03-033-10/+44 * Update to 0.08. Require 5.6 or 5.8, since one of its dependencies doestobez2005-03-032-8/+6 * As previously announced, remove ports that have reached their expiry date,kris2005-02-197-218/+0 * I hit 'x' too many times, and deleted the trailing 't' in gnometarget.marcus2005-02-131-1/+1 * * Fix the build on 4.Xmarcus2005-02-133-2/+92 * BROKEN: Does not buildkris2005-02-121-0/+2 * Chase the libofx shared lib version.marcus2005-02-121-2/+2 * Update to 1.8.11.marcus2005-02-126-16/+32 * Update to 0.7.0.marcus2005-02-125-192/+85 * Update to 0.05erwin2005-02-012-3/+3 * Split the postgresql ports into a server and a client part.girgen2005-01-311-2/+1 * Add patch to enter overdue scheduled paymentsvs2005-01-224-0/+64 * New port venice version 0.4alpha: Merchant Of Venice, a stock marketlioux2005-01-205-0/+105 * New port qtstalker version 0.28: Commodity and stock market chartinglioux2005-01-2010-0/+247 * Fix plist.thierry2005-01-122-3/+3 * Upgrade to 0.5.5.thierry2005-01-104-23/+23 * Fix build on 5.xarved2005-01-102-7/+24 * Update to 0.07mat2005-01-082-3/+12 * Upgrade to 0.5.4.thierry2004-12-282-3/+3 * This port is scheduled to be removed on 2005-02-18 if it is stillkris2004-12-191-0/+2 * Clean up handling of locale directories at deinstall-time:kris2004-12-162-0/+4 * Software developers fixed double-entry account field in transactionkrion2004-12-161-2/+2 * Software developers fixed double-entry account field inkrion2004-12-161-2/+2 * Add p5-Finance-Currency-Convert-XE, a currency conversion module thattobez2004-12-155-0/+51 * Update to version 3.2.3krion2004-12-123-13/+4 * Update to version 3.2.3krion2004-12-127-231/+81 * Update to 0.28.tobez2004-12-062-3/+3 * Upgrade to 0.5.3.thierry2004-11-293-7/+11 * Mark BROKEN on alpha for the time being. The build causes xsltproc tomarcus2004-11-291-1/+7 * Add missing libtool droppingskris2004-11-261-0/+8 * Use new INSTALLS_OMF.mezz2004-11-232-6/+1 * BROKEN: Does not compilekris2004-11-181-0/+2 * Update to 1.8.4ahze2004-11-123-129/+157 * Bump PORTREVISIONS for all ports that depend on atk or pango to ease in themarcus2004-11-082-0/+2 * Update to 0.6.4arved2004-11-058-40/+10 * Upgrade to 0.5.2.thierry2004-10-183-29/+48 * Make these stylesheets XSLT compliant by making sure templates with the samemarcus2004-10-172-0/+34 * Kill off automake18, switching to automake19. Requiem Mors Pacem.ade2004-10-161-1/+1 * Update to 0.04erwin2004-10-142-3/+3 * Update to 3.14erwin2004-10-142-3/+3 * Update to version 3.2.1krion2004-10-122-3/+4 * Update to version 3.2.1krion2004-10-12