| Top |  |  |  |  | 
GBoxed ├── EVCardAttribute ╰── EVCardAttributeParam GObject ╰── EVCard ╰── EContact
EVCard is a low-level representation of a vCard, as specified in RFCs 2425 and 2426 (for vCard version 3.0); this class only supports versions 2.1 and 3.0 of the vCard standard.
A vCard is an unordered set of attributes (otherwise known as properties), each with one or more values. The number of values an attribute has is determined by its type, and is given in the specification. Each attribute may also have zero or more named parameters, which provide metadata about its value.
For example, the following line from a vCard:
| 1 | ADR;TYPE=WORK:;;100 Waters Edge;Baytown;LA;30314;United States of America | 
is an ADR attribute with 6 values giving the different
components of the postal address. It has one parameter, TYPE,
which specifies that it’s a work address rather than a home address.
Using the EVCard API, this data is accessible as follows:
Example 1. Accessing a Multi-Valued Attribute
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | EVCard *vcard; EVCardAttribute *attr; GList *param_values, *values; vcard = e_vcard_new_from_string ( "BEGIN:VCARD\n" "VERSION:3.0\n" "ADR;TYPE=WORK:;;100 Waters Edge;Baytown;LA;30314;United States of America\n" "END:VCARD\n"); attr = e_vcard_get_attribute (vcard, "ADR"); g_assert_cmpstr (e_vcard_attribute_get_name (attr), ==, "ADR"); g_assert_true (e_vcard_attribute_is_single_valued (attr) == FALSE); param_values = e_vcard_attribute_get_param (attr, "TYPE"); g_assert_cmpuint (g_list_length (param_values), ==, 1); g_assert_cmpstr (param_values->data, ==, "WORK"); values = e_vcard_attribute_get_values (attr); g_assert_cmpuint (g_list_length (values), ==, 6); g_assert_cmpstr (values->data, ==, ""); g_assert_cmpstr (values->next->data, ==, "100 Waters Edge"); g_assert_cmpstr (values->next->next->data, ==, "Baytown"); /* etc. */ g_object_unref (vcard); | 
If a second ADR attribute was present in the vCard, the above
example would only ever return the first attribute. To access the values of
other attributes of the same type, the entire attribute list must be iterated
over using e_vcard_get_attributes(), then matching on
e_vcard_attribute_get_name().
vCard attribute values may be encoded in the vCard source, using base-64 or
quoted-printable encoding. Such encoded values are automatically decoded when
parsing the vCard, so the values returned by e_vcard_attribute_get_value()
do not need further decoding. The ‘decoded’ functions,
e_vcard_attribute_get_value_decoded() and
e_vcard_attribute_get_values_decoded() are only relevant when adding
attributes which use pre-encoded values and have their ENCODING
parameter set.
String comparisons in EVCard are almost universally case-insensitive. Attribute names, parameter names and parameter values are all compared case-insensitively. Only attribute values are case sensitive.
EVCard implements lazy parsing of its vCard data, so the first time its
attributes are accessed may take slightly longer than normal to allow for the
vCard to be parsed. This can be tested by calling e_vcard_is_parsed().
void e_vcard_construct (EVCard *evc,const gchar *str);
Constructs the existing EVCard, evc
, setting its vCard data to str
.
This modifies evc
.
void e_vcard_construct_with_uid (EVCard *evc,const gchar *str,const gchar *uid);
Constructs the existing EVCard, evc
, setting its vCard data to str
, and
adding a new UID attribute with the value given in uid
 (if uid
 is
non-NULL).
This modifies evc
.
Since: 3.4
void e_vcard_construct_full (EVCard *evc,const gchar *str,gssize len,const gchar *uid);
Similar to e_vcard_construct_with_uid(), but can also
be used with an str
 that is not NULL terminated.
Since: 3.12
EVCard *
e_vcard_new_from_string (const gchar *str);
Creates a new EVCard from the passed-in string representation.
gboolean
e_vcard_is_parsed (EVCard *evc);
Check if the evc
 has been parsed already, as EVCard implements lazy parsing
of its vCard data. Used for debugging.
Since: 3.2
gchar * e_vcard_to_string (EVCard *evc,EVCardFormat format);
Exports evc
 to a string representation, specified
by the format
 argument.
