elm_entry: fix typos
[framework/uifw/elementary.git] / src / lib / elm_calendar.h
index 2e083b4..6778018 100644 (file)
-   /**
-    * @addtogroup Calendar
-    * @{
-    */
+/**
+ * @defgroup Calendar Calendar
+ * @ingroup Elementary
+ *
+ * This is a Calendar widget. Calender widget helps applications to flexibly
+ * display a calender with day of the week, day, year and month. Applications will be
+ * able to choose a specific date that will be reported in the smart_callbacks for
+ * the calendar widget. The APIs of calendar widget let the applications perform
+ * other functions like,
+ * placing marks on specific dates
+ * Setting the bounds for the calendar (minimum and maximum years)
+ * Setting the day names of the week. ( for ex. Thu. or Thursday)
+ * Setting the year and month format.
+ *
+ * Signals that you can add callbacks for are:
+ * - @c "changed" - emitted when the date in the calendar is changed.
+ *
+ * Supported elm_object common APIs.
+ * @li @ref elm_object_signal_emit
+ * @li @ref elm_object_signal_callback_add
+ * @li @ref elm_object_signal_callback_del
+ *
+ * Here is some sample code using it:
+ * @li @ref calendar_example_01
+ * @li @ref calendar_example_02
+ * @li @ref calendar_example_03
+ * @li @ref calendar_example_04
+ * @li @ref calendar_example_05
+ * @li @ref calendar_example_06
+ */
 
-   /**
-    * @enum _Elm_Calendar_Mark_Repeat
-    * @typedef Elm_Calendar_Mark_Repeat
-    *
-    * Event periodicity, used to define if a mark should be repeated
-    * @b beyond event's day. It's set when a mark is added.
-    *
-    * So, for a mark added to 13th May with periodicity set to WEEKLY,
-    * there will be marks every week after this date. Marks will be displayed
-    * at 13th, 20th, 27th, 3rd June ...
-    *
-    * Values don't work as bitmask, only one can be choosen.
-    *
-    * @see elm_calendar_mark_add()
-    *
-    * @ingroup Calendar
-    */
-   typedef enum _Elm_Calendar_Mark_Repeat
-     {
-        ELM_CALENDAR_UNIQUE, /**< Default value. Marks will be displayed only on event day. */
-        ELM_CALENDAR_DAILY, /**< Marks will be displayed everyday after event day (inclusive). */
-        ELM_CALENDAR_WEEKLY, /**< Marks will be displayed every week after event day (inclusive) - i.e. each seven days. */
-        ELM_CALENDAR_MONTHLY, /**< Marks will be displayed every month day that coincides to event day. E.g.: if an event is set to 30th Jan, no marks will be displayed on Feb, but will be displayed on 30th Mar*/
-        ELM_CALENDAR_ANNUALLY /**< Marks will be displayed every year that coincides to event day (and month). E.g. an event added to 30th Jan 2012 will be repeated on 30th Jan 2013. */
-     } Elm_Calendar_Mark_Repeat;
+/**
+ * @addtogroup Calendar
+ * @{
+ */
 
-   typedef struct _Elm_Calendar_Mark Elm_Calendar_Mark; /**< Item handle for a calendar mark. Created with elm_calendar_mark_add() and deleted with elm_calendar_mark_del(). */
+typedef enum
+{
+   ELM_CALENDAR_UNIQUE, /**< Default value. Marks will be displayed only on event day. */
+   ELM_CALENDAR_DAILY, /**< Marks will be displayed every day after event day (inclusive). */
+   ELM_CALENDAR_WEEKLY, /**< Marks will be displayed every week after event day (inclusive) - i.e. each seven days. */
+   ELM_CALENDAR_MONTHLY, /**< Marks will be displayed every month day that coincides to event day. E.g.: if an event is set to 30th Jan, no marks will be displayed on Feb, but will be displayed on 30th Mar*/
+   ELM_CALENDAR_ANNUALLY /**< Marks will be displayed every year that coincides to event day (and month). E.g. an event added to 30th Jan 2012 will be repeated on 30th Jan 2013. */
+} _Elm_Calendar_Mark_Repeat_Type;
 
