author | zecke <zecke> | 2002-11-02 13:12:09 (UTC) |
---|---|---|
committer | zecke <zecke> | 2002-11-02 13:12:09 (UTC) |
commit | c795a77698b9fc785fb5f04fab8fed33f0570c3f (patch) (unidiff) | |
tree | d34d959a2e2d3937632f1eaea10fbd72cd7ac996 /library | |
parent | 87504764286a40162d74b03f26e040d4142c0cab (diff) | |
download | opie-c795a77698b9fc785fb5f04fab8fed33f0570c3f.zip opie-c795a77698b9fc785fb5f04fab8fed33f0570c3f.tar.gz opie-c795a77698b9fc785fb5f04fab8fed33f0570c3f.tar.bz2 |
Actually use local time in vCal
-rw-r--r-- | library/backend/event.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/library/backend/event.cpp b/library/backend/event.cpp index 7ccf16b..2d02a34 100644 --- a/library/backend/event.cpp +++ b/library/backend/event.cpp | |||
@@ -750,608 +750,608 @@ void Event::save( QString& buf ) | |||
750 | } | 750 | } |
751 | 751 | ||
752 | /*! | 752 | /*! |
753 | \internal | 753 | \internal |
754 | */ | 754 | */ |
755 | bool Event::RepeatPattern::operator==( const Event::RepeatPattern &right ) const | 755 | bool Event::RepeatPattern::operator==( const Event::RepeatPattern &right ) const |
756 | { | 756 | { |
757 | // *sigh* | 757 | // *sigh* |
758 | return ( type == right.type | 758 | return ( type == right.type |
759 | && frequency == right.frequency | 759 | && frequency == right.frequency |
760 | && position == right.position | 760 | && position == right.position |
761 | && days == right.days | 761 | && days == right.days |
762 | && hasEndDate == right.hasEndDate | 762 | && hasEndDate == right.hasEndDate |
763 | && endDateUTC == right.endDateUTC | 763 | && endDateUTC == right.endDateUTC |
764 | && createTime == right.createTime ); | 764 | && createTime == right.createTime ); |
765 | } | 765 | } |
766 | 766 | ||
767 | /*! | 767 | /*! |
768 | \class EffectiveEvent | 768 | \class EffectiveEvent |
769 | \brief The EffectiveEvent class the data for a single occurance of an event. | 769 | \brief The EffectiveEvent class the data for a single occurance of an event. |
770 | 770 | ||
771 | This class describes the event for a single occurance of it. For example if | 771 | This class describes the event for a single occurance of it. For example if |
772 | an Event occurs every week, the effective event might represent the third | 772 | an Event occurs every week, the effective event might represent the third |
773 | occurance of this Event. | 773 | occurance of this Event. |
774 | 774 | ||
775 | \ingroup qtopiaemb | 775 | \ingroup qtopiaemb |
776 | \ingroup qtopiadesktop | 776 | \ingroup qtopiadesktop |
777 | \warning This class will be phased out in Qtopia 3.x | 777 | \warning This class will be phased out in Qtopia 3.x |
778 | */ | 778 | */ |
779 | 779 | ||
780 | /*! | 780 | /*! |
781 | \enum EffectiveEvent::Position | 781 | \enum EffectiveEvent::Position |
782 | \internal | 782 | \internal |
783 | */ | 783 | */ |
784 | 784 | ||
785 | /*! | 785 | /*! |
786 | \fn EffectiveEvent &EffectiveEvent::operator=(const EffectiveEvent &) | 786 | \fn EffectiveEvent &EffectiveEvent::operator=(const EffectiveEvent &) |
787 | \internal | 787 | \internal |
788 | */ | 788 | */ |
789 | 789 | ||
790 | class EffectiveEventPrivate | 790 | class EffectiveEventPrivate |
791 | { | 791 | { |
792 | public: | 792 | public: |
793 | //currently the existence of the d pointer means multi-day repeating, | 793 | //currently the existence of the d pointer means multi-day repeating, |
794 | //msut be changed if we use the d pointer for anything else. | 794 | //msut be changed if we use the d pointer for anything else. |
795 | QDate startDate; | 795 | QDate startDate; |
796 | QDate endDate; | 796 | QDate endDate; |
797 | }; | 797 | }; |
798 | 798 | ||
799 | /*! | 799 | /*! |
800 | \internal | 800 | \internal |
801 | */ | 801 | */ |
802 | EffectiveEvent::EffectiveEvent() | 802 | EffectiveEvent::EffectiveEvent() |
803 | { | 803 | { |
804 | mDate = QDate::currentDate(); | 804 | mDate = QDate::currentDate(); |
805 | mStart = mEnd = QTime::currentTime(); | 805 | mStart = mEnd = QTime::currentTime(); |
806 | d = 0; | 806 | d = 0; |
807 | } | 807 | } |
808 | 808 | ||
809 | /*! | 809 | /*! |
810 | \internal | 810 | \internal |
811 | */ | 811 | */ |
812 | EffectiveEvent::EffectiveEvent( const Event &e, const QDate &date, Position pos ) | 812 | EffectiveEvent::EffectiveEvent( const Event &e, const QDate &date, Position pos ) |
813 | { | 813 | { |
814 | mEvent = e; | 814 | mEvent = e; |
815 | mDate = date; | 815 | mDate = date; |
816 | if ( pos & Start ) | 816 | if ( pos & Start ) |
817 | mStart = e.start( TRUE ).time(); | 817 | mStart = e.start( TRUE ).time(); |
818 | else | 818 | else |
819 | mStart = QTime( 0, 0, 0 ); | 819 | mStart = QTime( 0, 0, 0 ); |
820 | 820 | ||
821 | if ( pos & End ) | 821 | if ( pos & End ) |
822 | mEnd = e.end( TRUE ).time(); | 822 | mEnd = e.end( TRUE ).time(); |
823 | else | 823 | else |
824 | mEnd = QTime( 23, 59, 59 ); | 824 | mEnd = QTime( 23, 59, 59 ); |
825 | d = 0; | 825 | d = 0; |
826 | } | 826 | } |
827 | 827 | ||
828 | /*! | 828 | /*! |
829 | \internal | 829 | \internal |
830 | */ | 830 | */ |
831 | EffectiveEvent::~EffectiveEvent() | 831 | EffectiveEvent::~EffectiveEvent() |
832 | { | 832 | { |
833 | delete d; | 833 | delete d; |
834 | } | 834 | } |
835 | 835 | ||
836 | /*! | 836 | /*! |
837 | \internal | 837 | \internal |
838 | */ | 838 | */ |
839 | EffectiveEvent::EffectiveEvent( const EffectiveEvent &e ) | 839 | EffectiveEvent::EffectiveEvent( const EffectiveEvent &e ) |
840 | { | 840 | { |
841 | d = 0; | 841 | d = 0; |
842 | *this = e; | 842 | *this = e; |
843 | } | 843 | } |
844 | 844 | ||
845 | EffectiveEvent& EffectiveEvent::operator=( const EffectiveEvent & e ) | 845 | EffectiveEvent& EffectiveEvent::operator=( const EffectiveEvent & e ) |
846 | { | 846 | { |
847 | if ( &e == this ) | 847 | if ( &e == this ) |
848 | return *this; | 848 | return *this; |
849 | delete d; | 849 | delete d; |
850 | if ( e.d ) { | 850 | if ( e.d ) { |
851 | d = new EffectiveEventPrivate; | 851 | d = new EffectiveEventPrivate; |
852 | d->startDate = e.d->startDate; | 852 | d->startDate = e.d->startDate; |
853 | d->endDate = e.d->endDate; | 853 | d->endDate = e.d->endDate; |
854 | } else { | 854 | } else { |
855 | d = 0; | 855 | d = 0; |
856 | } | 856 | } |
857 | mEvent = e.mEvent; | 857 | mEvent = e.mEvent; |
858 | mDate = e.mDate; | 858 | mDate = e.mDate; |
859 | mStart = e.mStart; | 859 | mStart = e.mStart; |
860 | mEnd = e.mEnd; | 860 | mEnd = e.mEnd; |
861 | 861 | ||
862 | return *this; | 862 | return *this; |
863 | 863 | ||
864 | } | 864 | } |
865 | 865 | ||
866 | // QString EffectiveEvent::category() const | 866 | // QString EffectiveEvent::category() const |
867 | // { | 867 | // { |
868 | // return mEvent.category(); | 868 | // return mEvent.category(); |
869 | // } | 869 | // } |
870 | 870 | ||
871 | /*! | 871 | /*! |
872 | Returns the description of the event for this effective event. | 872 | Returns the description of the event for this effective event. |
873 | */ | 873 | */ |
874 | const QString &EffectiveEvent::description( ) const | 874 | const QString &EffectiveEvent::description( ) const |
875 | { | 875 | { |
876 | return mEvent.description(); | 876 | return mEvent.description(); |
877 | } | 877 | } |
878 | 878 | ||
879 | /*! | 879 | /*! |
880 | \internal | 880 | \internal |
881 | */ | 881 | */ |
882 | const QString &EffectiveEvent::location( ) const | 882 | const QString &EffectiveEvent::location( ) const |
883 | { | 883 | { |
884 | return mEvent.location(); | 884 | return mEvent.location(); |
885 | } | 885 | } |
886 | 886 | ||
887 | /*! | 887 | /*! |
888 | \internal | 888 | \internal |
889 | */ | 889 | */ |
890 | const QString &EffectiveEvent::notes() const | 890 | const QString &EffectiveEvent::notes() const |
891 | { | 891 | { |
892 | return mEvent.notes(); | 892 | return mEvent.notes(); |
893 | } | 893 | } |
894 | 894 | ||
895 | /*! | 895 | /*! |
896 | Returns the event associated with this effective event. | 896 | Returns the event associated with this effective event. |
897 | */ | 897 | */ |
898 | const Event &EffectiveEvent::event() const | 898 | const Event &EffectiveEvent::event() const |
899 | { | 899 | { |
900 | return mEvent; | 900 | return mEvent; |
901 | } | 901 | } |
902 | 902 | ||
903 | /*! | 903 | /*! |
904 | \internal | 904 | \internal |
905 | */ | 905 | */ |
906 | const QTime &EffectiveEvent::end() const | 906 | const QTime &EffectiveEvent::end() const |
907 | { | 907 | { |
908 | return mEnd; | 908 | return mEnd; |
909 | } | 909 | } |
910 | 910 | ||
911 | /*! | 911 | /*! |
912 | \internal | 912 | \internal |
913 | */ | 913 | */ |
914 | const QTime &EffectiveEvent::start() const | 914 | const QTime &EffectiveEvent::start() const |
915 | { | 915 | { |
916 | return mStart; | 916 | return mStart; |
917 | } | 917 | } |
918 | 918 | ||
919 | /*! | 919 | /*! |
920 | Returns the date the effective event occurs on. | 920 | Returns the date the effective event occurs on. |
921 | */ | 921 | */ |
922 | const QDate &EffectiveEvent::date() const | 922 | const QDate &EffectiveEvent::date() const |
923 | { | 923 | { |
924 | return mDate; | 924 | return mDate; |
925 | } | 925 | } |
926 | 926 | ||
927 | /*! | 927 | /*! |
928 | \internal | 928 | \internal |
929 | */ | 929 | */ |
930 | int EffectiveEvent::length() const | 930 | int EffectiveEvent::length() const |
931 | { | 931 | { |
932 | return (mEnd.hour() * 60 - mStart.hour() * 60) | 932 | return (mEnd.hour() * 60 - mStart.hour() * 60) |
933 | + QABS(mStart.minute() - mEnd.minute() ); | 933 | + QABS(mStart.minute() - mEnd.minute() ); |
934 | } | 934 | } |
935 | 935 | ||
936 | /*! | 936 | /*! |
937 | \internal | 937 | \internal |
938 | */ | 938 | */ |
939 | void EffectiveEvent::setDate( const QDate &dt ) | 939 | void EffectiveEvent::setDate( const QDate &dt ) |
940 | { | 940 | { |
941 | mDate = dt; | 941 | mDate = dt; |
942 | } | 942 | } |
943 | 943 | ||
944 | /*! | 944 | /*! |
945 | \internal | 945 | \internal |
946 | */ | 946 | */ |
947 | void EffectiveEvent::setStart( const QTime &start ) | 947 | void EffectiveEvent::setStart( const QTime &start ) |
948 | { | 948 | { |
949 | mStart = start; | 949 | mStart = start; |
950 | } | 950 | } |
951 | 951 | ||
952 | /*! | 952 | /*! |
953 | \internal | 953 | \internal |
954 | */ | 954 | */ |
955 | void EffectiveEvent::setEnd( const QTime &end ) | 955 | void EffectiveEvent::setEnd( const QTime &end ) |
956 | { | 956 | { |
957 | mEnd = end; | 957 | mEnd = end; |
958 | } | 958 | } |
959 | 959 | ||
960 | /*! | 960 | /*! |
961 | \internal | 961 | \internal |
962 | */ | 962 | */ |
963 | void EffectiveEvent::setEvent( Event e ) | 963 | void EffectiveEvent::setEvent( Event e ) |
964 | { | 964 | { |
965 | mEvent = e; | 965 | mEvent = e; |
966 | } | 966 | } |
967 | 967 | ||
968 | /*! | 968 | /*! |
969 | \internal | 969 | \internal |
970 | */ | 970 | */ |
971 | bool EffectiveEvent::operator<( const EffectiveEvent &e ) const | 971 | bool EffectiveEvent::operator<( const EffectiveEvent &e ) const |
972 | { | 972 | { |
973 | if ( mDate < e.date() ) | 973 | if ( mDate < e.date() ) |
974 | return TRUE; | 974 | return TRUE; |
975 | if ( mDate == e.date() ) | 975 | if ( mDate == e.date() ) |
976 | return ( mStart < e.start() ); | 976 | return ( mStart < e.start() ); |
977 | else | 977 | else |
978 | return FALSE; | 978 | return FALSE; |
979 | } | 979 | } |
980 | 980 | ||
981 | /*! | 981 | /*! |
982 | \internal | 982 | \internal |
983 | */ | 983 | */ |
984 | bool EffectiveEvent::operator<=( const EffectiveEvent &e ) const | 984 | bool EffectiveEvent::operator<=( const EffectiveEvent &e ) const |
985 | { | 985 | { |
986 | return (mDate <= e.date() ); | 986 | return (mDate <= e.date() ); |
987 | } | 987 | } |
988 | 988 | ||
989 | /*! | 989 | /*! |
990 | \internal | 990 | \internal |
991 | */ | 991 | */ |
992 | bool EffectiveEvent::operator==( const EffectiveEvent &e ) const | 992 | bool EffectiveEvent::operator==( const EffectiveEvent &e ) const |
993 | { | 993 | { |
994 | return ( mDate == e.date() | 994 | return ( mDate == e.date() |
995 | && mStart == e.start() | 995 | && mStart == e.start() |
996 | && mEnd == e.end() | 996 | && mEnd == e.end() |
997 | && mEvent == e.event() ); | 997 | && mEvent == e.event() ); |
998 | } | 998 | } |
999 | 999 | ||
1000 | /*! | 1000 | /*! |
1001 | \internal | 1001 | \internal |
1002 | */ | 1002 | */ |
1003 | bool EffectiveEvent::operator!=( const EffectiveEvent &e ) const | 1003 | bool EffectiveEvent::operator!=( const EffectiveEvent &e ) const |
1004 | { | 1004 | { |
1005 | return !(*this == e); | 1005 | return !(*this == e); |
1006 | } | 1006 | } |
1007 | 1007 | ||
1008 | /*! | 1008 | /*! |
1009 | \internal | 1009 | \internal |
1010 | */ | 1010 | */ |
1011 | bool EffectiveEvent::operator>( const EffectiveEvent &e ) const | 1011 | bool EffectiveEvent::operator>( const EffectiveEvent &e ) const |
1012 | { | 1012 | { |
1013 | return !(*this <= e ); | 1013 | return !(*this <= e ); |
1014 | } | 1014 | } |
1015 | 1015 | ||
1016 | /*! | 1016 | /*! |
1017 | \internal | 1017 | \internal |
1018 | */ | 1018 | */ |
1019 | bool EffectiveEvent::operator>=(const EffectiveEvent &e) const | 1019 | bool EffectiveEvent::operator>=(const EffectiveEvent &e) const |
1020 | { | 1020 | { |
1021 | return !(*this < e); | 1021 | return !(*this < e); |
1022 | } | 1022 | } |
1023 | 1023 | ||
1024 | /*! | 1024 | /*! |
1025 | \internal | 1025 | \internal |
1026 | */ | 1026 | */ |
1027 | void EffectiveEvent::setEffectiveDates( const QDate &from, const QDate &to ) | 1027 | void EffectiveEvent::setEffectiveDates( const QDate &from, const QDate &to ) |
1028 | { | 1028 | { |
1029 | if ( !from.isValid() ) { | 1029 | if ( !from.isValid() ) { |
1030 | delete d; | 1030 | delete d; |
1031 | d = 0; | 1031 | d = 0; |
1032 | return; | 1032 | return; |
1033 | } | 1033 | } |
1034 | if ( !d ) | 1034 | if ( !d ) |
1035 | d = new EffectiveEventPrivate; | 1035 | d = new EffectiveEventPrivate; |
1036 | d->startDate = from; | 1036 | d->startDate = from; |
1037 | d->endDate = to; | 1037 | d->endDate = to; |
1038 | } | 1038 | } |
1039 | 1039 | ||
1040 | /*! | 1040 | /*! |
1041 | \internal | 1041 | \internal |
1042 | */ | 1042 | */ |
1043 | QDate EffectiveEvent::startDate() const | 1043 | QDate EffectiveEvent::startDate() const |
1044 | { | 1044 | { |
1045 | if ( d ) | 1045 | if ( d ) |
1046 | return d->startDate; | 1046 | return d->startDate; |
1047 | else if ( mEvent.hasRepeat() ) | 1047 | else if ( mEvent.hasRepeat() ) |
1048 | return mDate; // single day, since multi-day should have a d pointer | 1048 | return mDate; // single day, since multi-day should have a d pointer |
1049 | else | 1049 | else |
1050 | return mEvent.start().date(); | 1050 | return mEvent.start().date(); |
1051 | } | 1051 | } |
1052 | 1052 | ||
1053 | /*! | 1053 | /*! |
1054 | \internal | 1054 | \internal |
1055 | */ | 1055 | */ |
1056 | QDate EffectiveEvent::endDate() const | 1056 | QDate EffectiveEvent::endDate() const |
1057 | { | 1057 | { |
1058 | if ( d ) | 1058 | if ( d ) |
1059 | return d->endDate; | 1059 | return d->endDate; |
1060 | else if ( mEvent.hasRepeat() ) | 1060 | else if ( mEvent.hasRepeat() ) |
1061 | return mDate; // single day, since multi-day should have a d pointer | 1061 | return mDate; // single day, since multi-day should have a d pointer |
1062 | else | 1062 | else |
1063 | return mEvent.end().date(); | 1063 | return mEvent.end().date(); |
1064 | } | 1064 | } |
1065 | 1065 | ||
1066 | /*! | 1066 | /*! |
1067 | \internal | 1067 | \internal |
1068 | */ | 1068 | */ |
1069 | int EffectiveEvent::size() const | 1069 | int EffectiveEvent::size() const |
1070 | { | 1070 | { |
1071 | return ( mEnd.hour() - mStart.hour() ) * 3600 | 1071 | return ( mEnd.hour() - mStart.hour() ) * 3600 |
1072 | + (mEnd.minute() - mStart.minute() * 60 | 1072 | + (mEnd.minute() - mStart.minute() * 60 |
1073 | + mEnd.second() - mStart.second() ); | 1073 | + mEnd.second() - mStart.second() ); |
1074 | } | 1074 | } |
1075 | 1075 | ||
1076 | 1076 | ||
1077 | // vcal conversion code | 1077 | // vcal conversion code |
1078 | static inline VObject *safeAddPropValue( VObject *o, const char *prop, const QString &value ) | 1078 | static inline VObject *safeAddPropValue( VObject *o, const char *prop, const QString &value ) |
1079 | { | 1079 | { |
1080 | VObject *ret = 0; | 1080 | VObject *ret = 0; |
1081 | if ( o && !value.isEmpty() ) | 1081 | if ( o && !value.isEmpty() ) |
1082 | ret = addPropValue( o, prop, value.latin1() ); | 1082 | ret = addPropValue( o, prop, value.latin1() ); |
1083 | return ret; | 1083 | return ret; |
1084 | } | 1084 | } |
1085 | 1085 | ||
1086 | static inline VObject *safeAddProp( VObject *o, const char *prop) | 1086 | static inline VObject *safeAddProp( VObject *o, const char *prop) |
1087 | { | 1087 | { |
1088 | VObject *ret = 0; | 1088 | VObject *ret = 0; |
1089 | if ( o ) | 1089 | if ( o ) |
1090 | ret = addProp( o, prop ); | 1090 | ret = addProp( o, prop ); |
1091 | return ret; | 1091 | return ret; |
1092 | } | 1092 | } |
1093 | 1093 | ||
1094 | /* | 1094 | /* |
1095 | * Until we support vCal/iCal right | 1095 | * Until we support vCal/iCal right |
1096 | * we will make DTSTART and other things | 1096 | * we will make DTSTART and other things |
1097 | * be floating in the sense of | 1097 | * be floating in the sense of |
1098 | * RFC 2445 | 1098 | * RFC 2445 |
1099 | */ | 1099 | */ |
1100 | namespace { | 1100 | namespace { |
1101 | /* | 1101 | /* |
1102 | * Convert QDateTime to iso8601 but take | 1102 | * Convert QDateTime to iso8601 but take |
1103 | * local time and do not use the Z at the end | 1103 | * local time and do not use the Z at the end |
1104 | * | 1104 | * |
1105 | */ | 1105 | */ |
1106 | QCString toISOLocal( const QDateTime& dt ) { | 1106 | QCString toISOLocal( const QDateTime& dt ) { |
1107 | QCString str; | 1107 | QCString str; |
1108 | /* | 1108 | /* |
1109 | * year month day T Hour Minute Second | 1109 | * year month day T Hour Minute Second |
1110 | * 4 2 2 2 2 2 digits | 1110 | * 4 2 2 2 2 2 digits |
1111 | */ | 1111 | */ |
1112 | str.sprintf("%04d%02d%02dT%02d%02d%02d", | 1112 | str.sprintf("%04d%02d%02dT%02d%02d%02d", |
1113 | dt.date().year(), | 1113 | dt.date().year(), |
1114 | dt.date().month(), | 1114 | dt.date().month(), |
1115 | dt.date().year(), | 1115 | dt.date().year(), |
1116 | dt.time().hour(), | 1116 | dt.time().hour(), |
1117 | dt.time().minute(), | 1117 | dt.time().minute(), |
1118 | dt.time().second() ); | 1118 | dt.time().second() ); |
1119 | 1119 | ||
1120 | 1120 | ||
1121 | 1121 | ||
1122 | return str; | 1122 | return str; |
1123 | } | 1123 | } |
1124 | 1124 | ||
1125 | 1125 | ||
1126 | }; | 1126 | }; |
1127 | 1127 | ||
1128 | static VObject *createVObject( const Event &e ) | 1128 | static VObject *createVObject( const Event &e ) |
1129 | { | 1129 | { |
1130 | VObject *vcal = newVObject( VCCalProp ); | 1130 | VObject *vcal = newVObject( VCCalProp ); |
1131 | safeAddPropValue( vcal, VCVersionProp, "1.0" ); | 1131 | safeAddPropValue( vcal, VCVersionProp, "1.0" ); |
1132 | VObject *event = safeAddProp( vcal, VCEventProp ); | 1132 | VObject *event = safeAddProp( vcal, VCEventProp ); |
1133 | 1133 | ||
1134 | safeAddPropValue( event, VCDTstartProp, TimeConversion::toISO8601( e.start() ) ); | 1134 | safeAddPropValue( event, VCDTstartProp, toISOLocal( e.start() ) ); |
1135 | safeAddPropValue( event, VCDTendProp, TimeConversion::toISO8601( e.end() ) ); | 1135 | safeAddPropValue( event, VCDTendProp, toISOLocal( e.end() ) ); |
1136 | safeAddPropValue( event, "X-Qtopia-NOTES", e.description() ); | 1136 | safeAddPropValue( event, "X-Qtopia-NOTES", e.description() ); |
1137 | safeAddPropValue( event, VCDescriptionProp, e.description() ); | 1137 | safeAddPropValue( event, VCDescriptionProp, e.description() ); |
1138 | safeAddPropValue( event, VCLocationProp, e.location() ); | 1138 | safeAddPropValue( event, VCLocationProp, e.location() ); |
1139 | 1139 | ||
1140 | if ( e.hasAlarm() ) { | 1140 | if ( e.hasAlarm() ) { |
1141 | VObject *alarm = safeAddProp( event, VCAAlarmProp ); | 1141 | VObject *alarm = safeAddProp( event, VCAAlarmProp ); |
1142 | QDateTime dt = e.start(); | 1142 | QDateTime dt = e.start(); |
1143 | dt = dt.addSecs( -e.alarmTime()*60 ); | 1143 | dt = dt.addSecs( -e.alarmTime()*60 ); |
1144 | safeAddPropValue( alarm, VCRunTimeProp, TimeConversion::toISO8601( dt ) ); | 1144 | safeAddPropValue( alarm, VCRunTimeProp, toISOLocal( dt ) ); |
1145 | safeAddPropValue( alarm, VCAudioContentProp, | 1145 | safeAddPropValue( alarm, VCAudioContentProp, |
1146 | (e.alarmSound() == Event::Silent ? "silent" : "alarm" ) ); | 1146 | (e.alarmSound() == Event::Silent ? "silent" : "alarm" ) ); |
1147 | } | 1147 | } |
1148 | 1148 | ||
1149 | safeAddPropValue( event, "X-Qtopia-TIMEZONE", e.timeZone() ); | 1149 | safeAddPropValue( event, "X-Qtopia-TIMEZONE", e.timeZone() ); |
1150 | 1150 | ||
1151 | if ( e.type() == Event::AllDay ) | 1151 | if ( e.type() == Event::AllDay ) |
1152 | safeAddPropValue( event, "X-Qtopia-AllDay", e.timeZone() ); | 1152 | safeAddPropValue( event, "X-Qtopia-AllDay", e.timeZone() ); |
1153 | 1153 | ||
1154 | // ### repeat missing | 1154 | // ### repeat missing |
1155 | 1155 | ||
1156 | // ### categories missing | 1156 | // ### categories missing |
1157 | 1157 | ||
1158 | return vcal; | 1158 | return vcal; |
1159 | } | 1159 | } |
1160 | 1160 | ||
1161 | 1161 | ||
1162 | static Event parseVObject( VObject *obj ) | 1162 | static Event parseVObject( VObject *obj ) |
1163 | { | 1163 | { |
1164 | Event e; | 1164 | Event e; |
1165 | 1165 | ||
1166 | bool haveAlarm = FALSE; | 1166 | bool haveAlarm = FALSE; |
1167 | bool haveStart = FALSE; | 1167 | bool haveStart = FALSE; |
1168 | bool haveEnd = FALSE; | 1168 | bool haveEnd = FALSE; |
1169 | QDateTime alarmTime; | 1169 | QDateTime alarmTime; |
1170 | Event::SoundTypeChoice soundType = Event::Silent; | 1170 | Event::SoundTypeChoice soundType = Event::Silent; |
1171 | 1171 | ||
1172 | VObjectIterator it; | 1172 | VObjectIterator it; |
1173 | initPropIterator( &it, obj ); | 1173 | initPropIterator( &it, obj ); |
1174 | while( moreIteration( &it ) ) { | 1174 | while( moreIteration( &it ) ) { |
1175 | VObject *o = nextVObject( &it ); | 1175 | VObject *o = nextVObject( &it ); |
1176 | QCString name = vObjectName( o ); | 1176 | QCString name = vObjectName( o ); |
1177 | QCString value = vObjectStringZValue( o ); | 1177 | QCString value = vObjectStringZValue( o ); |
1178 | if ( name == VCDTstartProp ) { | 1178 | if ( name == VCDTstartProp ) { |
1179 | e.setStart( TimeConversion::fromISO8601( value ) ); | 1179 | e.setStart( TimeConversion::fromISO8601( value ) ); |
1180 | haveStart = TRUE; | 1180 | haveStart = TRUE; |
1181 | } | 1181 | } |
1182 | else if ( name == VCDTendProp ) { | 1182 | else if ( name == VCDTendProp ) { |
1183 | e.setEnd( TimeConversion::fromISO8601( value ) ); | 1183 | e.setEnd( TimeConversion::fromISO8601( value ) ); |
1184 | haveEnd = TRUE; | 1184 | haveEnd = TRUE; |
1185 | } | 1185 | } |
1186 | else if ( name == "X-Qtopia-NOTES" ) { | 1186 | else if ( name == "X-Qtopia-NOTES" ) { |
1187 | e.setNotes( value ); | 1187 | e.setNotes( value ); |
1188 | } | 1188 | } |
1189 | else if ( name == VCDescriptionProp ) { | 1189 | else if ( name == VCDescriptionProp ) { |
1190 | e.setDescription( value ); | 1190 | e.setDescription( value ); |
1191 | } | 1191 | } |
1192 | else if ( name == VCLocationProp ) { | 1192 | else if ( name == VCLocationProp ) { |
1193 | e.setLocation( value ); | 1193 | e.setLocation( value ); |
1194 | } | 1194 | } |
1195 | else if ( name == VCAudioContentProp ) { | 1195 | else if ( name == VCAudioContentProp ) { |
1196 | haveAlarm = TRUE; | 1196 | haveAlarm = TRUE; |
1197 | VObjectIterator nit; | 1197 | VObjectIterator nit; |
1198 | initPropIterator( &nit, o ); | 1198 | initPropIterator( &nit, o ); |
1199 | while( moreIteration( &nit ) ) { | 1199 | while( moreIteration( &nit ) ) { |
1200 | VObject *o = nextVObject( &nit ); | 1200 | VObject *o = nextVObject( &nit ); |
1201 | QCString name = vObjectName( o ); | 1201 | QCString name = vObjectName( o ); |
1202 | QCString value = vObjectStringZValue( o ); | 1202 | QCString value = vObjectStringZValue( o ); |
1203 | if ( name == VCRunTimeProp ) | 1203 | if ( name == VCRunTimeProp ) |
1204 | alarmTime = TimeConversion::fromISO8601( value ); | 1204 | alarmTime = TimeConversion::fromISO8601( value ); |
1205 | else if ( name == VCAudioContentProp ) { | 1205 | else if ( name == VCAudioContentProp ) { |
1206 | if ( value == "silent" ) | 1206 | if ( value == "silent" ) |
1207 | soundType = Event::Silent; | 1207 | soundType = Event::Silent; |
1208 | else | 1208 | else |
1209 | soundType = Event::Loud; | 1209 | soundType = Event::Loud; |
1210 | } | 1210 | } |
1211 | } | 1211 | } |
1212 | } | 1212 | } |
1213 | else if ( name == "X-Qtopia-TIMEZONE") { | 1213 | else if ( name == "X-Qtopia-TIMEZONE") { |
1214 | e.setTimeZone( value ); | 1214 | e.setTimeZone( value ); |
1215 | } | 1215 | } |
1216 | else if ( name == "X-Qtopia-AllDay" ) { | 1216 | else if ( name == "X-Qtopia-AllDay" ) { |
1217 | e.setType( Event::AllDay ); | 1217 | e.setType( Event::AllDay ); |
1218 | } | 1218 | } |
1219 | #if 0 | 1219 | #if 0 |
1220 | else { | 1220 | else { |
1221 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); | 1221 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); |
1222 | VObjectIterator nit; | 1222 | VObjectIterator nit; |
1223 | initPropIterator( &nit, o ); | 1223 | initPropIterator( &nit, o ); |
1224 | while( moreIteration( &nit ) ) { | 1224 | while( moreIteration( &nit ) ) { |
1225 | VObject *o = nextVObject( &nit ); | 1225 | VObject *o = nextVObject( &nit ); |
1226 | QCString name = vObjectName( o ); | 1226 | QCString name = vObjectName( o ); |
1227 | QString value = vObjectStringZValue( o ); | 1227 | QString value = vObjectStringZValue( o ); |
1228 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); | 1228 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); |
1229 | } | 1229 | } |
1230 | } | 1230 | } |
1231 | #endif | 1231 | #endif |
1232 | } | 1232 | } |
1233 | 1233 | ||
1234 | if ( !haveStart && !haveEnd ) | 1234 | if ( !haveStart && !haveEnd ) |
1235 | e.setStart( QDateTime::currentDateTime() ); | 1235 | e.setStart( QDateTime::currentDateTime() ); |
1236 | 1236 | ||
1237 | if ( !haveEnd ) { | 1237 | if ( !haveEnd ) { |
1238 | e.setType( Event::AllDay ); | 1238 | e.setType( Event::AllDay ); |
1239 | e.setEnd( e.start() ); | 1239 | e.setEnd( e.start() ); |
1240 | } | 1240 | } |
1241 | 1241 | ||
1242 | if ( haveAlarm ) { | 1242 | if ( haveAlarm ) { |
1243 | int minutes = alarmTime.secsTo( e.start() ) / 60; | 1243 | int minutes = alarmTime.secsTo( e.start() ) / 60; |
1244 | e.setAlarm( TRUE, minutes, soundType ); | 1244 | e.setAlarm( TRUE, minutes, soundType ); |
1245 | } | 1245 | } |
1246 | return e; | 1246 | return e; |
1247 | } | 1247 | } |
1248 | 1248 | ||
1249 | 1249 | ||
1250 | /*! | 1250 | /*! |
1251 | Writes the list of \a events as a set of VCards to the file \a filename. | 1251 | Writes the list of \a events as a set of VCards to the file \a filename. |
1252 | */ | 1252 | */ |
1253 | void Event::writeVCalendar( const QString &filename, const QValueList<Event> &events) | 1253 | void Event::writeVCalendar( const QString &filename, const QValueList<Event> &events) |
1254 | { | 1254 | { |
1255 | 1255 | ||
1256 | QFileDirect f( filename.utf8().data() ); | 1256 | QFileDirect f( filename.utf8().data() ); |
1257 | 1257 | ||
1258 | if ( !f.open( IO_WriteOnly ) ) { | 1258 | if ( !f.open( IO_WriteOnly ) ) { |
1259 | 1259 | ||
1260 | qWarning("Unable to open vcard write"); | 1260 | qWarning("Unable to open vcard write"); |
1261 | 1261 | ||
1262 | return; | 1262 | return; |
1263 | 1263 | ||
1264 | } | 1264 | } |
1265 | 1265 | ||
1266 | 1266 | ||
1267 | QValueList<Event>::ConstIterator it; | 1267 | QValueList<Event>::ConstIterator it; |
1268 | for( it = events.begin(); it != events.end(); ++it ) { | 1268 | for( it = events.begin(); it != events.end(); ++it ) { |
1269 | VObject *obj = createVObject( *it ); | 1269 | VObject *obj = createVObject( *it ); |
1270 | writeVObject( f.directHandle() , obj ); | 1270 | writeVObject( f.directHandle() , obj ); |
1271 | cleanVObject( obj ); | 1271 | cleanVObject( obj ); |
1272 | } | 1272 | } |
1273 | 1273 | ||
1274 | 1274 | ||
1275 | cleanStrTbl(); | 1275 | cleanStrTbl(); |
1276 | } | 1276 | } |
1277 | 1277 | ||
1278 | /*! | 1278 | /*! |
1279 | Writes \a event as a VCard to the file \a filename. | 1279 | Writes \a event as a VCard to the file \a filename. |
1280 | */ | 1280 | */ |
1281 | void Event::writeVCalendar( const QString &filename, const Event &event) | 1281 | void Event::writeVCalendar( const QString &filename, const Event &event) |
1282 | { | 1282 | { |
1283 | 1283 | ||
1284 | QFileDirect f( filename.utf8().data() ); | 1284 | QFileDirect f( filename.utf8().data() ); |
1285 | 1285 | ||
1286 | if ( !f.open( IO_WriteOnly ) ) { | 1286 | if ( !f.open( IO_WriteOnly ) ) { |
1287 | 1287 | ||
1288 | qWarning("Unable to open vcard write"); | 1288 | qWarning("Unable to open vcard write"); |
1289 | 1289 | ||
1290 | return; | 1290 | return; |
1291 | 1291 | ||
1292 | } | 1292 | } |
1293 | 1293 | ||
1294 | 1294 | ||
1295 | VObject *obj = createVObject( event ); | 1295 | VObject *obj = createVObject( event ); |
1296 | writeVObject( f.directHandle() , obj ); | 1296 | writeVObject( f.directHandle() , obj ); |
1297 | cleanVObject( obj ); | 1297 | cleanVObject( obj ); |
1298 | 1298 | ||
1299 | cleanStrTbl(); | 1299 | cleanStrTbl(); |
1300 | } | 1300 | } |
1301 | 1301 | ||
1302 | /*! | 1302 | /*! |
1303 | Returns the set of events read as VCards from the file \a filename. | 1303 | Returns the set of events read as VCards from the file \a filename. |
1304 | */ | 1304 | */ |
1305 | QValueList<Event> Event::readVCalendar( const QString &filename ) | 1305 | QValueList<Event> Event::readVCalendar( const QString &filename ) |
1306 | { | 1306 | { |
1307 | VObject *obj = Parse_MIME_FromFileName( (char *)filename.utf8().data() ); | 1307 | VObject *obj = Parse_MIME_FromFileName( (char *)filename.utf8().data() ); |
1308 | 1308 | ||
1309 | QValueList<Event> events; | 1309 | QValueList<Event> events; |
1310 | 1310 | ||
1311 | while ( obj ) { | 1311 | while ( obj ) { |
1312 | QCString name = vObjectName( obj ); | 1312 | QCString name = vObjectName( obj ); |
1313 | if ( name == VCCalProp ) { | 1313 | if ( name == VCCalProp ) { |
1314 | VObjectIterator nit; | 1314 | VObjectIterator nit; |
1315 | initPropIterator( &nit, obj ); | 1315 | initPropIterator( &nit, obj ); |
1316 | while( moreIteration( &nit ) ) { | 1316 | while( moreIteration( &nit ) ) { |
1317 | VObject *o = nextVObject( &nit ); | 1317 | VObject *o = nextVObject( &nit ); |
1318 | QCString name = vObjectName( o ); | 1318 | QCString name = vObjectName( o ); |
1319 | if ( name == VCEventProp ) | 1319 | if ( name == VCEventProp ) |
1320 | events.append( parseVObject( o ) ); | 1320 | events.append( parseVObject( o ) ); |
1321 | } | 1321 | } |
1322 | } else if ( name == VCEventProp ) { | 1322 | } else if ( name == VCEventProp ) { |
1323 | // shouldn't happen, but just to be sure | 1323 | // shouldn't happen, but just to be sure |
1324 | events.append( parseVObject( obj ) ); | 1324 | events.append( parseVObject( obj ) ); |
1325 | } | 1325 | } |
1326 | VObject *t = obj; | 1326 | VObject *t = obj; |
1327 | obj = nextVObjectInList(obj); | 1327 | obj = nextVObjectInList(obj); |
1328 | cleanVObject( t ); | 1328 | cleanVObject( t ); |
1329 | } | 1329 | } |
1330 | 1330 | ||
1331 | return events; | 1331 | return events; |
1332 | } | 1332 | } |
1333 | 1333 | ||
1334 | bool Event::match( const QRegExp &r ) const | 1334 | bool Event::match( const QRegExp &r ) const |
1335 | { | 1335 | { |
1336 | bool returnMe; | 1336 | bool returnMe; |
1337 | returnMe = false; | 1337 | returnMe = false; |
1338 | 1338 | ||
1339 | if ( descript.find( r ) > -1 ) | 1339 | if ( descript.find( r ) > -1 ) |
1340 | returnMe = true; | 1340 | returnMe = true; |
1341 | else if ( locat.find( r ) > -1 ) | 1341 | else if ( locat.find( r ) > -1 ) |
1342 | returnMe = true; | 1342 | returnMe = true; |
1343 | else if ( TimeConversion::fromUTC( startUTC ).toString().find( r ) > -1 ) | 1343 | else if ( TimeConversion::fromUTC( startUTC ).toString().find( r ) > -1 ) |
1344 | returnMe = true; | 1344 | returnMe = true; |
1345 | else if ( TimeConversion::fromUTC( endUTC ).toString().find( r ) > -1 ) | 1345 | else if ( TimeConversion::fromUTC( endUTC ).toString().find( r ) > -1 ) |
1346 | returnMe = true; | 1346 | returnMe = true; |
1347 | else if ( tz.find( r ) > -1 ) | 1347 | else if ( tz.find( r ) > -1 ) |
1348 | returnMe = true; | 1348 | returnMe = true; |
1349 | else if ( note.find( r ) > -1 ) | 1349 | else if ( note.find( r ) > -1 ) |
1350 | returnMe = true; | 1350 | returnMe = true; |
1351 | else if ( doRepeat() ) { | 1351 | else if ( doRepeat() ) { |
1352 | if ( pattern.hasEndDate ) | 1352 | if ( pattern.hasEndDate ) |
1353 | if ( TimeConversion::fromUTC( pattern.endDateUTC ).toString().find(r) > -1 ) | 1353 | if ( TimeConversion::fromUTC( pattern.endDateUTC ).toString().find(r) > -1 ) |
1354 | returnMe = true; | 1354 | returnMe = true; |
1355 | } | 1355 | } |
1356 | return returnMe; | 1356 | return returnMe; |
1357 | } | 1357 | } |