evolution-sharp r202 - in trunk: . evolution evolution/src
- From: jjohnny svn gnome org
- To: svn-commits-list gnome org
- Subject: evolution-sharp r202 - in trunk: . evolution evolution/src
- Date: Tue, 13 Jan 2009 18:30:11 +0000 (UTC)
Author: jjohnny
Date: Tue Jan 13 18:30:10 2009
New Revision: 202
URL: http://svn.gnome.org/viewvc/evolution-sharp?rev=202&view=rev
Log:
Fixes and Recurrence support from Chenthill <pchenthill novell com> .
Modified:
trunk/ChangeLog
trunk/evolution/Cal.custom
trunk/evolution/CalBackend.custom
trunk/evolution/CalBackendCache.custom
trunk/evolution/Evolution.metadata
trunk/evolution/Icaltimetype.custom
trunk/evolution/Makefile.am
trunk/evolution/TestCache.cs
trunk/evolution/TestCal.cs
trunk/evolution/evolution-api.raw
trunk/evolution/src/CalComponent.cs
trunk/evolution/src/CalComponentDateTime.cs
trunk/evolution/src/CalRecurrence.cs
trunk/evolution/src/CalUtil.cs
Modified: trunk/evolution/Cal.custom
==============================================================================
--- trunk/evolution/Cal.custom (original)
+++ trunk/evolution/Cal.custom Tue Jan 13 18:30:10 2009
@@ -9,6 +9,17 @@
return ret;
}
+ [DllImport("ecal")]
+ static extern unsafe bool e_cal_set_mode (IntPtr raw, CalMode mode);
+
+ public unsafe bool SetMode (CalMode mode)
+ {
+ bool raw_ret = e_cal_set_mode (Handle, mode);
+ bool ret = raw_ret;
+
+ return ret;
+ }
+
public Evolution.CalComponent[] GetItems (string query)
{
IntPtr ecal_objects = IntPtr.Zero;
Modified: trunk/evolution/CalBackend.custom
==============================================================================
--- trunk/evolution/CalBackend.custom (original)
+++ trunk/evolution/CalBackend.custom Tue Jan 13 18:30:10 2009
@@ -20,14 +20,12 @@
}
[DllImport("edatacal")]
- static extern void e_cal_backend_notify_object_removed (IntPtr backend, IntPtr id, IntPtr old_object, IntPtr objekt);
+ static extern void e_cal_backend_notify_object_removed (IntPtr backend, IntPtr id, string old_object, string objekt);
- public void NotifyObjectRemoved (IntPtr id, string old_object, string objekt) {
- IntPtr native_old_object = GLib.Marshaller.StringToPtrGStrdup (old_object);
- IntPtr native_objekt = GLib.Marshaller.StringToPtrGStrdup (objekt);
- e_cal_backend_notify_object_removed (Handle, id, native_old_object, native_objekt);
- GLib.Marshaller.Free (native_old_object);
- GLib.Marshaller.Free (native_objekt);
+ public void NotifyObjectRemoved (CalComponentId id, string oldObject, string newObject) {
+ IntPtr native_id = GLib.Marshaller.StructureToPtrAlloc (id);
+ e_cal_backend_notify_object_removed (Handle, native_id, oldObject, newObject);
+ GLib.Marshaller.Free (native_id);
}
[GLib.CDeclCallback]
Modified: trunk/evolution/CalBackendCache.custom
==============================================================================
--- trunk/evolution/CalBackendCache.custom (original)
+++ trunk/evolution/CalBackendCache.custom Tue Jan 13 18:30:10 2009
@@ -3,18 +3,80 @@
public CalComponent GetComponent (string uid, string rid) {
IntPtr obj;
- CalComponent comp;
+ CalComponent comp = null;
IntPtr native_uid = GLib.Marshaller.StringToPtrGStrdup (uid);
IntPtr native_rid = GLib.Marshaller.StringToPtrGStrdup (rid);
obj = e_cal_backend_cache_get_component (Handle, native_uid, native_rid);
- comp = new CalComponent (obj);
+ if (obj != IntPtr.Zero)
+ comp = new CalComponent (obj);
GLib.Marshaller.Free (native_uid);
GLib.Marshaller.Free (native_rid);
return comp;
}
+
+ [DllImport("libglib-2.0.so.0")]
+ static extern int g_list_length (IntPtr slist);
+
+ [DllImport("glibsharpglue-2")]
+ static extern IntPtr gtksharp_list_get_data (IntPtr slist);
+
+ [DllImport("glibsharpglue-2")]
+ static extern IntPtr gtksharp_list_get_next (IntPtr slist);
+
+ [DllImport("libglib-2.0.so.0")]
+ static extern void g_list_free (IntPtr slist);
+
+
+ [DllImport("edatacal")]
+ static extern IntPtr e_cal_backend_cache_get_components (IntPtr cache);
+
+ public CalComponent [] Components
+ {
+ get
+ {
+ IntPtr list = e_cal_backend_cache_get_components (Handle);
+ int i = 0;
+ IntPtr iter = IntPtr.Zero;
+
+ int len = g_list_length (list);
+ CalComponent[] compArray = new CalComponent [len];
+
+ for (i = 0, iter=list; iter != IntPtr.Zero; iter = gtksharp_list_get_next (iter), i++)
+ {
+ IntPtr comp = gtksharp_list_get_data (iter);
+ compArray[i] = new CalComponent (comp);
+ }
+ g_list_free (list);
+
+ return compArray;
+
+ }
+ }
+
+ [DllImport("edatacal")]
+ static extern IntPtr e_cal_backend_cache_get_components_by_uid (IntPtr cache, string uid);
+
+ public CalComponent [] ComponentsByUid (string uid)
+ {
+ IntPtr list = e_cal_backend_cache_get_components_by_uid (Handle, uid);
+ int i = 0;
+ IntPtr iter = IntPtr.Zero;
+
+ int len = g_list_length (list);
+ CalComponent[] compArray = new CalComponent [len];
+
+ for (i = 0, iter=list; iter != IntPtr.Zero; iter = gtksharp_list_get_next (iter), i++)
+ {
+ IntPtr comp = gtksharp_list_get_data (iter);
+ compArray[i] = new CalComponent (comp);
+ }
+ g_list_free (list);
+
+ return compArray;
+ }
[DllImport("edatacal")]
static extern bool e_cal_backend_cache_put_component (IntPtr cache, IntPtr comp);
Modified: trunk/evolution/Evolution.metadata
==============================================================================
--- trunk/evolution/Evolution.metadata (original)
+++ trunk/evolution/Evolution.metadata Tue Jan 13 18:30:10 2009
@@ -60,7 +60,8 @@
<attr path="/api/namespace/struct[ cname='EDataCal']" name="hidden">1</attr>
<attr path="/api/namespace/struct[ cname='EDataCalClass']" name="hidden">1</attr>
<attr path="/api/namespace/object[ name='']" name="hidden">1</attr>
- <attr path="/api/namespace/struct[ name='Icaltimetype']" name="opaque">true</attr>
+ <attr path="/api/namespace/object[ name='CalBackendCache']/method[ name='GetComponents']" name="hidden">1</attr>
+ <attr path="/api/namespace/object[ name='CalBackendCache']/method[ name='GetComponentsByUid']" name="hidden">1</attr>
<attr path="/api/namespace" name="name">Evolution</attr>
<!-- Using custom for these signals because of BGO#555242 -->
Modified: trunk/evolution/Icaltimetype.custom
==============================================================================
--- trunk/evolution/Icaltimetype.custom (original)
+++ trunk/evolution/Icaltimetype.custom Tue Jan 13 18:30:10 2009
@@ -1,143 +1,28 @@
- [DllImport("evolutionglue")]
- public static extern IntPtr e_cal_alloc_icaltimetype ();
-
- public Icaltimetype ()
+ public DateTime AsDateTimeUtc
{
- Raw = e_cal_alloc_icaltimetype ();
- }
-
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_month (IntPtr dt, int month);
-
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_day (IntPtr dt, int day);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_year (IntPtr dt, int year);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_minute (IntPtr dt, int minute);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_second (IntPtr dt, int second);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_hour (IntPtr dt, int hour);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_is_utc (IntPtr dt, int is_utc);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_is_day (IntPtr dt, int is_day);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_is_daylight (IntPtr dt, int is_daylight);
- [DllImport("evolutionglue")]
- public static extern void e_cal_glue_set_itt_zone (IntPtr dt, IntPtr zone);
-
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_month (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_day (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_year (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_hour (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_minute (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_second (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_is_utc (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_is_daylight (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern int e_cal_glue_get_itt_is_day (IntPtr dt);
- [DllImport("evolutionglue")]
- public static extern IntPtr e_cal_glue_get_itt_zone (IntPtr dt);
-
- public int Month {
- get {
- return e_cal_glue_get_itt_month (Raw);
- }
- set {
- e_cal_glue_set_itt_month (Raw, value);
- }
- }
-
- public int Year {
- get {
- return e_cal_glue_get_itt_year (Raw);
- }
- set {
- e_cal_glue_set_itt_year (Raw, value);
- }
- }
-
- public int Day {
- get {
- return e_cal_glue_get_itt_day (Raw);
- }
- set {
- e_cal_glue_set_itt_day (Raw, value);
- }
- }
-
- public int Hour {
- get {
- return e_cal_glue_get_itt_hour (Raw);
- }
- set {
- e_cal_glue_set_itt_hour (Raw, value);
- }
- }
-
-
- public int Minute {
- get {
- return e_cal_glue_get_itt_minute (Raw);
- }
- set {
- e_cal_glue_set_itt_minute (Raw, value);
- }
- }
-
- public int Second {
- get {
- return e_cal_glue_get_itt_second (Raw);
- }
- set {
- e_cal_glue_set_itt_second (Raw, value);
- }
- }
-
- public int Isutc {
- get {
- return e_cal_glue_get_itt_is_utc (Raw);
- }
- set {
- e_cal_glue_set_itt_is_utc (Raw, value);
+ get
+ {
+ IntPtr raw = GLib.Marshaller.StructureToPtrAlloc (this);
+ DateTime dt = CalUtil.icaltimetype_to_datetime (raw, false);
+ Marshal.FreeHGlobal (raw);
+ return dt;
}
}
- public int IsDay {
- get {
- return e_cal_glue_get_itt_is_day (Raw);
- }
- set {
- e_cal_glue_set_itt_is_day (Raw, value);
- }
- }
-
- public int IsDayLight {
- get {
- return e_cal_glue_get_itt_is_daylight (Raw);
- }
- set {
- e_cal_glue_set_itt_is_daylight (Raw, value);
- }
- }
-
- public Icaltimezone Zone {
- get {
- IntPtr raw = e_cal_glue_get_itt_zone (Raw);
+ public DateTime SetDateTime
+ {
+ set
+ {
+ Year = value.Year;
+ Month = value.Month;
+ Day = value.Day;
+ Hour = value.Hour;
+ Second = value.Second;
+ Minute = value.Minute;
+ /*Fixme : Needs Mono 2.0*/
+ //IsDayLight = Convert.ToInt32 (TimeZone.CurrentTimeZone.IsDaylightSavingTime (value));
- return new Icaltimezone (raw);
+ //if (value.Kind == DateTimeKind.Utc)
+ IsUtc = 1;
}
- set {
- e_cal_glue_set_itt_zone (Raw, value.Handle);
- }
- }
+ }
Modified: trunk/evolution/Makefile.am
==============================================================================
--- trunk/evolution/Makefile.am (original)
+++ trunk/evolution/Makefile.am Tue Jan 13 18:30:10 2009
@@ -21,7 +21,7 @@
if USE_EDS_2_24
RAW_API = evolution-api.raw
CUSTOMS_2_24 = Icaltimetype.custom CalBackend.custom CalBackendCache.custom CalBackendSExp.custom
-SOURCES_2_24 = src/CalComponentDateTime.cs
+SOURCES_2_24 = src/CalComponentDateTime.cs src/CalCompChanges.cs
CSFLAGS = -define:USE_EDS_2_24
endif
Modified: trunk/evolution/TestCache.cs
==============================================================================
--- trunk/evolution/TestCache.cs (original)
+++ trunk/evolution/TestCache.cs Tue Jan 13 18:30:10 2009
@@ -17,15 +17,16 @@
/* Creating an Event */
comp.Summary = "1st event";
+ Icaltimezone zon = Icaltimezone.GetBuiltinTimezone ("America/New_York");
CalComponentDateTime dt = new CalComponentDateTime ();
- DateTime n = DateTime.Now;
- Icaltimetype t = dt.value;
- t.Year = n.Year;
- t.Month = n.Month;
- t.Day = n.Day;
- t.Hour = n.Hour;
- t.Second = n.Second;
- Icaltimezone zon = Icaltimezone.GetBuiltinTimezone ("Asia/Kolkata");
+ Icaltimetype icalt= new Icaltimetype ();
+ DateTime n = DateTime.Now.ToUniversalTime ();
+ icalt.SetDateTime = n;
+ icalt.IsUtc = 1;
+ Console.WriteLine ("Before " + icalt.Hour + icalt.Minute);
+ Icaltimezone.ConvertTime (icalt, Icaltimezone.UtcTimezone, zon);
+ Console.WriteLine ("After " + icalt.Hour + icalt.Minute);
+ dt.IcalTime = icalt;
dt.Tzid = zon.Tzid;
comp.DtStart = dt;
@@ -35,20 +36,26 @@
uid = comp.Uid;
/* Inserting a default zone */
- Icaltimezone zone = Icaltimezone.GetBuiltinTimezone ("Asia/Kolkata");
- cache.PutDefaultTimezone (zone);
+ cache.PutDefaultTimezone (zon);
/* Printing the default zone */
Icaltimezone dzone = cache.DefaultTimezone;
string dStr = "Default zone is cache is " + dzone.Location + "\n";
Console.WriteLine (dStr);
+ Console.WriteLine ("Get all components ");
+ CalComponent[] comps = cache.Components;
+ Console.WriteLine (comps.Length);
+ foreach (CalComponent c in comps)
+ {
+ Console.WriteLine (c.GetAsString ());
+ }
+
/* Printing the component */
CalComponent cacheComp = cache.GetComponent (uid, null);
- Console.WriteLine(cacheComp.GetAsString ());
dt = cacheComp.DtStart;
Console.WriteLine("The value of DateTime from Cache \n");
- string dts = "\n" + dt.value.Year + dt.value.Month + dt.value.Day + dt.value.Hour + " " + dt.Tzid;
+ string dts = "\n" + dt.IcalTime.Year + dt.IcalTime.Month + dt.IcalTime.Day + dt.IcalTime.Hour + " " + dt.Tzid;
Console.WriteLine(dts);
Console.WriteLine("Removing the cache!");
Modified: trunk/evolution/TestCal.cs
==============================================================================
--- trunk/evolution/TestCal.cs (original)
+++ trunk/evolution/TestCal.cs Tue Jan 13 18:30:10 2009
@@ -45,22 +45,49 @@
Console.WriteLine ("Location: {0}", comp.Location);
Console.WriteLine ("summary: {0}", comp.Summary);
- Console.WriteLine( "Attendee:" );
- foreach (CalComponentAttendee att in comp.Attendees) {
- Console.WriteLine ("value: \"{0}\"", att.value);
- Console.WriteLine ("member: \"{0}\"", att.member);
- Console.WriteLine ("cutype: \"{0}\"", att.cutype);
- Console.WriteLine ("role: \"{0}\"", att.role);
- Console.WriteLine ("status: \"{0}\"", att.status);
- Console.WriteLine ("rsvp: \"{0}\"", att.rsvp);
- Console.WriteLine ("delto: \"{0}\"", att.delto);
- Console.WriteLine ("delfrom: \"{0}\"", att.delfrom);
- Console.WriteLine ("sentby: \"{0}\"", att.sentby);
- Console.WriteLine ("cn: \"{0}\"", att.cn);
- Console.WriteLine ("language: \"{0}\"", att.language);
- Console.WriteLine ("-----------");
- }
- }
+ Console.WriteLine( "Attendee:" );
+ foreach (CalComponentAttendee att in comp.Attendees) {
+ Console.WriteLine ("value: \"{0}\"", att.value);
+ Console.WriteLine ("member: \"{0}\"", att.member);
+ Console.WriteLine ("cutype: \"{0}\"", att.cutype);
+ Console.WriteLine ("role: \"{0}\"", att.role);
+ Console.WriteLine ("status: \"{0}\"", att.status);
+ Console.WriteLine ("rsvp: \"{0}\"", att.rsvp);
+ Console.WriteLine ("delto: \"{0}\"", att.delto);
+ Console.WriteLine ("delfrom: \"{0}\"", att.delfrom);
+ Console.WriteLine ("sentby: \"{0}\"", att.sentby);
+ Console.WriteLine ("cn: \"{0}\"", att.cn);
+ Console.WriteLine ("language: \"{0}\"", att.language);
+ Console.WriteLine ("-----------");
+ }
+ if (comp.RRules == null) {
+ Console.WriteLine ("No recurrence data found");
+ return;
+ }
+ foreach (CalRecurrence recur in comp.RRules) {
+ Console.WriteLine ("--- Recurrence data starts ---");
+
+ Console.WriteLine ("Frequeny:- {0}", recur.freq);
+ Console.WriteLine ("Count:- {0}", recur.count);
+ Console.WriteLine ("Interval:- {0}", recur.interval);
+// Console.WriteLine ("Enddate:- {0}", recur.Until.DateTime);
+ Console.WriteLine ("BySecond:- {0}", recur.bySecond);
+ Console.WriteLine ("ByMinute:- {0}", recur.byMinute);
+ Console.WriteLine ("ByHour:- {0}", recur.byHour);
+ Console.WriteLine ("ByDay:- {0}", recur.byDay);
+ Console.WriteLine ("ByMonthDay:- {0}", recur.byMonthDay);
+ Console.WriteLine ("ByYearDay:- {0}", recur.byYearDay);
+ Console.WriteLine ("ByWeekNumber:- {0}", recur.byWeekNumber);
+ Console.WriteLine ("ByMonth:- {0}", recur.byMonth);
+ Console.WriteLine ("BySetPos:- {0}", recur.bySetPos);
+
+ Console.WriteLine ("--- Recurrence Data ends ---");
+ Console.WriteLine ("Recur string: \"{0}\"", recur.ToString());
+ }
+
+ }
+
+
Console.WriteLine ("Returning from addedComp");
}
@@ -233,32 +260,31 @@
Console.WriteLine ("language: \"{0}\"", att.language);
Console.WriteLine ("-----------");
}
-#if false
- if (comp.RecurrenceRules == null) {
- Console.WriteLine ("No recurrence data found");
- return;
- }
- foreach (CalRecurrence recur in comp.RecurrenceRules) {
- Console.WriteLine ("--- Recurrence data starts ---");
-
- Console.WriteLine ("Frequeny:- {0}", recur.Frequency);
- Console.WriteLine ("Count:- {0}", recur.Count);
- Console.WriteLine ("Interval:- {0}", recur.Interval);
- Console.WriteLine ("Enddate:- {0}", recur.Enddate);
- Console.WriteLine ("BySecond:- {0}", recur.BySecond);
- Console.WriteLine ("ByMinute:- {0}", recur.BySecond);
- Console.WriteLine ("ByHour:- {0}", recur.ByHour);
- Console.WriteLine ("ByDay:- {0}", recur.ByDay);
- Console.WriteLine ("ByMonthDay:- {0}", recur.ByMonthDay);
- Console.WriteLine ("ByYearDay:- {0}", recur.ByYearDay);
- Console.WriteLine ("ByWeekNumber:- {0}", recur.ByWeekNumber);
- Console.WriteLine ("ByMonth:- {0}", recur.ByMonth);
- Console.WriteLine ("BySetPos:- {0}", recur.BySetPos);
-
- Console.WriteLine ("--- Recurrence Data ends ---");
- Console.WriteLine ("Recur string: \"{0}\"", recur.ToString());
- }
-#endif
+
+ if (comp.RRules == null) {
+ Console.WriteLine ("No recurrence data found");
+ return;
+ }
+ foreach (CalRecurrence recur in comp.RRules) {
+ Console.WriteLine ("--- Recurrence data starts ---");
+
+ Console.WriteLine ("Frequeny:- {0}", recur.Frequency);
+ Console.WriteLine ("Count:- {0}", recur.Count);
+ Console.WriteLine ("Interval:- {0}", recur.Interval);
+ Console.WriteLine ("Enddate:- {0}", recur.Enddate);
+ Console.WriteLine ("BySecond:- {0}", recur.BySecond);
+ Console.WriteLine ("ByMinute:- {0}", recur.BySecond);
+ Console.WriteLine ("ByHour:- {0}", recur.ByHour);
+ Console.WriteLine ("ByDay:- {0}", recur.ByDay);
+ Console.WriteLine ("ByMonthDay:- {0}", recur.ByMonthDay);
+ Console.WriteLine ("ByYearDay:- {0}", recur.ByYearDay);
+ Console.WriteLine ("ByWeekNumber:- {0}", recur.ByWeekNumber);
+ Console.WriteLine ("ByMonth:- {0}", recur.ByMonth);
+ Console.WriteLine ("BySetPos:- {0}", recur.BySetPos);
+
+ Console.WriteLine ("--- Recurrence Data ends ---");
+ Console.WriteLine ("Recur string: \"{0}\"", recur.ToString());
+ }
#if false
if (comp.ExceptionRules != null) {
Console.WriteLine ("No exception rules present");
Modified: trunk/evolution/evolution-api.raw
==============================================================================
--- trunk/evolution/evolution-api.raw (original)
+++ trunk/evolution/evolution-api.raw Tue Jan 13 18:30:10 2009
@@ -3601,22 +3601,22 @@
<return-type type="icalcomponent*" />
</method>
<method name="GetDisplayName" cname="icaltimezone_get_display_name">
- <return-type type="char*" />
+ <return-type type="const-char*" />
</method>
<method name="GetLatitude" cname="icaltimezone_get_latitude">
<return-type type="double" />
</method>
<method name="GetLocation" cname="icaltimezone_get_location">
- <return-type type="char*" />
+ <return-type type="const-char*" />
</method>
<method name="GetLongitude" cname="icaltimezone_get_longitude">
<return-type type="double" />
</method>
<method name="GetTzid" cname="icaltimezone_get_tzid">
- <return-type type="char*" />
+ <return-type type="const-char*" />
</method>
<method name="GetTznames" cname="icaltimezone_get_tznames">
- <return-type type="char*" />
+ <return-type type="const-char*" />
</method>
<method name="GetUtcOffset" cname="icaltimezone_get_utc_offset">
<return-type type="int" />
Modified: trunk/evolution/src/CalComponent.cs
==============================================================================
--- trunk/evolution/src/CalComponent.cs (original)
+++ trunk/evolution/src/CalComponent.cs Tue Jan 13 18:30:10 2009
@@ -10,7 +10,16 @@
Private,
Confidental,
}
-
+
+#if USE_EDS_2_24
+ public enum CalTransparency : int {
+ None,
+ Transparent,
+ Opaque,
+ Unknown,
+ }
+#endif
+
public enum CalPriority : int {
Undefined = 0,
High = 3,
@@ -47,6 +56,20 @@
FreeBusy,
TimeZone
}
+
+#if USE_EDS_2_24
+ public enum CalComponentRangeType {
+ Single,
+ ThisPrior,
+ ThisFuture
+ }
+
+ public struct CalComponentRange {
+ public CalComponentRangeType rangeType;
+ public CalComponentDateTime dt;
+ }
+
+#endif
public struct CalComponentText {
public string value;
@@ -129,6 +152,8 @@
static extern IntPtr e_cal_component_new ();
[DllImport("ecal")]
static extern void e_cal_component_set_new_vtype (IntPtr handle, CalComponentVType type);
+ [DllImport("ecal")]
+ static extern IntPtr e_cal_component_new_from_string (string calobj);
public CalComponent ()
{
@@ -136,6 +161,13 @@
handle = e_cal_component_new ();
ecal = null;
}
+
+ public CalComponent (string calobj)
+ {
+ new_component = true;
+ handle = e_cal_component_new_from_string (calobj);
+ ecal = null;
+ }
public CalComponent (Cal _ecal)
{
@@ -247,6 +279,50 @@
}
}
+#if USE_EDS_2_24
+ [DllImport("ecal")]
+ static extern void e_cal_component_get_recurid (IntPtr handle, out IntPtr recurid);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_recurid (IntPtr handle, IntPtr recurid);
+
+ public DateTime Rid {
+ get
+ {
+ IntPtr native_r = IntPtr.Zero;
+ e_cal_component_get_recurid (Handle, out native_r);
+ CalComponentRange range = (CalComponentRange) Marshal.PtrToStructure (native_r,
+ typeof (CalComponentRange));
+
+ CalComponentDateTime cdt = range.dt;
+ Icaltimetype icalt = cdt.IcalTime;
+ DateTime dt = icalt.AsDateTimeUtc;
+
+ Marshal.FreeHGlobal (native_r);
+ return dt;
+ }
+
+ set
+ {
+ Icaltimetype icalt = new Icaltimetype ();
+ icalt.SetDateTime = value;
+
+ CalComponentDateTime cdt = new CalComponentDateTime ();
+ cdt.IcalTime = icalt;
+ cdt.Tzid = "UTC";
+
+ CalComponentRange range = new CalComponentRange ();
+ range.rangeType = CalComponentRangeType.Single;
+ range.dt = cdt;
+
+ IntPtr raw = Marshal.AllocHGlobal (Marshal.SizeOf (range));
+ Marshal.StructureToPtr (range, raw, false);
+
+ e_cal_component_set_recurid (Handle, raw);
+ Marshal.FreeHGlobal (raw);
+ }
+ }
+#endif
+
[DllImport("ecal")]
static extern void e_cal_component_get_summary (IntPtr raw, ref CalComponentText text);
[DllImport("ecal")]
@@ -312,6 +388,26 @@
}
}
+#if USE_EDS_2_24
+ [DllImport("ecal")]
+ static extern void e_cal_component_get_transparency (IntPtr raw, ref CalTransparency trans);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_transparency (IntPtr raw, CalTransparency trans);
+
+ public CalTransparency Transparency {
+ get
+ {
+ CalTransparency tr = CalTransparency.None;
+ e_cal_component_get_transparency (Handle, ref tr);
+ return tr;
+ }
+ set
+ {
+ e_cal_component_set_transparency (Handle, value);
+ }
+ }
+#endif
+
[DllImport("ecal")]
static extern void e_cal_component_get_location (IntPtr raw, out IntPtr location);
[DllImport("ecal")]
@@ -330,6 +426,21 @@
}
}
+#if USE_EDS_2_24
+ [DllImport("ecal")]
+ static extern bool e_cal_component_is_allday (IntPtr raw);
+
+ public bool IsAllDay
+ {
+ get
+ {
+ bool ret = e_cal_component_is_allday (Handle);
+
+ return ret;
+ }
+ }
+#endif
+
[DllImport("ecal")]
static extern void e_cal_component_get_dtstart (IntPtr raw, IntPtr dt);
[DllImport("ecal")]
@@ -370,6 +481,24 @@
Marshal.FreeHGlobal (native_dt);
}
}
+
+ public CalComponentDateTime DtEnd {
+ get {
+ CalComponentDateTime dt = new CalComponentDateTime ();
+ IntPtr native_dt = GLib.Marshaller.StructureToPtrAlloc (dt);
+ e_cal_component_get_dtend(Handle, native_dt);
+ dt = (CalComponentDateTime) Marshal.PtrToStructure (native_dt, typeof (CalComponentDateTime));
+ Marshal.FreeHGlobal (native_dt);
+
+ return dt;
+ }
+ set {
+ IntPtr native_dt = GLib.Marshaller.StructureToPtrAlloc (value);
+ e_cal_component_set_dtend(Handle, native_dt);
+ Marshal.FreeHGlobal (native_dt);
+ }
+ }
+
#endif
[DllImport("ecal")]
@@ -434,6 +563,8 @@
[DllImport("ecal")]
static extern void e_cal_component_get_last_modified (IntPtr raw, out IntPtr dt);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_last_modified (IntPtr raw, IntPtr dt);
public DateTime LastModified {
get {
@@ -441,6 +572,12 @@
e_cal_component_get_last_modified (Handle, out dt);
return CalUtil.icaltimetype_to_datetime (dt, true);
}
+ set
+ {
+ IntPtr dt = CalUtil.datetime_to_icaltimetype (value);
+ e_cal_component_set_last_modified (Handle, dt);
+ CalUtil.e_cal_glue_free_icaltimetype (dt);
+ }
}
[DllImport("ecal")]
@@ -506,8 +643,7 @@
for (i = 0, iter=raw_ret; iter != IntPtr.Zero;
iter = GLibUtil.gtksharp_slist_get_next (iter), i++) {
IntPtr data = GLibUtil.gtksharp_slist_get_data (iter);
- CalComponentAttendee a = (CalComponentAttendee) Marshal.PtrToStructure (data,
- typeof (CalComponentAttendee));
+ CalComponentAttendee a = (CalComponentAttendee) Marshal.PtrToStructure (data, typeof (CalComponentAttendee));
att_ret [i] = a;
}
}
@@ -526,6 +662,25 @@
}
[DllImport("ecal")]
+ static extern void e_cal_component_get_organizer (IntPtr raw, ref CalComponentOrganizer org);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_organizer (IntPtr raw, ref CalComponentOrganizer org);
+
+ public CalComponentOrganizer Organizer {
+ get
+ {
+ CalComponentOrganizer org = new CalComponentOrganizer ();
+ e_cal_component_get_organizer (Handle, ref org);
+ return org;
+ }
+ set
+ {
+ e_cal_component_set_organizer (Handle, ref value);
+ }
+ }
+
+
+ [DllImport("ecal")]
static extern void e_cal_component_get_description_list (IntPtr raw, out IntPtr list);
[DllImport("ecal")]
static extern void e_cal_component_set_description_list (IntPtr raw, IntPtr list);
@@ -590,7 +745,8 @@
e_cal_component_get_categories_list(Handle, out raw_ret);
return CalUtil.GSListToStringArray (raw_ret, true);
}
- set {
+ set
+ {
IntPtr list = GLibUtil.StringArrayToGSList (value);
e_cal_component_set_categories_list (Handle, list);
GLibUtil.FreeGSList (list);
@@ -605,9 +761,31 @@
return ical;
}
+
+#if USE_EDS_2_24
+ [DllImport("ecal")]
+ static extern int e_cal_component_get_sequence_as_int (IntPtr handle);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_sequence (IntPtr handle, ref int set);
+ public int Sequence {
+ get
+ {
+ int ret;
+ int raw = e_cal_component_get_sequence_as_int (Handle);
+ ret = raw;
+ return ret;
+
+ }
+ set
+ {
+ e_cal_component_set_sequence (Handle, ref value);
+ }
+ }
+#endif
+
[DllImport("ecal")]
- static extern int e_cal_component_commit_sequence (IntPtr handle);
+ static extern void e_cal_component_commit_sequence (IntPtr handle);
[DllImport("ecal")]
static extern int e_cal_component_abort_sequence (IntPtr handle);
[DllImport("ecal")]
@@ -659,6 +837,163 @@
{
e_cal_glue_free_cal_component (handle);
}
+
+#if USE_EDS_2_24
+ [DllImport("ecal")]
+ static extern void e_cal_component_get_rrule_list (IntPtr handle, out IntPtr list);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_rrule_list (IntPtr handle, IntPtr list);
+
+ public CalRecurrence [] RRules
+ {
+ get
+ {
+ IntPtr raw_ret = IntPtr.Zero;
+ IntPtr iter = IntPtr.Zero;
+ int i = 0;
+ int len = 0;
+ CalRecurrence[] ret = null;
+
+ e_cal_component_get_rrule_list (Handle, out raw_ret);
+
+ if (raw_ret != IntPtr.Zero) {
+ if ((len = GLibUtil.g_slist_length (raw_ret)) > 0 ) {
+ ret = new CalRecurrence [len];
+
+ for (i = 0, iter=raw_ret; iter != IntPtr.Zero;
+ iter = GLibUtil.gtksharp_slist_get_next (iter), i++) {
+ IntPtr data = GLibUtil.gtksharp_slist_get_data (iter);
+ CalRecurrence r = (CalRecurrence) Marshal.PtrToStructure (data, typeof (CalRecurrence));
+
+ ret [i] = r;
+ }
+ }
+ GLibUtil.g_slist_free (raw_ret);
+ }
+ return ret == null ? new CalRecurrence [0] : ret;
+ }
+ set
+ {
+ IntPtr ptr = IntPtr.Zero;
+ IntPtr raw = IntPtr.Zero;
+
+ foreach (CalRecurrence r in value) {
+ ptr = Marshal.AllocHGlobal (Marshal.SizeOf (r));
+ Marshal.StructureToPtr (r, ptr, false);
+ raw = GLibUtil.g_slist_append (raw, ptr);
+ }
+
+ e_cal_component_set_rrule_list (Handle, raw);
+ GLibUtil.g_slist_free (raw);
+ }
+ }
+
+ [DllImport("ecal")]
+ static extern bool e_cal_component_has_rrules (IntPtr handle);
+ [DllImport("ecal")]
+ static extern bool e_cal_component_has_exdates (IntPtr handle);
+ [DllImport("ecal")]
+ static extern bool e_cal_component_is_instance (IntPtr handle);
+
+ public bool HasRRules
+ {
+ get {
+ bool ret = e_cal_component_has_rrules (Handle);
+ return ret;
+ }
+ }
+
+ public bool HasExDates
+ {
+ get {
+ bool ret = e_cal_component_has_exdates (Handle);
+ return ret;
+ }
+ }
+
+ public bool IsInstance
+ {
+ get
+ {
+ bool ret = e_cal_component_is_instance (Handle);
+ return ret;
+ }
+ }
+
+ [DllImport("ecal")]
+ static extern void e_cal_component_get_exdate_list (IntPtr handle, out IntPtr list);
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_exdate_list (IntPtr handle, IntPtr list);
+
+ public CalComponentDateTime[] ExDates
+ {
+ get
+ {
+ IntPtr raw_ret = IntPtr.Zero;
+ IntPtr iter = IntPtr.Zero;
+ int i = 0;
+ int len = 0;
+ CalComponentDateTime [] ret = null;
+
+ e_cal_component_get_exdate_list (Handle, out raw_ret);
+ if (raw_ret != IntPtr.Zero) {
+ if ((len = GLibUtil.g_slist_length (raw_ret)) > 0 ) {
+ ret = new CalComponentDateTime [len];
+
+ for (i = 0, iter=raw_ret; iter != IntPtr.Zero;
+ iter = GLibUtil.gtksharp_slist_get_next (iter), i++) {
+ IntPtr data = GLibUtil.gtksharp_slist_get_data (iter);
+ CalComponentDateTime d = (CalComponentDateTime) Marshal.PtrToStructure (data, typeof (CalComponentDateTime));
+
+ ret [i] = d;
+ }
+ }
+ GLibUtil.g_slist_free (raw_ret);
+ }
+ return ret == null ? new CalComponentDateTime [0] : ret;
+
+ }
+ set
+ {
+ IntPtr ptr = IntPtr.Zero;
+ IntPtr raw = IntPtr.Zero;
+ foreach (CalComponentDateTime d in value) {
+ ptr = Marshal.AllocHGlobal (Marshal.SizeOf (d));
+ Marshal.StructureToPtr (d, ptr, false);
+ raw = GLibUtil.g_slist_append (raw, ptr);
+ }
+
+ e_cal_component_set_exdate_list (Handle, raw);
+ GLibUtil.g_slist_free (raw);
+ }
+ }
+
+ [DllImport("ecal")]
+ static extern void e_cal_component_set_x_prop (IntPtr handle, string name, string val);
+ [DllImport("ecal")]
+ static extern string e_cal_component_get_x_prop (IntPtr handle, string name);
+ [DllImport("ecal")]
+ static extern int e_cal_component_get_x_prop_as_int (IntPtr handle, string name);
+
+ public void SetXProp (string name, string val)
+ {
+ e_cal_component_set_x_prop (Handle, name, val);
+ }
+
+ public string GetXProp (string name)
+ {
+ string ret = e_cal_component_get_x_prop (Handle, name);
+
+ return ret;
+ }
+
+ public int GetXPropAsInt (string name)
+ {
+ int ret = e_cal_component_get_x_prop_as_int (Handle, name);
+
+ return ret;
+ }
}
+#endif
}
Modified: trunk/evolution/src/CalComponentDateTime.cs
==============================================================================
--- trunk/evolution/src/CalComponentDateTime.cs (original)
+++ trunk/evolution/src/CalComponentDateTime.cs Tue Jan 13 18:30:10 2009
@@ -10,23 +10,22 @@
private IntPtr _value;
- public Icaltimetype value {
- get {
- return new Icaltimetype (_value); }
- set {
- _value = value.Handle;
+ public Icaltimetype IcalTime {
+ get
+ {
+ return Icaltimetype.New (_value);
+ }
+ set
+ {
+ _value = GLib.Marshaller.StructureToPtrAlloc (value);
}
}
public string Tzid;
public static CalComponentDateTime Zero = new CalComponentDateTime ();
- public CalComponentDateTime () {
- _value = CalUtil.e_cal_alloc_icaltimetype ();
- }
-
- ~CalComponentDateTime () {
- CalUtil.e_cal_free_icaltimetype (_value);
+ public CalComponentDateTime ()
+ {
}
public static CalComponentDateTime New(IntPtr raw) {
Modified: trunk/evolution/src/CalRecurrence.cs
==============================================================================
--- trunk/evolution/src/CalRecurrence.cs (original)
+++ trunk/evolution/src/CalRecurrence.cs Tue Jan 13 18:30:10 2009
@@ -1,5 +1,6 @@
using System;
using System.Collections;
+using System.Runtime.InteropServices;
// TODO: (Also, we need exception-rules support.
// As of now, this provides a very basic support, (ie),
@@ -50,255 +51,119 @@
SET_POS
};
+ [StructLayout(LayoutKind.Sequential)]
public class CalRecurrence {
-
- static short recurrence_array_max = 0x7f7f;
- static short recurrence_array_max_byte = 0x7f;
+ public FrequencyType freq;
- IntPtr handle;
- FrequencyType freq;
- DateTime until;
- int count;
- int week_start_day;
- short interval;
- short[] by_second;
- short[] by_minute;
- short[] by_hour;
- short[] by_day;
- short[] by_month_day;
- short[] by_year_day;
- short[] by_week_no;
- short[] by_month;
- short[] by_set_pos;
-
- public CalRecurrence ()
- {
- freq = FrequencyType.FREQUENCY_NO;
- count = -1;
- week_start_day = -1;
- interval = -1;
- by_second = null;
- by_minute = null;
- by_hour = null;
- by_day = null;
- by_month_day = null;
- by_year_day = null;
- by_week_no = null;
- by_month = null;
- by_set_pos = null;
- }
+ Icaltimetype until;
+ public int count;
- public IntPtr Handle {
- get {
- return handle;
- }
- }
+ public short interval;
+
+ public WeekDayType week_start_day;
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=61)]
+ public short[] bySecond;
+
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=61)]
+ public short[] byMinute;
- public FrequencyType Frequency {
- get {
- return freq;
- }
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=25)]
+ public short[] byHour;
- set {
- freq = value;
- }
- }
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=364)]
+ public short[] byDay;
- public int Count {
- get {
- return count;
- }
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=32)]
+ public short[] byMonthDay;
- set {
- count = value;
- }
- }
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=367)]
+ public short[] byYearDay;
- public DateTime Enddate {
- get {
- return until;
- }
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=54)]
+ public short[] byWeekNumber;
+
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=13)]
+ public short[] byMonth;
- set {
- until = value;
- }
- }
+ [MarshalAs (UnmanagedType.ByValArray, SizeConst=367)]
+ public short[] bySetPos;
- public int WeekStartDay {
- get {
- return week_start_day;
- }
+ private short[] GetInitializedArray (int len)
+ {
+ short [] ret = new short [len];
- set {
- week_start_day = value;
+ for (int i = 0; i < len; i++)
+ {
+ ret [i] = 0x7f;
}
+ ret [0] = 0x7f7f;
+ return ret;
}
- public short Interval {
- get {
- return interval;
- }
-
- set {
- interval = value;
- }
- }
-
- public short[] BySecond {
- get {
- return by_second;
- }
-
- set {
- by_second = value;
- }
- }
-
- public short[] ByMinute {
- get {
- return by_minute;
- }
-
- set {
- by_minute = value;
- }
- }
-
- public short[] ByHour {
- get {
- return by_hour;
- }
-
- set {
- by_hour = value;
- }
- }
- public short[] ByDay {
- get {
- return by_day;
- }
-
- set {
- by_day = value;
- }
- }
- public short[] ByMonthDay {
- get {
- return by_month_day;
- }
-
- set {
- by_month_day = value;
- }
- }
- public short[] ByYearDay {
- get {
- return by_year_day;
- }
-
- set {
- by_year_day = value;
- }
- }
- public short[] ByWeekNumber {
- get {
- return by_week_no;
- }
-
- set {
- by_week_no = value;
- }
- }
-
- public short[] ByMonth {
- get {
- return by_month;
- }
-
- set {
- by_month = value;
- }
- }
-
- public short[] BySetPos {
- get {
- return by_set_pos;
- }
-
- set {
- by_set_pos = value;
- }
- }
-
- public string FrequencyToString (FrequencyType f)
+ public CalRecurrence ()
{
- switch (f) {
- case FrequencyType.SECONDLY: return "second(s)";
- case FrequencyType.MINUTELY: return "minute(s)";
- case FrequencyType.HOURLY: return "hour(s)";
- case FrequencyType.DAILY: return "day(s)";
- case FrequencyType.WEEKLY: return "week(s)";
- case FrequencyType.MONTHLY: return "month(s)";
- case FrequencyType.YEARLY: return "year(s)";
+ freq = FrequencyType.FREQUENCY_NO;
+ count = 0;
+ //week_start_day = -1;
+ interval = 1;
+ week_start_day = WeekDayType.NO_WEEKDAY;
+ until = new Icaltimetype ();
+ bySecond = GetInitializedArray (61);
+ byMinute = GetInitializedArray (61);
+ byHour = GetInitializedArray (25);
+ byDay = GetInitializedArray (364);
+ byMonthDay = GetInitializedArray (32);
+ byYearDay = GetInitializedArray (367);
+ byWeekNumber = GetInitializedArray (54);
+ byMonth = GetInitializedArray (13);
+ bySetPos = GetInitializedArray (367);
+ }
+
+ public DateTime Until
+ {
+ get
+ {
+ return until.AsDateTimeUtc;
+ }
+ set
+ {
+ until.SetDateTime = value;
}
- return "";
}
+
+ public static CalRecurrence Zero = new CalRecurrence ();
- public string WeekDayToString (WeekDayType d)
- {
- switch (d) {
- case WeekDayType.SUNDAY: return "sunday";
- case WeekDayType.MONDAY: return "monday";
- case WeekDayType.TUESDAY: return "tuesday";
- case WeekDayType.WEDNESDAY: return "wednesday";
- case WeekDayType.THURSDAY: return "thursday";
- case WeekDayType.FRIDAY: return "friday";
- case WeekDayType.SATURDAY: return "saturday";
- }
- return "";
- }
+ [DllImport("ecal")]
+ static extern IntPtr icalrecurrencetype_from_string (string str);
- private string DecodeSeconds (short[] by_value)
+ public static CalRecurrence New(string recur)
{
- int i;
- string retval;
+ IntPtr raw = icalrecurrencetype_from_string (recur);
- for (i = 0; i < by_value.Length; i++) {
- if (by_value [i] != recurrence_array_max) {
- ;//retval
- }
- }
- return "";
+ return (CalRecurrence) Marshal.PtrToStructure (raw, typeof (CalRecurrence));
}
- private string DecodeByValues (short[] by_value, ByValuesType which_by)
+
+ ~CalRecurrence ()
{
- switch (which_by) {
- case ByValuesType.SECOND: return DecodeSeconds (by_value);
- /*
- case ByValuesType.MINUTE: return DecodeMinutes (by_value);
- case ByValuesType.HOUR: return DecodeHours (by_value);
- case ByValuesType.DAY: return DecodeDayOfWeek (by_value);
- case ByValuesType.MONTH_DAY: return DecodeDayOfMonth (by_value);
- case ByValuesType.YEAR_DAY: return DecodeDayOfYear (by_value);
- case ByValuesType.WEEK_NUMBER: return DecodeWeekNumber (by_value);
- case ByValuesType.MONTH: return DecodeMonth (by_value);
- case ByValuesType.SET_POS: return DecodeSetPos (by_value);
- */
- }
- return "";
}
- override public string ToString ()
+ [DllImport("ecal")]
+ static extern string icalrecurrencetype_as_string(IntPtr recur);
+
+
+ public string ToString ()
{
- string strFreq;
- string strRecur;
-
- strFreq = String.Format ("every {0} {1}", interval, FrequencyToString (Frequency));
- strRecur = String.Format ("Meeting occurs {0}", strFreq);
-
- return strRecur;
+ IntPtr native_dt = GLib.Marshaller.StructureToPtrAlloc (this);
+ string ret = icalrecurrencetype_as_string (native_dt);
+ Marshal.FreeHGlobal (native_dt);
+
+ return ret;
+ }
+
+ private static GLib.GType GType {
+ get { return GLib.GType.Pointer; }
}
}
}
Modified: trunk/evolution/src/CalUtil.cs
==============================================================================
--- trunk/evolution/src/CalUtil.cs (original)
+++ trunk/evolution/src/CalUtil.cs Tue Jan 13 18:30:10 2009
@@ -135,6 +135,14 @@
}
[DllImport("ecal")]
+ static extern int icaltime_days_in_month (int month, int year);
+
+ public static int DaysInMonth (int month, int year)
+ {
+ return icaltime_days_in_month (month, year);
+ }
+
+ [DllImport("ecal")]
static extern void icalcomponent_free (IntPtr handle);
[DllImport("ecal")]
static extern IntPtr e_cal_component_new ();
@@ -186,7 +194,7 @@
[DllImport("evolutionglue")]
public static extern void e_cal_free_icaltimetype (IntPtr dt);
-
+
public static DateTime icaltimetype_to_datetime (IntPtr ptr, bool free_mem)
{
int d = 0;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]