-   /**
-    * Add a new calendar widget to the given parent Elementary
-    * (container) object.
-    *
-    * @param parent The parent object.
-    * @return a new calendar widget handle or @c NULL, on errors.
-    *
-    * This function inserts a new calendar widget on the canvas.
-    *
-    * @ref calendar_example_01
-    *
-    * @ingroup Calendar
-    */
-   EAPI Evas_Object       *elm_calendar_add(Evas_Object *parent) EINA_ARG_NONNULL(1);
+/**
+ * @enum _Elm_Calendar_Mark_Repeat_Type
+ * @typedef Elm_Calendar_Mark_Repeat_Type
+ *
+ * Event periodicity, used to define if a mark should be repeated
+ * @b beyond event's day. It's set when a mark is added.
+ *
+ * So, for a mark added to 13th May with periodicity set to WEEKLY,
+ * there will be marks every week after this date. Marks will be displayed
+ * at 13th, 20th, 27th, 3rd June ...
+ *
+ * Values don't work as bitmask, only one can be chosen.
+ *
+ * @see elm_calendar_mark_add()
+ *
+ * @ingroup Calendar
+ */
+typedef _Elm_Calendar_Mark_Repeat_Type Elm_Calendar_Mark_Repeat_Type;
 
-   /**
-    * Get weekdays names displayed by the calendar.
-    *
-    * @param obj The calendar object.
-    * @return Array of seven strings to be used as weekday names.
-    *
-    * By default, weekdays abbreviations get from system are displayed:
-    * E.g. for an en_US locale: "Sun, Mon, Tue, Wed, Thu, Fri, Sat"
-    * The first string is related to Sunday, the second to Monday...
-    *
-    * @see elm_calendar_weekdays_name_set()
-    *
-    * @ref calendar_example_05
-    *
-    * @ingroup Calendar
-    */
-   EAPI const char       **elm_calendar_weekdays_names_get(const Evas_Object *obj) EINA_ARG_NONNULL(1);
+typedef enum
+{
+   ELM_DAY_SUNDAY,
+   ELM_DAY_MONDAY,
+   ELM_DAY_TUESDAY,
+   ELM_DAY_WEDNESDAY,
+   ELM_DAY_THURSDAY,
+   ELM_DAY_FRIDAY,
+   ELM_DAY_SATURDAY,
+   ELM_DAY_LAST
+} _Elm_Calendar_Weekday;
 
-   /**
-    * Set weekdays names to be displayed by the calendar.
-    *
-    * @param obj The calendar object.
-    * @param weekdays Array of seven strings to be used as weekday names.
-    * @warning It must have 7 elements, or it will access invalid memory.
-    * @warning The strings must be NULL terminated ('@\0').
-    *
-    * By default, weekdays abbreviations get from system are displayed:
-    * E.g. for an en_US locale: "Sun, Mon, Tue, Wed, Thu, Fri, Sat"
-    *
-    * The first string should be related to Sunday, the second to Monday...
-    *
-    * The usage should be like this:
-    * @code
-    *   const char *weekdays[] =
-    *   {
-    *      "Sunday", "Monday", "Tuesday", "Wednesday",
-    *      "Thursday", "Friday", "Saturday"
-    *   };
-    *   elm_calendar_weekdays_names_set(calendar, weekdays);
-    * @endcode
-    *
-    * @see elm_calendar_weekdays_name_get()
-    *
-    * @ref calendar_example_02
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_weekdays_names_set(Evas_Object *obj, const char *weekdays[]) EINA_ARG_NONNULL(1, 2);
+/**
+ * @enum _Elm_Calendar_Weekday
+ * @typedef Elm_Calendar_Weekday
+ *
+ * a weekday
+ *
+ * @see elm_calendar_first_day_of_week_set()
+ *
+ * @ingroup Calendar
+ */
+typedef _Elm_Calendar_Weekday Elm_Calendar_Weekday;
 
-   /**
-    * Set the minimum and maximum values for the year
-    *
-    * @param obj The calendar object
-    * @param min The minimum year, greater than 1901;
-    * @param max The maximum year;
-    *
-    * Maximum must be greater than minimum, except if you don't wan't to set
-    * maximum year.
-    * Default values are 1902 and -1.
-    *
-    * If the maximum year is a negative value, it will be limited depending
-    * on the platform architecture (year 2037 for 32 bits);
-    *
-    * @see elm_calendar_min_max_year_get()
-    *
-    * @ref calendar_example_03
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_min_max_year_set(Evas_Object *obj, int min, int max) EINA_ARG_NONNULL(1);
 
-   /**
-    * Get the minimum and maximum values for the year
-    *
-    * @param obj The calendar object.
-    * @param min The minimum year.
-    * @param max The maximum year.
-    *
-    * Default values are 1902 and -1.
-    *
-    * @see elm_calendar_min_max_year_get() for more details.
-    *
-    * @ref calendar_example_05
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_min_max_year_get(const Evas_Object *obj, int *min, int *max) EINA_ARG_NONNULL(1);
+typedef enum
+{
+   ELM_CALENDAR_SELECT_MODE_DEFAULT = 0, /**< Default value. a day is always selected. */
+   ELM_CALENDAR_SELECT_MODE_ALWAYS, /**< a day is always selected. */
+   ELM_CALENDAR_SELECT_MODE_NONE, /**< None of the days can be selected. */
+   ELM_CALENDAR_SELECT_MODE_ONDEMAND /**< User may have selected a day or not. (not supported yet)*/
+} _Elm_Calendar_Select_Mode;
 