void
e_vcard_dump_structure (EVCard *evc);
Prints a dump of evc
's structure to stdout. Used for
debugging.
EVCardAttribute * e_vcard_attribute_new (const gchar *attr_group,const gchar *attr_name);
Creates a new EVCardAttribute with the specified group and
attribute names. The attr_group
 may be NULL or the empty string if no
group is needed.
void
e_vcard_attribute_free (EVCardAttribute *attr);
Frees an attribute, its values and its parameters.
EVCardAttribute *
e_vcard_attribute_copy (EVCardAttribute *attr);
Makes a copy of attr
.
void e_vcard_remove_attributes (EVCard *evc,const gchar *attr_group,const gchar *attr_name);
Removes all the attributes with group name and attribute name equal to the
passed in values. If attr_group
 is NULL or an empty string,
it removes all the attributes with passed in name irrespective of
their group names.
void e_vcard_remove_attribute (EVCard *evc,EVCardAttribute *attr);
Removes attr
 from evc
 and frees it. This takes ownership of attr
.
void e_vcard_append_attribute (EVCard *evc,EVCardAttribute *attr);
Appends attr
 to evc
 to the end of a list of attributes. This takes
ownership of attr
.
Since: 2.32
void e_vcard_append_attribute_with_value (EVCard *evcard,EVCardAttribute *attr,const gchar *value);
Appends attr
 to evcard
, setting it to value
. This takes ownership of
attr
.
This is a convenience wrapper around e_vcard_attribute_add_value() and
e_vcard_append_attribute().
| evcard | an EVCard | |
| attr | an EVCardAttribute to append. | [transfer full] | 
| value | a value to assign to the attribute | 
Since: 2.32
void e_vcard_append_attribute_with_values (EVCard *evcard,EVCardAttribute *attr,...);
Appends attr
 to evcard
, assigning the list of values to it. This takes
ownership of attr
.
This is a convenience wrapper around e_vcard_attribute_add_value() and
e_vcard_append_attribute().
| evcard | an  | |
| attr | an EVCardAttribute to append. | [transfer full] | 
| ... | a  | 
Since: 2.32
void e_vcard_add_attribute (EVCard *evc,EVCardAttribute *attr);
Prepends attr
 to evc
. This takes ownership of attr
.
void e_vcard_add_attribute_with_value (EVCard *evcard,EVCardAttribute *attr,const gchar *value);
Prepends attr
 to evcard
, setting it to value
. This takes ownership of
attr
.
This is a convenience wrapper around e_vcard_attribute_add_value() and
e_vcard_add_attribute().
| evcard | an EVCard | |
| attr | an EVCardAttribute to add. | [transfer full] | 
| value | a value to assign to the attribute | 
void e_vcard_add_attribute_with_values (EVCard *evcard,EVCardAttribute *attr,...);
Prepends attr
 to evcard
, assigning the list of values to it. This takes
ownership of attr
.
This is a convenience wrapper around e_vcard_attribute_add_value() and
e_vcard_add_attribute().
| evcard | an  | |
| attr | an EVCardAttribute to add. | [transfer full] | 
| ... | a  | 
void e_vcard_attribute_add_value (EVCardAttribute *attr,const gchar *value);
Appends value
 to attr
's list of values.
void e_vcard_attribute_add_value_decoded (EVCardAttribute *attr,const gchar *value,gint len);
Encodes value
 according to the encoding used for attr
, and appends it to
attr
's list of values.
This should only be used if the EVCardAttribute has a non-raw encoding (i.e. if it’s encoded in base-64 or quoted-printable encoding).
void e_vcard_attribute_add_values (EVCardAttribute *attr,...);
Appends a list of values to attr
.
void e_vcard_attribute_remove_value (EVCardAttribute *attr,const gchar *s);
Removes value s
 from the value list in attr
. The value s
 is not freed.
void
e_vcard_attribute_remove_values (EVCardAttribute *attr);
Removes and frees all values from attr
.
void
e_vcard_attribute_remove_params (EVCardAttribute *attr);
Removes and frees all parameters from attr
.
This also resets the EVCardAttribute's encoding back to raw.
void e_vcard_attribute_remove_param (EVCardAttribute *attr,const gchar *param_name);
Removes and frees parameter param_name
 from the attribute attr
