-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | libkcal/phoneformat.cpp | 34 |
2 files changed, 26 insertions, 10 deletions
@@ -1,159 +1,159 @@ | |||
1 | ############################################################################# | 1 | ############################################################################# |
2 | # Makefile for building: kopi-desktop | 2 | # Makefile for building: kopi-desktop |
3 | # Generated by qmake (1.07a) (Qt 3.3.3) on: Mon Aug 9 12:10:32 2004 | 3 | # Generated by qmake (1.07a) (Qt 3.3.3) on: Mon Aug 9 13:18:13 2004 |
4 | # Project: kopi-desktop.pro | 4 | # Project: kopi-desktop.pro |
5 | # Template: subdirs | 5 | # Template: subdirs |
6 | # Command: $(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kopi-desktop.pro | 6 | # Command: $(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kopi-desktop.pro |
7 | ############################################################################# | 7 | ############################################################################# |
8 | 8 | ||
9 | MAKEFILE =Makefile | 9 | MAKEFILE =Makefile |
10 | QMAKE =qmake | 10 | QMAKE =qmake |
11 | DEL_FILE = rm -f | 11 | DEL_FILE = rm -f |
12 | CHK_DIR_EXISTS= test -d | 12 | CHK_DIR_EXISTS= test -d |
13 | MKDIR = mkdir -p | 13 | MKDIR = mkdir -p |
14 | INSTALL_FILE= | 14 | INSTALL_FILE= |
15 | INSTALL_DIR = | 15 | INSTALL_DIR = |
16 | SUBTARGETS = \ | 16 | SUBTARGETS = \ |
17 | sub-gammu-emb-common \ | 17 | sub-gammu-emb-common \ |
18 | sub-libical \ | 18 | sub-libical \ |
19 | sub-libkcal \ | 19 | sub-libkcal \ |
20 | sub-microkde \ | 20 | sub-microkde \ |
21 | sub-libkdepim \ | 21 | sub-libkdepim \ |
22 | sub-kabc \ | 22 | sub-kabc \ |
23 | sub-korganizer \ | 23 | sub-korganizer \ |
24 | sub-kaddressbook \ | 24 | sub-kaddressbook \ |
25 | sub-kabc-plugins-file \ | 25 | sub-kabc-plugins-file \ |
26 | sub-kabc-plugins-dir | 26 | sub-kabc-plugins-dir |
27 | 27 | ||
28 | first: all | 28 | first: all |
29 | 29 | ||
30 | all: Makefile $(SUBTARGETS) | 30 | all: Makefile $(SUBTARGETS) |
31 | 31 | ||
32 | gammu/emb/common/$(MAKEFILE): | 32 | gammu/emb/common/$(MAKEFILE): |
33 | @$(CHK_DIR_EXISTS) "gammu/emb/common" || $(MKDIR) "gammu/emb/common" | 33 | @$(CHK_DIR_EXISTS) "gammu/emb/common" || $(MKDIR) "gammu/emb/common" |
34 | cd gammu/emb/common && $(QMAKE) common.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 34 | cd gammu/emb/common && $(QMAKE) common.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
35 | sub-gammu-emb-common: gammu/emb/common/$(MAKEFILE) FORCE | 35 | sub-gammu-emb-common: gammu/emb/common/$(MAKEFILE) FORCE |
36 | cd gammu/emb/common && $(MAKE) -f $(MAKEFILE) | 36 | cd gammu/emb/common && $(MAKE) -f $(MAKEFILE) |
37 | 37 | ||
38 | libical/$(MAKEFILE): | 38 | libical/$(MAKEFILE): |
39 | @$(CHK_DIR_EXISTS) "libical" || $(MKDIR) "libical" | 39 | @$(CHK_DIR_EXISTS) "libical" || $(MKDIR) "libical" |
40 | cd libical && $(QMAKE) libical.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 40 | cd libical && $(QMAKE) libical.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
41 | sub-libical: libical/$(MAKEFILE) FORCE | 41 | sub-libical: libical/$(MAKEFILE) FORCE |
42 | cd libical && $(MAKE) -f $(MAKEFILE) | 42 | cd libical && $(MAKE) -f $(MAKEFILE) |
43 | 43 | ||
44 | libkcal/$(MAKEFILE): | 44 | libkcal/$(MAKEFILE): |
45 | @$(CHK_DIR_EXISTS) "libkcal" || $(MKDIR) "libkcal" | 45 | @$(CHK_DIR_EXISTS) "libkcal" || $(MKDIR) "libkcal" |
46 | cd libkcal && $(QMAKE) libkcal.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 46 | cd libkcal && $(QMAKE) libkcal.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
47 | sub-libkcal: libkcal/$(MAKEFILE) FORCE | 47 | sub-libkcal: libkcal/$(MAKEFILE) FORCE |
48 | cd libkcal && $(MAKE) -f $(MAKEFILE) | 48 | cd libkcal && $(MAKE) -f $(MAKEFILE) |
49 | 49 | ||
50 | microkde/$(MAKEFILE): | 50 | microkde/$(MAKEFILE): |
51 | @$(CHK_DIR_EXISTS) "microkde" || $(MKDIR) "microkde" | 51 | @$(CHK_DIR_EXISTS) "microkde" || $(MKDIR) "microkde" |
52 | cd microkde && $(QMAKE) microkde.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 52 | cd microkde && $(QMAKE) microkde.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
53 | sub-microkde: microkde/$(MAKEFILE) FORCE | 53 | sub-microkde: microkde/$(MAKEFILE) FORCE |
54 | cd microkde && $(MAKE) -f $(MAKEFILE) | 54 | cd microkde && $(MAKE) -f $(MAKEFILE) |
55 | 55 | ||
56 | libkdepim/$(MAKEFILE): | 56 | libkdepim/$(MAKEFILE): |
57 | @$(CHK_DIR_EXISTS) "libkdepim" || $(MKDIR) "libkdepim" | 57 | @$(CHK_DIR_EXISTS) "libkdepim" || $(MKDIR) "libkdepim" |
58 | cd libkdepim && $(QMAKE) libkdepim.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 58 | cd libkdepim && $(QMAKE) libkdepim.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
59 | sub-libkdepim: libkdepim/$(MAKEFILE) FORCE | 59 | sub-libkdepim: libkdepim/$(MAKEFILE) FORCE |
60 | cd libkdepim && $(MAKE) -f $(MAKEFILE) | 60 | cd libkdepim && $(MAKE) -f $(MAKEFILE) |
61 | 61 | ||
62 | kabc/$(MAKEFILE): | 62 | kabc/$(MAKEFILE): |
63 | @$(CHK_DIR_EXISTS) "kabc" || $(MKDIR) "kabc" | 63 | @$(CHK_DIR_EXISTS) "kabc" || $(MKDIR) "kabc" |
64 | cd kabc && $(QMAKE) kabc.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 64 | cd kabc && $(QMAKE) kabc.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
65 | sub-kabc: kabc/$(MAKEFILE) FORCE | 65 | sub-kabc: kabc/$(MAKEFILE) FORCE |
66 | cd kabc && $(MAKE) -f $(MAKEFILE) | 66 | cd kabc && $(MAKE) -f $(MAKEFILE) |
67 | 67 | ||
68 | korganizer/$(MAKEFILE): | 68 | korganizer/$(MAKEFILE): |
69 | @$(CHK_DIR_EXISTS) "korganizer" || $(MKDIR) "korganizer" | 69 | @$(CHK_DIR_EXISTS) "korganizer" || $(MKDIR) "korganizer" |
70 | cd korganizer && $(QMAKE) korganizer.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 70 | cd korganizer && $(QMAKE) korganizer.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
71 | sub-korganizer: korganizer/$(MAKEFILE) FORCE | 71 | sub-korganizer: korganizer/$(MAKEFILE) FORCE |
72 | cd korganizer && $(MAKE) -f $(MAKEFILE) | 72 | cd korganizer && $(MAKE) -f $(MAKEFILE) |
73 | 73 | ||
74 | kaddressbook/$(MAKEFILE): | 74 | kaddressbook/$(MAKEFILE): |
75 | @$(CHK_DIR_EXISTS) "kaddressbook" || $(MKDIR) "kaddressbook" | 75 | @$(CHK_DIR_EXISTS) "kaddressbook" || $(MKDIR) "kaddressbook" |
76 | cd kaddressbook && $(QMAKE) kaddressbook.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 76 | cd kaddressbook && $(QMAKE) kaddressbook.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
77 | sub-kaddressbook: kaddressbook/$(MAKEFILE) FORCE | 77 | sub-kaddressbook: kaddressbook/$(MAKEFILE) FORCE |
78 | cd kaddressbook && $(MAKE) -f $(MAKEFILE) | 78 | cd kaddressbook && $(MAKE) -f $(MAKEFILE) |
79 | 79 | ||
80 | kabc/plugins/file/$(MAKEFILE): | 80 | kabc/plugins/file/$(MAKEFILE): |
81 | @$(CHK_DIR_EXISTS) "kabc/plugins/file" || $(MKDIR) "kabc/plugins/file" | 81 | @$(CHK_DIR_EXISTS) "kabc/plugins/file" || $(MKDIR) "kabc/plugins/file" |
82 | cd kabc/plugins/file && $(QMAKE) file.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 82 | cd kabc/plugins/file && $(QMAKE) file.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
83 | sub-kabc-plugins-file: kabc/plugins/file/$(MAKEFILE) FORCE | 83 | sub-kabc-plugins-file: kabc/plugins/file/$(MAKEFILE) FORCE |
84 | cd kabc/plugins/file && $(MAKE) -f $(MAKEFILE) | 84 | cd kabc/plugins/file && $(MAKE) -f $(MAKEFILE) |
85 | 85 | ||
86 | kabc/plugins/dir/$(MAKEFILE): | 86 | kabc/plugins/dir/$(MAKEFILE): |
87 | @$(CHK_DIR_EXISTS) "kabc/plugins/dir" || $(MKDIR) "kabc/plugins/dir" | 87 | @$(CHK_DIR_EXISTS) "kabc/plugins/dir" || $(MKDIR) "kabc/plugins/dir" |
88 | cd kabc/plugins/dir && $(QMAKE) dir.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) | 88 | cd kabc/plugins/dir && $(QMAKE) dir.pro "CONFIG+=thread" "CONFIG+=debug" -o $(MAKEFILE) |
89 | sub-kabc-plugins-dir: kabc/plugins/dir/$(MAKEFILE) FORCE | 89 | sub-kabc-plugins-dir: kabc/plugins/dir/$(MAKEFILE) FORCE |
90 | cd kabc/plugins/dir && $(MAKE) -f $(MAKEFILE) | 90 | cd kabc/plugins/dir && $(MAKE) -f $(MAKEFILE) |
91 | 91 | ||
92 | Makefile: kopi-desktop.pro /usr/local/qtgcc/mkspecs/default/qmake.conf | 92 | Makefile: kopi-desktop.pro /usr/local/qtgcc/mkspecs/default/qmake.conf |
93 | $(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kopi-desktop.pro | 93 | $(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kopi-desktop.pro |
94 | qmake: qmake_all | 94 | qmake: qmake_all |
95 | @$(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kopi-desktop.pro | 95 | @$(QMAKE) "CONFIG+=thread" "CONFIG+=debug" -o Makefile kopi-desktop.pro |
96 | 96 | ||
97 | all: $(SUBTARGETS) | 97 | all: $(SUBTARGETS) |
98 | qmake_all: gammu/emb/common/$(MAKEFILE) libical/$(MAKEFILE) libkcal/$(MAKEFILE) microkde/$(MAKEFILE) libkdepim/$(MAKEFILE) kabc/$(MAKEFILE) korganizer/$(MAKEFILE) kaddressbook/$(MAKEFILE) kabc/plugins/file/$(MAKEFILE) kabc/plugins/dir/$(MAKEFILE) | 98 | qmake_all: gammu/emb/common/$(MAKEFILE) libical/$(MAKEFILE) libkcal/$(MAKEFILE) microkde/$(MAKEFILE) libkdepim/$(MAKEFILE) kabc/$(MAKEFILE) korganizer/$(MAKEFILE) kaddressbook/$(MAKEFILE) kabc/plugins/file/$(MAKEFILE) kabc/plugins/dir/$(MAKEFILE) |
99 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 99 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
100 | ( [ -d libical ] && cd libical ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 100 | ( [ -d libical ] && cd libical ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
101 | ( [ -d libkcal ] && cd libkcal ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 101 | ( [ -d libkcal ] && cd libkcal ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
102 | ( [ -d microkde ] && cd microkde ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 102 | ( [ -d microkde ] && cd microkde ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
103 | ( [ -d libkdepim ] && cd libkdepim ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 103 | ( [ -d libkdepim ] && cd libkdepim ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
104 | ( [ -d kabc ] && cd kabc ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 104 | ( [ -d kabc ] && cd kabc ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
105 | ( [ -d korganizer ] && cd korganizer ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 105 | ( [ -d korganizer ] && cd korganizer ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
106 | ( [ -d kaddressbook ] && cd kaddressbook ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 106 | ( [ -d kaddressbook ] && cd kaddressbook ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
107 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 107 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
108 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true | 108 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; grep "^qmake_all:" $(MAKEFILE) && $(MAKE) -f $(MAKEFILE) qmake_all; ) || true |
109 | clean uicables mocables uiclean mocclean lexclean yaccclean : qmake_all FORCE | 109 | clean uicables mocables uiclean mocclean lexclean yaccclean : qmake_all FORCE |
110 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 110 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
111 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 111 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
112 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 112 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
113 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 113 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
114 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 114 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
115 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 115 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
116 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 116 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
117 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 117 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
118 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 118 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
119 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) $@; ) || true | 119 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) $@; ) || true |
120 | uninstall_subdirs: qmake_all FORCE | 120 | uninstall_subdirs: qmake_all FORCE |
121 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 121 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
122 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 122 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
123 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 123 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
124 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 124 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
125 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 125 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
126 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 126 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
127 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 127 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
128 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 128 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
129 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 129 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
130 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true | 130 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) uninstall; ) || true |
131 | install_subdirs: qmake_all FORCE | 131 | install_subdirs: qmake_all FORCE |
132 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) install; ) || true | 132 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) install; ) || true |
133 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) install; ) || true | 133 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) install; ) || true |
134 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) install; ) || true | 134 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) install; ) || true |
135 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) install; ) || true | 135 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) install; ) || true |
136 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) install; ) || true | 136 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) install; ) || true |
137 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) install; ) || true | 137 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) install; ) || true |
138 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) install; ) || true | 138 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) install; ) || true |
139 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) install; ) || true | 139 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) install; ) || true |
140 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) install; ) || true | 140 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) install; ) || true |
141 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) install; ) || true | 141 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) install; ) || true |
142 | distclean: qmake_all FORCE | 142 | distclean: qmake_all FORCE |
143 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 143 | ( [ -d gammu/emb/common ] && cd gammu/emb/common ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
144 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 144 | ( [ -d libical ] && cd libical ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
145 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 145 | ( [ -d libkcal ] && cd libkcal ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
146 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 146 | ( [ -d microkde ] && cd microkde ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
147 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 147 | ( [ -d libkdepim ] && cd libkdepim ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
148 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 148 | ( [ -d kabc ] && cd kabc ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
149 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 149 | ( [ -d korganizer ] && cd korganizer ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
150 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 150 | ( [ -d kaddressbook ] && cd kaddressbook ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
151 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 151 | ( [ -d kabc/plugins/file ] && cd kabc/plugins/file ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
152 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true | 152 | ( [ -d kabc/plugins/dir ] && cd kabc/plugins/dir ; $(MAKE) -f $(MAKEFILE) $@; $(DEL_FILE) $(MAKEFILE); ) || true |
153 | 153 | ||
154 | install: install_subdirs | 154 | install: install_subdirs |
155 | 155 | ||
156 | uninstall: uninstall_subdirs | 156 | uninstall: uninstall_subdirs |
157 | 157 | ||
158 | FORCE: | 158 | FORCE: |
159 | 159 | ||
diff --git a/libkcal/phoneformat.cpp b/libkcal/phoneformat.cpp index bc1b863..596148e 100644 --- a/libkcal/phoneformat.cpp +++ b/libkcal/phoneformat.cpp | |||
@@ -1,794 +1,810 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of libkcal. | 2 | This file is part of libkcal. |
3 | 3 | ||
4 | Copyright (c) 2003 Cornelius Schumacher <schumacher@kde.org> | 4 | Copyright (c) 2003 Cornelius Schumacher <schumacher@kde.org> |
5 | 5 | ||
6 | This library is free software; you can redistribute it and/or | 6 | This library is free software; you can redistribute it and/or |
7 | modify it under the terms of the GNU Library General Public | 7 | modify it under the terms of the GNU Library General Public |
8 | License as published by the Free Software Foundation; either | 8 | License as published by the Free Software Foundation; either |
9 | version 2 of the License, or (at your option) any later version. | 9 | version 2 of the License, or (at your option) any later version. |
10 | 10 | ||
11 | This library is distributed in the hope that it will be useful, | 11 | This library is distributed in the hope that it will be useful, |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
14 | Library General Public License for more details. | 14 | Library General Public License for more details. |
15 | 15 | ||
16 | You should have received a copy of the GNU Library General Public License | 16 | You should have received a copy of the GNU Library General Public License |
17 | along with this library; see the file COPYING.LIB. If not, write to | 17 | along with this library; see the file COPYING.LIB. If not, write to |
18 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 18 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
19 | Boston, MA 02111-1307, USA. | 19 | Boston, MA 02111-1307, USA. |
20 | */ | 20 | */ |
21 | 21 | ||
22 | #include <qdatetime.h> | 22 | #include <qdatetime.h> |
23 | #include <qstring.h> | 23 | #include <qstring.h> |
24 | #include <qapplication.h> | 24 | #include <qapplication.h> |
25 | #include <qptrlist.h> | 25 | #include <qptrlist.h> |
26 | #include <qregexp.h> | 26 | #include <qregexp.h> |
27 | #include <qmessagebox.h> | 27 | #include <qmessagebox.h> |
28 | #include <qclipboard.h> | 28 | #include <qclipboard.h> |
29 | #include <qfile.h> | 29 | #include <qfile.h> |
30 | #include <qtextstream.h> | 30 | #include <qtextstream.h> |
31 | #include <qtextcodec.h> | 31 | #include <qtextcodec.h> |
32 | #include <qxml.h> | 32 | #include <qxml.h> |
33 | #include <qlabel.h> | 33 | #include <qlabel.h> |
34 | 34 | ||
35 | #include <kdebug.h> | 35 | #include <kdebug.h> |
36 | #include <klocale.h> | 36 | #include <klocale.h> |
37 | #include <kglobal.h> | 37 | #include <kglobal.h> |
38 | 38 | ||
39 | #include "calendar.h" | 39 | #include "calendar.h" |
40 | #include "alarm.h" | 40 | #include "alarm.h" |
41 | #include "recurrence.h" | 41 | #include "recurrence.h" |
42 | #include "calendarlocal.h" | 42 | #include "calendarlocal.h" |
43 | 43 | ||
44 | #include "phoneformat.h" | 44 | #include "phoneformat.h" |
45 | #include "syncdefines.h" | 45 | #include "syncdefines.h" |
46 | 46 | ||
47 | using namespace KCal; | 47 | using namespace KCal; |
48 | 48 | ||
49 | class PhoneParser : public QObject | 49 | class PhoneParser : public QObject |
50 | { | 50 | { |
51 | public: | 51 | public: |
52 | PhoneParser( Calendar *calendar, QString profileName ) : mCalendar( calendar ), mProfileName ( profileName ) { | 52 | PhoneParser( Calendar *calendar, QString profileName ) : mCalendar( calendar ), mProfileName ( profileName ) { |
53 | ; | 53 | ; |
54 | } | 54 | } |
55 | bool readTodo( Calendar *existingCalendar,GSM_ToDoEntry *ToDo, GSM_StateMachine* s) | 55 | bool readTodo( Calendar *existingCalendar,GSM_ToDoEntry *ToDo, GSM_StateMachine* s) |
56 | { | 56 | { |
57 | 57 | ||
58 | int id = ToDo->Location; | 58 | int id = ToDo->Location; |
59 | Todo *todo; | 59 | Todo *todo; |
60 | todo = existingCalendar->todo( mProfileName ,QString::number( id ) ); | 60 | todo = existingCalendar->todo( mProfileName ,QString::number( id ) ); |
61 | if (todo ) | 61 | if (todo ) |
62 | todo = (Todo *)todo->clone(); | 62 | todo = (Todo *)todo->clone(); |
63 | else | 63 | else |
64 | todo = new Todo; | 64 | todo = new Todo; |
65 | todo->setID( mProfileName,QString::number( id ) ); | 65 | todo->setID( mProfileName,QString::number( id ) ); |
66 | todo->setTempSyncStat(SYNC_TEMPSTATE_NEW_EXTERNAL ); | 66 | todo->setTempSyncStat(SYNC_TEMPSTATE_NEW_EXTERNAL ); |
67 | int priority; | 67 | int priority; |
68 | switch (ToDo->Priority) { | 68 | switch (ToDo->Priority) { |
69 | case GSM_Priority_Low : priority = 1; break; | 69 | case GSM_Priority_Low : priority = 1; break; |
70 | case GSM_Priority_Medium : priority = 3; break; | 70 | case GSM_Priority_Medium : priority = 3; break; |
71 | case GSM_Priority_High : priority = 5; break; | 71 | case GSM_Priority_High : priority = 5; break; |
72 | default :priority = 3 ;break; | 72 | default :priority = 3 ;break; |
73 | } | 73 | } |
74 | todo->setPriority( priority ); | 74 | todo->setPriority( priority ); |
75 | GSM_Phone_Functions*Phone; | 75 | GSM_Phone_Functions*Phone; |
76 | Phone=s->Phone.Functions; | 76 | Phone=s->Phone.Functions; |
77 | int j; | 77 | int j; |
78 | GSM_DateTime* dtp; | 78 | GSM_DateTime* dtp; |
79 | bool alarm = false; | 79 | bool alarm = false; |
80 | QDateTime alarmDt; | 80 | QDateTime alarmDt; |
81 | GSM_Category Category; | 81 | GSM_Category Category; |
82 | int error; | 82 | int error; |
83 | QString completedString = "no"; | 83 | QString completedString = "no"; |
84 | for (j=0;j<ToDo->EntriesNum;j++) { | 84 | for (j=0;j<ToDo->EntriesNum;j++) { |
85 | 85 | ||
86 | //qDebug(" for todo %d",ToDo->Location ); | 86 | //qDebug(" for todo %d",ToDo->Location ); |
87 | switch (ToDo->Entries[j].EntryType) { | 87 | switch (ToDo->Entries[j].EntryType) { |
88 | case TODO_END_DATETIME: | 88 | case TODO_END_DATETIME: |
89 | dtp = &ToDo->Entries[j].Date ; | 89 | dtp = &ToDo->Entries[j].Date ; |
90 | todo->setDtDue (fromGSM ( dtp )); | 90 | todo->setDtDue (fromGSM ( dtp )); |
91 | break; | 91 | break; |
92 | case TODO_COMPLETED: | 92 | case TODO_COMPLETED: |
93 | if ( ToDo->Entries[j].Number == 1 ) { | 93 | if ( ToDo->Entries[j].Number == 1 ) { |
94 | todo->setCompleted( true ); | 94 | todo->setCompleted( true ); |
95 | completedString = "yes"; | 95 | completedString = "yes"; |
96 | } | 96 | } |
97 | else { | 97 | else { |
98 | todo->setCompleted( false ); | 98 | todo->setCompleted( false ); |
99 | } | 99 | } |
100 | break; | 100 | break; |
101 | case TODO_ALARM_DATETIME: | 101 | case TODO_ALARM_DATETIME: |
102 | dtp = &ToDo->Entries[j].Date ; | 102 | dtp = &ToDo->Entries[j].Date ; |
103 | alarm = true; | 103 | alarm = true; |
104 | alarmDt = fromGSM ( dtp ); | 104 | alarmDt = fromGSM ( dtp ); |
105 | break; | 105 | break; |
106 | case TODO_SILENT_ALARM_DATETIME: | 106 | case TODO_SILENT_ALARM_DATETIME: |
107 | dtp = &ToDo->Entries[j].Date ; | 107 | dtp = &ToDo->Entries[j].Date ; |
108 | alarm = true; | 108 | alarm = true; |
109 | alarmDt = fromGSM ( dtp ); | 109 | alarmDt = fromGSM ( dtp ); |
110 | break; | 110 | break; |
111 | case TODO_TEXT: | 111 | case TODO_TEXT: |
112 | //qDebug(" text *%s* ", (const char*) DecodeUnicodeConsole(ToDo->Entries[j].Text )); | 112 | //qDebug(" text *%s* ", (const char*) DecodeUnicodeConsole(ToDo->Entries[j].Text )); |
113 | todo->setSummary( QString::fromUtf8 ( (const char*)DecodeUnicodeConsole(ToDo->Entries[j].Text ))); | 113 | todo->setSummary( QString::fromUtf8 ( (const char*)DecodeUnicodeConsole(ToDo->Entries[j].Text ))); |
114 | break; | 114 | break; |
115 | case TODO_PRIVATE: | 115 | case TODO_PRIVATE: |
116 | if ( ToDo->Entries[j].Number == 1 ) | 116 | if ( ToDo->Entries[j].Number == 1 ) |
117 | todo->setSecrecy( Incidence::SecrecyPrivate ); | 117 | todo->setSecrecy( Incidence::SecrecyPrivate ); |
118 | else | 118 | else |
119 | todo->setSecrecy( Incidence::SecrecyPublic ); | 119 | todo->setSecrecy( Incidence::SecrecyPublic ); |
120 | break; | 120 | break; |
121 | case TODO_CATEGORY: | 121 | case TODO_CATEGORY: |
122 | Category.Location = ToDo->Entries[j].Number; | 122 | Category.Location = ToDo->Entries[j].Number; |
123 | Category.Type = Category_ToDo; | 123 | Category.Type = Category_ToDo; |
124 | error=Phone->GetCategory(s, &Category); | 124 | error=Phone->GetCategory(s, &Category); |
125 | if (error == ERR_NONE) { | 125 | if (error == ERR_NONE) { |
126 | QStringList cat = todo->categories(); | 126 | QStringList cat = todo->categories(); |
127 | QString nCat = QString ( (const char*)Category.Name ); | 127 | QString nCat = QString ( (const char*)Category.Name ); |
128 | if ( !nCat.isEmpty() ) | 128 | if ( !nCat.isEmpty() ) |
129 | if ( !cat.contains( nCat )) { | 129 | if ( !cat.contains( nCat )) { |
130 | cat << nCat; | 130 | cat << nCat; |
131 | todo->setCategories( cat ); | 131 | todo->setCategories( cat ); |
132 | } | 132 | } |
133 | } | 133 | } |
134 | break; | 134 | break; |
135 | case TODO_CONTACTID: | 135 | case TODO_CONTACTID: |
136 | #if 0 | 136 | #if 0 |
137 | // not supported | 137 | // not supported |
138 | entry.Location = ToDo->Entries[j].Number; | 138 | entry.Location = ToDo->Entries[j].Number; |
139 | entry.MemoryType = MEM_ME; | 139 | entry.MemoryType = MEM_ME; |
140 | error=Phone->GetMemory(s, &entry); | 140 | error=Phone->GetMemory(s, &entry); |
141 | if (error == ERR_NONE) { | 141 | if (error == ERR_NONE) { |
142 | name = GSM_PhonebookGetEntryName(&entry); | 142 | name = GSM_PhonebookGetEntryName(&entry); |
143 | if (name != NULL) { | 143 | if (name != NULL) { |
144 | printmsg("Contact ID : \"%s\" (%d)\n", DecodeUnicodeConsole(name), ToDo->Entries[j].Number); | 144 | printmsg("Contact ID : \"%s\" (%d)\n", DecodeUnicodeConsole(name), ToDo->Entries[j].Number); |
145 | } else { | 145 | } else { |
146 | printmsg("Contact ID : %d\n",ToDo->Entries[j].Number); | 146 | printmsg("Contact ID : %d\n",ToDo->Entries[j].Number); |
147 | } | 147 | } |
148 | } else { | 148 | } else { |
149 | printmsg("Contact : %d\n",ToDo->Entries[j].Number); | 149 | printmsg("Contact : %d\n",ToDo->Entries[j].Number); |
150 | } | 150 | } |
151 | #endif | 151 | #endif |
152 | break; | 152 | break; |
153 | case TODO_PHONE: | 153 | case TODO_PHONE: |
154 | #if 0 | 154 | #if 0 |
155 | // not supported | 155 | // not supported |
156 | printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(ToDo->Entries[j].Text)); | 156 | printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(ToDo->Entries[j].Text)); |
157 | #endif | 157 | #endif |
158 | break; | 158 | break; |
159 | } | 159 | } |
160 | } | 160 | } |
161 | QString alarmString = "na"; | 161 | QString alarmString = "na"; |
162 | if ( alarm ) { | 162 | if ( alarm ) { |
163 | Alarm *alarm; | 163 | Alarm *alarm; |
164 | if ( todo->alarms().count() > 0 ) | 164 | if ( todo->alarms().count() > 0 ) |
165 | alarm = todo->alarms().first(); | 165 | alarm = todo->alarms().first(); |
166 | else { | 166 | else { |
167 | alarm = new Alarm( todo ); | 167 | alarm = new Alarm( todo ); |
168 | todo->addAlarm( alarm ); | 168 | todo->addAlarm( alarm ); |
169 | } | 169 | } |
170 | alarm->setType( Alarm::Audio ); | 170 | alarm->setType( Alarm::Audio ); |
171 | alarm->setEnabled( true ); | 171 | alarm->setEnabled( true ); |
172 | int alarmOffset = alarmDt.secsTo( todo->dtStart() ); | 172 | int alarmOffset = alarmDt.secsTo( todo->dtStart() ); |
173 | alarm->setStartOffset( -alarmOffset ); | 173 | alarm->setStartOffset( -alarmOffset ); |
174 | alarmString = QString::number( alarmOffset ); | 174 | alarmString = QString::number( alarmOffset ); |
175 | } else { | 175 | } else { |
176 | Alarm *alarm; | 176 | Alarm *alarm; |
177 | if ( todo->alarms().count() > 0 ) { | 177 | if ( todo->alarms().count() > 0 ) { |
178 | alarm = todo->alarms().first(); | 178 | alarm = todo->alarms().first(); |
179 | alarm->setType( Alarm::Audio ); | 179 | alarm->setType( Alarm::Audio ); |
180 | alarm->setStartOffset( -60*15 ); | 180 | alarm->setStartOffset( -60*15 ); |
181 | alarm->setEnabled( false ); | 181 | alarm->setEnabled( false ); |
182 | } | 182 | } |
183 | } | 183 | } |
184 | // csum ***************************************** | 184 | // csum ***************************************** |
185 | QStringList attList; | 185 | QStringList attList; |
186 | uint cSum; | 186 | uint cSum; |
187 | if ( todo->hasDueDate() ) | 187 | if ( todo->hasDueDate() ) |
188 | attList << dtToString ( todo->dtDue() ); | 188 | attList << dtToString ( todo->dtDue() ); |
189 | attList << QString::number( id ); | 189 | attList << QString::number( id ); |
190 | attList << todo->summary(); | 190 | attList << todo->summary(); |
191 | attList << completedString; | 191 | attList << completedString; |
192 | attList << QString::number( todo->priority() ); | 192 | attList << QString::number( todo->priority() ); |
193 | attList << alarmString; | 193 | attList << alarmString; |
194 | attList << todo->categoriesStr(); | 194 | attList << todo->categoriesStr(); |
195 | attList << todo->secrecyStr(); | 195 | attList << todo->secrecyStr(); |
196 | cSum = PhoneFormat::getCsum(attList ); | 196 | cSum = PhoneFormat::getCsum(attList ); |
197 | todo->setCsum( mProfileName, QString::number( cSum )); | 197 | todo->setCsum( mProfileName, QString::number( cSum )); |
198 | mCalendar->addTodo( todo); | 198 | mCalendar->addTodo( todo); |
199 | 199 | ||
200 | return true; | 200 | return true; |
201 | } | 201 | } |
202 | bool readEvent( Calendar *existingCalendar, GSM_CalendarEntry*Note) | 202 | bool readEvent( Calendar *existingCalendar, GSM_CalendarEntry*Note) |
203 | { | 203 | { |
204 | 204 | ||
205 | int id = Note->Location; | 205 | int id = Note->Location; |
206 | Event *event; | 206 | Event *event; |
207 | event = existingCalendar->event( mProfileName ,QString::number( id ) ); | 207 | event = existingCalendar->event( mProfileName ,QString::number( id ) ); |
208 | if ( event ) | 208 | if ( event ) |
209 | event = (Event*)event->clone(); | 209 | event = (Event*)event->clone(); |
210 | else | 210 | else |
211 | event = new Event; | 211 | event = new Event; |
212 | event->setID( mProfileName,QString::number( id ) ); | 212 | event->setID( mProfileName,QString::number( id ) ); |
213 | event->setTempSyncStat(SYNC_TEMPSTATE_NEW_EXTERNAL ); | 213 | event->setTempSyncStat(SYNC_TEMPSTATE_NEW_EXTERNAL ); |
214 | 214 | ||
215 | 215 | ||
216 | int i = 0; | 216 | int i = 0; |
217 | bool repeating = false; | 217 | bool repeating = false; |
218 | int repeat_dayofweek = -1; | 218 | int repeat_dayofweek = -1; |
219 | int repeat_day = -1; | 219 | int repeat_day = -1; |
220 | int repeat_weekofmonth = -1; | 220 | int repeat_weekofmonth = -1; |
221 | int repeat_month = -1; | 221 | int repeat_month = -1; |
222 | int repeat_frequency = -1; | 222 | int repeat_frequency = -1; |
223 | int rec_type = -1; | 223 | int rec_type = -1; |
224 | GSM_DateTime repeat_startdate = {0,0,0,0,0,0,0}; | 224 | GSM_DateTime repeat_startdate = {0,0,0,0,0,0,0}; |
225 | GSM_DateTime repeat_stopdate = {0,0,0,0,0,0,0}; | 225 | GSM_DateTime repeat_stopdate = {0,0,0,0,0,0,0}; |
226 | GSM_DateTime* dtp; | 226 | GSM_DateTime* dtp; |
227 | bool alarm = false; | 227 | bool alarm = false; |
228 | QDateTime alarmDt; | 228 | QDateTime alarmDt; |
229 | repeat_startdate.Day= 0; | 229 | repeat_startdate.Day= 0; |
230 | repeat_stopdate.Day = 0; | 230 | repeat_stopdate.Day = 0; |
231 | for (i=0;i<Note->EntriesNum;i++) { | 231 | for (i=0;i<Note->EntriesNum;i++) { |
232 | 232 | ||
233 | //qDebug(" for ev"); | 233 | //qDebug(" for ev"); |
234 | switch (Note->Entries[i].EntryType) { | 234 | switch (Note->Entries[i].EntryType) { |
235 | case CAL_START_DATETIME: | 235 | case CAL_START_DATETIME: |
236 | dtp = &Note->Entries[i].Date ; | 236 | dtp = &Note->Entries[i].Date ; |
237 | if ( dtp->Hour > 24 ) { | 237 | if ( dtp->Hour > 24 ) { |
238 | event->setFloats( true ); | 238 | event->setFloats( true ); |
239 | event->setDtStart( QDateTime (datefromGSM ( dtp ), QTime(0,0,0 ))); | 239 | event->setDtStart( QDateTime (datefromGSM ( dtp ), QTime(0,0,0 ))); |
240 | } else { | 240 | } else { |
241 | event->setDtStart (fromGSM ( dtp )); | 241 | event->setDtStart (fromGSM ( dtp )); |
242 | 242 | ||
243 | } | 243 | } |
244 | break; | 244 | break; |
245 | case CAL_END_DATETIME: | 245 | case CAL_END_DATETIME: |
246 | dtp = &Note->Entries[i].Date ; | 246 | dtp = &Note->Entries[i].Date ; |
247 | if ( dtp->Hour > 24 ) { | 247 | if ( dtp->Hour > 24 ) { |
248 | event->setFloats( true ); | 248 | event->setFloats( true ); |
249 | event->setDtEnd( QDateTime (datefromGSM ( dtp ), QTime(0,0,0 ))); | 249 | event->setDtEnd( QDateTime (datefromGSM ( dtp ), QTime(0,0,0 ))); |
250 | } else { | 250 | } else { |
251 | event->setDtEnd (fromGSM ( dtp )); | 251 | event->setDtEnd (fromGSM ( dtp )); |
252 | } | 252 | } |
253 | break; | 253 | break; |
254 | case CAL_ALARM_DATETIME: | 254 | case CAL_ALARM_DATETIME: |
255 | dtp = &Note->Entries[i].Date ; | 255 | dtp = &Note->Entries[i].Date ; |
256 | alarm = true; | 256 | alarm = true; |
257 | alarmDt = fromGSM ( dtp ); | 257 | alarmDt = fromGSM ( dtp ); |
258 | break; | 258 | break; |
259 | case CAL_SILENT_ALARM_DATETIME: | 259 | case CAL_SILENT_ALARM_DATETIME: |
260 | dtp = &Note->Entries[i].Date ; | 260 | dtp = &Note->Entries[i].Date ; |
261 | alarm = true; | 261 | alarm = true; |
262 | alarmDt = fromGSM ( dtp ); | 262 | alarmDt = fromGSM ( dtp ); |
263 | break; | 263 | break; |
264 | case CAL_RECURRANCE: | 264 | case CAL_RECURRANCE: |
265 | rec_type = Note->Entries[i].Number; | 265 | rec_type = Note->Entries[i].Number; |
266 | //printmsg("Repeat : %d day%s\n",Note->Entries[i].Number/24,((Note->Entries[i].Number/24)>1) ? "s":"" ); | 266 | //printmsg("Repeat : %d day%s\n",Note->Entries[i].Number/24,((Note->Entries[i].Number/24)>1) ? "s":"" ); |
267 | break; | 267 | break; |
268 | case CAL_TEXT: | 268 | case CAL_TEXT: |
269 | //qDebug(" ev text %s", DecodeUnicodeConsole(Note->Entries[i].Text) ); | 269 | //qDebug(" ev text %s", DecodeUnicodeConsole(Note->Entries[i].Text) ); |
270 | event->setSummary( QString::fromUtf8 ( (const char*)DecodeUnicodeConsole( Note->Entries[i].Text ))); | 270 | event->setSummary( QString::fromUtf8 ( (const char*)DecodeUnicodeConsole( Note->Entries[i].Text ))); |
271 | break; | 271 | break; |
272 | case CAL_LOCATION: | 272 | case CAL_LOCATION: |
273 | event->setLocation(QString::fromUtf8 ((const char*) DecodeUnicodeConsole(Note->Entries[i].Text) )); | 273 | event->setLocation(QString::fromUtf8 ((const char*) DecodeUnicodeConsole(Note->Entries[i].Text) )); |
274 | break; | 274 | break; |
275 | case CAL_PHONE: | 275 | case CAL_PHONE: |
276 | //printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(Note->Entries[i].Text)); | 276 | //printmsg("Phone : \"%s\"\n",DecodeUnicodeConsole(Note->Entries[i].Text)); |
277 | break; | 277 | break; |
278 | case CAL_PRIVATE: | 278 | case CAL_PRIVATE: |
279 | if ( Note->Entries[i].Number == 1 ) | 279 | if ( Note->Entries[i].Number == 1 ) |
280 | event->setSecrecy( Incidence::SecrecyPrivate ); | 280 | event->setSecrecy( Incidence::SecrecyPrivate ); |
281 | else | 281 | else |
282 | event->setSecrecy( Incidence::SecrecyPublic ); | 282 | event->setSecrecy( Incidence::SecrecyPublic ); |
283 | 283 | ||
284 | break; | 284 | break; |
285 | case CAL_CONTACTID: | 285 | case CAL_CONTACTID: |
286 | #if 0 | 286 | #if 0 |
287 | entry.Location = Note->Entries[i].Number; | 287 | entry.Location = Note->Entries[i].Number; |
288 | entry.MemoryType = MEM_ME; | 288 | entry.MemoryType = MEM_ME; |
289 | error=Phone->GetMemory(&s, &entry); | 289 | error=Phone->GetMemory(&s, &entry); |
290 | if (error == ERR_NONE) { | 290 | if (error == ERR_NONE) { |
291 | name = GSM_PhonebookGetEntryName(&entry); | 291 | name = GSM_PhonebookGetEntryName(&entry); |
292 | if (name != NULL) { | 292 | if (name != NULL) { |
293 | //printmsg("Contact ID : \"%s\" (%d)\n", DecodeUnicodeConsole(name), Note->Entries[i].Number); | 293 | //printmsg("Contact ID : \"%s\" (%d)\n", DecodeUnicodeConsole(name), Note->Entries[i].Number); |
294 | } else { | 294 | } else { |
295 | //printmsg("Contact ID : %d\n",Note->Entries[i].Number); | 295 | //printmsg("Contact ID : %d\n",Note->Entries[i].Number); |
296 | } | 296 | } |
297 | } else { | 297 | } else { |
298 | //printmsg("Contact ID : %d\n",Note->Entries[i].Number); | 298 | //printmsg("Contact ID : %d\n",Note->Entries[i].Number); |
299 | } | 299 | } |
300 | #endif | 300 | #endif |
301 | break; | 301 | break; |
302 | case CAL_REPEAT_DAYOFWEEK: | 302 | case CAL_REPEAT_DAYOFWEEK: |
303 | repeat_dayofweek = Note->Entries[i].Number; | 303 | repeat_dayofweek = Note->Entries[i].Number; |
304 | repeating = true; | 304 | repeating = true; |
305 | break; | 305 | break; |
306 | case CAL_REPEAT_DAY: | 306 | case CAL_REPEAT_DAY: |
307 | repeat_day = Note->Entries[i].Number; | 307 | repeat_day = Note->Entries[i].Number; |
308 | repeating = true; | 308 | repeating = true; |
309 | break; | 309 | break; |
310 | case CAL_REPEAT_WEEKOFMONTH: | 310 | case CAL_REPEAT_WEEKOFMONTH: |
311 | repeat_weekofmonth = Note->Entries[i].Number; | 311 | repeat_weekofmonth = Note->Entries[i].Number; |
312 | repeating = true; | 312 | repeating = true; |
313 | break; | 313 | break; |
314 | case CAL_REPEAT_MONTH: | 314 | case CAL_REPEAT_MONTH: |
315 | repeat_month = Note->Entries[i].Number; | 315 | repeat_month = Note->Entries[i].Number; |
316 | repeating = true; | 316 | repeating = true; |
317 | break; | 317 | break; |
318 | case CAL_REPEAT_FREQUENCY: | 318 | case CAL_REPEAT_FREQUENCY: |
319 | repeat_frequency = Note->Entries[i].Number; | 319 | repeat_frequency = Note->Entries[i].Number; |
320 | repeating = true; | 320 | repeating = true; |
321 | break; | 321 | break; |
322 | case CAL_REPEAT_STARTDATE: | 322 | case CAL_REPEAT_STARTDATE: |
323 | repeat_startdate = Note->Entries[i].Date; | 323 | repeat_startdate = Note->Entries[i].Date; |
324 | repeating = true; | 324 | repeating = true; |
325 | break; | 325 | break; |
326 | case CAL_REPEAT_STOPDATE: | 326 | case CAL_REPEAT_STOPDATE: |
327 | repeat_stopdate = Note->Entries[i].Date; | 327 | repeat_stopdate = Note->Entries[i].Date; |
328 | repeating = true; | 328 | repeating = true; |
329 | break; | 329 | break; |
330 | } | 330 | } |
331 | } | 331 | } |
332 | #if 0 | 332 | #if 0 |
333 | event->setDescription( attList[4] ); | 333 | event->setDescription( attList[4] ); |
334 | bool repeating = false; | 334 | bool repeating = false; |
335 | int repeat_dayofweek = -1; | 335 | int repeat_dayofweek = -1; |
336 | int repeat_day = -1; | 336 | int repeat_day = -1; |
337 | int repeat_weekofmonth = -1; | 337 | int repeat_weekofmonth = -1; |
338 | int repeat_month = -1; | 338 | int repeat_month = -1; |
339 | int repeat_frequency = -1; | 339 | int repeat_frequency = -1; |
340 | GSM_DateTime repeat_startdate = {0,0,0,0,0,0,0}; | 340 | GSM_DateTime repeat_startdate = {0,0,0,0,0,0,0}; |
341 | GSM_DateTime repeat_stopdate = {0,0,0,0,0,0,0}; | 341 | GSM_DateTime repeat_stopdate = {0,0,0,0,0,0,0}; |
342 | 342 | ||
343 | #endif | 343 | #endif |
344 | 344 | ||
345 | QString recurString = "no"; | 345 | QString recurString = "no"; |
346 | if ( repeating ) { | 346 | if ( repeating && repeat_frequency != -1) { |
347 | recurString = "y"; | 347 | recurString = "y"; |
348 | if ( repeat_dayofweek >= 0 ) | 348 | if ( repeat_dayofweek >= 0 ) |
349 | recurString += "dow" + QString::number (repeat_dayofweek); | 349 | recurString += "dow" + QString::number (repeat_dayofweek); |
350 | if ( repeat_day >= 0 ) | 350 | if ( repeat_day >= 0 ) |
351 | recurString += "d" + QString::number (repeat_day); | 351 | recurString += "d" + QString::number (repeat_day); |
352 | if ( repeat_weekofmonth >= 0 ) | 352 | if ( repeat_weekofmonth >= 0 ) |
353 | recurString += "w" + QString::number (repeat_weekofmonth); | 353 | recurString += "w" + QString::number (repeat_weekofmonth); |
354 | if ( repeat_month >= 0 ) | 354 | if ( repeat_month >= 0 ) |
355 | recurString += "m" + QString::number ( repeat_month ); | 355 | recurString += "m" + QString::number ( repeat_month ); |
356 | if ( repeat_frequency >= 0 ) | 356 | if ( repeat_frequency >= 0 ) |
357 | recurString += "f" + QString::number (repeat_frequency ); | 357 | recurString += "f" + QString::number (repeat_frequency ); |
358 | 358 | ||
359 | int rtype = 0; | 359 | int rtype = 0; |
360 | // qDebug("recurs "); | 360 | // qDebug("recurs "); |
361 | QDate startDate, endDate; | 361 | QDate startDate, endDate; |
362 | if ( repeat_startdate.Day > 0 ) | 362 | if ( repeat_startdate.Day > 0 ) { |
363 | startDate = datefromGSM ( &repeat_startdate ); | 363 | startDate = datefromGSM ( &repeat_startdate ); |
364 | else | 364 | event->setDtStart(QDateTime ( startDate, event->dtStart().time())); |
365 | } else { | ||
365 | startDate = event->dtStart().date(); | 366 | startDate = event->dtStart().date(); |
367 | } | ||
366 | int freq = repeat_frequency; | 368 | int freq = repeat_frequency; |
367 | bool hasEndDate = false; | 369 | bool hasEndDate = false; |
368 | if ( repeat_stopdate.Day > 0 ) { | 370 | if ( repeat_stopdate.Day > 0 ) { |
369 | endDate = datefromGSM ( &repeat_stopdate ); | 371 | endDate = datefromGSM ( &repeat_stopdate ); |
370 | hasEndDate = true; | 372 | hasEndDate = true; |
371 | } | 373 | } |
372 | 374 | ||
373 | uint weekDaysNum = repeat_dayofweek ; | 375 | uint weekDaysNum = repeat_dayofweek ; |
374 | 376 | // 1 == monday, 7 == sunday | |
375 | QBitArray weekDays( 7 ); | 377 | QBitArray weekDays( 7 ); |
376 | int i; | 378 | int i; |
377 | int bb = 1; | 379 | int bb = 1; |
378 | for( i = 1; i <= 7; ++i ) { | 380 | for( i = 1; i <= 7; ++i ) { |
379 | weekDays.setBit( i - 1, ( bb & weekDaysNum )); | 381 | weekDays.setBit( i - 1, ( bb & weekDaysNum )); |
380 | bb = 2 << (i-1); | 382 | bb = 2 << (i-1); |
381 | //qDebug(" %d bit %d ",i-1,weekDays.at(i-1) ); | 383 | //qDebug(" %d bit %d ",i-1,weekDays.at(i-1) ); |
382 | } | 384 | } |
383 | // qDebug("next "); | 385 | // qDebug("next "); |
384 | int pos = 0; | 386 | int pos = 0; |
385 | Recurrence *r = event->recurrence(); | 387 | Recurrence *r = event->recurrence(); |
386 | /* | 388 | /* |
387 | 0 daily; | 389 | 0 daily; |
388 | 1 weekly;x | 390 | 1 weekly;x |
389 | 2 monthpos;x | 391 | 2 monthpos;x |
390 | 3 monthlyday; | 392 | 3 monthlyday; |
391 | 4 rYearlyMont | 393 | 4 rYearlyMont |
392 | bool repeating = false; | 394 | bool repeating = false; |
393 | int repeat_dayofweek = -1; | 395 | int repeat_dayofweek = -1; |
394 | int repeat_day = -1; | 396 | int repeat_day = -1; |
395 | int repeat_weekofmonth = -1; | 397 | int repeat_weekofmonth = -1; |
396 | int repeat_month = -1; | 398 | int repeat_month = -1; |
397 | int repeat_frequency = -1; | 399 | int repeat_frequency = -1; |
398 | */ | 400 | */ |
399 | int dayOfWeek = startDate.dayOfWeek(); | 401 | int dayOfWeek = startDate.dayOfWeek(); |
400 | if ( repeat_weekofmonth >= 0 ) { | 402 | if ( repeat_weekofmonth >= 0 ) { |
401 | rtype = 2; | 403 | rtype = 2; // ************************ 2 MonthlyPos |
402 | pos = repeat_weekofmonth; | 404 | pos = repeat_weekofmonth; |
403 | if ( repeat_dayofweek >= 0 ) | 405 | if ( repeat_dayofweek >= 0 ) |
404 | dayOfWeek = repeat_dayofweek; | 406 | dayOfWeek = repeat_dayofweek; |
407 | if (repeat_month > 0) { | ||
408 | if ( repeat_month != event->dtStart().date().month() ) { | ||
409 | QDate date (event->dtStart().date().year(),repeat_month,event->dtStart().date().day() ); | ||
410 | event->setDtStart(QDateTime ( date , event->dtStart().time()) ); | ||
411 | } | ||
412 | if ( freq == 1 ) | ||
413 | freq = 12; | ||
414 | } | ||
405 | } else if ( repeat_dayofweek >= 0 ) { | 415 | } else if ( repeat_dayofweek >= 0 ) { |
406 | rtype = 1; | 416 | rtype = 1;// ************************ 1 Weekly |
407 | } if ( repeat_dayofweek >= 0 ) { | 417 | } else if ( repeat_day >= 0 ) { |
408 | rtype = 1; | 418 | if ( repeat_month > 0) { |
419 | rtype = 4; | ||
420 | } else { | ||
421 | rtype = 3; | ||
422 | } | ||
423 | } else { | ||
424 | rtype = 0 ; | ||
409 | } | 425 | } |
410 | 426 | ||
411 | if ( rtype == 0 ) { | 427 | if ( rtype == 0 ) { |
412 | if ( hasEndDate ) r->setDaily( freq, endDate ); | 428 | if ( hasEndDate ) r->setDaily( freq, endDate ); |
413 | else r->setDaily( freq, -1 ); | 429 | else r->setDaily( freq, -1 ); |
414 | } else if ( rtype == 1 ) { | 430 | } else if ( rtype == 1 ) { |
415 | if ( hasEndDate ) r->setWeekly( freq, weekDays, endDate ); | 431 | if ( hasEndDate ) r->setWeekly( freq, weekDays, endDate ); |
416 | else r->setWeekly( freq, weekDays, -1 ); | 432 | else r->setWeekly( freq, weekDays, -1 ); |
417 | } else if ( rtype == 3 ) { | 433 | } else if ( rtype == 3 ) { |
418 | if ( hasEndDate ) | 434 | if ( hasEndDate ) |
419 | r->setMonthly( Recurrence::rMonthlyDay, freq, endDate ); | 435 | r->setMonthly( Recurrence::rMonthlyDay, freq, endDate ); |
420 | else | 436 | else |
421 | r->setMonthly( Recurrence::rMonthlyDay, freq, -1 ); | 437 | r->setMonthly( Recurrence::rMonthlyDay, freq, -1 ); |
422 | r->addMonthlyDay( startDate.day() ); | 438 | r->addMonthlyDay( startDate.day() ); |
423 | } else if ( rtype == 2 ) { | 439 | } else if ( rtype == 2 ) { |
424 | if ( hasEndDate ) | 440 | if ( hasEndDate ) |
425 | r->setMonthly( Recurrence::rMonthlyPos, freq, endDate ); | 441 | r->setMonthly( Recurrence::rMonthlyPos, freq, endDate ); |
426 | else | 442 | else |
427 | r->setMonthly( Recurrence::rMonthlyPos, freq, -1 ); | 443 | r->setMonthly( Recurrence::rMonthlyPos, freq, -1 ); |
428 | QBitArray days( 7 ); | 444 | QBitArray days( 7 ); |
429 | days.fill( false ); | 445 | days.fill( false ); |
430 | days.setBit( dayOfWeek - 1 ); | 446 | days.setBit( dayOfWeek - 1 ); |
431 | r->addMonthlyPos( pos, days ); | 447 | r->addMonthlyPos( pos, days ); |
432 | } else if ( rtype == 4 ) { | 448 | } else if ( rtype == 4 ) { |
433 | if ( hasEndDate ) | 449 | if ( hasEndDate ) |
434 | r->setYearly( Recurrence::rYearlyMonth, freq, endDate ); | 450 | r->setYearly( Recurrence::rYearlyMonth, freq, endDate ); |
435 | else | 451 | else |
436 | r->setYearly( Recurrence::rYearlyMonth, freq, -1 ); | 452 | r->setYearly( Recurrence::rYearlyMonth, freq, -1 ); |
437 | r->addYearlyNum( startDate.month() ); | 453 | r->addYearlyNum( startDate.month() ); |
438 | } | 454 | } |
439 | } else { | 455 | } else { |
440 | event->recurrence()->unsetRecurs(); | 456 | event->recurrence()->unsetRecurs(); |
441 | } | 457 | } |
442 | 458 | ||
443 | QStringList categoryList; | 459 | QStringList categoryList; |
444 | categoryList << getCategory( Note ); | 460 | categoryList << getCategory( Note ); |
445 | event->setCategories( categoryList ); | 461 | event->setCategories( categoryList ); |
446 | QString alarmString = "na"; | 462 | QString alarmString = "na"; |
447 | // strange 0 semms to mean: alarm enabled | 463 | // strange 0 semms to mean: alarm enabled |
448 | if ( alarm ) { | 464 | if ( alarm ) { |
449 | Alarm *alarm; | 465 | Alarm *alarm; |
450 | if ( event->alarms().count() > 0 ) | 466 | if ( event->alarms().count() > 0 ) |
451 | alarm = event->alarms().first(); | 467 | alarm = event->alarms().first(); |
452 | else { | 468 | else { |
453 | alarm = new Alarm( event ); | 469 | alarm = new Alarm( event ); |
454 | event->addAlarm( alarm ); | 470 | event->addAlarm( alarm ); |
455 | } | 471 | } |
456 | alarm->setType( Alarm::Audio ); | 472 | alarm->setType( Alarm::Audio ); |
457 | alarm->setEnabled( true ); | 473 | alarm->setEnabled( true ); |
458 | int alarmOffset = alarmDt.secsTo( event->dtStart() ); | 474 | int alarmOffset = alarmDt.secsTo( event->dtStart() ); |
459 | alarm->setStartOffset( -alarmOffset ); | 475 | alarm->setStartOffset( -alarmOffset ); |
460 | alarmString = QString::number( alarmOffset ); | 476 | alarmString = QString::number( alarmOffset ); |
461 | } else { | 477 | } else { |
462 | Alarm *alarm; | 478 | Alarm *alarm; |
463 | if ( event->alarms().count() > 0 ) { | 479 | if ( event->alarms().count() > 0 ) { |
464 | alarm = event->alarms().first(); | 480 | alarm = event->alarms().first(); |
465 | alarm->setType( Alarm::Audio ); | 481 | alarm->setType( Alarm::Audio ); |
466 | alarm->setStartOffset( -60*15 ); | 482 | alarm->setStartOffset( -60*15 ); |
467 | alarm->setEnabled( false ); | 483 | alarm->setEnabled( false ); |
468 | } | 484 | } |
469 | } | 485 | } |
470 | // csum ***************************************** | 486 | // csum ***************************************** |
471 | QStringList attList; | 487 | QStringList attList; |
472 | uint cSum; | 488 | uint cSum; |
473 | attList << dtToString ( event->dtStart() ); | 489 | attList << dtToString ( event->dtStart() ); |
474 | attList << dtToString ( event->dtEnd() ); | 490 | attList << dtToString ( event->dtEnd() ); |
475 | attList << QString::number( id ); | 491 | attList << QString::number( id ); |
476 | attList << event->summary(); | 492 | attList << event->summary(); |
477 | attList << event->location(); | 493 | attList << event->location(); |
478 | attList << alarmString; | 494 | attList << alarmString; |
479 | attList << recurString; | 495 | attList << recurString; |
480 | attList << event->categoriesStr(); | 496 | attList << event->categoriesStr(); |
481 | attList << event->secrecyStr(); | 497 | attList << event->secrecyStr(); |
482 | cSum = PhoneFormat::getCsum(attList ); | 498 | cSum = PhoneFormat::getCsum(attList ); |
483 | event->setCsum( mProfileName, QString::number( cSum )); | 499 | event->setCsum( mProfileName, QString::number( cSum )); |
484 | mCalendar->addEvent( event); | 500 | mCalendar->addEvent( event); |
485 | 501 | ||
486 | return true; | 502 | return true; |
487 | } | 503 | } |
488 | 504 | ||
489 | 505 | ||
490 | QDateTime fromGSM ( GSM_DateTime*dtp, bool useTz = true ) { | 506 | QDateTime fromGSM ( GSM_DateTime*dtp, bool useTz = true ) { |
491 | QDateTime dt; | 507 | QDateTime dt; |
492 | int y,m,t,h,min,sec; | 508 | int y,m,t,h,min,sec; |
493 | y = dtp->Year; | 509 | y = dtp->Year; |
494 | m = dtp->Month; | 510 | m = dtp->Month; |
495 | t = dtp->Day; | 511 | t = dtp->Day; |
496 | h = dtp->Hour; | 512 | h = dtp->Hour; |
497 | min = dtp->Minute; | 513 | min = dtp->Minute; |
498 | sec = dtp->Second; | 514 | sec = dtp->Second; |
499 | dt = QDateTime(QDate(y,m,t), QTime(h,min,sec)); | 515 | dt = QDateTime(QDate(y,m,t), QTime(h,min,sec)); |
500 | // dtp->Timezone: offset in hours | 516 | // dtp->Timezone: offset in hours |
501 | int offset = KGlobal::locale()->localTimeOffset( dt ); | 517 | int offset = KGlobal::locale()->localTimeOffset( dt ); |
502 | if ( useTz ) | 518 | if ( useTz ) |
503 | dt = dt.addSecs ( offset*60); | 519 | dt = dt.addSecs ( offset*60); |
504 | return dt; | 520 | return dt; |
505 | 521 | ||
506 | } | 522 | } |
507 | 523 | ||
508 | QString dtToString( const QDateTime& dti, bool useTZ = false ) | 524 | QString dtToString( const QDateTime& dti, bool useTZ = false ) |
509 | { | 525 | { |
510 | QString datestr; | 526 | QString datestr; |
511 | QString timestr; | 527 | QString timestr; |
512 | int offset = KGlobal::locale()->localTimeOffset( dti ); | 528 | int offset = KGlobal::locale()->localTimeOffset( dti ); |
513 | QDateTime dt; | 529 | QDateTime dt; |
514 | if (useTZ) | 530 | if (useTZ) |
515 | dt = dti.addSecs ( -(offset*60)); | 531 | dt = dti.addSecs ( -(offset*60)); |
516 | else | 532 | else |
517 | dt = dti; | 533 | dt = dti; |
518 | if(dt.date().isValid()){ | 534 | if(dt.date().isValid()){ |
519 | const QDate& date = dt.date(); | 535 | const QDate& date = dt.date(); |
520 | datestr.sprintf("%04d%02d%02d", | 536 | datestr.sprintf("%04d%02d%02d", |
521 | date.year(), date.month(), date.day()); | 537 | date.year(), date.month(), date.day()); |
522 | } | 538 | } |
523 | if(dt.time().isValid()){ | 539 | if(dt.time().isValid()){ |
524 | const QTime& time = dt.time(); | 540 | const QTime& time = dt.time(); |
525 | timestr.sprintf("T%02d%02d%02d", | 541 | timestr.sprintf("T%02d%02d%02d", |
526 | time.hour(), time.minute(), time.second()); | 542 | time.hour(), time.minute(), time.second()); |
527 | } | 543 | } |
528 | return datestr + timestr; | 544 | return datestr + timestr; |
529 | } | 545 | } |
530 | QDate datefromGSM ( GSM_DateTime*dtp ) { | 546 | QDate datefromGSM ( GSM_DateTime*dtp ) { |
531 | return QDate ( dtp->Year, dtp->Month, dtp->Day ); | 547 | return QDate ( dtp->Year, dtp->Month, dtp->Day ); |
532 | } | 548 | } |
533 | QString getCategory( GSM_CalendarEntry*Note) | 549 | QString getCategory( GSM_CalendarEntry*Note) |
534 | { | 550 | { |
535 | QString CATEGORY; | 551 | QString CATEGORY; |
536 | switch (Note->Type) { | 552 | switch (Note->Type) { |
537 | case GSM_CAL_REMINDER : CATEGORY = QString("Reminder"); break; | 553 | case GSM_CAL_REMINDER : CATEGORY = QString("Reminder"); break; |
538 | case GSM_CAL_CALL : CATEGORY = QString("Call"); break; | 554 | case GSM_CAL_CALL : CATEGORY = QString("Call"); break; |
539 | case GSM_CAL_MEETING : CATEGORY = QString("Meeting"); break; | 555 | case GSM_CAL_MEETING : CATEGORY = QString("Meeting"); break; |
540 | case GSM_CAL_BIRTHDAY : CATEGORY = QString("Birthday"); break; | 556 | case GSM_CAL_BIRTHDAY : CATEGORY = QString("Birthday"); break; |
541 | case GSM_CAL_MEMO : CATEGORY = QString("Memo"); break; | 557 | case GSM_CAL_MEMO : CATEGORY = QString("Memo"); break; |
542 | case GSM_CAL_TRAVEL : CATEGORY = QString("Travel"); break; | 558 | case GSM_CAL_TRAVEL : CATEGORY = QString("Travel"); break; |
543 | case GSM_CAL_VACATION : CATEGORY = QString("Vacation"); break; | 559 | case GSM_CAL_VACATION : CATEGORY = QString("Vacation"); break; |
544 | case GSM_CAL_ALARM : CATEGORY = QString("Alarm"); break; | 560 | case GSM_CAL_ALARM : CATEGORY = QString("Alarm"); break; |
545 | case GSM_CAL_DAILY_ALARM : CATEGORY = QString("Daily alarm"); break; | 561 | case GSM_CAL_DAILY_ALARM : CATEGORY = QString("Daily alarm"); break; |
546 | case GSM_CAL_T_ATHL : CATEGORY = QString("Training/Athletism"); break; | 562 | case GSM_CAL_T_ATHL : CATEGORY = QString("Training/Athletism"); break; |
547 | case GSM_CAL_T_BALL : CATEGORY = QString("Training/Ball Games"); break; | 563 | case GSM_CAL_T_BALL : CATEGORY = QString("Training/Ball Games"); break; |
548 | case GSM_CAL_T_CYCL : CATEGORY = QString("Training/Cycling"); break; | 564 | case GSM_CAL_T_CYCL : CATEGORY = QString("Training/Cycling"); break; |
549 | case GSM_CAL_T_BUDO : CATEGORY = QString("Training/Budo"); break; | 565 | case GSM_CAL_T_BUDO : CATEGORY = QString("Training/Budo"); break; |
550 | case GSM_CAL_T_DANC : CATEGORY = QString("Training/Dance"); break; | 566 | case GSM_CAL_T_DANC : CATEGORY = QString("Training/Dance"); break; |
551 | case GSM_CAL_T_EXTR : CATEGORY = QString("Training/Extreme Sports"); break; | 567 | case GSM_CAL_T_EXTR : CATEGORY = QString("Training/Extreme Sports"); break; |
552 | case GSM_CAL_T_FOOT : CATEGORY = QString("Training/Football"); break; | 568 | case GSM_CAL_T_FOOT : CATEGORY = QString("Training/Football"); break; |
553 | case GSM_CAL_T_GOLF : CATEGORY = QString("Training/Golf"); break; | 569 | case GSM_CAL_T_GOLF : CATEGORY = QString("Training/Golf"); break; |
554 | case GSM_CAL_T_GYM : CATEGORY = QString("Training/Gym"); break; | 570 | case GSM_CAL_T_GYM : CATEGORY = QString("Training/Gym"); break; |
555 | case GSM_CAL_T_HORS : CATEGORY = QString("Training/Horse Races"); break; | 571 | case GSM_CAL_T_HORS : CATEGORY = QString("Training/Horse Races"); break; |
556 | case GSM_CAL_T_HOCK : CATEGORY = QString("Training/Hockey"); break; | 572 | case GSM_CAL_T_HOCK : CATEGORY = QString("Training/Hockey"); break; |
557 | case GSM_CAL_T_RACE : CATEGORY = QString("Training/Races"); break; | 573 | case GSM_CAL_T_RACE : CATEGORY = QString("Training/Races"); break; |
558 | case GSM_CAL_T_RUGB : CATEGORY = QString("Training/Rugby"); break; | 574 | case GSM_CAL_T_RUGB : CATEGORY = QString("Training/Rugby"); break; |
559 | case GSM_CAL_T_SAIL : CATEGORY = QString("Training/Sailing"); break; | 575 | case GSM_CAL_T_SAIL : CATEGORY = QString("Training/Sailing"); break; |
560 | case GSM_CAL_T_STRE : CATEGORY = QString("Training/Street Games"); break; | 576 | case GSM_CAL_T_STRE : CATEGORY = QString("Training/Street Games"); break; |
561 | case GSM_CAL_T_SWIM : CATEGORY = QString("Training/Swimming"); break; | 577 | case GSM_CAL_T_SWIM : CATEGORY = QString("Training/Swimming"); break; |
562 | case GSM_CAL_T_TENN : CATEGORY = QString("Training/Tennis"); break; | 578 | case GSM_CAL_T_TENN : CATEGORY = QString("Training/Tennis"); break; |
563 | case GSM_CAL_T_TRAV : CATEGORY = QString("Training/Travels"); break; | 579 | case GSM_CAL_T_TRAV : CATEGORY = QString("Training/Travels"); break; |
564 | case GSM_CAL_T_WINT : CATEGORY = QString("Training/Winter Games"); break; | 580 | case GSM_CAL_T_WINT : CATEGORY = QString("Training/Winter Games"); break; |
565 | default : CATEGORY = QString(""); | 581 | default : CATEGORY = QString(""); |
566 | } | 582 | } |
567 | 583 | ||
568 | return CATEGORY; | 584 | return CATEGORY; |
569 | } | 585 | } |
570 | 586 | ||
571 | protected: | 587 | protected: |
572 | private: | 588 | private: |
573 | Calendar *mCalendar; | 589 | Calendar *mCalendar; |
574 | QString mProfileName ; | 590 | QString mProfileName ; |
575 | }; | 591 | }; |
576 | 592 | ||
577 | 593 | ||
578 | PhoneFormat::PhoneFormat() | 594 | PhoneFormat::PhoneFormat() |
579 | { | 595 | { |
580 | ; | 596 | ; |
581 | } | 597 | } |
582 | 598 | ||
583 | PhoneFormat::~PhoneFormat() | 599 | PhoneFormat::~PhoneFormat() |
584 | { | 600 | { |
585 | } | 601 | } |
586 | ulong PhoneFormat::getCsum( const QStringList & attList) | 602 | ulong PhoneFormat::getCsum( const QStringList & attList) |
587 | { | 603 | { |
588 | int max = attList.count() -1; | 604 | int max = attList.count() -1; |
589 | ulong cSum = 0; | 605 | ulong cSum = 0; |
590 | int j,k,i; | 606 | int j,k,i; |
591 | int add; | 607 | int add; |
592 | for ( i = 1; i < max ; ++i ) { | 608 | for ( i = 1; i < max ; ++i ) { |
593 | QString s = attList[i]; | 609 | QString s = attList[i]; |
594 | if ( ! s.isEmpty() ){ | 610 | if ( ! s.isEmpty() ){ |
595 | j = s.length(); | 611 | j = s.length(); |
596 | for ( k = 0; k < j; ++k ) { | 612 | for ( k = 0; k < j; ++k ) { |
597 | int mul = k +1; | 613 | int mul = k +1; |
598 | add = s[k].unicode (); | 614 | add = s[k].unicode (); |
599 | if ( k < 16 ) | 615 | if ( k < 16 ) |
600 | mul = mul * mul; | 616 | mul = mul * mul; |
601 | add = add * mul *i*i*i; | 617 | add = add * mul *i*i*i; |
602 | cSum += add; | 618 | cSum += add; |
603 | } | 619 | } |
604 | } | 620 | } |
605 | } | 621 | } |
606 | return cSum; | 622 | return cSum; |
607 | 623 | ||
608 | } | 624 | } |
609 | //extern "C" GSM_Error GSM_InitConnection(GSM_StateMachine *s, int ReplyNum); | 625 | //extern "C" GSM_Error GSM_InitConnection(GSM_StateMachine *s, int ReplyNum); |
610 | #include <stdlib.h> | 626 | #include <stdlib.h> |
611 | #define DEBUGMODE false | 627 | #define DEBUGMODE false |
612 | bool PhoneFormat::load( Calendar *calendar, Calendar *existingCal ,QString profileName, QString device,QString connection, QString model ) | 628 | bool PhoneFormat::load( Calendar *calendar, Calendar *existingCal ,QString profileName, QString device,QString connection, QString model ) |
613 | { | 629 | { |
614 | mProfileName = profileName; | 630 | mProfileName = profileName; |
615 | GSM_StateMachines; | 631 | GSM_StateMachines; |
616 | qDebug(" load "); | 632 | qDebug(" load "); |
617 | s.opened = false; | 633 | s.opened = false; |
618 | s.msg = NULL; | 634 | s.msg = NULL; |
619 | s.ConfigNum = 0; | 635 | s.ConfigNum = 0; |
620 | #if 0 | 636 | #if 0 |
621 | static char*cp; | 637 | static char*cp; |
622 | static INI_Section *cfg = NULL; | 638 | static INI_Section *cfg = NULL; |
623 | cfg=GSM_FindGammuRC(); | 639 | cfg=GSM_FindGammuRC(); |
624 | int i; | 640 | int i; |
625 | for (i = 0; i <= MAX_CONFIG_NUM; i++) { | 641 | for (i = 0; i <= MAX_CONFIG_NUM; i++) { |
626 | if (cfg!=NULL) { | 642 | if (cfg!=NULL) { |
627 | cp = (char *)INI_GetValue(cfg, (unsigned char*) "gammu", (unsigned char*)"gammucoding", false); | 643 | cp = (char *)INI_GetValue(cfg, (unsigned char*) "gammu", (unsigned char*)"gammucoding", false); |
628 | if (cp) di.coding = cp; | 644 | if (cp) di.coding = cp; |
629 | 645 | ||
630 | s.Config[i].Localize = (char *)INI_GetValue(cfg, (unsigned char*) "gammu", (unsigned char*) "gammuloc", false); | 646 | s.Config[i].Localize = (char *)INI_GetValue(cfg, (unsigned char*) "gammu", (unsigned char*) "gammuloc", false); |
631 | if (s.Config[i].Localize) { | 647 | if (s.Config[i].Localize) { |
632 | s.msg=INI_ReadFile(s.Config[i].Localize, true); | 648 | s.msg=INI_ReadFile(s.Config[i].Localize, true); |
633 | } else { | 649 | } else { |
634 | #if !defined(WIN32) && defined(LOCALE_PATH) | 650 | #if !defined(WIN32) && defined(LOCALE_PATH) |
635 | locale = setlocale(LC_MESSAGES, NULL); | 651 | locale = setlocale(LC_MESSAGES, NULL); |
636 | if (locale != NULL) { | 652 | if (locale != NULL) { |
637 | snprintf(locale_file, 200, "%s/gammu_%c%c.txt", | 653 | snprintf(locale_file, 200, "%s/gammu_%c%c.txt", |
638 | LOCALE_PATH, | 654 | LOCALE_PATH, |
639 | tolower(locale[0]), | 655 | tolower(locale[0]), |
640 | tolower(locale[1])); | 656 | tolower(locale[1])); |
641 | s.msg = INI_ReadFile(locale_file, true); | 657 | s.msg = INI_ReadFile(locale_file, true); |
642 | } | 658 | } |
643 | #endif | 659 | #endif |
644 | } | 660 | } |
645 | } | 661 | } |
646 | 662 | ||
647 | /* Wanted user specific configuration? */ | 663 | /* Wanted user specific configuration? */ |
648 | 664 | ||
649 | if (!GSM_ReadConfig(cfg, &s.Config[i], i) && i != 0) break; | 665 | if (!GSM_ReadConfig(cfg, &s.Config[i], i) && i != 0) break; |
650 | 666 | ||
651 | s.ConfigNum++; | 667 | s.ConfigNum++; |
652 | 668 | ||
653 | /* We want to use only one file descriptor for global and state machine debug output */ | 669 | /* We want to use only one file descriptor for global and state machine debug output */ |
654 | s.Config[i].UseGlobalDebugFile = true; | 670 | s.Config[i].UseGlobalDebugFile = true; |
655 | 671 | ||
656 | 672 | ||
657 | 673 | ||
658 | /* We wanted to read just user specified configuration. */ | 674 | /* We wanted to read just user specified configuration. */ |
659 | {break;} | 675 | {break;} |
660 | } | 676 | } |
661 | 677 | ||
662 | #endif | 678 | #endif |
663 | setlocale(LC_ALL, ""); | 679 | setlocale(LC_ALL, ""); |
664 | GSM_ReadConfig(NULL, &s.Config[0], 0); | 680 | GSM_ReadConfig(NULL, &s.Config[0], 0); |
665 | s.ConfigNum = 1; | 681 | s.ConfigNum = 1; |
666 | GSM_Config *cfg = &s.Config[0]; | 682 | GSM_Config *cfg = &s.Config[0]; |
667 | if ( ! connection.isEmpty() ) { | 683 | if ( ! connection.isEmpty() ) { |
668 | cfg->Connection = strdup(connection.latin1()); | 684 | cfg->Connection = strdup(connection.latin1()); |
669 | cfg->DefaultConnection = false; | 685 | cfg->DefaultConnection = false; |
670 | qDebug("Connection set %s ", cfg->Connection ); | 686 | qDebug("Connection set %s ", cfg->Connection ); |
671 | 687 | ||
672 | } | 688 | } |
673 | if ( ! device.isEmpty() ) { | 689 | if ( ! device.isEmpty() ) { |
674 | cfg->Device = strdup(device.latin1()); | 690 | cfg->Device = strdup(device.latin1()); |
675 | cfg->DefaultDevice = false; | 691 | cfg->DefaultDevice = false; |
676 | qDebug("Device set %s ", cfg->Device); | 692 | qDebug("Device set %s ", cfg->Device); |
677 | 693 | ||
678 | } | 694 | } |
679 | if ( ! model.isEmpty() ) { | 695 | if ( ! model.isEmpty() ) { |
680 | strcpy(cfg->Model,model.latin1() ); | 696 | strcpy(cfg->Model,model.latin1() ); |
681 | cfg->DefaultModel = false; | 697 | cfg->DefaultModel = false; |
682 | qDebug("Model set %s ",cfg->Model ); | 698 | qDebug("Model set %s ",cfg->Model ); |
683 | 699 | ||
684 | 700 | ||
685 | } | 701 | } |
686 | int error=GSM_InitConnection(&s,3); | 702 | int error=GSM_InitConnection(&s,3); |
687 | qDebug("GSM Init %d (no error is %d)", error, ERR_NONE); | 703 | qDebug("GSM Init %d (no error is %d)", error, ERR_NONE); |
688 | if ( error != ERR_NONE ) | 704 | if ( error != ERR_NONE ) |
689 | return false; | 705 | return false; |
690 | GSM_Phone_Functions*Phone; | 706 | GSM_Phone_Functions*Phone; |
691 | GSM_CalendarEntrynote; | 707 | GSM_CalendarEntrynote; |
692 | bool start = true; | 708 | bool start = true; |
693 | Phone=s.Phone.Functions; | 709 | Phone=s.Phone.Functions; |
694 | bool gshutdown = false; | 710 | bool gshutdown = false; |
695 | PhoneParser handler( calendar, profileName ); | 711 | PhoneParser handler( calendar, profileName ); |
696 | int ccc = 0; | 712 | int ccc = 0; |
697 | qDebug("Debug: only 10 calender items are downloaded "); | 713 | qDebug("Debug: only 10 calender items are downloaded "); |
698 | while (!gshutdown && ccc++ < 10) { | 714 | while (!gshutdown && ccc++ < 10) { |
699 | 715 | ||
700 | qDebug("readEvent %d ", ccc); | 716 | qDebug("readEvent %d ", ccc); |
701 | error=Phone->GetNextCalendar(&s,¬e,start); | 717 | error=Phone->GetNextCalendar(&s,¬e,start); |
702 | if (error == ERR_EMPTY) break; | 718 | if (error == ERR_EMPTY) break; |
703 | start = false; | 719 | start = false; |
704 | handler.readEvent( existingCal, ¬e ); | 720 | handler.readEvent( existingCal, ¬e ); |
705 | } | 721 | } |
706 | 722 | ||
707 | start = true; | 723 | start = true; |
708 | GSM_ToDoEntry ToDo; | 724 | GSM_ToDoEntry ToDo; |
709 | ccc = 0; | 725 | ccc = 0; |
710 | while (!gshutdown) { | 726 | while (!gshutdown) { |
711 | error = Phone->GetNextToDo(&s, &ToDo, start); | 727 | error = Phone->GetNextToDo(&s, &ToDo, start); |
712 | if (error == ERR_EMPTY) break; | 728 | if (error == ERR_EMPTY) break; |
713 | start = false; | 729 | start = false; |
714 | qDebug("ReadTodo %d ", ++ccc); | 730 | qDebug("ReadTodo %d ", ++ccc); |
715 | handler.readTodo( existingCal, &ToDo, &s); | 731 | handler.readTodo( existingCal, &ToDo, &s); |
716 | 732 | ||
717 | } | 733 | } |
718 | 734 | ||
719 | error=GSM_TerminateConnection(&s); | 735 | error=GSM_TerminateConnection(&s); |
720 | 736 | ||
721 | return true; | 737 | return true; |
722 | } | 738 | } |
723 | 739 | ||
724 | bool PhoneFormat::save( Calendar *calendar) | 740 | bool PhoneFormat::save( Calendar *calendar) |
725 | { | 741 | { |
726 | #if 0 | 742 | #if 0 |
727 | QLabel status ( i18n("Processing/adding events ..."), 0 ); | 743 | QLabel status ( i18n("Processing/adding events ..."), 0 ); |
728 | int w = status.sizeHint().width()+20 ; | 744 | int w = status.sizeHint().width()+20 ; |
729 | if ( w < 200 ) w = 200; | 745 | if ( w < 200 ) w = 200; |
730 | int h = status.sizeHint().height()+20 ; | 746 | int h = status.sizeHint().height()+20 ; |
731 | int dw = QApplication::desktop()->width(); | 747 | int dw = QApplication::desktop()->width(); |
732 | int dh = QApplication::desktop()->height(); | 748 | int dh = QApplication::desktop()->height(); |
733 | status.setCaption(i18n("Writing DTM Data") ); | 749 | status.setCaption(i18n("Writing DTM Data") ); |
734 | status.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 750 | status.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
735 | status.show(); | 751 | status.show(); |
736 | status.raise(); | 752 | status.raise(); |
737 | qApp->processEvents(); | 753 | qApp->processEvents(); |
738 | bool debug = DEBUGMODE; | 754 | bool debug = DEBUGMODE; |
739 | QString codec = "utf8"; | 755 | QString codec = "utf8"; |
740 | QString answer; | 756 | QString answer; |
741 | QString ePrefix = "CARDID,CATEGORY,DSRP,PLCE,MEM1,TIM1,TIM2,ADAY,ARON,ARMN,ARSD,RTYP,RFRQ,RPOS,RDYS,REND,REDT,ALSD,ALED,MDAY\n"; | 757 | QString ePrefix = "CARDID,CATEGORY,DSRP,PLCE,MEM1,TIM1,TIM2,ADAY,ARON,ARMN,ARSD,RTYP,RFRQ,RPOS,RDYS,REND,REDT,ALSD,ALED,MDAY\n"; |
742 | QString tPrefix = "CARDID,CATEGORY,ETDY,LTDY,FNDY,MARK,PRTY,TITL,MEM1\n"; | 758 | QString tPrefix = "CARDID,CATEGORY,ETDY,LTDY,FNDY,MARK,PRTY,TITL,MEM1\n"; |
743 | QString command; | 759 | QString command; |
744 | QPtrList<Event> er = calendar->rawEvents(); | 760 | QPtrList<Event> er = calendar->rawEvents(); |
745 | Event* ev = er.first(); | 761 | Event* ev = er.first(); |
746 | QString fileName = "/tmp/kopitempout"; | 762 | QString fileName = "/tmp/kopitempout"; |
747 | int i = 0; | 763 | int i = 0; |
748 | QString changeString = ePrefix; | 764 | QString changeString = ePrefix; |
749 | QString deleteString = ePrefix; | 765 | QString deleteString = ePrefix; |
750 | bool deleteEnt = false; | 766 | bool deleteEnt = false; |
751 | bool changeEnt = false; | 767 | bool changeEnt = false; |
752 | QString message = i18n("Processing event # "); | 768 | QString message = i18n("Processing event # "); |
753 | int procCount = 0; | 769 | int procCount = 0; |
754 | while ( ev ) { | 770 | while ( ev ) { |
755 | //qDebug("i %d ", ++i); | 771 | //qDebug("i %d ", ++i); |
756 | if ( true /*ev->zaurusStat() != -2*/ ) { | 772 | if ( true /*ev->zaurusStat() != -2*/ ) { |
757 | status.setText ( message + QString::number ( ++procCount ) ); | 773 | status.setText ( message + QString::number ( ++procCount ) ); |
758 | qApp->processEvents(); | 774 | qApp->processEvents(); |
759 | QString eString = getEventString( ev ); | 775 | QString eString = getEventString( ev ); |
760 | if (/* ev->zaurusStat() == -3 */ true) { // delete | 776 | if (/* ev->zaurusStat() == -3 */ true) { // delete |
761 | // deleting empty strings does not work. | 777 | // deleting empty strings does not work. |
762 | // we write first and x and then delete the record with the x | 778 | // we write first and x and then delete the record with the x |
763 | eString = eString.replace( QRegExp(",\"\""),",\"x\"" ); | 779 | eString = eString.replace( QRegExp(",\"\""),",\"x\"" ); |
764 | changeString += eString + "\n"; | 780 | changeString += eString + "\n"; |
765 | deleteString += eString + "\n"; | 781 | deleteString += eString + "\n"; |
766 | deleteEnt = true; | 782 | deleteEnt = true; |
767 | changeEnt = true; | 783 | changeEnt = true; |
768 | } | 784 | } |
769 | else if ( /*ev->zaurusId() == -1*/true ) { // add new | 785 | else if ( /*ev->zaurusId() == -1*/true ) { // add new |
770 | command = "(echo \"" + ePrefix + eString + "\" ) | db2file datebook -w -g -c " + codec+ " > "+ fileName; | 786 | command = "(echo \"" + ePrefix + eString + "\" ) | db2file datebook -w -g -c " + codec+ " > "+ fileName; |
771 | system ( command.utf8() ); | 787 | system ( command.utf8() ); |
772 | QFile file( fileName ); | 788 | QFile file( fileName ); |
773 | if (!file.open( IO_ReadOnly ) ) { | 789 | if (!file.open( IO_ReadOnly ) ) { |
774 | return false; | 790 | return false; |
775 | 791 | ||
776 | } | 792 | } |
777 | QTextStream ts( &file ); | 793 | QTextStream ts( &file ); |
778 | ts.setCodec( QTextCodec::codecForName("utf8") ); | 794 | ts.setCodec( QTextCodec::codecForName("utf8") ); |
779 | answer = ts.read(); | 795 | answer = ts.read(); |
780 | file.close(); | 796 | file.close(); |
781 | //qDebug("answer \n%s ", answer.latin1()); | 797 | //qDebug("answer \n%s ", answer.latin1()); |
782 | getNumFromRecord( answer, ev ) ; | 798 | getNumFromRecord( answer, ev ) ; |
783 | 799 | ||
784 | } | 800 | } |
785 | else { // change existing | 801 | else { // change existing |
786 | //qDebug("canging %d %d",ev->zaurusStat() ,ev->zaurusId() ); | 802 | //qDebug("canging %d %d",ev->zaurusStat() ,ev->zaurusId() ); |
787 | //command = "(echo \"" + ePrefix + eString + "\" ) | db2file datebook -w -g -c " + codec+ " > "+ fileName; | 803 | //command = "(echo \"" + ePrefix + eString + "\" ) | db2file datebook -w -g -c " + codec+ " > "+ fileName; |
788 | changeString += eString + "\n"; | 804 | changeString += eString + "\n"; |
789 | changeEnt = true; | 805 | changeEnt = true; |
790 | 806 | ||
791 | } | 807 | } |
792 | } | 808 | } |
793 | ev = er.next(); | 809 | ev = er.next(); |
794 | } | 810 | } |