-   /**
-    * Enable or disable day selection
-    *
-    * @param obj The calendar object.
-    * @param enabled @c EINA_TRUE to enable selection or @c EINA_FALSE to
-    * disable it.
-    *
-    * Enabled by default. If disabled, the user still can select months,
-    * but not days. Selected days are highlighted on calendar.
-    * It should be used if you won't need such selection for the widget usage.
-    *
-    * When a day is selected, or month is changed, smart callbacks for
-    * signal "changed" will be called.
-    *
-    * @see elm_calendar_day_selection_enable_get()
-    *
-    * @ref calendar_example_04
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_day_selection_enabled_set(Evas_Object *obj, Eina_Bool enabled) EINA_ARG_NONNULL(1);
+/**
+ * @enum _Elm_Calendar_Select_Mode
+ * @typedef Elm_Calendar_Select_Mode
+ *
+ * the mode, who determine how user could select a day
+ *
+ * @see elm_calendar_select_mode_set()
+ *
+ * @ingroup Calendar
+ */
+typedef _Elm_Calendar_Select_Mode Elm_Calendar_Select_Mode;
 
-   /**
-    * Get a value whether day selection is enabled or not.
-    *
-    * @see elm_calendar_day_selection_enable_set() for details.
-    *
-    * @param obj The calendar object.
-    * @return EINA_TRUE means day selection is enabled. EINA_FALSE indicates
-    * it's disabled. If @p obj is NULL, EINA_FALSE is returned.
-    *
-    * @ref calendar_example_05
-    *
-    * @ingroup Calendar
-    */
-   EAPI Eina_Bool          elm_calendar_day_selection_enabled_get(const Evas_Object *obj) EINA_ARG_NONNULL(1);
+typedef struct _Elm_Calendar_Mark Elm_Calendar_Mark;    /**< Item handle for a calendar mark. Created with elm_calendar_mark_add() and deleted with elm_calendar_mark_del(). */
 
+/**
+ * @typedef Elm_Calendar_Format_Cb
+ *
+ * This callback type is used to format the string that will be used
+ * to display month and year.
+ *
+ * @param stime Struct representing time.
+ * @return String representing time that will be set to calendar's text.
+ *
+ * @see elm_calendar_format_function_set()
+ *
+ * @ingroup Calendar
+ */
+typedef char * (*Elm_Calendar_Format_Cb)(struct tm *stime);
 
-   /**
-    * Set selected date to be highlighted on calendar.
-    *
-    * @param obj The calendar object.
-    * @param selected_time A @b tm struct to represent the selected date.
-    *
-    * Set the selected date, changing the displayed month if needed.
-    * Selected date changes when the user goes to next/previous month or
-    * select a day pressing over it on calendar.
-    *
-    * @see elm_calendar_selected_time_get()
-    *
-    * @ref calendar_example_04
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_selected_time_set(Evas_Object *obj, struct tm *selected_time) EINA_ARG_NONNULL(1);
+/**
+ * Add a new calendar widget to the given parent Elementary
+ * (container) object.
+ *
+ * @param parent The parent object.
+ * @return a new calendar widget handle or @c NULL, on errors.
+ *
+ * This function inserts a new calendar widget on the canvas.
+ *
+ * @ref calendar_example_01
+ *
+ * @ingroup Calendar
+ */
+EAPI Evas_Object         *elm_calendar_add(Evas_Object *parent);
 
