# Libical [![Travis Build Status](https://travis-ci.org/libical/libical.svg?branch=master)](https://travis-ci.org/libical/libical) [![Appveyor Build Status](https://ci.appveyor.com/api/projects/status/github/libical/libical?branch=master?svg=true)](https://ci.appveyor.com/api/projects/status/github/libical/libical) [![Coverity Scan Build Status](https://scan.coverity.com/projects/2367/badge.svg)](https://scan.coverity.com/projects/2367) [![Packaging status](https://repology.org/badge/tiny-repos/libical.svg)](https://repology.org/metapackage/libical) ## Introduction Libical — an implementation of iCalendar protocols and data formats Most of the code in here was written by Eric Busboom at the end of the last millennium with help from dozens of contributors. It is currently maintained by Allen Winter and the libical team at https://github.com/libical/libical. Libical is an Open Source implementation of the iCalendar protocols and protocol data units. The iCalendar specification describes how calendar clients can communicate with calendar servers so users can store their calendar data and arrange meetings with other users. Libical implements [RFC5545][], [RFC5546][], [RFC7529][]; the CalDav scheduling extensions in [RFC6638][]; iCalendar extensions in [RFC7986][]; plus the iCalendar iMIP protocol in [RFC6047][]. [RFC5545]: https://tools.ietf.org/html/rfc5545 [RFC5546]: https://tools.ietf.org/html/rfc5546 [RFC7529]: https://tools.ietf.org/html/rfc7529 [RFC6638]: https://tools.ietf.org/html/rfc6638 [RFC6047]: https://tools.ietf.org/html/rfc6047 [RFC7986]: https://tools.ietf.org/html/rfc7986 The libical-glib API is currently unstable and can change with any release. Until it is considered stable, there should be defined LIBICAL_GLIB_UNSTABLE_API=1 before including , to indicate that the library user is aware of it and is prepared to change the calls anytime. ## License The code and datafiles in this distribution are licensed under the Mozilla Public License (MPL) v2.0. See for a copy of this license. Alternately, you may use libical under the terms of the GNU Lesser General Public License (LGPL) v2.1. See for a copy of this license. This dual license ensures that the library can be incorporated into both proprietary code and GPL'd programs, and will benefit from improvements made by programmers in both realms. I will only accept changes into my version of the library if they are similarly dual-licensed. ## Building See the top-level [Install.txt](Install.txt) file. ## Documentation There is rudimentary, unfinished documentation in the `doc/` directory, see [UsingLibical.md](doc/UsingLibical.md) and annotated examples in `examples/` and the test code in `src/test/`. Additionally, progress is underway to add API documentation, which is available [here](https://libical.github.io/libical/apidocs/index.html) ## Acknowledgments Portions of this distribution are (C) Copyright 1996 Apple Computer, Inc., AT&T Corp., International Business Machines Corporation and Siemens Rolm Communications Inc. See [src/libicalvcal/README.TXT](src/libicalvcal/README.txt) for details. ## Libical Users In no particular order: * [Cyrus Email/Calendars/Contacts Server](https://www.cyrusimap.org) * [syncEvolution](https://syncevolution.org) * [Fantastical](https://flexibits.com/fantastical) * GNOME's EDS (evolution-data-server) which serves data to: * [Evolution](https://wiki.gnome.org/Apps/Evolution) * [GNOME Calendar](https://wiki.gnome.org/Apps/Calendar) * [GNOME Notes](https://wiki.gnome.org/Apps/Notes) * [GNOME Todo](https://wiki.gnome.org/Apps/Todo) * and more GNOME apps... * KDE's [Kontact Suite](https://kontact.kde.org) * [Akonadi framework](https://kontact.kde.org/components/akonadi.html) * [KOrganizer calendar and scheduling component](https://kontact.kde.org/components/korganizer.html) * and more KDE apps... ## Get Involved Subscribe to our mailing lists: For developer discussions For general discussions about libical and related projects Report bugs to our issue tracker at