aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/e-meeting-types.h
blob: 49ddaf22e37bcad4eafc078f1357dc8b6aaa2649 (plain) (blame)
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) version 3.
 *
 * 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with the program; if not, see <http://www.gnu.org/licenses/>
 *
 *
 * Authors:
 *      JP Rosevear <jpr@novell.com>
 *
 * Copyright (C) 1999-2008 Novell, Inc. (www.novell.com)
 *
 */

#ifndef _E_MEETING_TYPES_H_
#define _E_MEETING_TYPES_H_

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <glib.h>
#include "e-meeting-types.h"

G_BEGIN_DECLS



typedef struct _EMeetingTime               EMeetingTime;
typedef struct _EMeetingFreeBusyPeriod     EMeetingFreeBusyPeriod;

/* These are used to specify whether an attendee is free or busy at a
   particular time. We'll probably replace this with a global calendar type.
   These should be ordered in increasing order of preference. Higher precedence
   busy periods will be painted over lower precedence ones. These are also
   used as for loop counters, so they should start at 0 and be ordered. */
typedef enum
{
    E_MEETING_FREE_BUSY_TENTATIVE       = 0,
    E_MEETING_FREE_BUSY_OUT_OF_OFFICE   = 1,
    E_MEETING_FREE_BUSY_BUSY        = 2,
    E_MEETING_FREE_BUSY_FREE        = 3,

    E_MEETING_FREE_BUSY_LAST        = 4
} EMeetingFreeBusyType;

/* This is our representation of a time. We use a GDate to store the day,
   and guint8s for the hours and minutes. */
struct _EMeetingTime
{
    GDate   date;
    guint8  hour;
    guint8  minute;
};

/* This represents a busy period. */
struct _EMeetingFreeBusyPeriod
{
    EMeetingTime start;
    EMeetingTime end;
    EMeetingFreeBusyType busy_type;
};

G_END_DECLS

#endif /* _E_MEETING_TYPES_H_ */