-   /**
-    * Get selected date.
-    *
-    * @param obj The calendar object
-    * @param selected_time A @b tm struct to point to selected date
-    * @return EINA_FALSE means an error ocurred and returned time shouldn't
-    * be considered.
-    *
-    * Get date selected by the user or set by function
-    * elm_calendar_selected_time_set().
-    * Selected date changes when the user goes to next/previous month or
-    * select a day pressing over it on calendar.
-    *
-    * @see elm_calendar_selected_time_get()
-    *
-    * @ref calendar_example_05
-    *
-    * @ingroup Calendar
-    */
-   EAPI Eina_Bool          elm_calendar_selected_time_get(const Evas_Object *obj, struct tm *selected_time) EINA_ARG_NONNULL(1, 2);
+/**
+ * Get weekdays names displayed by the calendar.
+ *
+ * @param obj The calendar object.
+ * @return Array of seven strings to be used as weekday names.
+ *
+ * By default, weekdays abbreviations get from system are displayed:
+ * E.g. for an en_US locale: "Sun, Mon, Tue, Wed, Thu, Fri, Sat"
+ * The first string is related to Sunday, the second to Monday...
+ *
+ * @see elm_calendar_weekdays_name_set()
+ *
+ * @ref calendar_example_05
+ *
+ * @ingroup Calendar
+ */
+EAPI const char         **elm_calendar_weekdays_names_get(const Evas_Object *obj);
 
-   /**
-    * Set a function to format the string that will be used to display
-    * month and year;
-    *
-    * @param obj The calendar object
-    * @param format_function Function to set the month-year string given
-    * the selected date
-    *
-    * By default it uses strftime with "%B %Y" format string.
-    * It should allocate the memory that will be used by the string,
-    * that will be freed by the widget after usage.
-    * A pointer to the string and a pointer to the time struct will be provided.
-    *
-    * Example:
-    * @code
-    * static char *
-    * _format_month_year(struct tm *selected_time)
-    * {
-    *    char buf[32];
-    *    if (!strftime(buf, sizeof(buf), "%B %Y", selected_time)) return NULL;
-    *    return strdup(buf);
-    * }
-    *
-    * elm_calendar_format_function_set(calendar, _format_month_year);
-    * @endcode
-    *
-    * @ref calendar_example_02
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_format_function_set(Evas_Object *obj, char * (*format_function) (struct tm *stime)) EINA_ARG_NONNULL(1);
+/**
+ * Set weekdays names to be displayed by the calendar.
+ *
+ * @param obj The calendar object.
+ * @param weekdays Array of seven strings to be used as weekday names.
+ * @warning It must have 7 elements, or it will access invalid memory.
+ * @warning The strings must be NULL terminated ('@\0').
+ *
+ * By default, weekdays abbreviations get from system are displayed:
+ * E.g. for an en_US locale: "Sun, Mon, Tue, Wed, Thu, Fri, Sat"
+ *
+ * The first string should be related to Sunday, the second to Monday...
+ *
+ * The usage should be like this:
+ * @code
+ *   const char *weekdays[] =
+ *   {
+ *      "Sunday", "Monday", "Tuesday", "Wednesday",
+ *      "Thursday", "Friday", "Saturday"
+ *   };
+ *   elm_calendar_weekdays_names_set(calendar, weekdays);
+ * @endcode
+ *
+ * @see elm_calendar_weekdays_name_get()
+ *
+ * @ref calendar_example_02
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_weekdays_names_set(Evas_Object *obj, const char *weekdays[]);
 
-   /**
-    * Add a new mark to the calendar
-    *
-    * @param obj The calendar object
-    * @param mark_type A string used to define the type of mark. It will be
-    * emitted to the theme, that should display a related modification on these
-    * days representation.
-    * @param mark_time A time struct to represent the date of inclusion of the
-    * mark. For marks that repeats it will just be displayed after the inclusion
-    * date in the calendar.
-    * @param repeat Repeat the event following this periodicity. Can be a unique
-    * mark (that don't repeat), daily, weekly, monthly or annually.
-    * @return The created mark or @p NULL upon failure.
-    *
-    * Add a mark that will be drawn in the calendar respecting the insertion
-    * time and periodicity. It will emit the type as signal to the widget theme.
-    * Default theme supports "holiday" and "checked", but it can be extended.
-    *
-    * It won't immediately update the calendar, drawing the marks.
-    * For this, call elm_calendar_marks_draw(). However, when user selects
-    * next or previous month calendar forces marks drawn.
-    *
-    * Marks created with this method can be deleted with
-    * elm_calendar_mark_del().
-    *
-    * Example
-    * @code
-    * struct tm selected_time;
-    * time_t current_time;
-    *
-    * current_time = time(NULL) + 5 * 84600;
-    * localtime_r(&current_time, &selected_time);
-    * elm_calendar_mark_add(cal, "holiday", selected_time,
-    *     ELM_CALENDAR_ANNUALLY);
-    *
-    * current_time = time(NULL) + 1 * 84600;
-    * localtime_r(&current_time, &selected_time);
-    * elm_calendar_mark_add(cal, "checked", selected_time, ELM_CALENDAR_UNIQUE);
-    *
-    * elm_calendar_marks_draw(cal);
-    * @endcode
-    *
-    * @see elm_calendar_marks_draw()
-    * @see elm_calendar_mark_del()
-    *
-    * @ref calendar_example_06
-    *
-    * @ingroup Calendar
-    */
-   EAPI Elm_Calendar_Mark *elm_calendar_mark_add(Evas_Object *obj, const char *mark_type, struct tm *mark_time, Elm_Calendar_Mark_Repeat repeat) EINA_ARG_NONNULL(1);
+/**
+ * Set the minimum and maximum values for the year
+ *
+ * @param obj The calendar object
+ * @param min The minimum year, greater than 1901;
+ * @param max The maximum year;
+ *
+ * Maximum must be greater than minimum, except if you don't want to set
+ * maximum year.
+ * Default values are 1902 and -1.
+ *
+ * If the maximum year is a negative value, it will be limited depending
+ * on the platform architecture (year 2037 for 32 bits);
+ *
+ * @see elm_calendar_min_max_year_get()
+ *
+ * @ref calendar_example_03
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_min_max_year_set(Evas_Object *obj, int min, int max);
 
-   /**
-    * Delete mark from the calendar.
-    *
-    * @param mark The mark to be deleted.
-    *
-    * If deleting all calendar marks is required, elm_calendar_marks_clear()
-    * should be used instead of getting marks list and deleting each one.
-    *
-    * @see elm_calendar_mark_add()
-    *
-    * @ref calendar_example_06
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_mark_del(Elm_Calendar_Mark *mark) EINA_ARG_NONNULL(1);
+/**
+ * Get the minimum and maximum values for the year
+ *
+ * @param obj The calendar object.
+ * @param min The minimum year.
+ * @param max The maximum year.
+ *
+ * Default values are 1902 and -1.
+ *
+ * @see elm_calendar_min_max_year_get() for more details.
+ *
+ * @ref calendar_example_05
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_min_max_year_get(const Evas_Object *obj, int *min, int *max);
 
-   /**
-    * Remove all calendar's marks
   *
   * @param obj The calendar object.
-    *
-    * @see elm_calendar_mark_add()
-    * @see elm_calendar_mark_del()
   *
   * @ingroup Calendar
   */
