Logo Search packages:      
Sourcecode: libical version File versions


/* -*- Mode: C -*-
  FILE: testclassify.c
  CREATOR: eric 11 February 2000
  $Id: testclassify.c,v 1.6 2008-01-02 20:07:46 dothebart Exp $
  $Locker:  $
 (C) COPYRIGHT 2000 Eric Busboom

 The contents of this file are subject to the Mozilla Public License
 Version 1.0 (the "License"); you may not use this file except in
 compliance with the License. You may obtain a copy of the License at
 Software distributed under the License is distributed on an "AS IS"
 basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
 the License for the specific language governing rights and
 limitations under the License.
 The Original Code is eric. The Initial Developer of the Original
 Code is Eric Busboom


#include <stdio.h> /* for printf */
#include <libical/ical.h>
#include <errno.h>
#include <string.h> /* For strerror */
#include <libicalss/icalss.h>

/* Get a note about the purpose of the property*/
const char* get_note(icalcomponent *c)
    icalproperty *p;
    const char* note = 0;

    if(c != 0){
        for(p = icalcomponent_get_first_property(c,ICAL_X_PROPERTY);
            p!= 0;
            p = icalcomponent_get_next_property(c,ICAL_X_PROPERTY)){
            note = icalproperty_get_x(p);
    if(note == 0){
        note = "None";
    return note;

int main(int argc, char* argv[])
    icalcomponent *c;
    int i=0;

    /* Open up the two storage files, one for the incomming components, 
       one for the calendar */
    icalfileset_options options = {O_RDONLY, 0644, 0};
    icalset* incoming = icalset_new(ICAL_FILE_SET, TEST_DATADIR "/incoming.ics", &options);
    icalset* cal = icalset_new(ICAL_FILE_SET, TEST_DATADIR "/calendar.ics", &options);

    assert(incoming!= 0);

    /* Iterate through all of the incoming components */
      icalproperty_xlicclass class;
      icalcomponent *match = 0;
        const char* this_uid;


        /* Check this component against the restrictions imposed by
           iTIP. An errors will be inserted as X-LIC-ERROR properties
           in the component. The Parser will also insert errors if it
           cannot parse the component */

        /* If there are any errors, print out the component */
        if(icalcomponent_count_errors(c) != 0){
            printf("----- Component has errors ------- \n%s-----------------\n",

        /* Use one of the icalcomponent convenience routines to get
           the UID. This routine will save you from having to use
           icalcomponent_get_first_property(), checking the return
           value, and then calling icalproperty_get_uid. There are
           several other convenience routines for DTSTART, DTEND,
      this_uid = icalcomponent_get_uid(c);

        if(this_uid != 0){
            /* Look in the calendar for a component with the same UID
               as the incomming component. We should reall also be
               checking the RECURRENCE-ID. Another way to do this
               operation is to us icalset_find_match(), which does use
               the RECURRENCE-ID. */
            match = icalset_fetch(cal,this_uid);

        /* Classify the incoming component. The third argument is the
           calid of the user who owns the calendar. In a real program,
           you would probably switch() on the class.*/
      class = icalclassify(c,match,"A@example.com");

      printf("Test %d\n\
Incoming:      %s\n\
Matched:       %s\n\
Classification: %s\n\n",

    return 0;

Generated by  Doxygen 1.6.0   Back to index