. Parameter
names are guaranteed to be unique, so attr
 is guaranteed to have no
parameters named param_name
 after this function returns.
Since: 1.12
void e_vcard_attribute_remove_param_value (EVCardAttribute *attr,const gchar *param_name,const gchar *s);
Removes the value s
 from the parameter param_name
 on the attribute attr
.
If s
 was the only value for parameter param_name
, that parameter is removed
entirely from attr
 and freed.
EVCardAttributeParam *
e_vcard_attribute_param_new (const gchar *name);
Creates a new parameter named name
.
void
e_vcard_attribute_param_free (EVCardAttributeParam *param);
Frees param
 and its values.
EVCardAttributeParam *
e_vcard_attribute_param_copy (EVCardAttributeParam *param);
Makes a copy of param
 and all its values.
void e_vcard_attribute_add_param (EVCardAttribute *attr,EVCardAttributeParam *param);
Prepends param
 to attr
's list of parameters. This takes ownership of
param
 (and all its values).
Duplicate parameters have their values merged, so that all parameter names
in attr
 are unique. Values are also merged so that uniqueness is preserved.
void e_vcard_attribute_add_param_with_value (EVCardAttribute *attr,EVCardAttributeParam *param,const gchar *value);
Appends value
 to param
, then prepends param
 to attr
. This takes ownership
of param
, but not of value
.
This is a convenience method for e_vcard_attribute_param_add_value() and
e_vcard_attribute_add_param().
void e_vcard_attribute_add_param_with_values (EVCardAttribute *attr,EVCardAttributeParam *param,...);
Appends the list of values to param
, then prepends param
 to attr
. This
takes ownership of param
, but not of the list of values.
This is a convenience method for e_vcard_attribute_param_add_value() and
e_vcard_attribute_add_param().
void e_vcard_attribute_param_add_value (EVCardAttributeParam *param,const gchar *value);
Appends value
 to param
's list of values.
void e_vcard_attribute_param_add_values (EVCardAttributeParam *param,...);
Appends a list of values to param
.
void
e_vcard_attribute_param_remove_values (EVCardAttributeParam *param);
Removes and frees all values from param
.
EVCardAttribute * e_vcard_get_attribute (EVCard *evc,const gchar *name);
Get the attribute name
 from evc
.  The EVCardAttribute is owned by
evcard
 and should not be freed. If the attribute does not exist, NULL is
returned.
This will only return the first attribute
with the given name. To get other attributes of that name (for example,
other TEL attributes if a contact has multiple telephone
numbers), use e_vcard_get_attributes() and iterate over the list searching
for matching attributes.
This method iterates over all attributes in the EVCard, so should not
be called often. If extracting a large number of attributes from a vCard, it
is more efficient to iterate once over the list returned by
e_vcard_get_attributes().
EVCardAttribute * e_vcard_get_attribute_if_parsed (EVCard *evc,const gchar *name);
Similar to e_vcard_get_attribute() but this method will not attempt to
parse the vCard if it is not already parsed.
Since: 3.4
GList *
e_vcard_get_attributes (EVCard *evcard);
Gets the list of all attributes from evcard
. The list and its
contents are owned by evcard
, and must not be freed.
const gchar *
e_vcard_attribute_get_group (EVCardAttribute *attr);
Gets the group name of attr
.
const gchar *
e_vcard_attribute_get_name (EVCardAttribute *attr);
Gets the name of attr
.
GList *
e_vcard_attribute_get_values (EVCardAttribute *attr);
Gets the ordered list of values from attr
. The list and its
contents are owned by attr
, and must not be freed.
For example, for an ADR (postal address) attribute, this will
return the components of the postal address.
This may be called on a single-valued attribute (i.e. one for which
e_vcard_attribute_is_single_valued() returns TRUE) and will return a
one-element list in that case. Alternatively, use
e_vcard_attribute_get_value() in such cases.
A list of string values. They
will all be non-NULL, but may be empty strings. The list itself may be
empty. 
[transfer none][element-type utf8]
GList *
e_vcard_attribute_get_values_decoded (EVCardAttribute *attr);
Gets the ordered list of values from attr
, decoding them if
necessary according to the encoding given in the vCard’s
ENCODING attribute. The list and its contents are owned by
attr
, and must not be freed.
This may be called on a single-valued attribute (i.e. one for which
e_vcard_attribute_is_single_valued() returns TRUE) and will return a
one-element list in that case. Alternatively, use
e_vcard_attribute_get_value_decoded() in such cases.
gboolean
e_vcard_attribute_is_single_valued (EVCardAttribute *attr);
Checks if attr
 has a single value.