-   EAPI void               elm_calendar_marks_clear(Evas_Object *obj) EINA_ARG_NONNULL(1);
+/**
+ * Set select day mode to use.
+ *
+ * @param obj The calendar object.
+ * @param select_mdoe The select mode to use.
+ *
+ * Set the day selection mode used.
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_select_mode_set(Evas_Object *obj, Elm_Calendar_Select_Mode mode);
 
-   /**
-    * Get a list of all the calendar marks.
-    *
-    * @param obj The calendar object.
-    * @return An @c Eina_List of calendar marks objects, or @c NULL on failure.
-    *
-    * @see elm_calendar_mark_add()
-    * @see elm_calendar_mark_del()
-    * @see elm_calendar_marks_clear()
-    *
-    * @ingroup Calendar
-    */
-   EAPI const Eina_List   *elm_calendar_marks_get(const Evas_Object *obj) EINA_ARG_NONNULL(1);
+/**
+ * Get the select day mode used.
+ *
+ * @param obj The calendar object.
+ *
+ * @return the selected mode
+ *
+ * Get the day selection mode used.
+ *
+ * @see elm_calendar_select_mode_set() for more details
+ *
+ * @ingroup Calendar
+ */
+EAPI Elm_Calendar_Select_Mode elm_calendar_select_mode_get(const Evas_Object *obj);
 
-   /**
-    * Draw calendar marks.
-    *
-    * @param obj The calendar object.
-    *
-    * Should be used after adding, removing or clearing marks.
-    * It will go through the entire marks list updating the calendar.
-    * If lots of marks will be added, add all the marks and then call
-    * this function.
-    *
-    * When the month is changed, i.e. user selects next or previous month,
-    * marks will be drawed.
-    *
-    * @see elm_calendar_mark_add()
-    * @see elm_calendar_mark_del()
-    * @see elm_calendar_marks_clear()
-    *
-    * @ref calendar_example_06
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_marks_draw(Evas_Object *obj) EINA_ARG_NONNULL(1);
+/**
+ * Set selected date to be highlighted on calendar.
+ *
+ * @param obj The calendar object.
+ * @param selected_time A @b tm struct to represent the selected date.
+ *
+ * Set the selected date, changing the displayed month if needed.
+ * Selected date changes when the user goes to next/previous month or
+ * select a day pressing over it on calendar.
+ *
+ * @see elm_calendar_selected_time_get()
+ *
+ * @ref calendar_example_04
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_selected_time_set(Evas_Object *obj, struct tm *selected_time);
 
-   /**
-    * Set a day text color to the same that represents Saturdays.
-    *
-    * @param obj The calendar object.
-    * @param pos The text position. Position is the cell counter, from left
-    * to right, up to down. It starts on 0 and ends on 41.
-    *
-    * @deprecated use elm_calendar_mark_add() instead like:
-    *
-    * @code
-    * struct tm t = { 0, 0, 12, 6, 0, 0, 6, 6, -1 };
-    * elm_calendar_mark_add(obj, "sat", &t, ELM_CALENDAR_WEEKLY);
-    * @endcode
-    *
-    * @see elm_calendar_mark_add()
-    *
-    * @ingroup Calendar
-    */
-   EINA_DEPRECATED EAPI void               elm_calendar_text_saturday_color_set(Evas_Object *obj, int pos) EINA_ARG_NONNULL(1);
+/**
+ * Get selected date.
+ *
+ * @param obj The calendar object
+ * @param selected_time A @b tm struct to point to selected date
+ * @return EINA_FALSE means an error occurred and returned time shouldn't
+ * be considered.
+ *
+ * Get date selected by the user or set by function
+ * elm_calendar_selected_time_set().
+ * Selected date changes when the user goes to next/previous month or
+ * select a day pressing over it on calendar.
+ *
+ * @see elm_calendar_selected_time_get()
+ *
+ * @ref calendar_example_05
+ *
+ * @ingroup Calendar
+ */
+EAPI Eina_Bool            elm_calendar_selected_time_get(const Evas_Object *obj, struct tm *selected_time);
 
-   /**
-    * Set a day text color to the same that represents Sundays.
-    *
-    * @param obj The calendar object.
-    * @param pos The text position. Position is the cell counter, from left
-    * to right, up to down. It starts on 0 and ends on 41.
+/**
+ * Set a function to format the string that will be used to display
+ * month and year;
+ *
+ * @param obj The calendar object
+ * @param format_func Function to set the month-year string given
+ * the selected date
+ *
+ * By default it uses strftime with "%B %Y" format string.
+ * It should allocate the memory that will be used by the string,
+ * that will be freed by the widget after usage.
+ * A pointer to the string and a pointer to the time struct will be provided.
+ *
+ * Example:
+ * @code
+ * static char *
+ * _format_month_year(struct tm *selected_time)
+ * {
+ *    char buf[32];
+ *    if (!strftime(buf, sizeof(buf), "%B %Y", selected_time)) return NULL;
+ *    return strdup(buf);
+ * }
+ *
+ * elm_calendar_format_function_set(calendar, _format_month_year);
+ * @endcode
+ *
+ * @ref calendar_example_02
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_format_function_set(Evas_Object *obj, Elm_Calendar_Format_Cb format_func);
 
-    * @deprecated use elm_calendar_mark_add() instead like:
-    *
-    * @code
-    * struct tm t = { 0, 0, 12, 7, 0, 0, 0, 0, -1 };
-    * elm_calendar_mark_add(obj, "sat", &t, ELM_CALENDAR_WEEKLY);
-    * @endcode
-    *
-    * @see elm_calendar_mark_add()
-    *
-    * @ingroup Calendar
-    */
-   EINA_DEPRECATED EAPI void               elm_calendar_text_sunday_color_set(Evas_Object *obj, int pos) EINA_ARG_NONNULL(1);
+/**
+ * Add a new mark to the calendar
+ *
+ * @param obj The calendar object
+ * @param mark_type A string used to define the type of mark. It will be
+ * emitted to the theme, that should display a related modification on these
+ * days representation.
+ * @param mark_time A time struct to represent the date of inclusion of the
+ * mark. For marks that repeats it will just be displayed after the inclusion
+ * date in the calendar.
+ * @param repeat Repeat the event following this periodicity. Can be a unique
+ * mark (that don't repeat), daily, weekly, monthly or annually.
+ * @return The created mark or @p NULL upon failure.
+ *
+ * Add a mark that will be drawn in the calendar respecting the insertion
+ * time and periodicity. It will emit the type as signal to the widget theme.
+ * Default theme supports "holiday" and "checked", but it can be extended.
+ *
+ * It won't immediately update the calendar, drawing the marks.
+ * For this, call elm_calendar_marks_draw(). However, when user selects
+ * next or previous month calendar forces marks drawn.
+ *
+ * Marks created with this method can be deleted with
+ * elm_calendar_mark_del().
+ *
+ * Example
+ * @code
+ * struct tm selected_time;
+ * time_t current_time;
+ *
+ * current_time = time(NULL) + 5 * 84600;
+ * localtime_r(&current_time, &selected_time);
+ * elm_calendar_mark_add(cal, "holiday", selected_time,
+ *     ELM_CALENDAR_ANNUALLY);
+ *
+ * current_time = time(NULL) + 1 * 84600;
+ * localtime_r(&current_time, &selected_time);
+ * elm_calendar_mark_add(cal, "checked", selected_time, ELM_CALENDAR_UNIQUE);
+ *
+ * elm_calendar_marks_draw(cal);
+ * @endcode
+ *
+ * @see elm_calendar_marks_draw()
+ * @see elm_calendar_mark_del()
+ *
+ * @ref calendar_example_06
+ *
+ * @ingroup Calendar
+ */
+EAPI Elm_Calendar_Mark   *elm_calendar_mark_add(Evas_Object *obj, const char *mark_type, struct tm *mark_time, Elm_Calendar_Mark_Repeat_Type repeat);
 