gchar *
e_vcard_attribute_get_value (EVCardAttribute *attr);
Gets the value of a single-valued EVCardAttribute, attr
.
For example, for a FN (full name) attribute, this will
return the contact’s full name as a single string.
This will print a warning if called on an EVCardAttribute which is not
single-valued (i.e. for which e_vcard_attribute_is_single_valued() returns
FALSE). Use e_vcard_attribute_get_values() in such cases instead.
A newly allocated string representing
the value, or NULL if the attribute has no value. 
[nullable]
GString *
e_vcard_attribute_get_value_decoded (EVCardAttribute *attr);
Gets the value of a single-valued EVCardAttribute, attr
, decoding
it if necessary according to the encoding given in the vCard’s
ENCODING attribute.
This will print a warning if called on an EVCardAttribute which is not
single-valued (i.e. for which e_vcard_attribute_is_single_valued() returns
FALSE). Use e_vcard_attribute_get_values_decoded() in such cases instead.
GList *
e_vcard_attribute_get_params (EVCardAttribute *attr);
Gets the list of parameters (of type EVCardAttributeParam) from attr
. The
list and its contents are owned by attr
, and must not be freed.
A list of elements of type EVCardAttributeParam.
[transfer none][element-type EVCardAttributeParam]
GList * e_vcard_attribute_get_param (EVCardAttribute *attr,const gchar *name);
Gets the list of values for the paramater name
 from attr
. The list and its
contents are owned by attr
, and must not be freed. If no parameter with the
given name
 exists, NULL is returned.
A list of string
elements representing the parameter's values, or NULL. 
[transfer none][element-type utf8][nullable]
const gchar *
e_vcard_attribute_param_get_name (EVCardAttributeParam *param);
Gets the name of param
.
For example, for the only parameter of the vCard attribute:
| 1 | TEL;TYPE=WORK,VOICE:(111) 555-1212 | 
this would return TYPE (which is string-equivalent to
EVC_TYPE).
GList *
e_vcard_attribute_param_get_values (EVCardAttributeParam *param);
Gets the list of values from param
. The list and its
contents are owned by param
, and must not be freed.
For example, for the TYPE parameter of the vCard attribute:
| 1 | TEL;TYPE=WORK,VOICE:(111) 555-1212 | 
this would return the list WORK, VOICE.
gboolean e_vcard_attribute_has_type (EVCardAttribute *attr,const gchar *typestr);
Checks if attr
 has an EVCardAttributeParam with name EVC_TYPE and typestr
as one of its values.
For example, for the vCard attribute:
| 1 | TEL;TYPE=WORK,VOICE:(111) 555-1212 | 
the following holds true:
| 1 2 3 | g_assert_true (e_vcard_attribute_has_type (attr, "WORK") == TRUE); g_assert_true (e_vcard_attribute_has_type (attr, "voice") == TRUE); g_assert_true (e_vcard_attribute_has_type (attr, "HOME") == FALSE); | 
Comparisons against typestr
 are case-insensitive.
gchar *
e_vcard_escape_string (const gchar *s);
Escapes a string according to RFC2426, section 5.
gchar *
e_vcard_unescape_string (const gchar *s);
Unescapes a string according to RFC2426, section 5.
void e_vcard_util_set_x_attribute (EVCard *vcard,const gchar *x_name,const gchar *value);
Sets an "X-" attribute x_name
 to value value
 in vcard
, or
removes it from vcard
, when value
 is NULL.
Since: 3.26
#define EVC_X_DEST_EMAIL "X-EVOLUTION-DEST-EMAIL"
EVC_X_DEST_EMAIL is deprecated and should not be used in newly-written code.
#define EVC_X_DEST_NAME "X-EVOLUTION-DEST-NAME"
EVC_X_DEST_NAME is deprecated and should not be used in newly-written code.
#define E_TYPE_VCARD_PARAM_ATTRIBUTE (e_vcard_attribute_param_get_type ())