-   /**
-    * Set a day text color to the same that represents Weekdays.
-    *
-    * @param obj The calendar object
-    * @param pos The text position. Position is the cell counter, from left
-    * to right, up to down. It starts on 0 and ends on 41.
-    *
-    * @deprecated use elm_calendar_mark_add() instead like:
-    *
-    * @code
-    * struct tm t = { 0, 0, 12, 1, 0, 0, 0, 0, -1 };
-    *
-    * elm_calendar_mark_add(obj, "week", &t, ELM_CALENDAR_WEEKLY); // monday
-    * t.tm_tm_mday++; t.tm_wday++; t.tm_yday++;
-    * elm_calendar_mark_add(obj, "week", &t, ELM_CALENDAR_WEEKLY); // tuesday
-    * t.tm_tm_mday++; t.tm_wday++; t.tm_yday++;
-    * elm_calendar_mark_add(obj, "week", &t, ELM_CALENDAR_WEEKLY); // wednesday
-    * t.tm_tm_mday++; t.tm_wday++; t.tm_yday++;
-    * elm_calendar_mark_add(obj, "week", &t, ELM_CALENDAR_WEEKLY); // thursday
-    * t.tm_tm_mday++; t.tm_wday++; t.tm_yday++;
-    * elm_calendar_mark_add(obj, "week", &t, ELM_CALENDAR_WEEKLY); // friday
-    * @endcode
-    *
-    * @see elm_calendar_mark_add()
-    *
-    * @ingroup Calendar
-    */
-   EINA_DEPRECATED EAPI void               elm_calendar_text_weekday_color_set(Evas_Object *obj, int pos) EINA_ARG_NONNULL(1);
+/**
+ * Delete mark from the calendar.
+ *
+ * @param mark The mark to be deleted.
+ *
+ * If deleting all calendar marks is required, elm_calendar_marks_clear()
+ * should be used instead of getting marks list and deleting each one.
+ *
+ * @see elm_calendar_mark_add()
+ *
+ * @ref calendar_example_06
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_mark_del(Elm_Calendar_Mark *mark);
 
-   /**
-    * Set the interval on time updates for an user mouse button hold
-    * on calendar widgets' month selection.
-    *
-    * @param obj The calendar object
-    * @param interval The (first) interval value in seconds
-    *
-    * This interval value is @b decreased while the user holds the
-    * mouse pointer either selecting next or previous month.
-    *
-    * This helps the user to get to a given month distant from the
-    * current one easier/faster, as it will start to change quicker and
-    * quicker on mouse button holds.
-    *
-    * The calculation for the next change interval value, starting from
-    * the one set with this call, is the previous interval divided by
-    * 1.05, so it decreases a little bit.
-    *
-    * The default starting interval value for automatic changes is
-    * @b 0.85 seconds.
-    *
-    * @see elm_calendar_interval_get()
-    *
-    * @ingroup Calendar
-    */
-   EAPI void               elm_calendar_interval_set(Evas_Object *obj, double interval) EINA_ARG_NONNULL(1);
+/**
+ * Remove all calendar's marks
+ *
+ * @param obj The calendar object.
+ *
+ * @see elm_calendar_mark_add()
+ * @see elm_calendar_mark_del()
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_marks_clear(Evas_Object *obj);
 
-   /**
-    * Get the interval on time updates for an user mouse button hold
-    * on calendar widgets' month selection.
-    *
-    * @param obj The calendar object
-    * @return The (first) interval value, in seconds, set on it
-    *
-    * @see elm_calendar_interval_set() for more details
-    *
-    * @ingroup Calendar
-    */
-   EAPI double             elm_calendar_interval_get(const Evas_Object *obj) EINA_ARG_NONNULL(1);
+/**
+ * Get a list of all the calendar marks.
+ *
+ * @param obj The calendar object.
+ * @return An @c Eina_List of calendar marks objects, or @c NULL on failure.
+ *
+ * @see elm_calendar_mark_add()
+ * @see elm_calendar_mark_del()
+ * @see elm_calendar_marks_clear()
+ *
+ * @ingroup Calendar
+ */
+EAPI const Eina_List     *elm_calendar_marks_get(const Evas_Object *obj);
 
-   /**
-    * @}
-    */
+/**
+ * Draw calendar marks.
+ *
+ * @param obj The calendar object.
+ *
+ * Should be used after adding, removing or clearing marks.
+ * It will go through the entire marks list updating the calendar.
+ * If lots of marks will be added, add all the marks and then call
+ * this function.
+ *
+ * When the month is changed, i.e. user selects next or previous month,
+ * marks will be drawn.
+ *
+ * @see elm_calendar_mark_add()
+ * @see elm_calendar_mark_del()
+ * @see elm_calendar_marks_clear()
+ *
+ * @ref calendar_example_06
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_marks_draw(Evas_Object *obj);
 
+/**
+ * Set the interval on time updates for an user mouse button hold
+ * on calendar widgets' month selection.
+ *
+ * @param obj The calendar object
+ * @param interval The (first) interval value in seconds
+ *
+ * This interval value is @b decreased while the user holds the
+ * mouse pointer either selecting next or previous month.
+ *
+ * This helps the user to get to a given month distant from the
+ * current one easier/faster, as it will start to change quicker and
+ * quicker on mouse button holds.
+ *
+ * The calculation for the next change interval value, starting from
+ * the one set with this call, is the previous interval divided by
+ * 1.05, so it decreases a little bit.
+ *
+ * The default starting interval value for automatic changes is
+ * @b 0.85 seconds.
+ *
+ * @see elm_calendar_interval_get()
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_interval_set(Evas_Object *obj, double interval);
+
+/**
+ * Get the interval on time updates for an user mouse button hold
+ * on calendar widgets' month selection.
+ *
+ * @param obj The calendar object
+ * @return The (first) interval value, in seconds, set on it
+ *
+ * @see elm_calendar_interval_set() for more details
+ *
+ * @ingroup Calendar
+ */
+EAPI double               elm_calendar_interval_get(const Evas_Object *obj);
+
+/**
+ * Set the first day of week to use on calendar widgets'.
+ *
+ * @param obj The calendar object
+ * @param day An int which correspond to the first day of the week (Sunday = 0, monday = 1,
+ * ..., saturday = 6)
+ *
+ * @ingroup Calendar
+ */
+EAPI void                 elm_calendar_first_day_of_week_set(Evas_Object *obj, Elm_Calendar_Weekday day);
+
+/**
+ * Get the first day of week, who are used on calendar widgets'.
+ *
+ * @param obj The calendar object
+ * @return An int which correspond to the first day of the week (Sunday = 0, monday = 1,
+ * ..., saturday = 6)
+ *
+ * @see elm_calendar_first_day_of_week_set() for more details
+ *
+ * @ingroup Calendar
+ */
+EAPI Elm_Calendar_Weekday elm_calendar_first_day_of_week_get(const Evas_Object *obj);
+
+/**
+ * @}
+ */