author | zautrix <zautrix> | 2004-10-08 22:22:02 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-10-08 22:22:02 (UTC) |
commit | 44169895703beb3e8b1551a313d2d341bf742905 (patch) (unidiff) | |
tree | 4e337f9b55d544a939185dbcdbad558b1ed2504d | |
parent | 10a0e05cc4962d9412a7a5faf3d69a3caf6d1c34 (diff) | |
download | kdepimpi-44169895703beb3e8b1551a313d2d341bf742905.zip kdepimpi-44169895703beb3e8b1551a313d2d341bf742905.tar.gz kdepimpi-44169895703beb3e8b1551a313d2d341bf742905.tar.bz2 |
gammu changes
-rw-r--r-- | Makefile | 11 | ||||
-rw-r--r-- | Makefile.Embedded | 2 | ||||
-rw-r--r-- | bin/kdepim/korganizer/howtoSYNC.txt | 2 | ||||
-rw-r--r-- | gammu/emb/gammu/gammu.c | 2 | ||||
-rw-r--r-- | phoneaccess.control (renamed from kammu.control) | 0 |
5 files changed, 9 insertions, 8 deletions
@@ -1,329 +1,330 @@ | |||
1 | export KDEPIMDIR = $(shell pwd) | 1 | export KDEPIMDIR = $(shell pwd) |
2 | 2 | ||
3 | export KDEPIM_VERSION=$(shell sed -e 's/.*\"\([0-9]*\.[0-9]*\.[0-9]*\).*/\1/' < version) | 3 | export KDEPIM_VERSION=$(shell sed -e 's/.*\"\([0-9]*\.[0-9]*\.[0-9]*\).*/\1/' < version) |
4 | 4 | ||
5 | ifeq ($(PLATFORM) , zaurus) | 5 | ifeq ($(PLATFORM) , zaurus) |
6 | BUILD_NO_LDAP_PLUGIN=1 | 6 | BUILD_NO_LDAP_PLUGIN=1 |
7 | endif | 7 | endif |
8 | 8 | ||
9 | ifneq ($(PLATFORM) , zaurus) | 9 | ifneq ($(PLATFORM) , zaurus) |
10 | BUILD_NO_SHARP_PLUGIN=1 | 10 | BUILD_NO_SHARP_PLUGIN=1 |
11 | endif | 11 | endif |
12 | 12 | ||
13 | SUBDIRS_MICROKDE = \ | 13 | SUBDIRS_MICROKDE = \ |
14 | libical/src/libical \ | 14 | libical/src/libical \ |
15 | libical/src/libicalss \ | 15 | libical/src/libicalss \ |
16 | qtcompat \ | 16 | qtcompat \ |
17 | microkde \ | 17 | microkde \ |
18 | libkcal \ | 18 | libkcal \ |
19 | libkdepim \ | 19 | libkdepim \ |
20 | kabc \ | 20 | kabc \ |
21 | kabc/formats/binary \ | 21 | kabc/formats/binary \ |
22 | kabc/plugins/file \ | 22 | kabc/plugins/file \ |
23 | kabc/plugins/dir \ | 23 | kabc/plugins/dir \ |
24 | korganizer \ | 24 | korganizer \ |
25 | kalarmd \ | 25 | kalarmd \ |
26 | kaddressbook | 26 | kaddressbook |
27 | 27 | ||
28 | SUBDIRS_QTOPIA_PLUGIN = \ | 28 | SUBDIRS_QTOPIA_PLUGIN = \ |
29 | kabc/plugins/qtopia | 29 | kabc/plugins/qtopia |
30 | 30 | ||
31 | SUBDIRS_OPIE_PLUGIN = \ | 31 | SUBDIRS_OPIE_PLUGIN = \ |
32 | kabc/plugins/opie | 32 | kabc/plugins/opie |
33 | 33 | ||
34 | SUBDIRS_SHARP_PLUGIN = \ | 34 | SUBDIRS_SHARP_PLUGIN = \ |
35 | kabc/plugins/sharpdtm | 35 | kabc/plugins/sharpdtm |
36 | 36 | ||
37 | SUBDIRS_LDAP_PLUGIN = \ | 37 | SUBDIRS_LDAP_PLUGIN = \ |
38 | kabc/plugins/ldap | 38 | kabc/plugins/ldap |
39 | 39 | ||
40 | SUBDIRS_MICROMAIL = \ | 40 | SUBDIRS_MICROMAIL = \ |
41 | kmicromail/libetpan \ | 41 | kmicromail/libetpan \ |
42 | kmicromail/libmailwrapper \ | 42 | kmicromail/libmailwrapper \ |
43 | kmicromail | 43 | kmicromail |
44 | 44 | ||
45 | SUBDIRS_GAMMU = \ | 45 | SUBDIRS_GAMMU = \ |
46 | gammu/emb/common \ | 46 | gammu/emb/common \ |
47 | gammu/emb/gammu | 47 | gammu/emb/gammu |
48 | 48 | ||
49 | SUBDIRS_PWMANAGER = \ | 49 | SUBDIRS_PWMANAGER = \ |
50 | pwmanager/pwmanager | 50 | pwmanager/pwmanager |
51 | 51 | ||
52 | SUBDIRS = \ | 52 | SUBDIRS = \ |
53 | $(SUBDIRS_MICROKDE) \ | 53 | $(SUBDIRS_MICROKDE) \ |
54 | $(SUBDIRS_QTOPIA_PLUGIN) \ | 54 | $(SUBDIRS_QTOPIA_PLUGIN) \ |
55 | $(SUBDIRS_OPIE_PLUGIN) \ | 55 | $(SUBDIRS_OPIE_PLUGIN) \ |
56 | $(SUBDIRS_SHARP_PLUGIN) \ | 56 | $(SUBDIRS_SHARP_PLUGIN) \ |
57 | $(SUBDIRS_LDAP_PLUGIN) \ | 57 | $(SUBDIRS_LDAP_PLUGIN) \ |
58 | $(SUBDIRS_MICROMAIL) \ | 58 | $(SUBDIRS_MICROMAIL) \ |
59 | $(SUBDIRS_GAMMU) \ | 59 | $(SUBDIRS_GAMMU) \ |
60 | $(SUBDIRS_PWMANAGER) | 60 | $(SUBDIRS_PWMANAGER) |
61 | 61 | ||
62 | |||
62 | all: build_microkde \ | 63 | all: build_microkde \ |
63 | build_qtopia_plugin \ | 64 | build_qtopia_plugin \ |
64 | build_opie_plugin \ | 65 | build_opie_plugin \ |
65 | build_sharp_plugin \ | 66 | build_sharp_plugin \ |
66 | build_ldap_plugin \ | 67 | build_ldap_plugin \ |
67 | build_micromail \ | 68 | build_micromail \ |
68 | build_gammu \ | 69 | build_gammu \ |
69 | build_pwmanager | 70 | build_pwmanager |
70 | 71 | ||
71 | 72 | ||
72 | build_microkde: variable_test tmake | 73 | build_microkde: variable_test tmake |
73 | for i in $(SUBDIRS_MICROKDE); do pushd $$i; \ | 74 | for i in $(SUBDIRS_MICROKDE); do pushd $$i; \ |
74 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 75 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
75 | done | 76 | done |
76 | 77 | ||
77 | build_qtopia_plugin: build_microkde | 78 | build_qtopia_plugin: build_microkde |
78 | for i in $(SUBDIRS_QTOPIA_PLUGIN); do pushd $$i; \ | 79 | for i in $(SUBDIRS_QTOPIA_PLUGIN); do pushd $$i; \ |
79 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 80 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
80 | done | 81 | done |
81 | 82 | ||
82 | build_opie_plugin: build_microkde | 83 | build_opie_plugin: build_microkde |
83 | ifdef BUILD_NO_OPIE_PLUGIN | 84 | ifdef BUILD_NO_OPIE_PLUGIN |
84 | @echo == opie plugin not build. | 85 | @echo == opie plugin not build. |
85 | else | 86 | else |
86 | for i in $(SUBDIRS_OPIE_PLUGIN); do pushd $$i; \ | 87 | for i in $(SUBDIRS_OPIE_PLUGIN); do pushd $$i; \ |
87 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 88 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
88 | done | 89 | done |
89 | endif | 90 | endif |
90 | 91 | ||
91 | build_sharp_plugin: build_microkde | 92 | build_sharp_plugin: build_microkde |
92 | ifdef BUILD_NO_SHARP_PLUGIN | 93 | ifdef BUILD_NO_SHARP_PLUGIN |
93 | @echo == ldap plugin not build. | 94 | @echo == ldap plugin not build. |
94 | else | 95 | else |
95 | for i in $(SUBDIRS_SHARP_PLUGIN); do pushd $$i; \ | 96 | for i in $(SUBDIRS_SHARP_PLUGIN); do pushd $$i; \ |
96 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 97 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
97 | done | 98 | done |
98 | endif | 99 | endif |
99 | 100 | ||
100 | build_ldap_plugin: build_microkde | 101 | build_ldap_plugin: build_microkde |
101 | ifdef BUILD_NO_LDAP_PLUGIN | 102 | ifdef BUILD_NO_LDAP_PLUGIN |
102 | @echo == ldap plugin not build. | 103 | @echo == ldap plugin not build. |
103 | else | 104 | else |
104 | for i in $(SUBDIRS_LDAP_PLUGIN); do pushd $$i; \ | 105 | for i in $(SUBDIRS_LDAP_PLUGIN); do pushd $$i; \ |
105 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 106 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
106 | done | 107 | done |
107 | endif | 108 | endif |
108 | 109 | ||
109 | 110 | ||
110 | build_micromail: build_microkde | 111 | build_micromail: build_microkde |
111 | ifdef BUILD_NO_MICROMAIL | 112 | ifdef BUILD_NO_MICROMAIL |
112 | @echo == kmicromail not build. | 113 | @echo == kmicromail not build. |
113 | else | 114 | else |
114 | for i in $(SUBDIRS_MICROMAIL); do pushd $$i; \ | 115 | for i in $(SUBDIRS_MICROMAIL); do pushd $$i; \ |
115 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 116 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
116 | done | 117 | done |
117 | endif | 118 | endif |
118 | 119 | ||
119 | build_gammu: variable_test tmake | 120 | build_gammu: variable_test tmake |
120 | ifdef BUILD_NO_GAMMU | 121 | ifdef BUILD_NO_GAMMU |
121 | @echo == gammu not build. | 122 | @echo == gammu not build. |
122 | else | 123 | else |
123 | for i in $(SUBDIRS_GAMMU); do pushd $$i; \ | 124 | for i in $(SUBDIRS_GAMMU); do pushd $$i; \ |
124 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 125 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
125 | done | 126 | done |
126 | endif | 127 | endif |
127 | 128 | ||
128 | build_pwmanager: build_microkde | 129 | build_pwmanager: build_microkde |
129 | ifdef BUILD_NO_PWMANAGER | 130 | ifdef BUILD_NO_PWMANAGER |
130 | @echo == pwmanager not build. | 131 | @echo == pwmanager not build. |
131 | else | 132 | else |
132 | for i in $(SUBDIRS_PWMANAGER); do pushd $$i; \ | 133 | for i in $(SUBDIRS_PWMANAGER); do pushd $$i; \ |
133 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 134 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
134 | done | 135 | done |
135 | endif | 136 | endif |
136 | 137 | ||
137 | 138 | ||
138 | variable_info: | 139 | variable_info: |
139 | @echo -------------------------------------- | 140 | @echo -------------------------------------- |
140 | @echo KDEPIM buildsystem, variableinfo... | 141 | @echo KDEPIM buildsystem, variableinfo... |
141 | @echo KDEPIMDIR=$(KDEPIMDIR) | 142 | @echo KDEPIMDIR=$(KDEPIMDIR) |
142 | @echo QTDIR=$(QTDIR) | 143 | @echo QTDIR=$(QTDIR) |
143 | @echo QPEDIR=$(QPEDIR) | 144 | @echo QPEDIR=$(QPEDIR) |
144 | @echo OPIEDIR=$(OPIEDIR) | 145 | @echo OPIEDIR=$(OPIEDIR) |
145 | @echo PLATFORM=$(PLATFORM) | 146 | @echo PLATFORM=$(PLATFORM) |
146 | @echo RELEASE_DEBUG=$(RELEASE_DEBUG) | 147 | @echo RELEASE_DEBUG=$(RELEASE_DEBUG) |
147 | @echo BUILD_NO_MICROMAIL=$(BUILD_NO_MICROMAIL) | 148 | @echo BUILD_NO_MICROMAIL=$(BUILD_NO_MICROMAIL) |
148 | @echo BUILD_NO_LDAP_PLUGIN=$(BUILD_NO_LDAP_PLUGIN) | 149 | @echo BUILD_NO_LDAP_PLUGIN=$(BUILD_NO_LDAP_PLUGIN) |
149 | @echo BUILD_NO_OPIE_PLUGIN=$(BUILD_NO_OPIE_PLUGIN) | 150 | @echo BUILD_NO_OPIE_PLUGIN=$(BUILD_NO_OPIE_PLUGIN) |
150 | @echo BUILD_NO_SHARP_PLUGIN=$(BUILD_NO_SHARP_PLUGIN) | 151 | @echo BUILD_NO_SHARP_PLUGIN=$(BUILD_NO_SHARP_PLUGIN) |
151 | ifndef BUILD_NO_SHARP_PLUGIN | 152 | ifndef BUILD_NO_SHARP_PLUGIN |
152 | @echo SHARPDTMSDK=$(SHARPDTMSDK) | 153 | @echo SHARPDTMSDK=$(SHARPDTMSDK) |
153 | endif | 154 | endif |
154 | @echo BUILD_NO_GAMMU=$(BUILD_NO_GAMMU) | 155 | @echo BUILD_NO_GAMMU=$(BUILD_NO_GAMMU) |
155 | @echo BUILD_NO_PWMANAGER=$(BUILD_NO_PWMANAGER) | 156 | @echo BUILD_NO_PWMANAGER=$(BUILD_NO_PWMANAGER) |
156 | @echo -------------------------------------- | 157 | @echo -------------------------------------- |
157 | 158 | ||
158 | variable_test: variable_info | 159 | variable_test: variable_info |
159 | @echo KDEPIM buildsystem, variablecheck... | 160 | @echo KDEPIM buildsystem, variablecheck... |
160 | ifndef KDEPIMDIR | 161 | ifndef KDEPIMDIR |
161 | @echo KDEPIMDIR is not defined. | 162 | @echo KDEPIMDIR is not defined. |
162 | $(error KDEPIMDIR is not defined) | 163 | $(error KDEPIMDIR is not defined) |
163 | endif | 164 | endif |
164 | ifndef PLATFORM | 165 | ifndef PLATFORM |
165 | @echo PLATFORM is not defined. | 166 | @echo PLATFORM is not defined. |
166 | $(error PLATFORM is not defined) | 167 | $(error PLATFORM is not defined) |
167 | endif | 168 | endif |
168 | ifdef BUILD_NO_LDAP_PLUGIN | 169 | ifdef BUILD_NO_LDAP_PLUGIN |
169 | @echo LDAP PLUGIN will not be build, because BUILD_NO_LDAP_PLUGIN is set to $(BUILD_NO_LDAP_PLUGIN) | 170 | @echo LDAP PLUGIN will not be build, because BUILD_NO_LDAP_PLUGIN is set to $(BUILD_NO_LDAP_PLUGIN) |
170 | endif | 171 | endif |
171 | ifdef BUILD_NO_OPIE_PLUGIN | 172 | ifdef BUILD_NO_OPIE_PLUGIN |
172 | @echo OPIE PLUGIN will not be build, because BUILD_NO_OPIE_PLUGIN is set to $(BUILD_NO_OPIE_PLUGIN) | 173 | @echo OPIE PLUGIN will not be build, because BUILD_NO_OPIE_PLUGIN is set to $(BUILD_NO_OPIE_PLUGIN) |
173 | endif | 174 | endif |
174 | ifdef BUILD_NO_MICROMAIL | 175 | ifdef BUILD_NO_MICROMAIL |
175 | @echo MICROMAIL will not be build, because BUILD_NO_MICROMAIL is set to $(BUILD_NO_MICROMAIL) | 176 | @echo MICROMAIL will not be build, because BUILD_NO_MICROMAIL is set to $(BUILD_NO_MICROMAIL) |
176 | endif | 177 | endif |
177 | ifdef BUILD_NO_SHARP_PLUGIN | 178 | ifdef BUILD_NO_SHARP_PLUGIN |
178 | @echo SHARP PLUGIN will not be build, because BUILD_NO_SHARP_PLUGIN is set to $(BUILD_NO_SHARP_PLUGIN) | 179 | @echo SHARP PLUGIN will not be build, because BUILD_NO_SHARP_PLUGIN is set to $(BUILD_NO_SHARP_PLUGIN) |
179 | else | 180 | else |
180 | ifndef SHARPDTMSDK | 181 | ifndef SHARPDTMSDK |
181 | @echo SHARP PLUGIN can not be build, because SHARPDTMSDK is set to $(SHARPDTMSDK) | 182 | @echo SHARP PLUGIN can not be build, because SHARPDTMSDK is set to $(SHARPDTMSDK) |
182 | $(error SHARPDTMSDK is not defined) | 183 | $(error SHARPDTMSDK is not defined) |
183 | endif | 184 | endif |
184 | endif | 185 | endif |
185 | ifdef BUILD_NO_GAMMU | 186 | ifdef BUILD_NO_GAMMU |
186 | @echo GAMMU will not be build, because BUILD_NO_GAMMU is set to $(BUILD_NO_GAMMU) | 187 | @echo GAMMU will not be build, because BUILD_NO_GAMMU is set to $(BUILD_NO_GAMMU) |
187 | endif | 188 | endif |
188 | ifdef BUILD_NO_PWMANAGER | 189 | ifdef BUILD_NO_PWMANAGER |
189 | @echo PWMANAGER will not be build, because BUILD_NO_PWMANAGER is set to $(BUILD_NO_PWMANAGER) | 190 | @echo PWMANAGER will not be build, because BUILD_NO_PWMANAGER is set to $(BUILD_NO_PWMANAGER) |
190 | endif | 191 | endif |
191 | @echo -------------------------------------- | 192 | @echo -------------------------------------- |
192 | 193 | ||
193 | 194 | ||
194 | objects: | 195 | objects: |
195 | for i in $(SUBDIRS); do mkdir -p $$i/obj/$(PLATFORM); done | 196 | for i in $(SUBDIRS); do mkdir -p $$i/obj/$(PLATFORM); done |
196 | for i in $(SUBDIRS); do mkdir -p $$i/moc/$(PLATFORM); done | 197 | for i in $(SUBDIRS); do mkdir -p $$i/moc/$(PLATFORM); done |
197 | mkdir -p libical/lib/$(PLATFORM) | 198 | mkdir -p libical/lib/$(PLATFORM) |
198 | 199 | ||
199 | clean: | 200 | clean: |
200 | rm -rf libical/lib/$(PLATFORM)/*; | 201 | rm -rf libical/lib/$(PLATFORM)/*; |
201 | for i in $(SUBDIRS); do pushd $$i; make clean; rm -f *~;\ | 202 | for i in $(SUBDIRS); do pushd $$i; make clean; rm -f *~;\ |
202 | rm -f obj/$(PLATFORM)/*; rm -f moc/$(PLATFORM)/*; rm Makefile$(PLATFORM); popd; \ | 203 | rm -f obj/$(PLATFORM)/*; rm -f moc/$(PLATFORM)/*; rm Makefile$(PLATFORM); popd; \ |
203 | done | 204 | done |
205 | |||
204 | install: | 206 | install: |
205 | 207 | ||
206 | cd bin/kdepim; make install | 208 | cd bin/kdepim; make install |
207 | cp -r Pim $(QPEDIR)/apps | 209 | cp -r Pim $(QPEDIR)/apps |
208 | cp db2file/db2file $(QPEDIR)/bin/db2file | 210 | cp db2file/db2file $(QPEDIR)/bin/db2file |
209 | cp korganizer/korganizer.desktop $(QPEDIR)/apps/Pim/korganizer.desktop | 211 | cp korganizer/korganizer.desktop $(QPEDIR)/apps/Pim/korganizer.desktop |
210 | cp kaddressbook/kaddressbook.desktop $(QPEDIR)/apps/Pim/kaddressbook.desktop | 212 | cp kaddressbook/kaddressbook.desktop $(QPEDIR)/apps/Pim/kaddressbook.desktop |
211 | cp kmicromail/kmicromail.desktop $(QPEDIR)/apps/Pim/kopiemail.desktop | 213 | cp kmicromail/kmicromail.desktop $(QPEDIR)/apps/Pim/kopiemail.desktop |
212 | cp pwmanager/pwmanager/pwmanager.desktop $(QPEDIR)/apps/Pim/pwmanager.desktop | 214 | cp pwmanager/pwmanager/pwmanager.desktop $(QPEDIR)/apps/Pim/pwmanager.desktop |
213 | 215 | ||
214 | dist: | 216 | dist: |
215 | @echo Dont forget to do "make install" before "make dist" | 217 | @echo Dont forget to do "make install" before "make dist" |
216 | rm -f *arm.ipk | 218 | rm -f *arm.ipk |
217 | rm -f *~ | 219 | rm -f *~ |
218 | cd ..; tar czf kdepim.src.tar.gz --exclude=obj --exclude=moc --exclude=CVS --exclude=Makefilezaurus --exclude=Makefileqtopia kdepim | 220 | cd ..; tar czf kdepim.src.tar.gz --exclude=obj --exclude=moc --exclude=CVS --exclude=Makefilezaurus --exclude=Makefileqtopia kdepim |
219 | ./mkipks kmicrokdelibs.control | 221 | ./mkipks kmicrokdelibs.control |
220 | ./mkipks korganizer.control | 222 | ./mkipks korganizer.control |
221 | ./mkipks kaddressbook.control | 223 | ./mkipks kaddressbook.control |
222 | ifndef BUILD_NO_MICROMAIL | 224 | ifndef BUILD_NO_MICROMAIL |
223 | ./mkipks kopiemail.control | 225 | ./mkipks kopiemail.control |
224 | endif | 226 | endif |
225 | ./mkipks korganizer-alarm.control | 227 | ./mkipks korganizer-alarm.control |
226 | ifndef BUILD_NO_GAMMU | 228 | ifndef BUILD_NO_GAMMU |
227 | ./mkipks kammu.control | 229 | ./mkipks phoneaccess.control |
228 | endif | 230 | endif |
229 | ifndef BUILD_NO_PWMANAGER | 231 | ifndef BUILD_NO_PWMANAGER |
230 | ./mkipks pwmanager.control | 232 | ./mkipks pwmanager.control |
231 | endif | 233 | endif |
232 | ./mkipks pim_TAB_icon.control | 234 | ./mkipks pim_TAB_icon.control |
233 | 235 | ||
234 | tmake: objects \ | 236 | tmake: objects \ |
235 | qtcompat/Makefile$(PLATFORM) \ | 237 | qtcompat/Makefile$(PLATFORM) \ |
236 | microkde/Makefile$(PLATFORM) \ | 238 | microkde/Makefile$(PLATFORM) \ |
237 | libkcal/Makefile$(PLATFORM) \ | 239 | libkcal/Makefile$(PLATFORM) \ |
238 | libkdepim/Makefile$(PLATFORM) \ | 240 | libkdepim/Makefile$(PLATFORM) \ |
239 | korganizer/Makefile$(PLATFORM) \ | 241 | korganizer/Makefile$(PLATFORM) \ |
240 | kalarmd/Makefile$(PLATFORM) \ | 242 | kalarmd/Makefile$(PLATFORM) \ |
241 | libical/src/libical/Makefile$(PLATFORM) \ | 243 | libical/src/libical/Makefile$(PLATFORM) \ |
242 | libical/src/libicalss/Makefile$(PLATFORM) \ | 244 | libical/src/libicalss/Makefile$(PLATFORM) \ |
243 | kabc/Makefile$(PLATFORM) \ | 245 | kabc/Makefile$(PLATFORM) \ |
244 | kabc/formats/binary/Makefile$(PLATFORM) \ | 246 | kabc/formats/binary/Makefile$(PLATFORM) \ |
245 | kabc/plugins/file/Makefile$(PLATFORM) \ | 247 | kabc/plugins/file/Makefile$(PLATFORM) \ |
246 | kabc/plugins/dir/Makefile$(PLATFORM) \ | 248 | kabc/plugins/dir/Makefile$(PLATFORM) \ |
247 | kabc/plugins/ldap/Makefile$(PLATFORM) \ | 249 | kabc/plugins/ldap/Makefile$(PLATFORM) \ |
248 | kabc/plugins/opie/Makefile$(PLATFORM) \ | 250 | kabc/plugins/opie/Makefile$(PLATFORM) \ |
249 | kabc/plugins/qtopia/Makefile$(PLATFORM) \ | 251 | kabc/plugins/qtopia/Makefile$(PLATFORM) \ |
250 | kabc/plugins/sharpdtm/Makefile$(PLATFORM) \ | 252 | kabc/plugins/sharpdtm/Makefile$(PLATFORM) \ |
251 | kaddressbook/Makefile$(PLATFORM) \ | 253 | kaddressbook/Makefile$(PLATFORM) \ |
252 | kmicromail/Makefile$(PLATFORM) \ | 254 | kmicromail/Makefile$(PLATFORM) \ |
253 | kmicromail/libetpan/Makefile$(PLATFORM) \ | 255 | kmicromail/libetpan/Makefile$(PLATFORM) \ |
254 | kmicromail/libmailwrapper/Makefile$(PLATFORM) \ | 256 | kmicromail/libmailwrapper/Makefile$(PLATFORM) \ |
255 | gammu/emb/common/Makefile$(PLATFORM) \ | 257 | gammu/emb/common/Makefile$(PLATFORM) \ |
256 | gammu/emb/gammu/Makefile$(PLATFORM) \ | 258 | gammu/emb/gammu/Makefile$(PLATFORM) \ |
257 | pwmanager/pwmanager/Makefile$(PLATFORM) \ | 259 | pwmanager/pwmanager/Makefile$(PLATFORM) \ |
258 | 260 | ||
259 | |||
260 | |||
261 | qtcompat/Makefile$(PLATFORM): qtcompat/qtcompat.pro | 261 | qtcompat/Makefile$(PLATFORM): qtcompat/qtcompat.pro |
262 | cd qtcompat; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtcompat.pro -o Makefile$(PLATFORM) | 262 | cd qtcompat; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtcompat.pro -o Makefile$(PLATFORM) |
263 | 263 | ||
264 | microkde/Makefile$(PLATFORM): microkde/microkdeE.pro | 264 | microkde/Makefile$(PLATFORM): microkde/microkdeE.pro |
265 | cd microkde; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" microkdeE.pro -o Makefile$(PLATFORM) | 265 | cd microkde; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" microkdeE.pro -o Makefile$(PLATFORM) |
266 | 266 | ||
267 | libkcal/Makefile$(PLATFORM): libkcal/libkcalE.pro | 267 | libkcal/Makefile$(PLATFORM): libkcal/libkcalE.pro |
268 | cd libkcal; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkcalE.pro -o Makefile$(PLATFORM) | 268 | cd libkcal; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkcalE.pro -o Makefile$(PLATFORM) |
269 | 269 | ||
270 | 270 | ||
271 | libkdepim/Makefile$(PLATFORM): libkdepim/libkdepimE.pro | 271 | libkdepim/Makefile$(PLATFORM): libkdepim/libkdepimE.pro |
272 | cd libkdepim; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkdepimE.pro -o Makefile$(PLATFORM) | 272 | cd libkdepim; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkdepimE.pro -o Makefile$(PLATFORM) |
273 | 273 | ||
274 | kalarmd/Makefile$(PLATFORM): kalarmd/kalarmdE.pro | 274 | kalarmd/Makefile$(PLATFORM): kalarmd/kalarmdE.pro |
275 | cd kalarmd; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kalarmdE.pro -o Makefile$(PLATFORM) | 275 | cd kalarmd; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kalarmdE.pro -o Makefile$(PLATFORM) |
276 | 276 | ||
277 | korganizer/Makefile$(PLATFORM): korganizer/korganizerE.pro | 277 | korganizer/Makefile$(PLATFORM): korganizer/korganizerE.pro |
278 | cd korganizer; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" korganizerE.pro -o Makefile$(PLATFORM) | 278 | cd korganizer; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" korganizerE.pro -o Makefile$(PLATFORM) |
279 | 279 | ||
280 | libical/src/libical/Makefile$(PLATFORM): libical/src/libical/libicalE.pro | 280 | libical/src/libical/Makefile$(PLATFORM): libical/src/libical/libicalE.pro |
281 | cd libical/src/libical; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalE.pro -o Makefile$(PLATFORM) | 281 | cd libical/src/libical; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalE.pro -o Makefile$(PLATFORM) |
282 | 282 | ||
283 | libical/src/libicalss/Makefile$(PLATFORM): libical/src/libicalss/libicalssE.pro | 283 | libical/src/libicalss/Makefile$(PLATFORM): libical/src/libicalss/libicalssE.pro |
284 | cd libical/src/libicalss; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalssE.pro -o Makefile$(PLATFORM) | 284 | cd libical/src/libicalss; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalssE.pro -o Makefile$(PLATFORM) |
285 | 285 | ||
286 | kabc/Makefile$(PLATFORM): kabc/kabcE.pro | 286 | kabc/Makefile$(PLATFORM): kabc/kabcE.pro |
287 | cd kabc; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcE.pro -o Makefile$(PLATFORM) | 287 | cd kabc; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcE.pro -o Makefile$(PLATFORM) |
288 | 288 | ||
289 | kabc/formats/binary/Makefile$(PLATFORM): kabc/formats/binary/kabcformat_binaryE.pro | 289 | kabc/formats/binary/Makefile$(PLATFORM): kabc/formats/binary/kabcformat_binaryE.pro |
290 | cd kabc/formats/binary; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcformat_binaryE.pro -o Makefile$(PLATFORM) | 290 | cd kabc/formats/binary; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcformat_binaryE.pro -o Makefile$(PLATFORM) |
291 | 291 | ||
292 | kabc/plugins/file/Makefile$(PLATFORM): kabc/plugins/file/fileE.pro | 292 | kabc/plugins/file/Makefile$(PLATFORM): kabc/plugins/file/fileE.pro |
293 | cd kabc/plugins/file; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" fileE.pro -o Makefile$(PLATFORM) | 293 | cd kabc/plugins/file; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" fileE.pro -o Makefile$(PLATFORM) |
294 | 294 | ||
295 | kabc/plugins/dir/Makefile$(PLATFORM): kabc/plugins/dir/dirE.pro | 295 | kabc/plugins/dir/Makefile$(PLATFORM): kabc/plugins/dir/dirE.pro |
296 | cd kabc/plugins/dir; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" dirE.pro -o Makefile$(PLATFORM) | 296 | cd kabc/plugins/dir; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" dirE.pro -o Makefile$(PLATFORM) |
297 | 297 | ||
298 | kabc/plugins/ldap/Makefile$(PLATFORM): kabc/plugins/ldap/ldapE.pro | 298 | kabc/plugins/ldap/Makefile$(PLATFORM): kabc/plugins/ldap/ldapE.pro |
299 | cd kabc/plugins/ldap; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" ldapE.pro -o Makefile$(PLATFORM) | 299 | cd kabc/plugins/ldap; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" ldapE.pro -o Makefile$(PLATFORM) |
300 | 300 | ||
301 | kabc/plugins/opie/Makefile$(PLATFORM): kabc/plugins/opie/opieE.pro | 301 | kabc/plugins/opie/Makefile$(PLATFORM): kabc/plugins/opie/opieE.pro |
302 | cd kabc/plugins/opie; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" opieE.pro -o Makefile$(PLATFORM) | 302 | cd kabc/plugins/opie; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" opieE.pro -o Makefile$(PLATFORM) |
303 | 303 | ||
304 | kabc/plugins/qtopia/Makefile$(PLATFORM): kabc/plugins/qtopia/qtopiaE.pro | 304 | kabc/plugins/qtopia/Makefile$(PLATFORM): kabc/plugins/qtopia/qtopiaE.pro |
305 | cd kabc/plugins/qtopia; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtopiaE.pro -o Makefile$(PLATFORM) | 305 | cd kabc/plugins/qtopia; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtopiaE.pro -o Makefile$(PLATFORM) |
306 | 306 | ||
307 | kabc/plugins/sharpdtm/Makefile$(PLATFORM): kabc/plugins/sharpdtm/sharpdtmE.pro | 307 | kabc/plugins/sharpdtm/Makefile$(PLATFORM): kabc/plugins/sharpdtm/sharpdtmE.pro |
308 | cd kabc/plugins/sharpdtm; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" sharpdtmE.pro -o Makefile$(PLATFORM) | 308 | cd kabc/plugins/sharpdtm; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" sharpdtmE.pro -o Makefile$(PLATFORM) |
309 | 309 | ||
310 | kaddressbook/Makefile$(PLATFORM): kaddressbook/kaddressbookE.pro | 310 | kaddressbook/Makefile$(PLATFORM): kaddressbook/kaddressbookE.pro |
311 | cd kaddressbook; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kaddressbookE.pro -o Makefile$(PLATFORM) | 311 | cd kaddressbook; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kaddressbookE.pro -o Makefile$(PLATFORM) |
312 | 312 | ||
313 | kmicromail/Makefile$(PLATFORM): kmicromail/kmicromailE.pro | 313 | kmicromail/Makefile$(PLATFORM): kmicromail/kmicromailE.pro |
314 | cd kmicromail; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kmicromailE.pro -o Makefile$(PLATFORM) | 314 | cd kmicromail; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kmicromailE.pro -o Makefile$(PLATFORM) |
315 | 315 | ||
316 | kmicromail/libetpan/Makefile$(PLATFORM): kmicromail/libetpan/libetpanE.pro | 316 | kmicromail/libetpan/Makefile$(PLATFORM): kmicromail/libetpan/libetpanE.pro |
317 | cd kmicromail/libetpan; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libetpanE.pro -o Makefile$(PLATFORM) | 317 | cd kmicromail/libetpan; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libetpanE.pro -o Makefile$(PLATFORM) |
318 | 318 | ||
319 | kmicromail/libmailwrapper/Makefile$(PLATFORM): kmicromail/libmailwrapper/libmailwrapperE.pro | 319 | kmicromail/libmailwrapper/Makefile$(PLATFORM): kmicromail/libmailwrapper/libmailwrapperE.pro |
320 | cd kmicromail/libmailwrapper; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libmailwrapperE.pro -o Makefile$(PLATFORM) | 320 | cd kmicromail/libmailwrapper; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libmailwrapperE.pro -o Makefile$(PLATFORM) |
321 | 321 | ||
322 | gammu/emb/common/Makefile$(PLATFORM): gammu/emb/common/commonE.pro | 322 | gammu/emb/common/Makefile$(PLATFORM): gammu/emb/common/commonE.pro |
323 | cd gammu/emb/common; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" commonE.pro -o Makefile$(PLATFORM) | 323 | cd gammu/emb/common; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" commonE.pro -o Makefile$(PLATFORM) |
324 | 324 | ||
325 | gammu/emb/gammu/Makefile$(PLATFORM): gammu/emb/gammu/gammuE.pro | 325 | gammu/emb/gammu/Makefile$(PLATFORM): gammu/emb/gammu/gammuE.pro |
326 | cd gammu/emb/gammu; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" gammuE.pro -o Makefile$(PLATFORM) | 326 | cd gammu/emb/gammu; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" gammuE.pro -o Makefile$(PLATFORM) |
327 | 327 | ||
328 | pwmanager/pwmanager/Makefile$(PLATFORM): pwmanager/pwmanager/pwmanagerE.pro | 328 | pwmanager/pwmanager/Makefile$(PLATFORM): pwmanager/pwmanager/pwmanagerE.pro |
329 | cd pwmanager/pwmanager; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" pwmanagerE.pro -o Makefile$(PLATFORM) | 329 | cd pwmanager/pwmanager; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" pwmanagerE.pro -o Makefile$(PLATFORM) |
330 | |||
diff --git a/Makefile.Embedded b/Makefile.Embedded index 2e1651c..0b8997e 100644 --- a/Makefile.Embedded +++ b/Makefile.Embedded | |||
@@ -1,330 +1,330 @@ | |||
1 | export KDEPIMDIR = $(shell pwd) | 1 | export KDEPIMDIR = $(shell pwd) |
2 | 2 | ||
3 | export KDEPIM_VERSION=$(shell sed -e 's/.*\"\([0-9]*\.[0-9]*\.[0-9]*\).*/\1/' < version) | 3 | export KDEPIM_VERSION=$(shell sed -e 's/.*\"\([0-9]*\.[0-9]*\.[0-9]*\).*/\1/' < version) |
4 | 4 | ||
5 | ifeq ($(PLATFORM) , zaurus) | 5 | ifeq ($(PLATFORM) , zaurus) |
6 | BUILD_NO_LDAP_PLUGIN=1 | 6 | BUILD_NO_LDAP_PLUGIN=1 |
7 | endif | 7 | endif |
8 | 8 | ||
9 | ifneq ($(PLATFORM) , zaurus) | 9 | ifneq ($(PLATFORM) , zaurus) |
10 | BUILD_NO_SHARP_PLUGIN=1 | 10 | BUILD_NO_SHARP_PLUGIN=1 |
11 | endif | 11 | endif |
12 | 12 | ||
13 | SUBDIRS_MICROKDE = \ | 13 | SUBDIRS_MICROKDE = \ |
14 | libical/src/libical \ | 14 | libical/src/libical \ |
15 | libical/src/libicalss \ | 15 | libical/src/libicalss \ |
16 | qtcompat \ | 16 | qtcompat \ |
17 | microkde \ | 17 | microkde \ |
18 | libkcal \ | 18 | libkcal \ |
19 | libkdepim \ | 19 | libkdepim \ |
20 | kabc \ | 20 | kabc \ |
21 | kabc/formats/binary \ | 21 | kabc/formats/binary \ |
22 | kabc/plugins/file \ | 22 | kabc/plugins/file \ |
23 | kabc/plugins/dir \ | 23 | kabc/plugins/dir \ |
24 | korganizer \ | 24 | korganizer \ |
25 | kalarmd \ | 25 | kalarmd \ |
26 | kaddressbook | 26 | kaddressbook |
27 | 27 | ||
28 | SUBDIRS_QTOPIA_PLUGIN = \ | 28 | SUBDIRS_QTOPIA_PLUGIN = \ |
29 | kabc/plugins/qtopia | 29 | kabc/plugins/qtopia |
30 | 30 | ||
31 | SUBDIRS_OPIE_PLUGIN = \ | 31 | SUBDIRS_OPIE_PLUGIN = \ |
32 | kabc/plugins/opie | 32 | kabc/plugins/opie |
33 | 33 | ||
34 | SUBDIRS_SHARP_PLUGIN = \ | 34 | SUBDIRS_SHARP_PLUGIN = \ |
35 | kabc/plugins/sharpdtm | 35 | kabc/plugins/sharpdtm |
36 | 36 | ||
37 | SUBDIRS_LDAP_PLUGIN = \ | 37 | SUBDIRS_LDAP_PLUGIN = \ |
38 | kabc/plugins/ldap | 38 | kabc/plugins/ldap |
39 | 39 | ||
40 | SUBDIRS_MICROMAIL = \ | 40 | SUBDIRS_MICROMAIL = \ |
41 | kmicromail/libetpan \ | 41 | kmicromail/libetpan \ |
42 | kmicromail/libmailwrapper \ | 42 | kmicromail/libmailwrapper \ |
43 | kmicromail | 43 | kmicromail |
44 | 44 | ||
45 | SUBDIRS_GAMMU = \ | 45 | SUBDIRS_GAMMU = \ |
46 | gammu/emb/common \ | 46 | gammu/emb/common \ |
47 | gammu/emb/gammu | 47 | gammu/emb/gammu |
48 | 48 | ||
49 | SUBDIRS_PWMANAGER = \ | 49 | SUBDIRS_PWMANAGER = \ |
50 | pwmanager/pwmanager | 50 | pwmanager/pwmanager |
51 | 51 | ||
52 | SUBDIRS = \ | 52 | SUBDIRS = \ |
53 | $(SUBDIRS_MICROKDE) \ | 53 | $(SUBDIRS_MICROKDE) \ |
54 | $(SUBDIRS_QTOPIA_PLUGIN) \ | 54 | $(SUBDIRS_QTOPIA_PLUGIN) \ |
55 | $(SUBDIRS_OPIE_PLUGIN) \ | 55 | $(SUBDIRS_OPIE_PLUGIN) \ |
56 | $(SUBDIRS_SHARP_PLUGIN) \ | 56 | $(SUBDIRS_SHARP_PLUGIN) \ |
57 | $(SUBDIRS_LDAP_PLUGIN) \ | 57 | $(SUBDIRS_LDAP_PLUGIN) \ |
58 | $(SUBDIRS_MICROMAIL) \ | 58 | $(SUBDIRS_MICROMAIL) \ |
59 | $(SUBDIRS_GAMMU) \ | 59 | $(SUBDIRS_GAMMU) \ |
60 | $(SUBDIRS_PWMANAGER) | 60 | $(SUBDIRS_PWMANAGER) |
61 | 61 | ||
62 | 62 | ||
63 | all: build_microkde \ | 63 | all: build_microkde \ |
64 | build_qtopia_plugin \ | 64 | build_qtopia_plugin \ |
65 | build_opie_plugin \ | 65 | build_opie_plugin \ |
66 | build_sharp_plugin \ | 66 | build_sharp_plugin \ |
67 | build_ldap_plugin \ | 67 | build_ldap_plugin \ |
68 | build_micromail \ | 68 | build_micromail \ |
69 | build_gammu \ | 69 | build_gammu \ |
70 | build_pwmanager | 70 | build_pwmanager |
71 | 71 | ||
72 | 72 | ||
73 | build_microkde: variable_test tmake | 73 | build_microkde: variable_test tmake |
74 | for i in $(SUBDIRS_MICROKDE); do pushd $$i; \ | 74 | for i in $(SUBDIRS_MICROKDE); do pushd $$i; \ |
75 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 75 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
76 | done | 76 | done |
77 | 77 | ||
78 | build_qtopia_plugin: build_microkde | 78 | build_qtopia_plugin: build_microkde |
79 | for i in $(SUBDIRS_QTOPIA_PLUGIN); do pushd $$i; \ | 79 | for i in $(SUBDIRS_QTOPIA_PLUGIN); do pushd $$i; \ |
80 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 80 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
81 | done | 81 | done |
82 | 82 | ||
83 | build_opie_plugin: build_microkde | 83 | build_opie_plugin: build_microkde |
84 | ifdef BUILD_NO_OPIE_PLUGIN | 84 | ifdef BUILD_NO_OPIE_PLUGIN |
85 | @echo == opie plugin not build. | 85 | @echo == opie plugin not build. |
86 | else | 86 | else |
87 | for i in $(SUBDIRS_OPIE_PLUGIN); do pushd $$i; \ | 87 | for i in $(SUBDIRS_OPIE_PLUGIN); do pushd $$i; \ |
88 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 88 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
89 | done | 89 | done |
90 | endif | 90 | endif |
91 | 91 | ||
92 | build_sharp_plugin: build_microkde | 92 | build_sharp_plugin: build_microkde |
93 | ifdef BUILD_NO_SHARP_PLUGIN | 93 | ifdef BUILD_NO_SHARP_PLUGIN |
94 | @echo == ldap plugin not build. | 94 | @echo == ldap plugin not build. |
95 | else | 95 | else |
96 | for i in $(SUBDIRS_SHARP_PLUGIN); do pushd $$i; \ | 96 | for i in $(SUBDIRS_SHARP_PLUGIN); do pushd $$i; \ |
97 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 97 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
98 | done | 98 | done |
99 | endif | 99 | endif |
100 | 100 | ||
101 | build_ldap_plugin: build_microkde | 101 | build_ldap_plugin: build_microkde |
102 | ifdef BUILD_NO_LDAP_PLUGIN | 102 | ifdef BUILD_NO_LDAP_PLUGIN |
103 | @echo == ldap plugin not build. | 103 | @echo == ldap plugin not build. |
104 | else | 104 | else |
105 | for i in $(SUBDIRS_LDAP_PLUGIN); do pushd $$i; \ | 105 | for i in $(SUBDIRS_LDAP_PLUGIN); do pushd $$i; \ |
106 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 106 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
107 | done | 107 | done |
108 | endif | 108 | endif |
109 | 109 | ||
110 | 110 | ||
111 | build_micromail: build_microkde | 111 | build_micromail: build_microkde |
112 | ifdef BUILD_NO_MICROMAIL | 112 | ifdef BUILD_NO_MICROMAIL |
113 | @echo == kmicromail not build. | 113 | @echo == kmicromail not build. |
114 | else | 114 | else |
115 | for i in $(SUBDIRS_MICROMAIL); do pushd $$i; \ | 115 | for i in $(SUBDIRS_MICROMAIL); do pushd $$i; \ |
116 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 116 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
117 | done | 117 | done |
118 | endif | 118 | endif |
119 | 119 | ||
120 | build_gammu: variable_test tmake | 120 | build_gammu: variable_test tmake |
121 | ifdef BUILD_NO_GAMMU | 121 | ifdef BUILD_NO_GAMMU |
122 | @echo == gammu not build. | 122 | @echo == gammu not build. |
123 | else | 123 | else |
124 | for i in $(SUBDIRS_GAMMU); do pushd $$i; \ | 124 | for i in $(SUBDIRS_GAMMU); do pushd $$i; \ |
125 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 125 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
126 | done | 126 | done |
127 | endif | 127 | endif |
128 | 128 | ||
129 | build_pwmanager: build_microkde | 129 | build_pwmanager: build_microkde |
130 | ifdef BUILD_NO_PWMANAGER | 130 | ifdef BUILD_NO_PWMANAGER |
131 | @echo == pwmanager not build. | 131 | @echo == pwmanager not build. |
132 | else | 132 | else |
133 | for i in $(SUBDIRS_PWMANAGER); do pushd $$i; \ | 133 | for i in $(SUBDIRS_PWMANAGER); do pushd $$i; \ |
134 | make -f Makefile$(PLATFORM) || exit 1; popd; \ | 134 | make -f Makefile$(PLATFORM) || exit 1; popd; \ |
135 | done | 135 | done |
136 | endif | 136 | endif |
137 | 137 | ||
138 | 138 | ||
139 | variable_info: | 139 | variable_info: |
140 | @echo -------------------------------------- | 140 | @echo -------------------------------------- |
141 | @echo KDEPIM buildsystem, variableinfo... | 141 | @echo KDEPIM buildsystem, variableinfo... |
142 | @echo KDEPIMDIR=$(KDEPIMDIR) | 142 | @echo KDEPIMDIR=$(KDEPIMDIR) |
143 | @echo QTDIR=$(QTDIR) | 143 | @echo QTDIR=$(QTDIR) |
144 | @echo QPEDIR=$(QPEDIR) | 144 | @echo QPEDIR=$(QPEDIR) |
145 | @echo OPIEDIR=$(OPIEDIR) | 145 | @echo OPIEDIR=$(OPIEDIR) |
146 | @echo PLATFORM=$(PLATFORM) | 146 | @echo PLATFORM=$(PLATFORM) |
147 | @echo RELEASE_DEBUG=$(RELEASE_DEBUG) | 147 | @echo RELEASE_DEBUG=$(RELEASE_DEBUG) |
148 | @echo BUILD_NO_MICROMAIL=$(BUILD_NO_MICROMAIL) | 148 | @echo BUILD_NO_MICROMAIL=$(BUILD_NO_MICROMAIL) |
149 | @echo BUILD_NO_LDAP_PLUGIN=$(BUILD_NO_LDAP_PLUGIN) | 149 | @echo BUILD_NO_LDAP_PLUGIN=$(BUILD_NO_LDAP_PLUGIN) |
150 | @echo BUILD_NO_OPIE_PLUGIN=$(BUILD_NO_OPIE_PLUGIN) | 150 | @echo BUILD_NO_OPIE_PLUGIN=$(BUILD_NO_OPIE_PLUGIN) |
151 | @echo BUILD_NO_SHARP_PLUGIN=$(BUILD_NO_SHARP_PLUGIN) | 151 | @echo BUILD_NO_SHARP_PLUGIN=$(BUILD_NO_SHARP_PLUGIN) |
152 | ifndef BUILD_NO_SHARP_PLUGIN | 152 | ifndef BUILD_NO_SHARP_PLUGIN |
153 | @echo SHARPDTMSDK=$(SHARPDTMSDK) | 153 | @echo SHARPDTMSDK=$(SHARPDTMSDK) |
154 | endif | 154 | endif |
155 | @echo BUILD_NO_GAMMU=$(BUILD_NO_GAMMU) | 155 | @echo BUILD_NO_GAMMU=$(BUILD_NO_GAMMU) |
156 | @echo BUILD_NO_PWMANAGER=$(BUILD_NO_PWMANAGER) | 156 | @echo BUILD_NO_PWMANAGER=$(BUILD_NO_PWMANAGER) |
157 | @echo -------------------------------------- | 157 | @echo -------------------------------------- |
158 | 158 | ||
159 | variable_test: variable_info | 159 | variable_test: variable_info |
160 | @echo KDEPIM buildsystem, variablecheck... | 160 | @echo KDEPIM buildsystem, variablecheck... |
161 | ifndef KDEPIMDIR | 161 | ifndef KDEPIMDIR |
162 | @echo KDEPIMDIR is not defined. | 162 | @echo KDEPIMDIR is not defined. |
163 | $(error KDEPIMDIR is not defined) | 163 | $(error KDEPIMDIR is not defined) |
164 | endif | 164 | endif |
165 | ifndef PLATFORM | 165 | ifndef PLATFORM |
166 | @echo PLATFORM is not defined. | 166 | @echo PLATFORM is not defined. |
167 | $(error PLATFORM is not defined) | 167 | $(error PLATFORM is not defined) |
168 | endif | 168 | endif |
169 | ifdef BUILD_NO_LDAP_PLUGIN | 169 | ifdef BUILD_NO_LDAP_PLUGIN |
170 | @echo LDAP PLUGIN will not be build, because BUILD_NO_LDAP_PLUGIN is set to $(BUILD_NO_LDAP_PLUGIN) | 170 | @echo LDAP PLUGIN will not be build, because BUILD_NO_LDAP_PLUGIN is set to $(BUILD_NO_LDAP_PLUGIN) |
171 | endif | 171 | endif |
172 | ifdef BUILD_NO_OPIE_PLUGIN | 172 | ifdef BUILD_NO_OPIE_PLUGIN |
173 | @echo OPIE PLUGIN will not be build, because BUILD_NO_OPIE_PLUGIN is set to $(BUILD_NO_OPIE_PLUGIN) | 173 | @echo OPIE PLUGIN will not be build, because BUILD_NO_OPIE_PLUGIN is set to $(BUILD_NO_OPIE_PLUGIN) |
174 | endif | 174 | endif |
175 | ifdef BUILD_NO_MICROMAIL | 175 | ifdef BUILD_NO_MICROMAIL |
176 | @echo MICROMAIL will not be build, because BUILD_NO_MICROMAIL is set to $(BUILD_NO_MICROMAIL) | 176 | @echo MICROMAIL will not be build, because BUILD_NO_MICROMAIL is set to $(BUILD_NO_MICROMAIL) |
177 | endif | 177 | endif |
178 | ifdef BUILD_NO_SHARP_PLUGIN | 178 | ifdef BUILD_NO_SHARP_PLUGIN |
179 | @echo SHARP PLUGIN will not be build, because BUILD_NO_SHARP_PLUGIN is set to $(BUILD_NO_SHARP_PLUGIN) | 179 | @echo SHARP PLUGIN will not be build, because BUILD_NO_SHARP_PLUGIN is set to $(BUILD_NO_SHARP_PLUGIN) |
180 | else | 180 | else |
181 | ifndef SHARPDTMSDK | 181 | ifndef SHARPDTMSDK |
182 | @echo SHARP PLUGIN can not be build, because SHARPDTMSDK is set to $(SHARPDTMSDK) | 182 | @echo SHARP PLUGIN can not be build, because SHARPDTMSDK is set to $(SHARPDTMSDK) |
183 | $(error SHARPDTMSDK is not defined) | 183 | $(error SHARPDTMSDK is not defined) |
184 | endif | 184 | endif |
185 | endif | 185 | endif |
186 | ifdef BUILD_NO_GAMMU | 186 | ifdef BUILD_NO_GAMMU |
187 | @echo GAMMU will not be build, because BUILD_NO_GAMMU is set to $(BUILD_NO_GAMMU) | 187 | @echo GAMMU will not be build, because BUILD_NO_GAMMU is set to $(BUILD_NO_GAMMU) |
188 | endif | 188 | endif |
189 | ifdef BUILD_NO_PWMANAGER | 189 | ifdef BUILD_NO_PWMANAGER |
190 | @echo PWMANAGER will not be build, because BUILD_NO_PWMANAGER is set to $(BUILD_NO_PWMANAGER) | 190 | @echo PWMANAGER will not be build, because BUILD_NO_PWMANAGER is set to $(BUILD_NO_PWMANAGER) |
191 | endif | 191 | endif |
192 | @echo -------------------------------------- | 192 | @echo -------------------------------------- |
193 | 193 | ||
194 | 194 | ||
195 | objects: | 195 | objects: |
196 | for i in $(SUBDIRS); do mkdir -p $$i/obj/$(PLATFORM); done | 196 | for i in $(SUBDIRS); do mkdir -p $$i/obj/$(PLATFORM); done |
197 | for i in $(SUBDIRS); do mkdir -p $$i/moc/$(PLATFORM); done | 197 | for i in $(SUBDIRS); do mkdir -p $$i/moc/$(PLATFORM); done |
198 | mkdir -p libical/lib/$(PLATFORM) | 198 | mkdir -p libical/lib/$(PLATFORM) |
199 | 199 | ||
200 | clean: | 200 | clean: |
201 | rm -rf libical/lib/$(PLATFORM)/*; | 201 | rm -rf libical/lib/$(PLATFORM)/*; |
202 | for i in $(SUBDIRS); do pushd $$i; make clean; rm -f *~;\ | 202 | for i in $(SUBDIRS); do pushd $$i; make clean; rm -f *~;\ |
203 | rm -f obj/$(PLATFORM)/*; rm -f moc/$(PLATFORM)/*; rm Makefile$(PLATFORM); popd; \ | 203 | rm -f obj/$(PLATFORM)/*; rm -f moc/$(PLATFORM)/*; rm Makefile$(PLATFORM); popd; \ |
204 | done | 204 | done |
205 | 205 | ||
206 | install: | 206 | install: |
207 | 207 | ||
208 | cd bin/kdepim; make install | 208 | cd bin/kdepim; make install |
209 | cp -r Pim $(QPEDIR)/apps | 209 | cp -r Pim $(QPEDIR)/apps |
210 | cp db2file/db2file $(QPEDIR)/bin/db2file | 210 | cp db2file/db2file $(QPEDIR)/bin/db2file |
211 | cp korganizer/korganizer.desktop $(QPEDIR)/apps/Pim/korganizer.desktop | 211 | cp korganizer/korganizer.desktop $(QPEDIR)/apps/Pim/korganizer.desktop |
212 | cp kaddressbook/kaddressbook.desktop $(QPEDIR)/apps/Pim/kaddressbook.desktop | 212 | cp kaddressbook/kaddressbook.desktop $(QPEDIR)/apps/Pim/kaddressbook.desktop |
213 | cp kmicromail/kmicromail.desktop $(QPEDIR)/apps/Pim/kopiemail.desktop | 213 | cp kmicromail/kmicromail.desktop $(QPEDIR)/apps/Pim/kopiemail.desktop |
214 | cp pwmanager/pwmanager/pwmanager.desktop $(QPEDIR)/apps/Pim/pwmanager.desktop | 214 | cp pwmanager/pwmanager/pwmanager.desktop $(QPEDIR)/apps/Pim/pwmanager.desktop |
215 | 215 | ||
216 | dist: | 216 | dist: |
217 | @echo Dont forget to do "make install" before "make dist" | 217 | @echo Dont forget to do "make install" before "make dist" |
218 | rm -f *arm.ipk | 218 | rm -f *arm.ipk |
219 | rm -f *~ | 219 | rm -f *~ |
220 | cd ..; tar czf kdepim.src.tar.gz --exclude=obj --exclude=moc --exclude=CVS --exclude=Makefilezaurus --exclude=Makefileqtopia kdepim | 220 | cd ..; tar czf kdepim.src.tar.gz --exclude=obj --exclude=moc --exclude=CVS --exclude=Makefilezaurus --exclude=Makefileqtopia kdepim |
221 | ./mkipks kmicrokdelibs.control | 221 | ./mkipks kmicrokdelibs.control |
222 | ./mkipks korganizer.control | 222 | ./mkipks korganizer.control |
223 | ./mkipks kaddressbook.control | 223 | ./mkipks kaddressbook.control |
224 | ifndef BUILD_NO_MICROMAIL | 224 | ifndef BUILD_NO_MICROMAIL |
225 | ./mkipks kopiemail.control | 225 | ./mkipks kopiemail.control |
226 | endif | 226 | endif |
227 | ./mkipks korganizer-alarm.control | 227 | ./mkipks korganizer-alarm.control |
228 | ifndef BUILD_NO_GAMMU | 228 | ifndef BUILD_NO_GAMMU |
229 | ./mkipks kammu.control | 229 | ./mkipks phoneaccess.control |
230 | endif | 230 | endif |
231 | ifndef BUILD_NO_PWMANAGER | 231 | ifndef BUILD_NO_PWMANAGER |
232 | ./mkipks pwmanager.control | 232 | ./mkipks pwmanager.control |
233 | endif | 233 | endif |
234 | ./mkipks pim_TAB_icon.control | 234 | ./mkipks pim_TAB_icon.control |
235 | 235 | ||
236 | tmake: objects \ | 236 | tmake: objects \ |
237 | qtcompat/Makefile$(PLATFORM) \ | 237 | qtcompat/Makefile$(PLATFORM) \ |
238 | microkde/Makefile$(PLATFORM) \ | 238 | microkde/Makefile$(PLATFORM) \ |
239 | libkcal/Makefile$(PLATFORM) \ | 239 | libkcal/Makefile$(PLATFORM) \ |
240 | libkdepim/Makefile$(PLATFORM) \ | 240 | libkdepim/Makefile$(PLATFORM) \ |
241 | korganizer/Makefile$(PLATFORM) \ | 241 | korganizer/Makefile$(PLATFORM) \ |
242 | kalarmd/Makefile$(PLATFORM) \ | 242 | kalarmd/Makefile$(PLATFORM) \ |
243 | libical/src/libical/Makefile$(PLATFORM) \ | 243 | libical/src/libical/Makefile$(PLATFORM) \ |
244 | libical/src/libicalss/Makefile$(PLATFORM) \ | 244 | libical/src/libicalss/Makefile$(PLATFORM) \ |
245 | kabc/Makefile$(PLATFORM) \ | 245 | kabc/Makefile$(PLATFORM) \ |
246 | kabc/formats/binary/Makefile$(PLATFORM) \ | 246 | kabc/formats/binary/Makefile$(PLATFORM) \ |
247 | kabc/plugins/file/Makefile$(PLATFORM) \ | 247 | kabc/plugins/file/Makefile$(PLATFORM) \ |
248 | kabc/plugins/dir/Makefile$(PLATFORM) \ | 248 | kabc/plugins/dir/Makefile$(PLATFORM) \ |
249 | kabc/plugins/ldap/Makefile$(PLATFORM) \ | 249 | kabc/plugins/ldap/Makefile$(PLATFORM) \ |
250 | kabc/plugins/opie/Makefile$(PLATFORM) \ | 250 | kabc/plugins/opie/Makefile$(PLATFORM) \ |
251 | kabc/plugins/qtopia/Makefile$(PLATFORM) \ | 251 | kabc/plugins/qtopia/Makefile$(PLATFORM) \ |
252 | kabc/plugins/sharpdtm/Makefile$(PLATFORM) \ | 252 | kabc/plugins/sharpdtm/Makefile$(PLATFORM) \ |
253 | kaddressbook/Makefile$(PLATFORM) \ | 253 | kaddressbook/Makefile$(PLATFORM) \ |
254 | kmicromail/Makefile$(PLATFORM) \ | 254 | kmicromail/Makefile$(PLATFORM) \ |
255 | kmicromail/libetpan/Makefile$(PLATFORM) \ | 255 | kmicromail/libetpan/Makefile$(PLATFORM) \ |
256 | kmicromail/libmailwrapper/Makefile$(PLATFORM) \ | 256 | kmicromail/libmailwrapper/Makefile$(PLATFORM) \ |
257 | gammu/emb/common/Makefile$(PLATFORM) \ | 257 | gammu/emb/common/Makefile$(PLATFORM) \ |
258 | gammu/emb/gammu/Makefile$(PLATFORM) \ | 258 | gammu/emb/gammu/Makefile$(PLATFORM) \ |
259 | pwmanager/pwmanager/Makefile$(PLATFORM) \ | 259 | pwmanager/pwmanager/Makefile$(PLATFORM) \ |
260 | 260 | ||
261 | qtcompat/Makefile$(PLATFORM): qtcompat/qtcompat.pro | 261 | qtcompat/Makefile$(PLATFORM): qtcompat/qtcompat.pro |
262 | cd qtcompat; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtcompat.pro -o Makefile$(PLATFORM) | 262 | cd qtcompat; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtcompat.pro -o Makefile$(PLATFORM) |
263 | 263 | ||
264 | microkde/Makefile$(PLATFORM): microkde/microkdeE.pro | 264 | microkde/Makefile$(PLATFORM): microkde/microkdeE.pro |
265 | cd microkde; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" microkdeE.pro -o Makefile$(PLATFORM) | 265 | cd microkde; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" microkdeE.pro -o Makefile$(PLATFORM) |
266 | 266 | ||
267 | libkcal/Makefile$(PLATFORM): libkcal/libkcalE.pro | 267 | libkcal/Makefile$(PLATFORM): libkcal/libkcalE.pro |
268 | cd libkcal; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkcalE.pro -o Makefile$(PLATFORM) | 268 | cd libkcal; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkcalE.pro -o Makefile$(PLATFORM) |
269 | 269 | ||
270 | 270 | ||
271 | libkdepim/Makefile$(PLATFORM): libkdepim/libkdepimE.pro | 271 | libkdepim/Makefile$(PLATFORM): libkdepim/libkdepimE.pro |
272 | cd libkdepim; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkdepimE.pro -o Makefile$(PLATFORM) | 272 | cd libkdepim; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libkdepimE.pro -o Makefile$(PLATFORM) |
273 | 273 | ||
274 | kalarmd/Makefile$(PLATFORM): kalarmd/kalarmdE.pro | 274 | kalarmd/Makefile$(PLATFORM): kalarmd/kalarmdE.pro |
275 | cd kalarmd; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kalarmdE.pro -o Makefile$(PLATFORM) | 275 | cd kalarmd; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kalarmdE.pro -o Makefile$(PLATFORM) |
276 | 276 | ||
277 | korganizer/Makefile$(PLATFORM): korganizer/korganizerE.pro | 277 | korganizer/Makefile$(PLATFORM): korganizer/korganizerE.pro |
278 | cd korganizer; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" korganizerE.pro -o Makefile$(PLATFORM) | 278 | cd korganizer; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" korganizerE.pro -o Makefile$(PLATFORM) |
279 | 279 | ||
280 | libical/src/libical/Makefile$(PLATFORM): libical/src/libical/libicalE.pro | 280 | libical/src/libical/Makefile$(PLATFORM): libical/src/libical/libicalE.pro |
281 | cd libical/src/libical; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalE.pro -o Makefile$(PLATFORM) | 281 | cd libical/src/libical; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalE.pro -o Makefile$(PLATFORM) |
282 | 282 | ||
283 | libical/src/libicalss/Makefile$(PLATFORM): libical/src/libicalss/libicalssE.pro | 283 | libical/src/libicalss/Makefile$(PLATFORM): libical/src/libicalss/libicalssE.pro |
284 | cd libical/src/libicalss; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalssE.pro -o Makefile$(PLATFORM) | 284 | cd libical/src/libicalss; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libicalssE.pro -o Makefile$(PLATFORM) |
285 | 285 | ||
286 | kabc/Makefile$(PLATFORM): kabc/kabcE.pro | 286 | kabc/Makefile$(PLATFORM): kabc/kabcE.pro |
287 | cd kabc; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcE.pro -o Makefile$(PLATFORM) | 287 | cd kabc; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcE.pro -o Makefile$(PLATFORM) |
288 | 288 | ||
289 | kabc/formats/binary/Makefile$(PLATFORM): kabc/formats/binary/kabcformat_binaryE.pro | 289 | kabc/formats/binary/Makefile$(PLATFORM): kabc/formats/binary/kabcformat_binaryE.pro |
290 | cd kabc/formats/binary; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcformat_binaryE.pro -o Makefile$(PLATFORM) | 290 | cd kabc/formats/binary; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kabcformat_binaryE.pro -o Makefile$(PLATFORM) |
291 | 291 | ||
292 | kabc/plugins/file/Makefile$(PLATFORM): kabc/plugins/file/fileE.pro | 292 | kabc/plugins/file/Makefile$(PLATFORM): kabc/plugins/file/fileE.pro |
293 | cd kabc/plugins/file; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" fileE.pro -o Makefile$(PLATFORM) | 293 | cd kabc/plugins/file; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" fileE.pro -o Makefile$(PLATFORM) |
294 | 294 | ||
295 | kabc/plugins/dir/Makefile$(PLATFORM): kabc/plugins/dir/dirE.pro | 295 | kabc/plugins/dir/Makefile$(PLATFORM): kabc/plugins/dir/dirE.pro |
296 | cd kabc/plugins/dir; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" dirE.pro -o Makefile$(PLATFORM) | 296 | cd kabc/plugins/dir; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" dirE.pro -o Makefile$(PLATFORM) |
297 | 297 | ||
298 | kabc/plugins/ldap/Makefile$(PLATFORM): kabc/plugins/ldap/ldapE.pro | 298 | kabc/plugins/ldap/Makefile$(PLATFORM): kabc/plugins/ldap/ldapE.pro |
299 | cd kabc/plugins/ldap; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" ldapE.pro -o Makefile$(PLATFORM) | 299 | cd kabc/plugins/ldap; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" ldapE.pro -o Makefile$(PLATFORM) |
300 | 300 | ||
301 | kabc/plugins/opie/Makefile$(PLATFORM): kabc/plugins/opie/opieE.pro | 301 | kabc/plugins/opie/Makefile$(PLATFORM): kabc/plugins/opie/opieE.pro |
302 | cd kabc/plugins/opie; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" opieE.pro -o Makefile$(PLATFORM) | 302 | cd kabc/plugins/opie; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" opieE.pro -o Makefile$(PLATFORM) |
303 | 303 | ||
304 | kabc/plugins/qtopia/Makefile$(PLATFORM): kabc/plugins/qtopia/qtopiaE.pro | 304 | kabc/plugins/qtopia/Makefile$(PLATFORM): kabc/plugins/qtopia/qtopiaE.pro |
305 | cd kabc/plugins/qtopia; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtopiaE.pro -o Makefile$(PLATFORM) | 305 | cd kabc/plugins/qtopia; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" qtopiaE.pro -o Makefile$(PLATFORM) |
306 | 306 | ||
307 | kabc/plugins/sharpdtm/Makefile$(PLATFORM): kabc/plugins/sharpdtm/sharpdtmE.pro | 307 | kabc/plugins/sharpdtm/Makefile$(PLATFORM): kabc/plugins/sharpdtm/sharpdtmE.pro |
308 | cd kabc/plugins/sharpdtm; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" sharpdtmE.pro -o Makefile$(PLATFORM) | 308 | cd kabc/plugins/sharpdtm; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" sharpdtmE.pro -o Makefile$(PLATFORM) |
309 | 309 | ||
310 | kaddressbook/Makefile$(PLATFORM): kaddressbook/kaddressbookE.pro | 310 | kaddressbook/Makefile$(PLATFORM): kaddressbook/kaddressbookE.pro |
311 | cd kaddressbook; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kaddressbookE.pro -o Makefile$(PLATFORM) | 311 | cd kaddressbook; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kaddressbookE.pro -o Makefile$(PLATFORM) |
312 | 312 | ||
313 | kmicromail/Makefile$(PLATFORM): kmicromail/kmicromailE.pro | 313 | kmicromail/Makefile$(PLATFORM): kmicromail/kmicromailE.pro |
314 | cd kmicromail; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kmicromailE.pro -o Makefile$(PLATFORM) | 314 | cd kmicromail; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" kmicromailE.pro -o Makefile$(PLATFORM) |
315 | 315 | ||
316 | kmicromail/libetpan/Makefile$(PLATFORM): kmicromail/libetpan/libetpanE.pro | 316 | kmicromail/libetpan/Makefile$(PLATFORM): kmicromail/libetpan/libetpanE.pro |
317 | cd kmicromail/libetpan; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libetpanE.pro -o Makefile$(PLATFORM) | 317 | cd kmicromail/libetpan; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libetpanE.pro -o Makefile$(PLATFORM) |
318 | 318 | ||
319 | kmicromail/libmailwrapper/Makefile$(PLATFORM): kmicromail/libmailwrapper/libmailwrapperE.pro | 319 | kmicromail/libmailwrapper/Makefile$(PLATFORM): kmicromail/libmailwrapper/libmailwrapperE.pro |
320 | cd kmicromail/libmailwrapper; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libmailwrapperE.pro -o Makefile$(PLATFORM) | 320 | cd kmicromail/libmailwrapper; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" libmailwrapperE.pro -o Makefile$(PLATFORM) |
321 | 321 | ||
322 | gammu/emb/common/Makefile$(PLATFORM): gammu/emb/common/commonE.pro | 322 | gammu/emb/common/Makefile$(PLATFORM): gammu/emb/common/commonE.pro |
323 | cd gammu/emb/common; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" commonE.pro -o Makefile$(PLATFORM) | 323 | cd gammu/emb/common; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" commonE.pro -o Makefile$(PLATFORM) |
324 | 324 | ||
325 | gammu/emb/gammu/Makefile$(PLATFORM): gammu/emb/gammu/gammuE.pro | 325 | gammu/emb/gammu/Makefile$(PLATFORM): gammu/emb/gammu/gammuE.pro |
326 | cd gammu/emb/gammu; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" gammuE.pro -o Makefile$(PLATFORM) | 326 | cd gammu/emb/gammu; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" gammuE.pro -o Makefile$(PLATFORM) |
327 | 327 | ||
328 | pwmanager/pwmanager/Makefile$(PLATFORM): pwmanager/pwmanager/pwmanagerE.pro | 328 | pwmanager/pwmanager/Makefile$(PLATFORM): pwmanager/pwmanager/pwmanagerE.pro |
329 | cd pwmanager/pwmanager; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" pwmanagerE.pro -o Makefile$(PLATFORM) | 329 | cd pwmanager/pwmanager; tmake "CONFIG+=$(RELEASE_DEBUG)" "VERSION=$(KDEPIM_VERSION)" pwmanagerE.pro -o Makefile$(PLATFORM) |
330 | 330 | ||
diff --git a/bin/kdepim/korganizer/howtoSYNC.txt b/bin/kdepim/korganizer/howtoSYNC.txt index c4e80f5..3cab446 100644 --- a/bin/kdepim/korganizer/howtoSYNC.txt +++ b/bin/kdepim/korganizer/howtoSYNC.txt | |||
@@ -1,483 +1,483 @@ | |||
1 | WARNING: | 1 | WARNING: |
2 | YOU MAY GET UNEXSPECTED (I.E. WRONG) SYNCHRONIZATION RESULTS, | 2 | YOU MAY GET UNEXSPECTED (I.E. WRONG) SYNCHRONIZATION RESULTS, |
3 | IF YOU CHANGE AN EVENT ON THE FIRST DEVICE AND SYNC IMMEDIATELY FROM | 3 | IF YOU CHANGE AN EVENT ON THE FIRST DEVICE AND SYNC IMMEDIATELY FROM |
4 | THE OTHER DEVICE WITH THIS DEVICE, IF THE CLOCKS OF THE TWO DEVICES | 4 | THE OTHER DEVICE WITH THIS DEVICE, IF THE CLOCKS OF THE TWO DEVICES |
5 | HAVE TOO MUCH DIFFERENCE. | 5 | HAVE TOO MUCH DIFFERENCE. |
6 | 6 | ||
7 | In other words: Please make shure, that the clocks of the devices | 7 | In other words: Please make shure, that the clocks of the devices |
8 | you want to sync have only a difference of some seconds! | 8 | you want to sync have only a difference of some seconds! |
9 | 9 | ||
10 | 10 | ||
11 | CONTENT: | 11 | CONTENT: |
12 | 12 | ||
13 | 0) How syncing works | 13 | 0) How syncing works |
14 | 1) Qick overview of settings | 14 | 1) Qick overview of settings |
15 | 2) Sync settings in sync dialog | 15 | 2) Sync settings in sync dialog |
16 | 3) Syncing background | 16 | 3) Syncing background |
17 | 4) Sync preferences | 17 | 4) Sync preferences |
18 | 5) Details about sync profile kinds | 18 | 5) Details about sync profile kinds |
19 | 19 | ||
20 | ************************************************************************* | 20 | ************************************************************************* |
21 | 0) How syncing works | 21 | 0) How syncing works |
22 | ************************************************************************* | 22 | ************************************************************************* |
23 | 23 | ||
24 | Note: | 24 | Note: |
25 | The recommended and easiest way to syncronize two devices where | 25 | The recommended and easiest way to syncronize two devices where |
26 | KO/Pi or KA/Pi is installed, is the profile kind "Pi-Sync". | 26 | KO/Pi or KA/Pi is installed, is the profile kind "Pi-Sync". |
27 | Details about that in 5) b). | 27 | Details about that in 5) b). |
28 | 28 | ||
29 | In KDE-Pim/Pi you can synchronize ( sync ) your calendar/addressbook | 29 | In KDE-Pim/Pi you can synchronize ( sync ) your calendar/addressbook |
30 | with another calendar/addressbook , by syncing your | 30 | with another calendar/addressbook , by syncing your |
31 | (local) calendar/addressbook with a (remote) file. | 31 | (local) calendar/addressbook with a (remote) file. |
32 | This remote file may on your local filesystem | 32 | This remote file may on your local filesystem |
33 | or on another (remote) device. | 33 | or on another (remote) device. |
34 | 34 | ||
35 | If you want to sync with another remote device, | 35 | If you want to sync with another remote device, |
36 | you have two create a sync profile. | 36 | you have two create a sync profile. |
37 | You have two choices for choosing the profil kind: | 37 | You have two choices for choosing the profil kind: |
38 | I) You have to choose profile kind "Remote file" and to specify a | 38 | I) You have to choose profile kind "Remote file" and to specify a |
39 | command line download/upload command ( like scp, ftp, ...) to | 39 | command line download/upload command ( like scp, ftp, ...) to |
40 | a) download the remote file to your local machine to a temp file | 40 | a) download the remote file to your local machine to a temp file |
41 | b) sync with this temp file | 41 | b) sync with this temp file |
42 | c) upload the synced file to the remote device | 42 | c) upload the synced file to the remote device |
43 | II) If you want to sync with a device, where KO/Pi( or KA/Pi ) is | 43 | II) If you want to sync with a device, where KO/Pi( or KA/Pi ) is |
44 | installed, you can easily get the remote file via network | 44 | installed, you can easily get the remote file via network |
45 | with the build in file transfer feature: | 45 | with the build in file transfer feature: |
46 | Choose profile kind "Pi-Sync" and | 46 | Choose profile kind "Pi-Sync" and |
47 | a) Start KO/Pi or KA/Pi on remote device and | 47 | a) Start KO/Pi or KA/Pi on remote device and |
48 | enable "Pi-Sync" on remote device with password and port. | 48 | enable "Pi-Sync" on remote device with password and port. |
49 | b) Specify password, port and IP address in your profile. | 49 | b) Specify password, port and IP address in your profile. |
50 | 50 | ||
51 | 51 | ||
52 | You can sync with your mobile phone as well. | 52 | You can sync with your mobile phone as well. |
53 | Everything is explained in more details below. | 53 | Everything is explained in more details below. |
54 | 54 | ||
55 | NOTE: | 55 | NOTE: |
56 | If you do not use profile kind "Pi-Sync", | 56 | If you do not use profile kind "Pi-Sync", |
57 | it is recommended to close | 57 | it is recommended to close |
58 | a running KO/Pi ( or KA/Pi) on the remote device. | 58 | a running KO/Pi ( or KA/Pi) on the remote device. |
59 | (Note: KO/Pi( or KA/Pi) running on Zaurus with | 59 | (Note: KO/Pi( or KA/Pi) running on Zaurus with |
60 | FastLoad enabled will never be closed!) | 60 | FastLoad enabled will never be closed!) |
61 | After syncing with a running KO/Pi on the remote device, | 61 | After syncing with a running KO/Pi on the remote device, |
62 | a "save" on the remote device will tell you that it needs to merge (sync). | 62 | a "save" on the remote device will tell you that it needs to merge (sync). |
63 | After merging (just a syncing with the changed file) | 63 | After merging (just a syncing with the changed file) |
64 | you will get the new data showing in remote KO/Pi. | 64 | you will get the new data showing in remote KO/Pi. |
65 | 65 | ||
66 | ************************************************************************* | 66 | ************************************************************************* |
67 | 1) Qick overview of settings | 67 | 1) Qick overview of settings |
68 | ************************************************************************* | 68 | ************************************************************************* |
69 | 69 | ||
70 | a) Open sync settings dialog (Menu Synchronize - Configure...) | 70 | a) Open sync settings dialog (Menu Synchronize - Configure...) |
71 | b) Give your device a unique name. | 71 | b) Give your device a unique name. |
72 | (unique in the set of all devices you want to sync with). | 72 | (unique in the set of all devices you want to sync with). |
73 | If you have already configured another devive and created | 73 | If you have already configured another devive and created |
74 | there a sync profile to sync with this device, give your device | 74 | there a sync profile to sync with this device, give your device |
75 | the same name as this sync profile! The same name is important, | 75 | the same name as this sync profile! The same name is important, |
76 | because it makes it possible to sync first A->B | 76 | because it makes it possible to sync first A->B |
77 | (A local device, that performs the sync, B remote device) | 77 | (A local device, that performs the sync, B remote device) |
78 | and then B->A. Such that the B->A sync knows about the | 78 | and then B->A. Such that the B->A sync knows about the |
79 | already performed A->B sync. | 79 | already performed A->B sync. |
80 | That means: It is unimportant if you sync A->B or B->A, | 80 | That means: It is unimportant if you sync A->B or B->A, |
81 | the devices A and B will be synced properly. | 81 | the devices A and B will be synced properly. |
82 | c) Create a new sync profile and give it a unique name. | 82 | c) Create a new sync profile and give it a unique name. |
83 | (unique in the set of all sync profiles on this device). | 83 | (unique in the set of all sync profiles on this device). |
84 | If you want to sync with a device, where KO/Pi is already installed | 84 | If you want to sync with a device, where KO/Pi is already installed |
85 | and which has a given unique device name, use this device name as | 85 | and which has a given unique device name, use this device name as |
86 | your profile name ( refer to b) ). | 86 | your profile name ( refer to b) ). |
87 | d) Coose the profile kind of your syncing method: | 87 | d) Coose the profile kind of your syncing method: |
88 | (i) Local file or | 88 | (i) Local file or |
89 | (ii) Pi-Sync or | 89 | (ii) Pi-Sync or |
90 | (iii) Remote file or | 90 | (iii) Remote file or |
91 | (iiii) Mobile Phone. | 91 | (iiii) Mobile Phone. |
92 | Detailed explanation in 5) | 92 | Detailed explanation in 5) |
93 | e) Choose the other profile options. | 93 | e) Choose the other profile options. |
94 | Detailed explanation in 2) | 94 | Detailed explanation in 2) |
95 | f) Close sync dialog with OK. | 95 | f) Close sync dialog with OK. |
96 | g) Sync. | 96 | g) Sync. |
97 | 97 | ||
98 | NOTE: | 98 | NOTE: |
99 | AFTER SYNCING THERE ARE "SYNC EVENTS" CREATED | 99 | AFTER SYNCING THERE ARE "SYNC EVENTS" CREATED |
100 | (OR UPDATED, IF IT ALREADY EXITS) FOR EACH SYNC PROFILE. | 100 | (OR UPDATED, IF IT ALREADY EXITS) FOR EACH SYNC PROFILE. |
101 | YOU MAY NOT DELETE OR CHANGE THESE EVENTS. | 101 | YOU MAY NOT DELETE OR CHANGE THESE EVENTS. |
102 | 102 | ||
103 | ************************************************************************* | 103 | ************************************************************************* |
104 | 2) Sync settings in sync dialog | 104 | 2) Sync settings in sync dialog |
105 | ************************************************************************* | 105 | ************************************************************************* |
106 | 106 | ||
107 | a) Local device name: | 107 | a) Local device name: |
108 | -> 1) b) | 108 | -> 1) b) |
109 | b) Profile: | 109 | b) Profile: |
110 | -> 1) c) | 110 | -> 1) c) |
111 | c) Include in multiple sync: | 111 | c) Include in multiple sync: |
112 | In the Synchronize menu, there is a multiple sync menu entry. | 112 | In the Synchronize menu, there is a multiple sync menu entry. |
113 | If you choose this menu entry, all user defined profiles with this | 113 | If you choose this menu entry, all user defined profiles with this |
114 | 'Include in multiple sync' option enabled will be synced | 114 | 'Include in multiple sync' option enabled will be synced |
115 | one after another. And this twice. This will take some time. | 115 | one after another. And this twice. This will take some time. |
116 | After that sync, on all devices should be the same data. | 116 | After that sync, on all devices should be the same data. |
117 | d) Ask for preferences before sync: | 117 | d) Ask for preferences before sync: |
118 | Check this to be asked for sync preferences settings before each sync. | 118 | Check this to be asked for sync preferences settings before each sync. |
119 | If the profile kind is "Pi-Sync" you will be asked to confirm | 119 | If the profile kind is "Pi-Sync" you will be asked to confirm |
120 | the "Pi-Sync" specific settings (Password,IP address, port number) | 120 | the "Pi-Sync" specific settings (Password,IP address, port number) |
121 | as well. That makes it possible to use that profile for a | 121 | as well. That makes it possible to use that profile for a |
122 | device that is connected via DHCP to the network and gets different | 122 | device that is connected via DHCP to the network and gets different |
123 | IP addresses when connection to the network. | 123 | IP addresses when connection to the network. |
124 | e) Sync preferences: | 124 | e) Sync preferences: |
125 | Choose here your sync preferences. | 125 | Choose here your sync preferences. |
126 | Details -> 4) | 126 | Details -> 4) |
127 | f) Show summary after sync: | 127 | f) Show summary after sync: |
128 | Check this to get a small summary dialog after sync | 128 | Check this to get a small summary dialog after sync |
129 | about number of added/changed/deleted events on local/remote. | 129 | about number of added/changed/deleted events on local/remote. |
130 | g) Write back synced data: | 130 | g) Write back synced data: |
131 | Uncheck this to update the local calendar only. | 131 | Uncheck this to update the local calendar only. |
132 | I.e. your local calendar is synced with the remote calendar | 132 | I.e. your local calendar is synced with the remote calendar |
133 | but nothing on the remote calendar is changed. | 133 | but nothing on the remote calendar is changed. |
134 | If you uncheck "Write back synced data", the settings | 134 | If you uncheck "Write back synced data", the settings |
135 | under h) and i) are ignored, of course. | 135 | under h) and i) are ignored, of course. |
136 | h) --Write back (on remote) existing entries only: | 136 | h) --Write back (on remote) existing entries only: |
137 | Check this to update the remote data only. | 137 | Check this to update the remote data only. |
138 | I.e. no data from yor local calendar/addressbook is added to the | 138 | I.e. no data from yor local calendar/addressbook is added to the |
139 | remote device. You may use this option to | 139 | remote device. You may use this option to |
140 | sync against some kind of "public calendar/addressbook" without | 140 | sync against some kind of "public calendar/addressbook" without |
141 | writing back your personal data. | 141 | writing back your personal data. |
142 | i) --Write back (calendar) entries in future only: | 142 | i) --Write back (calendar) entries in future only: |
143 | Check this to write back only calendar entries in future. | 143 | Check this to write back only calendar entries in future. |
144 | (Useful when syncing with mobile phones.) | 144 | (Useful when syncing with mobile phones.) |
145 | You can specify the date range in weeks with | 145 | You can specify the date range in weeks with |
146 | ---- Max. weeks in future. | 146 | ---- Max. weeks in future. |
147 | Note: The date range starts always 7 days before the actual date! | 147 | Note: The date range starts always 7 days before the actual date! |
148 | I.e. the calendar events of the last week are written back always. | 148 | I.e. the calendar events of the last week are written back always. |
149 | j) Profile kind: | 149 | j) Profile kind: |
150 | Details -> 5) | 150 | Details -> 5) |
151 | 151 | ||
152 | ************************************************************************* | 152 | ************************************************************************* |
153 | 3) Syncing background | 153 | 3) Syncing background |
154 | ************************************************************************* | 154 | ************************************************************************* |
155 | 155 | ||
156 | The same mentioned for calendars is valid for addressbooks as well. | 156 | The same mentioned for calendars is valid for addressbooks as well. |
157 | 157 | ||
158 | Synchronizing calendars ( i.e. files ) means, | 158 | Synchronizing calendars ( i.e. files ) means, |
159 | to merge two calendars in a useful way. | 159 | to merge two calendars in a useful way. |
160 | If the two calendars are completely different, | 160 | If the two calendars are completely different, |
161 | there is no problem, the resulting calendar contains | 161 | there is no problem, the resulting calendar contains |
162 | all data from the local and from the remote calendar. | 162 | all data from the local and from the remote calendar. |
163 | 163 | ||
164 | Problems will occur, if you have edited items | 164 | Problems will occur, if you have edited items |
165 | from the local calendar on the remote machine. | 165 | from the local calendar on the remote machine. |
166 | Then it could be, that items are in conflict. | 166 | Then it could be, that items are in conflict. |
167 | Two items are "in conflict", if they have the | 167 | Two items are "in conflict", if they have the |
168 | same unique ID (which get an item at time of | 168 | same unique ID (which get an item at time of |
169 | creation and owns it until it is deleted ) | 169 | creation and owns it until it is deleted ) |
170 | and they both are modified after the last | 170 | and they both are modified after the last |
171 | synchronization. | 171 | synchronization. |
172 | 172 | ||
173 | At first sync of two calendars there is no item deleted. | 173 | At first sync of two calendars there is no item deleted. |
174 | If the calendars are synced before and there is an item, | 174 | If the calendars are synced before and there is an item, |
175 | which is not edited after the last sync and is only | 175 | which is not edited after the last sync and is only |
176 | available in one calendar, then this item is deleted | 176 | available in one calendar, then this item is deleted |
177 | in this calendar. | 177 | in this calendar. |
178 | 178 | ||
179 | But when was the last synchronization between two calendars? | 179 | But when was the last synchronization between two calendars? |
180 | 180 | ||
181 | To know that, KO/Pi creates at first syncing | 181 | To know that, KO/Pi creates at first syncing |
182 | of two files an unique event "<profile name> - sync Event" | 182 | of two files an unique event "<profile name> - sync Event" |
183 | on the remote and the local calendar. | 183 | on the remote and the local calendar. |
184 | After syncing, the start time of this event is set | 184 | After syncing, the start time of this event is set |
185 | to the time of syncing. | 185 | to the time of syncing. |
186 | The event is read only and the user may not change it. | 186 | The event is read only and the user may not change it. |
187 | 187 | ||
188 | If two such files are synced, that both have an event | 188 | If two such files are synced, that both have an event |
189 | "<profile name> - sync Event" and the events have | 189 | "<profile name> - sync Event" and the events have |
190 | the same start time, then deleted items on the one calendar | 190 | the same start time, then deleted items on the one calendar |
191 | are deleted on the other as well. | 191 | are deleted on the other as well. |
192 | 192 | ||
193 | 193 | ||
194 | ************************************************************************* | 194 | ************************************************************************* |
195 | 4) Sync preferences | 195 | 4) Sync preferences |
196 | ************************************************************************* | 196 | ************************************************************************* |
197 | 197 | ||
198 | Two items are "in conflict", if they have the same unique ID | 198 | Two items are "in conflict", if they have the same unique ID |
199 | and they both are modified after the last synchronization. | 199 | and they both are modified after the last synchronization. |
200 | (Details -> 3) ). | 200 | (Details -> 3) ). |
201 | 201 | ||
202 | If an item is not modified after the last sync and | 202 | If an item is not modified after the last sync and |
203 | it is not found in the other calendar, it is deleted. | 203 | it is not found in the other calendar, it is deleted. |
204 | 204 | ||
205 | On the first sync, there is no item deleted. | 205 | On the first sync, there is no item deleted. |
206 | 206 | ||
207 | SYNC PREFERENCES: | 207 | SYNC PREFERENCES: |
208 | -Take local entry on conflict: | 208 | -Take local entry on conflict: |
209 | Takes the local entry on conflict. | 209 | Takes the local entry on conflict. |
210 | If it is the first sync, | 210 | If it is the first sync, |
211 | "Ask for every entry" | 211 | "Ask for every entry" |
212 | is chosen automatically, | 212 | is chosen automatically, |
213 | if this is selected. | 213 | if this is selected. |
214 | 214 | ||
215 | -Take remote entry on conflict: | 215 | -Take remote entry on conflict: |
216 | Takes the remote entry on conflict. | 216 | Takes the remote entry on conflict. |
217 | If it is the first sync, | 217 | If it is the first sync, |
218 | "Ask for every entry" | 218 | "Ask for every entry" |
219 | is chosen automatically, | 219 | is chosen automatically, |
220 | if this is selected. | 220 | if this is selected. |
221 | 221 | ||
222 | -Take newest entry on conflict: | 222 | -Take newest entry on conflict: |
223 | This takes the newest entry on conflict. | 223 | This takes the newest entry on conflict. |
224 | May be the most useful syncing mode. | 224 | May be the most useful syncing mode. |
225 | 225 | ||
226 | -Ask for every entry on conflict: | 226 | -Ask for every entry on conflict: |
227 | Pops up an event viewer dialog and | 227 | Pops up an event viewer dialog and |
228 | shows the two conflicting entries there. | 228 | shows the two conflicting entries there. |
229 | The user can chose, which entry he would like to take. | 229 | The user can chose, which entry he would like to take. |
230 | The button for the newest entry | 230 | The button for the newest entry |
231 | is automatically set as default button. | 231 | is automatically set as default button. |
232 | The color for the newest entry is green. | 232 | The color for the newest entry is green. |
233 | 233 | ||
234 | -Force: Take local entry always: | 234 | -Force: Take local entry always: |
235 | Even if the calendars are already synced | 235 | Even if the calendars are already synced |
236 | there is no item deleted on local. | 236 | there is no item deleted on local. |
237 | 237 | ||
238 | -Force: Take remote entry always: | 238 | -Force: Take remote entry always: |
239 | Analogous to | 239 | Analogous to |
240 | "Force: Take local entry always" | 240 | "Force: Take local entry always" |
241 | 241 | ||
242 | ************************************************************************* | 242 | ************************************************************************* |
243 | 5) Details about sync profile kinds | 243 | 5) Details about sync profile kinds |
244 | ************************************************************************* | 244 | ************************************************************************* |
245 | 245 | ||
246 | a) Local file | 246 | a) Local file |
247 | Please specify a local file you want to sync with. | 247 | Please specify a local file you want to sync with. |
248 | 248 | ||
249 | b) Pi-Sync (direct Kx/Pi to Kx/Pi sync) | 249 | b) Pi-Sync (direct Kx/Pi to Kx/Pi sync) |
250 | We mention here only KO/Pi, but the same is valid for KA/Pi. | 250 | We mention here only KO/Pi, but the same is valid for KA/Pi. |
251 | If you want to sync with a device, where KO/Pi is | 251 | If you want to sync with a device, where KO/Pi is |
252 | installed, you can easily get the remote file via network | 252 | installed, you can easily get the remote file via network |
253 | with the build in file transfer feature "Pi-Sync": | 253 | with the build in file transfer feature "Pi-Sync": |
254 | You have first to enable file transfer on the remote device: | 254 | You have first to enable file transfer on the remote device: |
255 | - Start KO/Pi on the remote device. | 255 | - Start KO/Pi on the remote device. |
256 | - Choose Menu Synchronize-Enable Pi-Sync. | 256 | - Choose Menu Synchronize-Enable Pi-Sync. |
257 | - Choose a port number, where KO/Pi should listen for | 257 | - Choose a port number, where KO/Pi should listen for |
258 | file sending requests. Valid port numbers are numbers | 258 | file sending requests. Valid port numbers are numbers |
259 | between 1 and 65565. Do not specify port numbers, that are | 259 | between 1 and 65565. Do not specify port numbers, that are |
260 | used by other applications. A port number between 9000 and 9999 | 260 | used by other applications. A port number between 9000 and 9999 |
261 | is most likely not used by another application. | 261 | is most likely not used by another application. |
262 | The default port number is 9197 for KO/Pi. | 262 | The default port number is 9197 for KO/Pi. |
263 | If you specify a port number, which is already in use, | 263 | If you specify a port number, which is already in use, |
264 | you will get an error message when closing this dialog. | 264 | you will get an error message when closing this dialog. |
265 | - Choose a password. | 265 | - Choose a password. |
266 | - Click OK. | 266 | - Click OK. |
267 | Now KO/Pi will send the calendar data via the network, | 267 | Now KO/Pi will send the calendar data via the network, |
268 | if some other device is sending a "please send calendar" | 268 | if some other device is sending a "please send calendar" |
269 | request on the given port using the given password. | 269 | request on the given port using the given password. |
270 | If you want to be sure, nobody can access your calendar | 270 | If you want to be sure, nobody can access your calendar |
271 | data, simply disable the file transfer feature on the | 271 | data, simply disable the file transfer feature on the |
272 | remote device after the syncing is done by choosing: | 272 | remote device after the syncing is done by choosing: |
273 | Menu Synchronize-Disable Pi-Sync. | 273 | Menu Synchronize-Disable Pi-Sync. |
274 | 274 | ||
275 | Note: If you want to sync with a remote device that gets different | 275 | Note: If you want to sync with a remote device that gets different |
276 | IPaddresses each time connected to the network | 276 | IPaddresses each time connected to the network |
277 | (this may be the case, if you use DHCP for connection | 277 | (this may be the case, if you use DHCP for connection |
278 | of the remote device to the network) simply enable | 278 | of the remote device to the network) simply enable |
279 | "Ask for preferences before sync". | 279 | "Ask for preferences before sync". |
280 | Then you will be asked to confirm the | 280 | Then you will be asked to confirm the |
281 | "Pi-Sync" specific settings | 281 | "Pi-Sync" specific settings |
282 | (Password,IP address, port number) | 282 | (Password,IP address, port number) |
283 | and you can easily change the IP address before each sync. | 283 | and you can easily change the IP address before each sync. |
284 | 284 | ||
285 | On your local device, create a new profile and choose | 285 | On your local device, create a new profile and choose |
286 | profile kind "Pi-Sync". | 286 | profile kind "Pi-Sync". |
287 | Fill in the needed values: | 287 | Fill in the needed values: |
288 | - Password for remote access: | 288 | - Password for remote access: |
289 | The password you specified on the remote device. | 289 | The password you specified on the remote device. |
290 | - Remote IP address: | 290 | - Remote IP address: |
291 | The IP address of the remote device. | 291 | The IP address of the remote device. |
292 | - Remote port number: | 292 | - Remote port number: |
293 | The port number you specified on the remote device. | 293 | The port number you specified on the remote device. |
294 | 294 | ||
295 | Now you can syncronize your local device easily with your | 295 | Now you can syncronize your local device easily with your |
296 | remote device. This works well for all platforms KO/Pi is | 296 | remote device. This works well for all platforms KO/Pi is |
297 | running on, e.g. syncing a KO/Pi on Zaurus with KO/Pi on Windows | 297 | running on, e.g. syncing a KO/Pi on Zaurus with KO/Pi on Windows |
298 | is now very easy. | 298 | is now very easy. |
299 | 299 | ||
300 | c) Remote file | 300 | c) Remote file |
301 | Syncing with the profile kind "Remote file" is performed in three steps: | 301 | Syncing with the profile kind "Remote file" is performed in three steps: |
302 | i) download the remote file to your local machine to a temp file | 302 | i) download the remote file to your local machine to a temp file |
303 | ii) sync with this temp file | 303 | ii) sync with this temp file |
304 | iii) upload the synced file to the remote device | 304 | iii) upload the synced file to the remote device |
305 | 305 | ||
306 | The down-/uploading if i) and iii) is done via a command line command. | 306 | The down-/uploading if i) and iii) is done via a command line command. |
307 | Please specify the download/upload command ( like scp, ftp, ...) and the | 307 | Please specify the download/upload command ( like scp, ftp, ...) and the |
308 | file name of the temp file in the corresponding fields. | 308 | file name of the temp file in the corresponding fields. |
309 | 309 | ||
310 | d) Mobile device (cell phone) | 310 | d) Mobile device (cell phone) |
311 | Note: On the Zaurus you have to install the kammu_xxx_arm.ipk package | 311 | Note: On the Zaurus you have to install the phoneaccess_xxx_arm.ipk package |
312 | to be able to access mobile phones. | 312 | to be able to access mobile phones. |
313 | We mention here only KO/Pi, but the same is valid for KA/Pi. | 313 | We mention here only KO/Pi, but the same is valid for KA/Pi. |
314 | Note: | 314 | Note: |
315 | It is only possible to sync a mobile phone with one particular device | 315 | It is only possible to sync a mobile phone with one particular device |
316 | running KO/Pi. If you want to be able to write data of more than one device | 316 | running KO/Pi. If you want to be able to write data of more than one device |
317 | to the mobile phone (e.g. from your Zaurus and from your Windows Laptop) | 317 | to the mobile phone (e.g. from your Zaurus and from your Windows Laptop) |
318 | do not sync with the mobile phone at all, but use the | 318 | do not sync with the mobile phone at all, but use the |
319 | "Export to phone" functionality from the different devices. | 319 | "Export to phone" functionality from the different devices. |
320 | Using "Export to phone" makes it not possible to get back data from the | 320 | Using "Export to phone" makes it not possible to get back data from the |
321 | phone, if it was changed there, of course. | 321 | phone, if it was changed there, of course. |
322 | If you sync with the phone, do not use "Export to phone" from any device. | 322 | If you sync with the phone, do not use "Export to phone" from any device. |
323 | (And do not sync, as mentioned above, from any other device with that phone). | 323 | (And do not sync, as mentioned above, from any other device with that phone). |
324 | It would delete the needed information for syncing with that phone! | 324 | It would delete the needed information for syncing with that phone! |
325 | 325 | ||
326 | We are using Gammu (Version: 0.98.9) ( http://freshmeat.net/projects/gammu/ ) | 326 | We are using Gammu (Version: 0.98.9) ( http://freshmeat.net/projects/gammu/ ) |
327 | for accessing the phones. | 327 | for accessing the phones. |
328 | Note: You cannot use the original Gammu for syncing KDE-Pim/Pi, because | 328 | Note: You cannot use the original Gammu for syncing KDE-Pim/Pi, because |
329 | we have modified the original version to make it useable for syncing! | 329 | we have modified the original version to make it useable for syncing! |
330 | Gammu allows access to many phones in many ways (Irda, Bluetooth, serial,...). | 330 | Gammu allows access to many phones in many ways (Irda, Bluetooth, serial,...). |
331 | The recommended phone access using Gammu with KDE-Pim/Pi is Irda (infrared). | 331 | The recommended phone access using Gammu with KDE-Pim/Pi is Irda (infrared). |
332 | Bluetooth access is disabled on the Zaurus, but may work on Windows. | 332 | Bluetooth access is disabled on the Zaurus, but may work on Windows. |
333 | Please look at the Gammu homepage and documentation about more details | 333 | Please look at the Gammu homepage and documentation about more details |
334 | configuring Gammu how to access your phone. | 334 | configuring Gammu how to access your phone. |
335 | If you have problems accessing your phone, start KO/Pi from the konsole | 335 | If you have problems accessing your phone, start KO/Pi from the konsole |
336 | and you will get a more detailed output what went wrong. | 336 | and you will get a more detailed output what went wrong. |
337 | About Gammu from the Gammu homepage: | 337 | About Gammu from the Gammu homepage: |
338 | Gammu (formerly known as MyGnokii2) is a cellular | 338 | Gammu (formerly known as MyGnokii2) is a cellular |
339 | manager for various mobile phones/modems. | 339 | manager for various mobile phones/modems. |
340 | It supports the Nokia 2100, 3100, 32xx, 33xx, | 340 | It supports the Nokia 2100, 3100, 32xx, 33xx, |
341 | 3410, 35xx, 51xx, 5210, 5510, 61xx, 62xx, | 341 | 3410, 35xx, 51xx, 5210, 5510, 61xx, 62xx, |
342 | 63xx, 6510, 6610, 6800, 71xx, 7210, 7250, | 342 | 63xx, 6510, 6610, 6800, 71xx, 7210, 7250, |
343 | 7250i, 82xx, 83xx, 8910, 9110, 9210 | 343 | 7250i, 82xx, 83xx, 8910, 9110, 9210 |
344 | and compatible and AT devices (Siemens, Alcatel, | 344 | and compatible and AT devices (Siemens, Alcatel, |
345 | Falcom, WaveCom, IPAQ, Samsung, SE, and others) | 345 | Falcom, WaveCom, IPAQ, Samsung, SE, and others) |
346 | over cables/infrared/BlueTooth. | 346 | over cables/infrared/BlueTooth. |
347 | 347 | ||
348 | Here is an example what to specify to access a Nokia 6310i via infrared: | 348 | Here is an example what to specify to access a Nokia 6310i via infrared: |
349 | On Linux (Zaurus): | 349 | On Linux (Zaurus): |
350 | I/O device: /dev/ircomm | 350 | I/O device: /dev/ircomm |
351 | Connection: irda | 351 | Connection: irda |
352 | Model: <leave empty> | 352 | Model: <leave empty> |
353 | 353 | ||
354 | On Windows: | 354 | On Windows: |
355 | I/O device: <ignored - i.e. leave empty> | 355 | I/O device: <ignored - i.e. leave empty> |
356 | Connection: irda | 356 | Connection: irda |
357 | Model: <leave empty> | 357 | Model: <leave empty> |
358 | 358 | ||
359 | Here is the overview from the Gammu documentation, | 359 | Here is the overview from the Gammu documentation, |
360 | how to specify the connection settings for | 360 | how to specify the connection settings for |
361 | I/O device: | 361 | I/O device: |
362 | Connection: | 362 | Connection: |
363 | Model: | 363 | Model: |
364 | 364 | ||
365 | Note: The documentation uses the term "port", | 365 | Note: The documentation uses the term "port", |
366 | where we use the term "I/O device". | 366 | where we use the term "I/O device". |
367 | Note: You do not have to create/change the gammurc configuration file. | 367 | Note: You do not have to create/change the gammurc configuration file. |
368 | That will do KO/Pi for you. | 368 | That will do KO/Pi for you. |
369 | Note: For a known model, leave "Model:" always empty, | 369 | Note: For a known model, leave "Model:" always empty, |
370 | such that Gammu can auto detect the model. | 370 | such that Gammu can auto detect the model. |
371 | 371 | ||
372 | # This is a sample ~/.gammurc file. | 372 | # This is a sample ~/.gammurc file. |
373 | # In Unix/Linux copy it into your home directory and name it .gammurc | 373 | # In Unix/Linux copy it into your home directory and name it .gammurc |
374 | # or into /etc and name it gammurc | 374 | # or into /etc and name it gammurc |
375 | # In Win32 copy it into directory with Gammu.exe and name gammurc | 375 | # In Win32 copy it into directory with Gammu.exe and name gammurc |
376 | # More about parameters later | 376 | # More about parameters later |
377 | # ----------------------------------------------------------------------------- | 377 | # ----------------------------------------------------------------------------- |
378 | 378 | ||
379 | [gammu] | 379 | [gammu] |
380 | 380 | ||
381 | port = com8: | 381 | port = com8: |
382 | #model = 6110 | 382 | #model = 6110 |
383 | connection = fbusblue | 383 | connection = fbusblue |
384 | #synchronizetime = yes | 384 | #synchronizetime = yes |
385 | #logfile = gammulog | 385 | #logfile = gammulog |
386 | #logformat = textall | 386 | #logformat = textall |
387 | #use_locking = yes | 387 | #use_locking = yes |
388 | #gammuloc = locfile | 388 | #gammuloc = locfile |
389 | #startinfo = yes | 389 | #startinfo = yes |
390 | #gammucoding = utf8 | 390 | #gammucoding = utf8 |
391 | 391 | ||
392 | [gammu1] | 392 | [gammu1] |
393 | 393 | ||
394 | port = com8: | 394 | port = com8: |
395 | #model = 6110 | 395 | #model = 6110 |
396 | connection = fbusblue | 396 | connection = fbusblue |
397 | #synchronizetime = yes | 397 | #synchronizetime = yes |
398 | #logfile = gammulog | 398 | #logfile = gammulog |
399 | #logformat = textall | 399 | #logformat = textall |
400 | #use_locking = yes | 400 | #use_locking = yes |
401 | #gammuloc = locfile | 401 | #gammuloc = locfile |
402 | #startinfo = yes | 402 | #startinfo = yes |
403 | #gammucoding = utf8 | 403 | #gammucoding = utf8 |
404 | 404 | ||
405 | # ----------------------------------------------------------------------------- | 405 | # ----------------------------------------------------------------------------- |
406 | # Now info about "Connection" parameter and connected with it port type | 406 | # Now info about "Connection" parameter and connected with it port type |
407 | # (more about port types later) | 407 | # (more about port types later) |
408 | # ----------------------------------------------------------------------------- | 408 | # ----------------------------------------------------------------------------- |
409 | # "Connection" parameter | Port type | More details | 409 | # "Connection" parameter | Port type | More details |
410 | # -----------------------|-----------|----------------------------------------- | 410 | # -----------------------|-----------|----------------------------------------- |
411 | # "fbus" | serial | Nokia FBUS2 | 411 | # "fbus" | serial | Nokia FBUS2 |
412 | # "fbusirda"/"infrared" | serial | Nokia FBUS2 over direct infrared device | 412 | # "fbusirda"/"infrared" | serial | Nokia FBUS2 over direct infrared device |
413 | # "fbusdlr3"/"dlr3" | serial | Nokia FBUS2 with DLR3 cable | 413 | # "fbusdlr3"/"dlr3" | serial | Nokia FBUS2 with DLR3 cable |
414 | # "fbusdku5" | dku5 | Nokia FBUS2 with DKU5 cable. WIN32 ONLY | 414 | # "fbusdku5" | dku5 | Nokia FBUS2 with DKU5 cable. WIN32 ONLY |
415 | # "fbuspl2303" | usb | Nokia FBUS2 with USB cable based on | 415 | # "fbuspl2303" | usb | Nokia FBUS2 with USB cable based on |
416 | # | | PL2303 chip. | 416 | # | | PL2303 chip. |
417 | # "fbusblue" | serial | Nokia FBUS2 over Bluetooth serial device | 417 | # "fbusblue" | serial | Nokia FBUS2 over Bluetooth serial device |
418 | # "phonetblue" | serial | Nokia PHONET FBUS over Bluetooth serial | 418 | # "phonetblue" | serial | Nokia PHONET FBUS over Bluetooth serial |
419 | # | | device | 419 | # | | device |
420 | # "mrouterblue" | serial | | 420 | # "mrouterblue" | serial | |
421 | # "mbus" | serial | Nokia MBUS2 | 421 | # "mbus" | serial | Nokia MBUS2 |
422 | # "at19200"/"at115200"/..| serial | AT commands.8 bits, None parity, 1 stop | 422 | # "at19200"/"at115200"/..| serial | AT commands.8 bits, None parity, 1 stop |
423 | # | | bit, no flow control | 423 | # | | bit, no flow control |
424 | # -----------------------|-----------|----------------------------------------- | 424 | # -----------------------|-----------|----------------------------------------- |
425 | # "irdaphonet"/"irda" | irda | Nokia PHONET FBUS over socket infrared | 425 | # "irdaphonet"/"irda" | irda | Nokia PHONET FBUS over socket infrared |
426 | # "irdaat" | irda | AT commands with socket infrared | 426 | # "irdaat" | irda | AT commands with socket infrared |
427 | # "irdaobex" | irda | OBEX over socket infrared. MODEL "obex" | 427 | # "irdaobex" | irda | OBEX over socket infrared. MODEL "obex" |
428 | # -----------------------|-----------|----------------------------------------- | 428 | # -----------------------|-----------|----------------------------------------- |
429 | # "bluephonet" | BT | Nokia PHONET FBUS with Bluetooth stack | 429 | # "bluephonet" | BT | Nokia PHONET FBUS with Bluetooth stack |
430 | # "bluefbus"/"dlr3blue" | BT | Nokia FBUS2 with Bluetooth stack | 430 | # "bluefbus"/"dlr3blue" | BT | Nokia FBUS2 with Bluetooth stack |
431 | # "blueat"/"atblue" | BT | AT commands with Bluetooth stack | 431 | # "blueat"/"atblue" | BT | AT commands with Bluetooth stack |
432 | # "blueobex" | BT | OBEX with Bluetooth. MODEL "obex" | 432 | # "blueobex" | BT | OBEX with Bluetooth. MODEL "obex" |
433 | # | 433 | # |
434 | # Now more about port types and connected with it "Port" parameter | 434 | # Now more about port types and connected with it "Port" parameter |
435 | # ----------------------------------------------------------------------------- | 435 | # ----------------------------------------------------------------------------- |
436 | # Port type | "Port" parameter in Windows/DOS | "Port" parameter in Linux/Unix | 436 | # Port type | "Port" parameter in Windows/DOS | "Port" parameter in Linux/Unix |
437 | # ----------|---------------------------------|-------------------------------- | 437 | # ----------|---------------------------------|-------------------------------- |
438 | # serial | "com*:" | "/dev/ttyS*" | 438 | # serial | "com*:" | "/dev/ttyS*" |
439 | # | (example "com1:") | (example "/dev/ttyS1") | 439 | # | (example "com1:") | (example "/dev/ttyS1") |
440 | # | | or "/dev/tts/**" (with DevFS) | 440 | # | | or "/dev/tts/**" (with DevFS) |
441 | # ----------|---------------------------------|-------------------------------- | 441 | # ----------|---------------------------------|-------------------------------- |
442 | # irda | ignored (can be empty) | "/dev/ircomm*" | 442 | # irda | ignored (can be empty) | "/dev/ircomm*" |
443 | # ----------|---------------------------------|-------------------------------- | 443 | # ----------|---------------------------------|-------------------------------- |
444 | # BT | Bluetooth device address | 444 | # BT | Bluetooth device address |
445 | # | (example "") | 445 | # | (example "") |
446 | # ----------|---------------------------------|-------------------------------- | 446 | # ----------|---------------------------------|-------------------------------- |
447 | # dku5 | ignored (can be empty) | connection with it not possible | 447 | # dku5 | ignored (can be empty) | connection with it not possible |
448 | # ----------|---------------------------------|-------------------------------- | 448 | # ----------|---------------------------------|-------------------------------- |
449 | # usb | connection with it not possible | "/dev/ttyUSB*" | 449 | # usb | connection with it not possible | "/dev/ttyUSB*" |
450 | # | 450 | # |
451 | # Other config parameters | 451 | # Other config parameters |
452 | # ----------------------------------------------------------------------------- | 452 | # ----------------------------------------------------------------------------- |
453 | # Parameter name | Description | 453 | # Parameter name | Description |
454 | # ----------------|------------------------------------------------------------ | 454 | # ----------------|------------------------------------------------------------ |
455 | # Model | use only, when Gammu doesn't recognize your phone model. | 455 | # Model | use only, when Gammu doesn't recognize your phone model. |
456 | # | Put it here. Example values: "6110", "6150", "6210", "8210" | 456 | # | Put it here. Example values: "6110", "6150", "6210", "8210" |
457 | # SynchronizeTime | if you want to set time from computer to phone during | 457 | # SynchronizeTime | if you want to set time from computer to phone during |
458 | # | starting connection. Do not rather use this option when | 458 | # | starting connection. Do not rather use this option when |
459 | # | when to reset phone during connection (in some phones need | 459 | # | when to reset phone during connection (in some phones need |
460 | # | to set time again after restart) | 460 | # | to set time again after restart) |
461 | # GammuLoc | name of localisation file | 461 | # GammuLoc | name of localisation file |
462 | # StartInfo | this option allow to set, that you want (setting "yes") | 462 | # StartInfo | this option allow to set, that you want (setting "yes") |
463 | # | to see message on the phone screen or phone should enable | 463 | # | to see message on the phone screen or phone should enable |
464 | # | light for a moment during starting connection. Phone | 464 | # | light for a moment during starting connection. Phone |
465 | # | WON'T beep during starting connection with this option. | 465 | # | WON'T beep during starting connection with this option. |
466 | # GammuCoding | forces using specified codepage (in win32 - for example | 466 | # GammuCoding | forces using specified codepage (in win32 - for example |
467 | # | "1250" will force CP1250) or UTF8 (in Linux - "utf8") | 467 | # | "1250" will force CP1250) or UTF8 (in Linux - "utf8") |
468 | # ----------------|------------------------------------------------------------ | 468 | # ----------------|------------------------------------------------------------ |
469 | # Logfile | Use, when want to have logfile from communication. | 469 | # Logfile | Use, when want to have logfile from communication. |
470 | # Logformat | What debug info and format should be used: | 470 | # Logformat | What debug info and format should be used: |
471 | # | "nothing" - no debug level (default) | 471 | # | "nothing" - no debug level (default) |
472 | # | "text" - transmission dump in text format | 472 | # | "text" - transmission dump in text format |
473 | # | "textall" - all possible info in text format | 473 | # | "textall" - all possible info in text format |
474 | # | "errors" - errors in text format | 474 | # | "errors" - errors in text format |
475 | # | "binary" - transmission dump in binary format | 475 | # | "binary" - transmission dump in binary format |
476 | # ----------------|------------------------------------------------------------ | 476 | # ----------------|------------------------------------------------------------ |
477 | # Use_Locking | under Unix/Linux use "yes", if want to lock used device | 477 | # Use_Locking | under Unix/Linux use "yes", if want to lock used device |
478 | # | to prevent using it by other applications. In win32 ignored | 478 | # | to prevent using it by other applications. In win32 ignored |
479 | 479 | ||
480 | 480 | ||
481 | 481 | ||
482 | 482 | ||
483 | \ No newline at end of file | 483 | \ No newline at end of file |
diff --git a/gammu/emb/gammu/gammu.c b/gammu/emb/gammu/gammu.c index c436b90..8db9afb 100644 --- a/gammu/emb/gammu/gammu.c +++ b/gammu/emb/gammu/gammu.c | |||
@@ -3286,1537 +3286,1537 @@ static void SendSaveDisplaySMS(int argc, char *argv[]) | |||
3286 | } | 3286 | } |
3287 | if (mystrncasecmp(argv[i],"-tone10long",0)) { | 3287 | if (mystrncasecmp(argv[i],"-tone10long",0)) { |
3288 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSound10Long; | 3288 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSound10Long; |
3289 | if (Protected != 0) { | 3289 | if (Protected != 0) { |
3290 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3290 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3291 | Protected --; | 3291 | Protected --; |
3292 | } | 3292 | } |
3293 | nextlong = 14; | 3293 | nextlong = 14; |
3294 | break; | 3294 | break; |
3295 | } | 3295 | } |
3296 | if (mystrncasecmp(argv[i],"-tone12",0)) { | 3296 | if (mystrncasecmp(argv[i],"-tone12",0)) { |
3297 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSound12; | 3297 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSound12; |
3298 | if (Protected != 0) { | 3298 | if (Protected != 0) { |
3299 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3299 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3300 | Protected --; | 3300 | Protected --; |
3301 | } | 3301 | } |
3302 | nextlong = 14; | 3302 | nextlong = 14; |
3303 | break; | 3303 | break; |
3304 | } | 3304 | } |
3305 | if (mystrncasecmp(argv[i],"-tone12long",0)) { | 3305 | if (mystrncasecmp(argv[i],"-tone12long",0)) { |
3306 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSound12Long; | 3306 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSound12Long; |
3307 | if (Protected != 0) { | 3307 | if (Protected != 0) { |
3308 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3308 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3309 | Protected --; | 3309 | Protected --; |
3310 | } | 3310 | } |
3311 | nextlong = 14; | 3311 | nextlong = 14; |
3312 | break; | 3312 | break; |
3313 | } | 3313 | } |
3314 | if (mystrncasecmp(argv[i],"-toneSE",0)) { | 3314 | if (mystrncasecmp(argv[i],"-toneSE",0)) { |
3315 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSonyEricssonSound; | 3315 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSonyEricssonSound; |
3316 | if (Protected != 0) { | 3316 | if (Protected != 0) { |
3317 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3317 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3318 | Protected --; | 3318 | Protected --; |
3319 | } | 3319 | } |
3320 | nextlong = 14; | 3320 | nextlong = 14; |
3321 | break; | 3321 | break; |
3322 | } | 3322 | } |
3323 | if (mystrncasecmp(argv[i],"-toneSElong",0)) { | 3323 | if (mystrncasecmp(argv[i],"-toneSElong",0)) { |
3324 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSonyEricssonSoundLong; | 3324 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSSonyEricssonSoundLong; |
3325 | if (Protected != 0) { | 3325 | if (Protected != 0) { |
3326 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3326 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3327 | Protected --; | 3327 | Protected --; |
3328 | } | 3328 | } |
3329 | nextlong = 14; | 3329 | nextlong = 14; |
3330 | break; | 3330 | break; |
3331 | } | 3331 | } |
3332 | if (mystrncasecmp(argv[i],"-fixedbitmap",0)) { | 3332 | if (mystrncasecmp(argv[i],"-fixedbitmap",0)) { |
3333 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSFixedBitmap; | 3333 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSFixedBitmap; |
3334 | if (Protected != 0) { | 3334 | if (Protected != 0) { |
3335 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3335 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3336 | Protected --; | 3336 | Protected --; |
3337 | } | 3337 | } |
3338 | nextlong = 15; | 3338 | nextlong = 15; |
3339 | break; | 3339 | break; |
3340 | } | 3340 | } |
3341 | if (mystrncasecmp(argv[i],"-variablebitmap",0)) { | 3341 | if (mystrncasecmp(argv[i],"-variablebitmap",0)) { |
3342 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSVariableBitmap; | 3342 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSVariableBitmap; |
3343 | if (Protected != 0) { | 3343 | if (Protected != 0) { |
3344 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3344 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3345 | Protected --; | 3345 | Protected --; |
3346 | } | 3346 | } |
3347 | nextlong = 15; | 3347 | nextlong = 15; |
3348 | break; | 3348 | break; |
3349 | } | 3349 | } |
3350 | if (mystrncasecmp(argv[i],"-variablebitmaplong",0)) { | 3350 | if (mystrncasecmp(argv[i],"-variablebitmaplong",0)) { |
3351 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSVariableBitmapLong; | 3351 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSVariableBitmapLong; |
3352 | if (Protected != 0) { | 3352 | if (Protected != 0) { |
3353 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3353 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3354 | Protected --; | 3354 | Protected --; |
3355 | } | 3355 | } |
3356 | nextlong = 15; | 3356 | nextlong = 15; |
3357 | break; | 3357 | break; |
3358 | } | 3358 | } |
3359 | if (mystrncasecmp(argv[i],"-animation",0)) { | 3359 | if (mystrncasecmp(argv[i],"-animation",0)) { |
3360 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSAnimation; | 3360 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_EMSAnimation; |
3361 | if (Protected != 0) { | 3361 | if (Protected != 0) { |
3362 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; | 3362 | SMSInfo.Entries[SMSInfo.EntriesNum].Protected = true; |
3363 | Protected --; | 3363 | Protected --; |
3364 | } | 3364 | } |
3365 | bitmap[SMSInfo.EntriesNum].Number = 0; | 3365 | bitmap[SMSInfo.EntriesNum].Number = 0; |
3366 | nextlong = 16; | 3366 | nextlong = 16; |
3367 | break; | 3367 | break; |
3368 | } | 3368 | } |
3369 | } | 3369 | } |
3370 | if (mystrncasecmp(argv[2],"OPERATOR",0)) { | 3370 | if (mystrncasecmp(argv[2],"OPERATOR",0)) { |
3371 | if (mystrncasecmp(argv[i],"-netcode",0)) { | 3371 | if (mystrncasecmp(argv[i],"-netcode",0)) { |
3372 | nextlong = 7; | 3372 | nextlong = 7; |
3373 | break; | 3373 | break; |
3374 | } | 3374 | } |
3375 | if (mystrncasecmp(argv[i],"-biglogo",0)) { | 3375 | if (mystrncasecmp(argv[i],"-biglogo",0)) { |
3376 | SMSInfo.Entries[0].ID = SMS_NokiaOperatorLogoLong; | 3376 | SMSInfo.Entries[0].ID = SMS_NokiaOperatorLogoLong; |
3377 | break; | 3377 | break; |
3378 | } | 3378 | } |
3379 | break; | 3379 | break; |
3380 | } | 3380 | } |
3381 | printmsg("Unknown parameter (\"%s\")\n",argv[i]); | 3381 | printmsg("Unknown parameter (\"%s\")\n",argv[i]); |
3382 | exit(-1); | 3382 | exit(-1); |
3383 | break; | 3383 | break; |
3384 | case 1: /* SMS folder - only during saving SMS */ | 3384 | case 1: /* SMS folder - only during saving SMS */ |
3385 | Folder = atoi(argv[i]); | 3385 | Folder = atoi(argv[i]); |
3386 | nextlong = 0; | 3386 | nextlong = 0; |
3387 | break; | 3387 | break; |
3388 | case 2: /* Sender number - only during saving SMS */ | 3388 | case 2: /* Sender number - only during saving SMS */ |
3389 | EncodeUnicode(Sender,argv[i],strlen(argv[i])); | 3389 | EncodeUnicode(Sender,argv[i],strlen(argv[i])); |
3390 | nextlong = 0; | 3390 | nextlong = 0; |
3391 | break; | 3391 | break; |
3392 | case 3: /* SMSC set number */ | 3392 | case 3: /* SMSC set number */ |
3393 | SMSCSet = atoi(argv[i]); | 3393 | SMSCSet = atoi(argv[i]); |
3394 | nextlong = 0; | 3394 | nextlong = 0; |
3395 | break; | 3395 | break; |
3396 | case 4: /* Number of SMSC */ | 3396 | case 4: /* Number of SMSC */ |
3397 | EncodeUnicode(SMSC,argv[i],strlen(argv[i])); | 3397 | EncodeUnicode(SMSC,argv[i],strlen(argv[i])); |
3398 | SMSCSet = 0; | 3398 | SMSCSet = 0; |
3399 | nextlong= 0; | 3399 | nextlong= 0; |
3400 | break; | 3400 | break; |
3401 | case 5: /* Length of text SMS */ | 3401 | case 5: /* Length of text SMS */ |
3402 | if (atoi(argv[i])<chars_read) | 3402 | if (atoi(argv[i])<chars_read) |
3403 | { | 3403 | { |
3404 | Buffer[0][atoi(argv[i])*2]= 0x00; | 3404 | Buffer[0][atoi(argv[i])*2]= 0x00; |
3405 | Buffer[0][atoi(argv[i])*2+1]= 0x00; | 3405 | Buffer[0][atoi(argv[i])*2+1]= 0x00; |
3406 | } | 3406 | } |
3407 | SMSInfo.Entries[0].ID = SMS_ConcatenatedTextLong; | 3407 | SMSInfo.Entries[0].ID = SMS_ConcatenatedTextLong; |
3408 | if (mystrncasecmp(argv[i-1],"-autolen",0)) SMSInfo.Entries[0].ID = SMS_ConcatenatedAutoTextLong; | 3408 | if (mystrncasecmp(argv[i-1],"-autolen",0)) SMSInfo.Entries[0].ID = SMS_ConcatenatedAutoTextLong; |
3409 | nextlong = 0; | 3409 | nextlong = 0; |
3410 | break; | 3410 | break; |
3411 | case 6:/* Picture Images - text */ | 3411 | case 6:/* Picture Images - text */ |
3412 | EncodeUnicode(bitmap[0].Bitmap[0].Text,argv[i],strlen(argv[i])); | 3412 | EncodeUnicode(bitmap[0].Bitmap[0].Text,argv[i],strlen(argv[i])); |
3413 | nextlong = 0; | 3413 | nextlong = 0; |
3414 | break; | 3414 | break; |
3415 | case 7:/* Operator Logo - network code */ | 3415 | case 7:/* Operator Logo - network code */ |
3416 | strncpy(bitmap[0].Bitmap[0].NetworkCode,argv[i],7); | 3416 | strncpy(bitmap[0].Bitmap[0].NetworkCode,argv[i],7); |
3417 | if (!strcmp(DecodeUnicodeConsole(GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode)),"unknown")) { | 3417 | if (!strcmp(DecodeUnicodeConsole(GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode)),"unknown")) { |
3418 | printmsg("Unknown GSM network code (\"%s\")\n",argv[i]); | 3418 | printmsg("Unknown GSM network code (\"%s\")\n",argv[i]); |
3419 | exit(-1); | 3419 | exit(-1); |
3420 | } | 3420 | } |
3421 | if (mystrncasecmp(argv[1],"--savesms",0)) { | 3421 | if (mystrncasecmp(argv[1],"--savesms",0)) { |
3422 | EncodeUnicode(Sender, "OpLogo",6); | 3422 | EncodeUnicode(Sender, "OpLogo",6); |
3423 | EncodeUnicode(Sender+6*2,bitmap[0].Bitmap[0].NetworkCode,3); | 3423 | EncodeUnicode(Sender+6*2,bitmap[0].Bitmap[0].NetworkCode,3); |
3424 | EncodeUnicode(Sender+6*2+3*2,bitmap[0].Bitmap[0].NetworkCode+4,2); | 3424 | EncodeUnicode(Sender+6*2+3*2,bitmap[0].Bitmap[0].NetworkCode+4,2); |
3425 | if (UnicodeLength(GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode))<GSM_MAX_SMS_NAME_LENGTH-7) { | 3425 | if (UnicodeLength(GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode))<GSM_MAX_SMS_NAME_LENGTH-7) { |
3426 | EncodeUnicode(Name,"OpLogo ",7); | 3426 | EncodeUnicode(Name,"OpLogo ",7); |
3427 | CopyUnicodeString(Name+7*2,GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode)); | 3427 | CopyUnicodeString(Name+7*2,GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode)); |
3428 | } else { | 3428 | } else { |
3429 | CopyUnicodeString(Name,Sender); | 3429 | CopyUnicodeString(Name,Sender); |
3430 | } | 3430 | } |
3431 | } | 3431 | } |
3432 | nextlong = 0; | 3432 | nextlong = 0; |
3433 | break; | 3433 | break; |
3434 | case 8:/* Reject duplicates ID */ | 3434 | case 8:/* Reject duplicates ID */ |
3435 | SMSInfo.ReplaceMessage = atoi(argv[i]); | 3435 | SMSInfo.ReplaceMessage = atoi(argv[i]); |
3436 | if (SMSInfo.ReplaceMessage < 1 || SMSInfo.ReplaceMessage > 7) { | 3436 | if (SMSInfo.ReplaceMessage < 1 || SMSInfo.ReplaceMessage > 7) { |
3437 | printmsg("You have to give number between 1 and 7 (\"%s\")\n",argv[i]); | 3437 | printmsg("You have to give number between 1 and 7 (\"%s\")\n",argv[i]); |
3438 | exit(-1); | 3438 | exit(-1); |
3439 | } | 3439 | } |
3440 | nextlong = 0; | 3440 | nextlong = 0; |
3441 | break; | 3441 | break; |
3442 | case 9:/* Replace file for text SMS */ | 3442 | case 9:/* Replace file for text SMS */ |
3443 | ReplaceFile = fopen(argv[i], "rb"); | 3443 | ReplaceFile = fopen(argv[i], "rb"); |
3444 | if (ReplaceFile == NULL) Print_Error(ERR_CANTOPENFILE); | 3444 | if (ReplaceFile == NULL) Print_Error(ERR_CANTOPENFILE); |
3445 | memset(ReplaceBuffer,0,sizeof(ReplaceBuffer)); | 3445 | memset(ReplaceBuffer,0,sizeof(ReplaceBuffer)); |
3446 | fread(ReplaceBuffer,1,sizeof(ReplaceBuffer),ReplaceFile); | 3446 | fread(ReplaceBuffer,1,sizeof(ReplaceBuffer),ReplaceFile); |
3447 | fclose(ReplaceFile); | 3447 | fclose(ReplaceFile); |
3448 | ReadUnicodeFile(ReplaceBuffer2,ReplaceBuffer); | 3448 | ReadUnicodeFile(ReplaceBuffer2,ReplaceBuffer); |
3449 | for(j=0;j<(int)(UnicodeLength(Buffer[0]));j++) { | 3449 | for(j=0;j<(int)(UnicodeLength(Buffer[0]));j++) { |
3450 | for (z=0;z<(int)(UnicodeLength(ReplaceBuffer2)/2);z++) { | 3450 | for (z=0;z<(int)(UnicodeLength(ReplaceBuffer2)/2);z++) { |
3451 | if (ReplaceBuffer2[z*4] == Buffer[0][j] && | 3451 | if (ReplaceBuffer2[z*4] == Buffer[0][j] && |
3452 | ReplaceBuffer2[z*4+1] == Buffer[0][j+1]) { | 3452 | ReplaceBuffer2[z*4+1] == Buffer[0][j+1]) { |
3453 | Buffer[0][j] = ReplaceBuffer2[z*4+2]; | 3453 | Buffer[0][j] = ReplaceBuffer2[z*4+2]; |
3454 | Buffer[0][j+1] = ReplaceBuffer2[z*4+3]; | 3454 | Buffer[0][j+1] = ReplaceBuffer2[z*4+3]; |
3455 | break; | 3455 | break; |
3456 | } | 3456 | } |
3457 | } | 3457 | } |
3458 | } | 3458 | } |
3459 | nextlong = 0; | 3459 | nextlong = 0; |
3460 | break; | 3460 | break; |
3461 | case 10: | 3461 | case 10: |
3462 | Validity.Format = SMS_Validity_RelativeFormat; | 3462 | Validity.Format = SMS_Validity_RelativeFormat; |
3463 | if (mystrncasecmp(argv[i],"HOUR",0)) Validity.Relative = SMS_VALID_1_Hour; | 3463 | if (mystrncasecmp(argv[i],"HOUR",0)) Validity.Relative = SMS_VALID_1_Hour; |
3464 | else if (mystrncasecmp(argv[i],"6HOURS",0))Validity.Relative = SMS_VALID_6_Hours; | 3464 | else if (mystrncasecmp(argv[i],"6HOURS",0))Validity.Relative = SMS_VALID_6_Hours; |
3465 | else if (mystrncasecmp(argv[i],"DAY",0)) Validity.Relative = SMS_VALID_1_Day; | 3465 | else if (mystrncasecmp(argv[i],"DAY",0)) Validity.Relative = SMS_VALID_1_Day; |
3466 | else if (mystrncasecmp(argv[i],"3DAYS",0)) Validity.Relative = SMS_VALID_3_Days; | 3466 | else if (mystrncasecmp(argv[i],"3DAYS",0)) Validity.Relative = SMS_VALID_3_Days; |
3467 | else if (mystrncasecmp(argv[i],"WEEK",0)) Validity.Relative = SMS_VALID_1_Week; | 3467 | else if (mystrncasecmp(argv[i],"WEEK",0)) Validity.Relative = SMS_VALID_1_Week; |
3468 | else if (mystrncasecmp(argv[i],"MAX",0)) Validity.Relative = SMS_VALID_Max_Time; | 3468 | else if (mystrncasecmp(argv[i],"MAX",0)) Validity.Relative = SMS_VALID_Max_Time; |
3469 | else { | 3469 | else { |
3470 | printmsg("Unknown validity string (\"%s\")\n",argv[i]); | 3470 | printmsg("Unknown validity string (\"%s\")\n",argv[i]); |
3471 | exit(-1); | 3471 | exit(-1); |
3472 | } | 3472 | } |
3473 | nextlong = 0; | 3473 | nextlong = 0; |
3474 | break; | 3474 | break; |
3475 | case 11:/* EMS text from parameter */ | 3475 | case 11:/* EMS text from parameter */ |
3476 | EncodeUnicode(Buffer[SMSInfo.EntriesNum],argv[i],strlen(argv[i])); | 3476 | EncodeUnicode(Buffer[SMSInfo.EntriesNum],argv[i],strlen(argv[i])); |
3477 | dbgprintf("buffer is \"%s\"\n",DecodeUnicodeConsole(Buffer[SMSInfo.EntriesNum])); | 3477 | dbgprintf("buffer is \"%s\"\n",DecodeUnicodeConsole(Buffer[SMSInfo.EntriesNum])); |
3478 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_ConcatenatedTextLong; | 3478 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_ConcatenatedTextLong; |
3479 | SMSInfo.Entries[SMSInfo.EntriesNum].Buffer = Buffer[SMSInfo.EntriesNum]; | 3479 | SMSInfo.Entries[SMSInfo.EntriesNum].Buffer = Buffer[SMSInfo.EntriesNum]; |
3480 | SMSInfo.EntriesNum++; | 3480 | SMSInfo.EntriesNum++; |
3481 | nextlong = 0; | 3481 | nextlong = 0; |
3482 | break; | 3482 | break; |
3483 | case 12:/* EMS predefined sound/animation number */ | 3483 | case 12:/* EMS predefined sound/animation number */ |
3484 | SMSInfo.Entries[SMSInfo.EntriesNum].Number = atoi(argv[i]); | 3484 | SMSInfo.Entries[SMSInfo.EntriesNum].Number = atoi(argv[i]); |
3485 | SMSInfo.EntriesNum++; | 3485 | SMSInfo.EntriesNum++; |
3486 | nextlong = 0; | 3486 | nextlong = 0; |
3487 | break; | 3487 | break; |
3488 | case 14: /* EMS ringtone - IMelody */ | 3488 | case 14: /* EMS ringtone - IMelody */ |
3489 | ringtone[SMSInfo.EntriesNum].Format=RING_NOTETONE; | 3489 | ringtone[SMSInfo.EntriesNum].Format=RING_NOTETONE; |
3490 | error=GSM_ReadRingtoneFile(argv[i],&ringtone[SMSInfo.EntriesNum]); | 3490 | error=GSM_ReadRingtoneFile(argv[i],&ringtone[SMSInfo.EntriesNum]); |
3491 | Print_Error(error); | 3491 | Print_Error(error); |
3492 | SMSInfo.Entries[SMSInfo.EntriesNum].Ringtone = &ringtone[SMSInfo.EntriesNum]; | 3492 | SMSInfo.Entries[SMSInfo.EntriesNum].Ringtone = &ringtone[SMSInfo.EntriesNum]; |
3493 | SMSInfo.EntriesNum++; | 3493 | SMSInfo.EntriesNum++; |
3494 | nextlong = 0; | 3494 | nextlong = 0; |
3495 | break; | 3495 | break; |
3496 | case 15:/* EMS bitmap file */ | 3496 | case 15:/* EMS bitmap file */ |
3497 | bitmap[SMSInfo.EntriesNum].Bitmap[0].Type=GSM_StartupLogo; | 3497 | bitmap[SMSInfo.EntriesNum].Bitmap[0].Type=GSM_StartupLogo; |
3498 | error=GSM_ReadBitmapFile(argv[i],&bitmap[SMSInfo.EntriesNum]); | 3498 | error=GSM_ReadBitmapFile(argv[i],&bitmap[SMSInfo.EntriesNum]); |
3499 | Print_Error(error); | 3499 | Print_Error(error); |
3500 | SMSInfo.Entries[SMSInfo.EntriesNum].Bitmap = &bitmap[SMSInfo.EntriesNum]; | 3500 | SMSInfo.Entries[SMSInfo.EntriesNum].Bitmap = &bitmap[SMSInfo.EntriesNum]; |
3501 | SMSInfo.EntriesNum++; | 3501 | SMSInfo.EntriesNum++; |
3502 | nextlong = 0; | 3502 | nextlong = 0; |
3503 | break; | 3503 | break; |
3504 | case 16:/* Number of frames for EMS animation */ | 3504 | case 16:/* Number of frames for EMS animation */ |
3505 | FramesNum = atoi(argv[i]); | 3505 | FramesNum = atoi(argv[i]); |
3506 | if (FramesNum < 1 || FramesNum > 4) { | 3506 | if (FramesNum < 1 || FramesNum > 4) { |
3507 | printmsg("You have to give number of EMS frames between 1 and 4 (\"%s\")\n",argv[i]); | 3507 | printmsg("You have to give number of EMS frames between 1 and 4 (\"%s\")\n",argv[i]); |
3508 | exit(-1); | 3508 | exit(-1); |
3509 | } | 3509 | } |
3510 | bitmap[SMSInfo.EntriesNum].Number = 0; | 3510 | bitmap[SMSInfo.EntriesNum].Number = 0; |
3511 | nextlong = 17; | 3511 | nextlong = 17; |
3512 | break; | 3512 | break; |
3513 | case 17:/*File for EMS animation */ | 3513 | case 17:/*File for EMS animation */ |
3514 | bitmap2.Bitmap[0].Type=GSM_StartupLogo; | 3514 | bitmap2.Bitmap[0].Type=GSM_StartupLogo; |
3515 | error=GSM_ReadBitmapFile(argv[i],&bitmap2); | 3515 | error=GSM_ReadBitmapFile(argv[i],&bitmap2); |
3516 | for (j=0;j<bitmap2.Number;j++) { | 3516 | for (j=0;j<bitmap2.Number;j++) { |
3517 | if (bitmap[SMSInfo.EntriesNum].Number == FramesNum) break; | 3517 | if (bitmap[SMSInfo.EntriesNum].Number == FramesNum) break; |
3518 | memcpy(&bitmap[SMSInfo.EntriesNum].Bitmap[bitmap[SMSInfo.EntriesNum].Number],&bitmap2.Bitmap[j],sizeof(GSM_Bitmap)); | 3518 | memcpy(&bitmap[SMSInfo.EntriesNum].Bitmap[bitmap[SMSInfo.EntriesNum].Number],&bitmap2.Bitmap[j],sizeof(GSM_Bitmap)); |
3519 | bitmap[SMSInfo.EntriesNum].Number++; | 3519 | bitmap[SMSInfo.EntriesNum].Number++; |
3520 | } | 3520 | } |
3521 | if (bitmap[SMSInfo.EntriesNum].Number == FramesNum) { | 3521 | if (bitmap[SMSInfo.EntriesNum].Number == FramesNum) { |
3522 | SMSInfo.Entries[SMSInfo.EntriesNum].Bitmap = &bitmap[SMSInfo.EntriesNum]; | 3522 | SMSInfo.Entries[SMSInfo.EntriesNum].Bitmap = &bitmap[SMSInfo.EntriesNum]; |
3523 | SMSInfo.EntriesNum++; | 3523 | SMSInfo.EntriesNum++; |
3524 | nextlong = 0; | 3524 | nextlong = 0; |
3525 | } | 3525 | } |
3526 | break; | 3526 | break; |
3527 | case 18:/* EMS text from Unicode file */ | 3527 | case 18:/* EMS text from Unicode file */ |
3528 | f = fopen(argv[i],"rb"); | 3528 | f = fopen(argv[i],"rb"); |
3529 | if (f == NULL) { | 3529 | if (f == NULL) { |
3530 | printmsg("Can't open file \"%s\"\n",argv[i]); | 3530 | printmsg("Can't open file \"%s\"\n",argv[i]); |
3531 | exit(-1); | 3531 | exit(-1); |
3532 | } | 3532 | } |
3533 | z=fread(InputBuffer,1,2000,f); | 3533 | z=fread(InputBuffer,1,2000,f); |
3534 | InputBuffer[z] = 0; | 3534 | InputBuffer[z] = 0; |
3535 | InputBuffer[z+1] = 0; | 3535 | InputBuffer[z+1] = 0; |
3536 | fclose(f); | 3536 | fclose(f); |
3537 | ReadUnicodeFile(Buffer[SMSInfo.EntriesNum],InputBuffer); | 3537 | ReadUnicodeFile(Buffer[SMSInfo.EntriesNum],InputBuffer); |
3538 | dbgprintf("buffer is \"%s\"\n",DecodeUnicodeConsole(Buffer[SMSInfo.EntriesNum])); | 3538 | dbgprintf("buffer is \"%s\"\n",DecodeUnicodeConsole(Buffer[SMSInfo.EntriesNum])); |
3539 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_ConcatenatedTextLong; | 3539 | SMSInfo.Entries[SMSInfo.EntriesNum].ID = SMS_ConcatenatedTextLong; |
3540 | SMSInfo.Entries[SMSInfo.EntriesNum].Buffer = Buffer[SMSInfo.EntriesNum]; | 3540 | SMSInfo.Entries[SMSInfo.EntriesNum].Buffer = Buffer[SMSInfo.EntriesNum]; |
3541 | SMSInfo.EntriesNum++; | 3541 | SMSInfo.EntriesNum++; |
3542 | nextlong = 0; | 3542 | nextlong = 0; |
3543 | break; | 3543 | break; |
3544 | case 19:/* Number of protected items */ | 3544 | case 19:/* Number of protected items */ |
3545 | Protected = atoi(argv[i]); | 3545 | Protected = atoi(argv[i]); |
3546 | nextlong = 0; | 3546 | nextlong = 0; |
3547 | break; | 3547 | break; |
3548 | case 20:/* Formatting text for EMS */ | 3548 | case 20:/* Formatting text for EMS */ |
3549 | if (SMSInfo.Entries[SMSInfo.EntriesNum-1].ID == SMS_ConcatenatedTextLong) { | 3549 | if (SMSInfo.Entries[SMSInfo.EntriesNum-1].ID == SMS_ConcatenatedTextLong) { |
3550 | for(j=0;j<(int)strlen(argv[i]);j++) { | 3550 | for(j=0;j<(int)strlen(argv[i]);j++) { |
3551 | switch(argv[i][j]) { | 3551 | switch(argv[i][j]) { |
3552 | case 'l': case 'L': | 3552 | case 'l': case 'L': |
3553 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Left = true; | 3553 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Left = true; |
3554 | break; | 3554 | break; |
3555 | case 'c': case 'C': | 3555 | case 'c': case 'C': |
3556 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Center = true; | 3556 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Center = true; |
3557 | break; | 3557 | break; |
3558 | case 'r': case 'R': | 3558 | case 'r': case 'R': |
3559 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Right = true; | 3559 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Right = true; |
3560 | break; | 3560 | break; |
3561 | case 'a': case 'A': | 3561 | case 'a': case 'A': |
3562 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Large = true; | 3562 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Large = true; |
3563 | break; | 3563 | break; |
3564 | case 's': case 'S': | 3564 | case 's': case 'S': |
3565 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Small = true; | 3565 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Small = true; |
3566 | break; | 3566 | break; |
3567 | case 'b': case 'B': | 3567 | case 'b': case 'B': |
3568 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Bold = true; | 3568 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Bold = true; |
3569 | break; | 3569 | break; |
3570 | case 'i': case 'I': | 3570 | case 'i': case 'I': |
3571 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Italic = true; | 3571 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Italic = true; |
3572 | break; | 3572 | break; |
3573 | case 'u': case 'U': | 3573 | case 'u': case 'U': |
3574 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Underlined = true; | 3574 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Underlined = true; |
3575 | break; | 3575 | break; |
3576 | case 't': case 'T': | 3576 | case 't': case 'T': |
3577 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Strikethrough = true; | 3577 | SMSInfo.Entries[SMSInfo.EntriesNum-1].Strikethrough = true; |
3578 | break; | 3578 | break; |
3579 | default: | 3579 | default: |
3580 | printmsg("Unknown parameter \"%c\"\n",argv[i][j]); | 3580 | printmsg("Unknown parameter \"%c\"\n",argv[i][j]); |
3581 | exit(-1); | 3581 | exit(-1); |
3582 | } | 3582 | } |
3583 | } | 3583 | } |
3584 | } else { | 3584 | } else { |
3585 | printmsg("Last parameter wasn't text\n"); | 3585 | printmsg("Last parameter wasn't text\n"); |
3586 | exit(-1); | 3586 | exit(-1); |
3587 | } | 3587 | } |
3588 | nextlong = 0; | 3588 | nextlong = 0; |
3589 | break; | 3589 | break; |
3590 | case 21:/*MaxSMS*/ | 3590 | case 21:/*MaxSMS*/ |
3591 | MaxSMS = atoi(argv[i]); | 3591 | MaxSMS = atoi(argv[i]); |
3592 | nextlong = 0; | 3592 | nextlong = 0; |
3593 | break; | 3593 | break; |
3594 | case 22:/* profile name */ | 3594 | case 22:/* profile name */ |
3595 | EncodeUnicode(Buffer[0],argv[i],strlen(argv[i])); | 3595 | EncodeUnicode(Buffer[0],argv[i],strlen(argv[i])); |
3596 | SMSInfo.Entries[0].Buffer = Buffer[0]; | 3596 | SMSInfo.Entries[0].Buffer = Buffer[0]; |
3597 | nextlong = 0; | 3597 | nextlong = 0; |
3598 | break; | 3598 | break; |
3599 | case 23:/* profile ringtone */ | 3599 | case 23:/* profile ringtone */ |
3600 | ringtone[0].Format = RING_NOTETONE; | 3600 | ringtone[0].Format = RING_NOTETONE; |
3601 | error=GSM_ReadRingtoneFile(argv[i],&ringtone[0]); | 3601 | error=GSM_ReadRingtoneFile(argv[i],&ringtone[0]); |
3602 | Print_Error(error); | 3602 | Print_Error(error); |
3603 | SMSInfo.Entries[0].Ringtone = &ringtone[0]; | 3603 | SMSInfo.Entries[0].Ringtone = &ringtone[0]; |
3604 | nextlong = 0; | 3604 | nextlong = 0; |
3605 | break; | 3605 | break; |
3606 | case 24:/* profile bitmap */ | 3606 | case 24:/* profile bitmap */ |
3607 | bitmap[0].Bitmap[0].Type = GSM_PictureImage; | 3607 | bitmap[0].Bitmap[0].Type = GSM_PictureImage; |
3608 | error=GSM_ReadBitmapFile(argv[i],&bitmap[0]); | 3608 | error=GSM_ReadBitmapFile(argv[i],&bitmap[0]); |
3609 | Print_Error(error); | 3609 | Print_Error(error); |
3610 | bitmap[0].Bitmap[0].Text[0] = 0; | 3610 | bitmap[0].Bitmap[0].Text[0] = 0; |
3611 | bitmap[0].Bitmap[0].Text[1] = 0; | 3611 | bitmap[0].Bitmap[0].Text[1] = 0; |
3612 | SMSInfo.Entries[0].Bitmap = &bitmap[0]; | 3612 | SMSInfo.Entries[0].Bitmap = &bitmap[0]; |
3613 | nextlong = 0; | 3613 | nextlong = 0; |
3614 | break; | 3614 | break; |
3615 | } | 3615 | } |
3616 | } | 3616 | } |
3617 | if (nextlong!=0) { | 3617 | if (nextlong!=0) { |
3618 | printmsg("Parameter missed...\n"); | 3618 | printmsg("Parameter missed...\n"); |
3619 | exit(-1); | 3619 | exit(-1); |
3620 | } | 3620 | } |
3621 | 3621 | ||
3622 | if (mystrncasecmp(argv[2],"EMS",0) && EMS16Bit) { | 3622 | if (mystrncasecmp(argv[2],"EMS",0) && EMS16Bit) { |
3623 | for (i=0;i<SMSInfo.EntriesNum;i++) { | 3623 | for (i=0;i<SMSInfo.EntriesNum;i++) { |
3624 | switch (SMSInfo.Entries[i].ID) { | 3624 | switch (SMSInfo.Entries[i].ID) { |
3625 | case SMS_ConcatenatedTextLong: | 3625 | case SMS_ConcatenatedTextLong: |
3626 | SMSInfo.Entries[i].ID = SMS_ConcatenatedTextLong16bit; | 3626 | SMSInfo.Entries[i].ID = SMS_ConcatenatedTextLong16bit; |
3627 | default: | 3627 | default: |
3628 | break; | 3628 | break; |
3629 | 3629 | ||
3630 | } | 3630 | } |
3631 | } | 3631 | } |
3632 | 3632 | ||
3633 | } | 3633 | } |
3634 | if (mystrncasecmp(argv[2],"TEXT",0)) { | 3634 | if (mystrncasecmp(argv[2],"TEXT",0)) { |
3635 | chars_read = UnicodeLength(Buffer[0]); | 3635 | chars_read = UnicodeLength(Buffer[0]); |
3636 | if (chars_read != 0) { | 3636 | if (chars_read != 0) { |
3637 | /* Trim \n at the end of string */ | 3637 | /* Trim \n at the end of string */ |
3638 | if (Buffer[0][chars_read*2-1] == '\n' && Buffer[0][chars_read*2-2] == 0) | 3638 | if (Buffer[0][chars_read*2-1] == '\n' && Buffer[0][chars_read*2-2] == 0) |
3639 | { | 3639 | { |
3640 | Buffer[0][chars_read*2-1] = 0; | 3640 | Buffer[0][chars_read*2-1] = 0; |
3641 | } | 3641 | } |
3642 | } | 3642 | } |
3643 | } | 3643 | } |
3644 | 3644 | ||
3645 | if (mystrncasecmp(argv[1],"--displaysms",0) || mystrncasecmp(argv[1],"--sendsmsdsms",0)) { | 3645 | if (mystrncasecmp(argv[1],"--displaysms",0) || mystrncasecmp(argv[1],"--sendsmsdsms",0)) { |
3646 | if (mystrncasecmp(argv[2],"OPERATOR",0)) { | 3646 | if (mystrncasecmp(argv[2],"OPERATOR",0)) { |
3647 | if (bitmap[0].Bitmap[0].Type==GSM_OperatorLogo && strcmp(bitmap[0].Bitmap[0].NetworkCode,"000 00")==0) { | 3647 | if (bitmap[0].Bitmap[0].Type==GSM_OperatorLogo && strcmp(bitmap[0].Bitmap[0].NetworkCode,"000 00")==0) { |
3648 | printmsg("No network code\n"); | 3648 | printmsg("No network code\n"); |
3649 | exit(-1); | 3649 | exit(-1); |
3650 | } | 3650 | } |
3651 | } | 3651 | } |
3652 | } else { | 3652 | } else { |
3653 | GSM_Init(true); | 3653 | GSM_Init(true); |
3654 | 3654 | ||
3655 | if (mystrncasecmp(argv[2],"OPERATOR",0)) { | 3655 | if (mystrncasecmp(argv[2],"OPERATOR",0)) { |
3656 | if (bitmap[0].Bitmap[0].Type==GSM_OperatorLogo && strcmp(bitmap[0].Bitmap[0].NetworkCode,"000 00")==0) { | 3656 | if (bitmap[0].Bitmap[0].Type==GSM_OperatorLogo && strcmp(bitmap[0].Bitmap[0].NetworkCode,"000 00")==0) { |
3657 | error=Phone->GetNetworkInfo(&s,&NetInfo); | 3657 | error=Phone->GetNetworkInfo(&s,&NetInfo); |
3658 | Print_Error(error); | 3658 | Print_Error(error); |
3659 | strcpy(bitmap[0].Bitmap[0].NetworkCode,NetInfo.NetworkCode); | 3659 | strcpy(bitmap[0].Bitmap[0].NetworkCode,NetInfo.NetworkCode); |
3660 | if (mystrncasecmp(argv[1],"--savesms",0)) { | 3660 | if (mystrncasecmp(argv[1],"--savesms",0)) { |
3661 | EncodeUnicode(Sender, "OpLogo",6); | 3661 | EncodeUnicode(Sender, "OpLogo",6); |
3662 | EncodeUnicode(Sender+6*2,bitmap[0].Bitmap[0].NetworkCode,3); | 3662 | EncodeUnicode(Sender+6*2,bitmap[0].Bitmap[0].NetworkCode,3); |
3663 | EncodeUnicode(Sender+6*2+3*2,bitmap[0].Bitmap[0].NetworkCode+4,2); | 3663 | EncodeUnicode(Sender+6*2+3*2,bitmap[0].Bitmap[0].NetworkCode+4,2); |
3664 | if (UnicodeLength(GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode))<GSM_MAX_SMS_NAME_LENGTH-7) { | 3664 | if (UnicodeLength(GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode))<GSM_MAX_SMS_NAME_LENGTH-7) { |
3665 | EncodeUnicode(Name,"OpLogo ",7); | 3665 | EncodeUnicode(Name,"OpLogo ",7); |
3666 | CopyUnicodeString(Name+7*2,GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode)); | 3666 | CopyUnicodeString(Name+7*2,GSM_GetNetworkName(bitmap[0].Bitmap[0].NetworkCode)); |
3667 | } else { | 3667 | } else { |
3668 | CopyUnicodeString(Name,Sender); | 3668 | CopyUnicodeString(Name,Sender); |
3669 | } | 3669 | } |
3670 | } | 3670 | } |
3671 | } | 3671 | } |
3672 | } | 3672 | } |
3673 | } | 3673 | } |
3674 | 3674 | ||
3675 | error=GSM_EncodeMultiPartSMS(&SMSInfo,&sms); | 3675 | error=GSM_EncodeMultiPartSMS(&SMSInfo,&sms); |
3676 | Print_Error(error); | 3676 | Print_Error(error); |
3677 | 3677 | ||
3678 | for (i=0;i<SMSInfo.EntriesNum;i++) { | 3678 | for (i=0;i<SMSInfo.EntriesNum;i++) { |
3679 | switch (SMSInfo.Entries[i].ID) { | 3679 | switch (SMSInfo.Entries[i].ID) { |
3680 | case SMS_NokiaRingtone: | 3680 | case SMS_NokiaRingtone: |
3681 | case SMS_NokiaRingtoneLong: | 3681 | case SMS_NokiaRingtoneLong: |
3682 | case SMS_NokiaProfileLong: | 3682 | case SMS_NokiaProfileLong: |
3683 | case SMS_EMSSound10: | 3683 | case SMS_EMSSound10: |
3684 | case SMS_EMSSound12: | 3684 | case SMS_EMSSound12: |
3685 | case SMS_EMSSonyEricssonSound: | 3685 | case SMS_EMSSonyEricssonSound: |
3686 | case SMS_EMSSound10Long: | 3686 | case SMS_EMSSound10Long: |
3687 | case SMS_EMSSound12Long: | 3687 | case SMS_EMSSound12Long: |
3688 | case SMS_EMSSonyEricssonSoundLong: | 3688 | case SMS_EMSSonyEricssonSoundLong: |
3689 | if (SMSInfo.Entries[i].RingtoneNotes!=SMSInfo.Entries[i].Ringtone->NoteTone.NrCommands) { | 3689 | if (SMSInfo.Entries[i].RingtoneNotes!=SMSInfo.Entries[i].Ringtone->NoteTone.NrCommands) { |
3690 | printmsg("Warning: ringtone too long. %i percent part cut\n", | 3690 | printmsg("Warning: ringtone too long. %i percent part cut\n", |
3691 | (SMSInfo.Entries[i].Ringtone->NoteTone.NrCommands-SMSInfo.Entries[i].RingtoneNotes)*100/SMSInfo.Entries[i].Ringtone->NoteTone.NrCommands); | 3691 | (SMSInfo.Entries[i].Ringtone->NoteTone.NrCommands-SMSInfo.Entries[i].RingtoneNotes)*100/SMSInfo.Entries[i].Ringtone->NoteTone.NrCommands); |
3692 | } | 3692 | } |
3693 | default: | 3693 | default: |
3694 | break; | 3694 | break; |
3695 | 3695 | ||
3696 | } | 3696 | } |
3697 | } | 3697 | } |
3698 | if (MaxSMS != -1 && sms.Number > MaxSMS) { | 3698 | if (MaxSMS != -1 && sms.Number > MaxSMS) { |
3699 | printmsg("There is %i SMS packed and %i limit. Exiting\n",sms.Number,MaxSMS); | 3699 | printmsg("There is %i SMS packed and %i limit. Exiting\n",sms.Number,MaxSMS); |
3700 | if (!mystrncasecmp(argv[1],"--displaysms",0) && !mystrncasecmp(argv[1],"--sendsmsdsms",0)) GSM_Terminate(); | 3700 | if (!mystrncasecmp(argv[1],"--displaysms",0) && !mystrncasecmp(argv[1],"--sendsmsdsms",0)) GSM_Terminate(); |
3701 | exit(-1); | 3701 | exit(-1); |
3702 | } | 3702 | } |
3703 | 3703 | ||
3704 | if (mystrncasecmp(argv[1],"--displaysms",0)) { | 3704 | if (mystrncasecmp(argv[1],"--displaysms",0)) { |
3705 | if (SMSCSet != 0) { | 3705 | if (SMSCSet != 0) { |
3706 | printmsg("Use -smscnumber option to give SMSC number\n"); | 3706 | printmsg("Use -smscnumber option to give SMSC number\n"); |
3707 | exit(-1); | 3707 | exit(-1); |
3708 | } | 3708 | } |
3709 | 3709 | ||
3710 | for (i=0;i<sms.Number;i++) { | 3710 | for (i=0;i<sms.Number;i++) { |
3711 | sms.SMS[i].Location = 0; | 3711 | sms.SMS[i].Location = 0; |
3712 | sms.SMS[i].ReplyViaSameSMSC = ReplyViaSameSMSC; | 3712 | sms.SMS[i].ReplyViaSameSMSC = ReplyViaSameSMSC; |
3713 | sms.SMS[i].SMSC.Location = 0; | 3713 | sms.SMS[i].SMSC.Location = 0; |
3714 | sms.SMS[i].PDU = SMS_Submit; | 3714 | sms.SMS[i].PDU = SMS_Submit; |
3715 | if (DeliveryReport) sms.SMS[i].PDU= SMS_Status_Report; | 3715 | if (DeliveryReport) sms.SMS[i].PDU= SMS_Status_Report; |
3716 | CopyUnicodeString(sms.SMS[i].Number, Sender); | 3716 | CopyUnicodeString(sms.SMS[i].Number, Sender); |
3717 | CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); | 3717 | CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); |
3718 | if (Validity.Format != 0) memcpy(&sms.SMS[i].SMSC.Validity,&Validity,sizeof(GSM_SMSValidity)); | 3718 | if (Validity.Format != 0) memcpy(&sms.SMS[i].SMSC.Validity,&Validity,sizeof(GSM_SMSValidity)); |
3719 | DisplaySMSFrame(&sms.SMS[i]); | 3719 | DisplaySMSFrame(&sms.SMS[i]); |
3720 | } | 3720 | } |
3721 | 3721 | ||
3722 | printmsg("\nNumber of SMS: %i\n",sms.Number); | 3722 | printmsg("\nNumber of SMS: %i\n",sms.Number); |
3723 | exit(sms.Number); | 3723 | exit(sms.Number); |
3724 | } | 3724 | } |
3725 | if (mystrncasecmp(argv[1],"--sendsmsdsms",0)) { | 3725 | if (mystrncasecmp(argv[1],"--sendsmsdsms",0)) { |
3726 | if (SMSCSet != 0) { | 3726 | if (SMSCSet != 0) { |
3727 | printmsg("Use -smscnumber option to give SMSC number\n"); | 3727 | printmsg("Use -smscnumber option to give SMSC number\n"); |
3728 | exit(-1); | 3728 | exit(-1); |
3729 | } | 3729 | } |
3730 | 3730 | ||
3731 | for (i=0;i<sms.Number;i++) { | 3731 | for (i=0;i<sms.Number;i++) { |
3732 | sms.SMS[i].Location = 0; | 3732 | sms.SMS[i].Location = 0; |
3733 | sms.SMS[i].ReplyViaSameSMSC = ReplyViaSameSMSC; | 3733 | sms.SMS[i].ReplyViaSameSMSC = ReplyViaSameSMSC; |
3734 | sms.SMS[i].SMSC.Location = 0; | 3734 | sms.SMS[i].SMSC.Location = 0; |
3735 | sms.SMS[i].PDU = SMS_Submit; | 3735 | sms.SMS[i].PDU = SMS_Submit; |
3736 | if (DeliveryReport) sms.SMS[i].PDU= SMS_Status_Report; | 3736 | if (DeliveryReport) sms.SMS[i].PDU= SMS_Status_Report; |
3737 | CopyUnicodeString(sms.SMS[i].Number, Sender); | 3737 | CopyUnicodeString(sms.SMS[i].Number, Sender); |
3738 | CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); | 3738 | CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); |
3739 | if (Validity.Format != 0) memcpy(&sms.SMS[i].SMSC.Validity,&Validity,sizeof(GSM_SMSValidity)); | 3739 | if (Validity.Format != 0) memcpy(&sms.SMS[i].SMSC.Validity,&Validity,sizeof(GSM_SMSValidity)); |
3740 | } | 3740 | } |
3741 | SMSDaemonSendSMS(argv[4],argv[5],&sms); | 3741 | SMSDaemonSendSMS(argv[4],argv[5],&sms); |
3742 | exit(0); | 3742 | exit(0); |
3743 | } | 3743 | } |
3744 | if (mystrncasecmp(argv[1],"--savesms",0) || SendSaved) { | 3744 | if (mystrncasecmp(argv[1],"--savesms",0) || SendSaved) { |
3745 | error=Phone->GetSMSFolders(&s, &folders); | 3745 | error=Phone->GetSMSFolders(&s, &folders); |
3746 | Print_Error(error); | 3746 | Print_Error(error); |
3747 | 3747 | ||
3748 | if (SendSaved){ | 3748 | if (SendSaved){ |
3749 | if (Validity.Format != 0 && SMSCSet != 0) { | 3749 | if (Validity.Format != 0 && SMSCSet != 0) { |
3750 | PhoneSMSC.Location = SMSCSet; | 3750 | PhoneSMSC.Location = SMSCSet; |
3751 | error=Phone->GetSMSC(&s,&PhoneSMSC); | 3751 | error=Phone->GetSMSC(&s,&PhoneSMSC); |
3752 | Print_Error(error); | 3752 | Print_Error(error); |
3753 | CopyUnicodeString(SMSC,PhoneSMSC.Number); | 3753 | CopyUnicodeString(SMSC,PhoneSMSC.Number); |
3754 | SMSCSet = 0; | 3754 | SMSCSet = 0; |
3755 | } | 3755 | } |
3756 | 3756 | ||
3757 | s.User.SendSMSStatus = SendSMSStatus; | 3757 | s.User.SendSMSStatus = SendSMSStatus; |
3758 | 3758 | ||
3759 | signal(SIGINT, interrupt); | 3759 | signal(SIGINT, interrupt); |
3760 | printmsgerr("If you want break, press Ctrl+C...\n"); | 3760 | printmsgerr("If you want break, press Ctrl+C...\n"); |
3761 | } | 3761 | } |
3762 | 3762 | ||
3763 | for (i=0;i<sms.Number;i++) { | 3763 | for (i=0;i<sms.Number;i++) { |
3764 | printmsg("Saving SMS %i/%i\n",i+1,sms.Number); | 3764 | printmsg("Saving SMS %i/%i\n",i+1,sms.Number); |
3765 | // sms.SMS[i].Location = 0; | 3765 | // sms.SMS[i].Location = 0; |
3766 | sms.SMS[i].Folder = Folder; | 3766 | sms.SMS[i].Folder = Folder; |
3767 | sms.SMS[i].State = State; | 3767 | sms.SMS[i].State = State; |
3768 | sms.SMS[i].ReplyViaSameSMSC= ReplyViaSameSMSC; | 3768 | sms.SMS[i].ReplyViaSameSMSC= ReplyViaSameSMSC; |
3769 | sms.SMS[i].SMSC.Location= SMSCSet; | 3769 | sms.SMS[i].SMSC.Location= SMSCSet; |
3770 | 3770 | ||
3771 | if (SendSaved){ | 3771 | if (SendSaved){ |
3772 | sms.SMS[i].PDU= SMS_Submit; | 3772 | sms.SMS[i].PDU= SMS_Submit; |
3773 | if (DeliveryReport) sms.SMS[i].PDU = SMS_Status_Report; | 3773 | if (DeliveryReport) sms.SMS[i].PDU = SMS_Status_Report; |
3774 | if (Validity.Format != 0) sms.SMS[i].SMSC.Validity = Validity; | 3774 | if (Validity.Format != 0) sms.SMS[i].SMSC.Validity = Validity; |
3775 | } else { | 3775 | } else { |
3776 | sms.SMS[i].PDU= SMS_Deliver; | 3776 | sms.SMS[i].PDU= SMS_Deliver; |
3777 | } | 3777 | } |
3778 | 3778 | ||
3779 | CopyUnicodeString(sms.SMS[i].Number, Sender); | 3779 | CopyUnicodeString(sms.SMS[i].Number, Sender); |
3780 | CopyUnicodeString(sms.SMS[i].Name, Name); | 3780 | CopyUnicodeString(sms.SMS[i].Name, Name); |
3781 | if (SMSCSet==0) CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); | 3781 | if (SMSCSet==0) CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); |
3782 | error=Phone->AddSMS(&s, &sms.SMS[i]); | 3782 | error=Phone->AddSMS(&s, &sms.SMS[i]); |
3783 | Print_Error(error); | 3783 | Print_Error(error); |
3784 | printmsg("Saved in folder \"%s\", location %i\n", | 3784 | printmsg("Saved in folder \"%s\", location %i\n", |
3785 | DecodeUnicodeConsole(folders.Folder[sms.SMS[i].Folder-1].Name),sms.SMS[i].Location); | 3785 | DecodeUnicodeConsole(folders.Folder[sms.SMS[i].Folder-1].Name),sms.SMS[i].Location); |
3786 | 3786 | ||
3787 | if (SendSaved) { | 3787 | if (SendSaved) { |
3788 | printmsg("Sending sms from folder \"%s\", location %i\n", | 3788 | printmsg("Sending sms from folder \"%s\", location %i\n", |
3789 | DecodeUnicodeString(folders.Folder[sms.SMS[i].Folder-1].Name),sms.SMS[i].Location); | 3789 | DecodeUnicodeString(folders.Folder[sms.SMS[i].Folder-1].Name),sms.SMS[i].Location); |
3790 | SMSStatus = ERR_TIMEOUT; | 3790 | SMSStatus = ERR_TIMEOUT; |
3791 | error=Phone->SendSavedSMS(&s, 0, sms.SMS[i].Location); | 3791 | error=Phone->SendSavedSMS(&s, 0, sms.SMS[i].Location); |
3792 | Print_Error(error); | 3792 | Print_Error(error); |
3793 | printmsg("....waiting for network answer"); | 3793 | printmsg("....waiting for network answer"); |
3794 | while (!gshutdown) { | 3794 | while (!gshutdown) { |
3795 | GSM_ReadDevice(&s,true); | 3795 | GSM_ReadDevice(&s,true); |
3796 | if (SMSStatus == ERR_UNKNOWN) { | 3796 | if (SMSStatus == ERR_UNKNOWN) { |
3797 | GSM_Terminate(); | 3797 | GSM_Terminate(); |
3798 | exit(-1); | 3798 | exit(-1); |
3799 | } | 3799 | } |
3800 | if (SMSStatus == ERR_NONE) break; | 3800 | if (SMSStatus == ERR_NONE) break; |
3801 | } | 3801 | } |
3802 | } | 3802 | } |
3803 | } | 3803 | } |
3804 | } else { | 3804 | } else { |
3805 | if (Validity.Format != 0 && SMSCSet != 0) { | 3805 | if (Validity.Format != 0 && SMSCSet != 0) { |
3806 | PhoneSMSC.Location = SMSCSet; | 3806 | PhoneSMSC.Location = SMSCSet; |
3807 | error=Phone->GetSMSC(&s,&PhoneSMSC); | 3807 | error=Phone->GetSMSC(&s,&PhoneSMSC); |
3808 | Print_Error(error); | 3808 | Print_Error(error); |
3809 | CopyUnicodeString(SMSC,PhoneSMSC.Number); | 3809 | CopyUnicodeString(SMSC,PhoneSMSC.Number); |
3810 | SMSCSet = 0; | 3810 | SMSCSet = 0; |
3811 | } | 3811 | } |
3812 | 3812 | ||
3813 | signal(SIGINT, interrupt); | 3813 | signal(SIGINT, interrupt); |
3814 | printmsgerr("If you want break, press Ctrl+C...\n"); | 3814 | printmsgerr("If you want break, press Ctrl+C...\n"); |
3815 | 3815 | ||
3816 | s.User.SendSMSStatus = SendSMSStatus; | 3816 | s.User.SendSMSStatus = SendSMSStatus; |
3817 | 3817 | ||
3818 | for (i=0;i<sms.Number;i++) { | 3818 | for (i=0;i<sms.Number;i++) { |
3819 | printmsg("Sending SMS %i/%i",i+1,sms.Number); | 3819 | printmsg("Sending SMS %i/%i",i+1,sms.Number); |
3820 | sms.SMS[i].Location = 0; | 3820 | sms.SMS[i].Location = 0; |
3821 | sms.SMS[i].ReplyViaSameSMSC = ReplyViaSameSMSC; | 3821 | sms.SMS[i].ReplyViaSameSMSC = ReplyViaSameSMSC; |
3822 | sms.SMS[i].SMSC.Location = SMSCSet; | 3822 | sms.SMS[i].SMSC.Location = SMSCSet; |
3823 | sms.SMS[i].PDU = SMS_Submit; | 3823 | sms.SMS[i].PDU = SMS_Submit; |
3824 | if (DeliveryReport) sms.SMS[i].PDU= SMS_Status_Report; | 3824 | if (DeliveryReport) sms.SMS[i].PDU= SMS_Status_Report; |
3825 | CopyUnicodeString(sms.SMS[i].Number, Sender); | 3825 | CopyUnicodeString(sms.SMS[i].Number, Sender); |
3826 | if (SMSCSet==0) CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); | 3826 | if (SMSCSet==0) CopyUnicodeString(sms.SMS[i].SMSC.Number, SMSC); |
3827 | if (Validity.Format != 0) memcpy(&sms.SMS[i].SMSC.Validity,&Validity,sizeof(GSM_SMSValidity)); | 3827 | if (Validity.Format != 0) memcpy(&sms.SMS[i].SMSC.Validity,&Validity,sizeof(GSM_SMSValidity)); |
3828 | SMSStatus = ERR_TIMEOUT; | 3828 | SMSStatus = ERR_TIMEOUT; |
3829 | error=Phone->SendSMS(&s, &sms.SMS[i]); | 3829 | error=Phone->SendSMS(&s, &sms.SMS[i]); |
3830 | Print_Error(error); | 3830 | Print_Error(error); |
3831 | printmsg("....waiting for network answer"); | 3831 | printmsg("....waiting for network answer"); |
3832 | while (!gshutdown) { | 3832 | while (!gshutdown) { |
3833 | GSM_ReadDevice(&s,true); | 3833 | GSM_ReadDevice(&s,true); |
3834 | if (SMSStatus == ERR_UNKNOWN) { | 3834 | if (SMSStatus == ERR_UNKNOWN) { |
3835 | GSM_Terminate(); | 3835 | GSM_Terminate(); |
3836 | exit(-1); | 3836 | exit(-1); |
3837 | } | 3837 | } |
3838 | if (SMSStatus == ERR_NONE) break; | 3838 | if (SMSStatus == ERR_NONE) break; |
3839 | } | 3839 | } |
3840 | } | 3840 | } |
3841 | } | 3841 | } |
3842 | 3842 | ||
3843 | GSM_Terminate(); | 3843 | GSM_Terminate(); |
3844 | } | 3844 | } |
3845 | 3845 | ||
3846 | #ifdef GSM_ENABLE_BACKUP | 3846 | #ifdef GSM_ENABLE_BACKUP |
3847 | static void SaveFile(int argc, char *argv[]) | 3847 | static void SaveFile(int argc, char *argv[]) |
3848 | { | 3848 | { |
3849 | GSM_Backup Backup; | 3849 | GSM_Backup Backup; |
3850 | int i,j; | 3850 | int i,j; |
3851 | FILE *file; | 3851 | FILE *file; |
3852 | unsigned char Buffer[10000]; | 3852 | unsigned char Buffer[10000]; |
3853 | GSM_MemoryEntry *pbk; | 3853 | GSM_MemoryEntry *pbk; |
3854 | 3854 | ||
3855 | if (mystrncasecmp(argv[2],"CALENDAR",0)) { | 3855 | if (mystrncasecmp(argv[2],"CALENDAR",0)) { |
3856 | if (argc<5) { | 3856 | if (argc<5) { |
3857 | printmsg("Where is backup filename and location ?\n"); | 3857 | printmsg("Where is backup filename and location ?\n"); |
3858 | exit(-1); | 3858 | exit(-1); |
3859 | } | 3859 | } |
3860 | error=GSM_ReadBackupFile(argv[4],&Backup); | 3860 | error=GSM_ReadBackupFile(argv[4],&Backup); |
3861 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); | 3861 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); |
3862 | i = 0; | 3862 | i = 0; |
3863 | while (Backup.Calendar[i]!=NULL) { | 3863 | while (Backup.Calendar[i]!=NULL) { |
3864 | if (i == atoi(argv[5])-1) break; | 3864 | if (i == atoi(argv[5])-1) break; |
3865 | i++; | 3865 | i++; |
3866 | } | 3866 | } |
3867 | if (i != atoi(argv[5])-1) { | 3867 | if (i != atoi(argv[5])-1) { |
3868 | printmsg("Calendar note not found in file\n"); | 3868 | printmsg("Calendar note not found in file\n"); |
3869 | exit(-1); | 3869 | exit(-1); |
3870 | } | 3870 | } |
3871 | j = 0; | 3871 | j = 0; |
3872 | GSM_EncodeVCALENDAR(Buffer, &j, Backup.Calendar[i],true,Nokia_VCalendar); | 3872 | GSM_EncodeVCALENDAR(Buffer, &j, Backup.Calendar[i],true,Nokia_VCalendar); |
3873 | } else if (mystrncasecmp(argv[2],"BOOKMARK",0)) { | 3873 | } else if (mystrncasecmp(argv[2],"BOOKMARK",0)) { |
3874 | if (argc<5) { | 3874 | if (argc<5) { |
3875 | printmsg("Where is backup filename and location ?\n"); | 3875 | printmsg("Where is backup filename and location ?\n"); |
3876 | exit(-1); | 3876 | exit(-1); |
3877 | } | 3877 | } |
3878 | error=GSM_ReadBackupFile(argv[4],&Backup); | 3878 | error=GSM_ReadBackupFile(argv[4],&Backup); |
3879 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); | 3879 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); |
3880 | i = 0; | 3880 | i = 0; |
3881 | while (Backup.WAPBookmark[i]!=NULL) { | 3881 | while (Backup.WAPBookmark[i]!=NULL) { |
3882 | if (i == atoi(argv[5])-1) break; | 3882 | if (i == atoi(argv[5])-1) break; |
3883 | i++; | 3883 | i++; |
3884 | } | 3884 | } |
3885 | if (i != atoi(argv[5])-1) { | 3885 | if (i != atoi(argv[5])-1) { |
3886 | printmsg("WAP bookmark not found in file\n"); | 3886 | printmsg("WAP bookmark not found in file\n"); |
3887 | exit(-1); | 3887 | exit(-1); |
3888 | } | 3888 | } |
3889 | j = 0; | 3889 | j = 0; |
3890 | GSM_EncodeURLFile(Buffer, &j, Backup.WAPBookmark[i]); | 3890 | GSM_EncodeURLFile(Buffer, &j, Backup.WAPBookmark[i]); |
3891 | } else if (mystrncasecmp(argv[2],"NOTE",0)) { | 3891 | } else if (mystrncasecmp(argv[2],"NOTE",0)) { |
3892 | if (argc<5) { | 3892 | if (argc<5) { |
3893 | printmsg("Where is backup filename and location ?\n"); | 3893 | printmsg("Where is backup filename and location ?\n"); |
3894 | exit(-1); | 3894 | exit(-1); |
3895 | } | 3895 | } |
3896 | error=GSM_ReadBackupFile(argv[4],&Backup); | 3896 | error=GSM_ReadBackupFile(argv[4],&Backup); |
3897 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); | 3897 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); |
3898 | i = 0; | 3898 | i = 0; |
3899 | while (Backup.Note[i]!=NULL) { | 3899 | while (Backup.Note[i]!=NULL) { |
3900 | if (i == atoi(argv[5])-1) break; | 3900 | if (i == atoi(argv[5])-1) break; |
3901 | i++; | 3901 | i++; |
3902 | } | 3902 | } |
3903 | if (i != atoi(argv[5])-1) { | 3903 | if (i != atoi(argv[5])-1) { |
3904 | printmsg("Note not found in file\n"); | 3904 | printmsg("Note not found in file\n"); |
3905 | exit(-1); | 3905 | exit(-1); |
3906 | } | 3906 | } |
3907 | j = 0; | 3907 | j = 0; |
3908 | GSM_EncodeVNTFile(Buffer, &j, Backup.Note[i]); | 3908 | GSM_EncodeVNTFile(Buffer, &j, Backup.Note[i]); |
3909 | } else if (mystrncasecmp(argv[2],"TODO",0)) { | 3909 | } else if (mystrncasecmp(argv[2],"TODO",0)) { |
3910 | if (argc<5) { | 3910 | if (argc<5) { |
3911 | printmsg("Where is backup filename and location ?\n"); | 3911 | printmsg("Where is backup filename and location ?\n"); |
3912 | exit(-1); | 3912 | exit(-1); |
3913 | } | 3913 | } |
3914 | error=GSM_ReadBackupFile(argv[4],&Backup); | 3914 | error=GSM_ReadBackupFile(argv[4],&Backup); |
3915 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); | 3915 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); |
3916 | i = 0; | 3916 | i = 0; |
3917 | while (Backup.ToDo[i]!=NULL) { | 3917 | while (Backup.ToDo[i]!=NULL) { |
3918 | if (i == atoi(argv[5])-1) break; | 3918 | if (i == atoi(argv[5])-1) break; |
3919 | i++; | 3919 | i++; |
3920 | } | 3920 | } |
3921 | if (i != atoi(argv[5])-1) { | 3921 | if (i != atoi(argv[5])-1) { |
3922 | printmsg("ToDo note not found in file\n"); | 3922 | printmsg("ToDo note not found in file\n"); |
3923 | exit(-1); | 3923 | exit(-1); |
3924 | } | 3924 | } |
3925 | j = 0; | 3925 | j = 0; |
3926 | GSM_EncodeVTODO(Buffer, &j, Backup.ToDo[i], true, Nokia_VToDo); | 3926 | GSM_EncodeVTODO(Buffer, &j, Backup.ToDo[i], true, Nokia_VToDo); |
3927 | } else if (mystrncasecmp(argv[2],"VCARD10",0) || mystrncasecmp(argv[2],"VCARD21",0)) { | 3927 | } else if (mystrncasecmp(argv[2],"VCARD10",0) || mystrncasecmp(argv[2],"VCARD21",0)) { |
3928 | if (argc<6) { | 3928 | if (argc<6) { |
3929 | printmsg("Where is backup filename and location and memory type ?\n"); | 3929 | printmsg("Where is backup filename and location and memory type ?\n"); |
3930 | exit(-1); | 3930 | exit(-1); |
3931 | } | 3931 | } |
3932 | error=GSM_ReadBackupFile(argv[4],&Backup); | 3932 | error=GSM_ReadBackupFile(argv[4],&Backup); |
3933 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); | 3933 | if (error!=ERR_NOTIMPLEMENTED) Print_Error(error); |
3934 | i = 0; | 3934 | i = 0; |
3935 | if (mystrncasecmp(argv[5],"SM",0)) { | 3935 | if (mystrncasecmp(argv[5],"SM",0)) { |
3936 | while (Backup.SIMPhonebook[i]!=NULL) { | 3936 | while (Backup.SIMPhonebook[i]!=NULL) { |
3937 | if (i == atoi(argv[6])-1) break; | 3937 | if (i == atoi(argv[6])-1) break; |
3938 | i++; | 3938 | i++; |
3939 | } | 3939 | } |
3940 | if (i != atoi(argv[6])-1) { | 3940 | if (i != atoi(argv[6])-1) { |
3941 | printmsg("Phonebook entry not found in file\n"); | 3941 | printmsg("Phonebook entry not found in file\n"); |
3942 | exit(-1); | 3942 | exit(-1); |
3943 | } | 3943 | } |
3944 | pbk = Backup.SIMPhonebook[i]; | 3944 | pbk = Backup.SIMPhonebook[i]; |
3945 | } else if (mystrncasecmp(argv[5],"ME",0)) { | 3945 | } else if (mystrncasecmp(argv[5],"ME",0)) { |
3946 | while (Backup.PhonePhonebook[i]!=NULL) { | 3946 | while (Backup.PhonePhonebook[i]!=NULL) { |
3947 | if (i == atoi(argv[6])-1) break; | 3947 | if (i == atoi(argv[6])-1) break; |
3948 | i++; | 3948 | i++; |
3949 | } | 3949 | } |
3950 | if (i != atoi(argv[6])-1) { | 3950 | if (i != atoi(argv[6])-1) { |
3951 | printmsg("Phonebook entry not found in file\n"); | 3951 | printmsg("Phonebook entry not found in file\n"); |
3952 | exit(-1); | 3952 | exit(-1); |
3953 | } | 3953 | } |
3954 | pbk = Backup.PhonePhonebook[i]; | 3954 | pbk = Backup.PhonePhonebook[i]; |
3955 | } else { | 3955 | } else { |
3956 | printmsg("Unknown memory type: \"%s\"\n",argv[5]); | 3956 | printmsg("Unknown memory type: \"%s\"\n",argv[5]); |
3957 | exit(-1); | 3957 | exit(-1); |
3958 | } | 3958 | } |
3959 | j = 0; | 3959 | j = 0; |
3960 | if (mystrncasecmp(argv[2],"VCARD10",0)) { | 3960 | if (mystrncasecmp(argv[2],"VCARD10",0)) { |
3961 | GSM_EncodeVCARD(Buffer,&j,pbk,true,Nokia_VCard10); | 3961 | GSM_EncodeVCARD(Buffer,&j,pbk,true,Nokia_VCard10); |
3962 | } else { | 3962 | } else { |
3963 | GSM_EncodeVCARD(Buffer,&j,pbk,true,Nokia_VCard21); | 3963 | GSM_EncodeVCARD(Buffer,&j,pbk,true,Nokia_VCard21); |
3964 | } | 3964 | } |
3965 | } else { | 3965 | } else { |
3966 | printmsg("What format of file (\"%s\") ?\n",argv[2]); | 3966 | printmsg("What format of file (\"%s\") ?\n",argv[2]); |
3967 | exit(-1); | 3967 | exit(-1); |
3968 | } | 3968 | } |
3969 | 3969 | ||
3970 | file = fopen(argv[3],"wb"); | 3970 | file = fopen(argv[3],"wb"); |
3971 | fwrite(Buffer,1,j,file); | 3971 | fwrite(Buffer,1,j,file); |
3972 | fclose(file); | 3972 | fclose(file); |
3973 | } | 3973 | } |
3974 | 3974 | ||
3975 | static void Backup(int argc, char *argv[]) | 3975 | static void Backup(int argc, char *argv[]) |
3976 | { | 3976 | { |
3977 | int i, used; | 3977 | int i, used; |
3978 | GSM_MemoryStatusMemStatus; | 3978 | GSM_MemoryStatusMemStatus; |
3979 | GSM_ToDoEntry ToDo; | 3979 | GSM_ToDoEntry ToDo; |
3980 | GSM_ToDoStatus ToDoStatus; | 3980 | GSM_ToDoStatus ToDoStatus; |
3981 | GSM_MemoryEntry Pbk; | 3981 | GSM_MemoryEntry Pbk; |
3982 | GSM_CalendarEntryCalendar; | 3982 | GSM_CalendarEntryCalendar; |
3983 | GSM_Bitmap Bitmap; | 3983 | GSM_Bitmap Bitmap; |
3984 | GSM_WAPBookmark Bookmark; | 3984 | GSM_WAPBookmark Bookmark; |
3985 | GSM_Profile Profile; | 3985 | GSM_Profile Profile; |
3986 | GSM_MultiWAPSettingsSettings; | 3986 | GSM_MultiWAPSettingsSettings; |
3987 | GSM_SyncMLSettingsSyncML; | 3987 | GSM_SyncMLSettingsSyncML; |
3988 | GSM_ChatSettingsChat; | 3988 | GSM_ChatSettingsChat; |
3989 | GSM_Ringtone Ringtone; | 3989 | GSM_Ringtone Ringtone; |
3990 | GSM_SMSC SMSC; | 3990 | GSM_SMSC SMSC; |
3991 | GSM_Backup Backup; | 3991 | GSM_Backup Backup; |
3992 | GSM_NoteEntry Note; | 3992 | GSM_NoteEntry Note; |
3993 | GSM_Backup_Info Info; | 3993 | GSM_Backup_Info Info; |
3994 | GSM_FMStation FMStation; | 3994 | GSM_FMStation FMStation; |
3995 | GSM_GPRSAccessPointGPRSPoint; | 3995 | GSM_GPRSAccessPointGPRSPoint; |
3996 | bool DoBackup; | 3996 | bool DoBackup; |
3997 | 3997 | ||
3998 | if (argc == 4 && mystrncasecmp(argv[3],"-yes",0)) always_answer_yes = true; | 3998 | if (argc == 4 && mystrncasecmp(argv[3],"-yes",0)) always_answer_yes = true; |
3999 | 3999 | ||
4000 | GSM_ClearBackup(&Backup); | 4000 | GSM_ClearBackup(&Backup); |
4001 | GSM_GetBackupFormatFeatures(argv[2],&Info); | 4001 | GSM_GetBackupFormatFeatures(argv[2],&Info); |
4002 | 4002 | ||
4003 | sprintf(Backup.Creator,"Gammu %s",VERSION); | 4003 | sprintf(Backup.Creator,"Gammu %s",VERSION); |
4004 | if (strlen(GetOS()) != 0) { | 4004 | if (strlen(GetOS()) != 0) { |
4005 | strcat(Backup.Creator+strlen(Backup.Creator),", "); | 4005 | strcat(Backup.Creator+strlen(Backup.Creator),", "); |
4006 | strcat(Backup.Creator+strlen(Backup.Creator),GetOS()); | 4006 | strcat(Backup.Creator+strlen(Backup.Creator),GetOS()); |
4007 | } | 4007 | } |
4008 | if (strlen(GetCompiler()) != 0) { | 4008 | if (strlen(GetCompiler()) != 0) { |
4009 | strcat(Backup.Creator+strlen(Backup.Creator),", "); | 4009 | strcat(Backup.Creator+strlen(Backup.Creator),", "); |
4010 | strcat(Backup.Creator+strlen(Backup.Creator),GetCompiler()); | 4010 | strcat(Backup.Creator+strlen(Backup.Creator),GetCompiler()); |
4011 | } | 4011 | } |
4012 | 4012 | ||
4013 | signal(SIGINT, interrupt); | 4013 | signal(SIGINT, interrupt); |
4014 | printmsgerr("Press Ctrl+C to break...\n"); | 4014 | printmsgerr("Press Ctrl+C to break...\n"); |
4015 | 4015 | ||
4016 | GSM_Init(true); | 4016 | GSM_Init(true); |
4017 | 4017 | ||
4018 | if (Info.UseUnicode) { | 4018 | if (Info.UseUnicode) { |
4019 | Info.UseUnicode=answer_yes("Use Unicode subformat of backup file"); | 4019 | Info.UseUnicode=answer_yes("Use Unicode subformat of backup file"); |
4020 | } | 4020 | } |
4021 | if (Info.DateTime) { | 4021 | if (Info.DateTime) { |
4022 | GSM_GetCurrentDateTime (&Backup.DateTime); | 4022 | GSM_GetCurrentDateTime (&Backup.DateTime); |
4023 | Backup.DateTimeAvailable=true; | 4023 | Backup.DateTimeAvailable=true; |
4024 | } | 4024 | } |
4025 | if (Info.Model) { | 4025 | if (Info.Model) { |
4026 | error=Phone->GetManufacturer(&s); | 4026 | error=Phone->GetManufacturer(&s); |
4027 | Print_Error(error); | 4027 | Print_Error(error); |
4028 | sprintf(Backup.Model,"%s ",s.Phone.Data.Manufacturer); | 4028 | sprintf(Backup.Model,"%s ",s.Phone.Data.Manufacturer); |
4029 | if (s.Phone.Data.ModelInfo->model[0]!=0) { | 4029 | if (s.Phone.Data.ModelInfo->model[0]!=0) { |
4030 | strcat(Backup.Model,s.Phone.Data.ModelInfo->model); | 4030 | strcat(Backup.Model,s.Phone.Data.ModelInfo->model); |
4031 | } else { | 4031 | } else { |
4032 | strcat(Backup.Model,s.Phone.Data.Model); | 4032 | strcat(Backup.Model,s.Phone.Data.Model); |
4033 | } | 4033 | } |
4034 | strcat(Backup.Model," "); | 4034 | strcat(Backup.Model," "); |
4035 | strcat(Backup.Model,s.Phone.Data.Version); | 4035 | strcat(Backup.Model,s.Phone.Data.Version); |
4036 | } | 4036 | } |
4037 | if (Info.IMEI) { | 4037 | if (Info.IMEI) { |
4038 | error=Phone->GetIMEI(&s); | 4038 | error=Phone->GetIMEI(&s); |
4039 | if (error != ERR_NOTSUPPORTED) { | 4039 | if (error != ERR_NOTSUPPORTED) { |
4040 | strcpy(Backup.IMEI, s.Phone.Data.IMEI); | 4040 | strcpy(Backup.IMEI, s.Phone.Data.IMEI); |
4041 | Print_Error(error); | 4041 | Print_Error(error); |
4042 | } else { | 4042 | } else { |
4043 | Backup.IMEI[0] = 0; | 4043 | Backup.IMEI[0] = 0; |
4044 | } | 4044 | } |
4045 | } | 4045 | } |
4046 | printf("\n"); | 4046 | printf("\n"); |
4047 | 4047 | ||
4048 | DoBackup = false; | 4048 | DoBackup = false; |
4049 | if (Info.PhonePhonebook) { | 4049 | if (Info.PhonePhonebook) { |
4050 | printmsg("Checking phone phonebook\n"); | 4050 | printmsg("Checking phone phonebook\n"); |
4051 | MemStatus.MemoryType = MEM_ME; | 4051 | MemStatus.MemoryType = MEM_ME; |
4052 | error=Phone->GetMemoryStatus(&s, &MemStatus); | 4052 | error=Phone->GetMemoryStatus(&s, &MemStatus); |
4053 | if (error==ERR_NONE && MemStatus.MemoryUsed != 0) { | 4053 | if (error==ERR_NONE && MemStatus.MemoryUsed != 0) { |
4054 | if (answer_yes(" Backup phone phonebook")) DoBackup = true; | 4054 | /*LRif (answer_yes(" Backup phone phonebook")) */DoBackup = true; |
4055 | } | 4055 | } |
4056 | } | 4056 | } |
4057 | if (DoBackup) { | 4057 | if (DoBackup) { |
4058 | Pbk.MemoryType = MEM_ME; | 4058 | Pbk.MemoryType = MEM_ME; |
4059 | i = 1; | 4059 | i = 1; |
4060 | used = 0; | 4060 | used = 0; |
4061 | while (used != MemStatus.MemoryUsed) { | 4061 | while (used != MemStatus.MemoryUsed) { |
4062 | Pbk.Location = i; | 4062 | Pbk.Location = i; |
4063 | error=Phone->GetMemory(&s, &Pbk); | 4063 | error=Phone->GetMemory(&s, &Pbk); |
4064 | if (error != ERR_EMPTY) { | 4064 | if (error != ERR_EMPTY) { |
4065 | Print_Error(error); | 4065 | Print_Error(error); |
4066 | if (used < GSM_BACKUP_MAX_PHONEPHONEBOOK) { | 4066 | if (used < GSM_BACKUP_MAX_PHONEPHONEBOOK) { |
4067 | Backup.PhonePhonebook[used] = malloc(sizeof(GSM_MemoryEntry)); | 4067 | Backup.PhonePhonebook[used] = malloc(sizeof(GSM_MemoryEntry)); |
4068 | if (Backup.PhonePhonebook[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4068 | if (Backup.PhonePhonebook[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4069 | Backup.PhonePhonebook[used+1] = NULL; | 4069 | Backup.PhonePhonebook[used+1] = NULL; |
4070 | } else { | 4070 | } else { |
4071 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_PHONEPHONEBOOK"); | 4071 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_PHONEPHONEBOOK"); |
4072 | GSM_Terminate(); | 4072 | GSM_Terminate(); |
4073 | exit(-1); | 4073 | exit(-1); |
4074 | } | 4074 | } |
4075 | *Backup.PhonePhonebook[used]=Pbk; | 4075 | *Backup.PhonePhonebook[used]=Pbk; |
4076 | used++; | 4076 | used++; |
4077 | } | 4077 | } |
4078 | printmsgerr("%c Reading: %i percent",13,used*100/MemStatus.MemoryUsed); | 4078 | printmsgerr("%c Reading: %i percent",13,used*100/MemStatus.MemoryUsed); |
4079 | i++; | 4079 | i++; |
4080 | if (gshutdown) { | 4080 | if (gshutdown) { |
4081 | GSM_Terminate(); | 4081 | GSM_Terminate(); |
4082 | exit(0); | 4082 | exit(0); |
4083 | } | 4083 | } |
4084 | } | 4084 | } |
4085 | printmsgerr("\n"); | 4085 | printmsgerr("\n"); |
4086 | } | 4086 | } |
4087 | DoBackup = false; | 4087 | DoBackup = false; |
4088 | if (Info.SIMPhonebook) { | 4088 | if (Info.SIMPhonebook) { |
4089 | printmsg("Checking SIM phonebook\n"); | 4089 | printmsg("Checking SIM phonebook\n"); |
4090 | MemStatus.MemoryType = MEM_SM; | 4090 | MemStatus.MemoryType = MEM_SM; |
4091 | error=Phone->GetMemoryStatus(&s, &MemStatus); | 4091 | error=Phone->GetMemoryStatus(&s, &MemStatus); |
4092 | if (error==ERR_NONE && MemStatus.MemoryUsed != 0) { | 4092 | if (error==ERR_NONE && MemStatus.MemoryUsed != 0) { |
4093 | if (answer_yes(" Backup SIM phonebook")) DoBackup=true; | 4093 | if (answer_yes(" Backup SIM phonebook")) DoBackup=true; |
4094 | } | 4094 | } |
4095 | } | 4095 | } |
4096 | if (DoBackup) { | 4096 | if (DoBackup) { |
4097 | Pbk.MemoryType = MEM_SM; | 4097 | Pbk.MemoryType = MEM_SM; |
4098 | i = 1; | 4098 | i = 1; |
4099 | used = 0; | 4099 | used = 0; |
4100 | while (used != MemStatus.MemoryUsed) { | 4100 | while (used != MemStatus.MemoryUsed) { |
4101 | Pbk.Location = i; | 4101 | Pbk.Location = i; |
4102 | error=Phone->GetMemory(&s, &Pbk); | 4102 | error=Phone->GetMemory(&s, &Pbk); |
4103 | if (error != ERR_EMPTY) { | 4103 | if (error != ERR_EMPTY) { |
4104 | Print_Error(error); | 4104 | Print_Error(error); |
4105 | if (used < GSM_BACKUP_MAX_SIMPHONEBOOK) { | 4105 | if (used < GSM_BACKUP_MAX_SIMPHONEBOOK) { |
4106 | Backup.SIMPhonebook[used] = malloc(sizeof(GSM_MemoryEntry)); | 4106 | Backup.SIMPhonebook[used] = malloc(sizeof(GSM_MemoryEntry)); |
4107 | if (Backup.SIMPhonebook[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4107 | if (Backup.SIMPhonebook[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4108 | Backup.SIMPhonebook[used + 1] = NULL; | 4108 | Backup.SIMPhonebook[used + 1] = NULL; |
4109 | } else { | 4109 | } else { |
4110 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_SIMPHONEBOOK"); | 4110 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_SIMPHONEBOOK"); |
4111 | GSM_Terminate(); | 4111 | GSM_Terminate(); |
4112 | exit(-1); | 4112 | exit(-1); |
4113 | } | 4113 | } |
4114 | *Backup.SIMPhonebook[used]=Pbk; | 4114 | *Backup.SIMPhonebook[used]=Pbk; |
4115 | used++; | 4115 | used++; |
4116 | } | 4116 | } |
4117 | printmsgerr("%c Reading: %i percent",13,used*100/MemStatus.MemoryUsed); | 4117 | printmsgerr("%c Reading: %i percent",13,used*100/MemStatus.MemoryUsed); |
4118 | i++; | 4118 | i++; |
4119 | if (gshutdown) { | 4119 | if (gshutdown) { |
4120 | GSM_Terminate(); | 4120 | GSM_Terminate(); |
4121 | exit(0); | 4121 | exit(0); |
4122 | } | 4122 | } |
4123 | } | 4123 | } |
4124 | printmsgerr("\n"); | 4124 | printmsgerr("\n"); |
4125 | } | 4125 | } |
4126 | DoBackup = false; | 4126 | DoBackup = false; |
4127 | if (Info.Calendar) { | 4127 | if (Info.Calendar) { |
4128 | printmsg("Checking calendar\n"); | 4128 | printmsg("Checking calendar\n"); |
4129 | error=Phone->GetNextCalendar(&s,&Calendar,true); | 4129 | error=Phone->GetNextCalendar(&s,&Calendar,true); |
4130 | if (error==ERR_NONE) { | 4130 | if (error==ERR_NONE) { |
4131 | if (answer_yes(" Backup calendar notes")) DoBackup = true; | 4131 | if (answer_yes(" Backup calendar notes")) DoBackup = true; |
4132 | } | 4132 | } |
4133 | } | 4133 | } |
4134 | if (DoBackup) { | 4134 | if (DoBackup) { |
4135 | used = 0; | 4135 | used = 0; |
4136 | printmsgerr(" Reading : "); | 4136 | printmsgerr(" Reading : "); |
4137 | while (error == ERR_NONE) { | 4137 | while (error == ERR_NONE) { |
4138 | if (used < GSM_MAXCALENDARTODONOTES) { | 4138 | if (used < GSM_MAXCALENDARTODONOTES) { |
4139 | Backup.Calendar[used] = malloc(sizeof(GSM_CalendarEntry)); | 4139 | Backup.Calendar[used] = malloc(sizeof(GSM_CalendarEntry)); |
4140 | if (Backup.Calendar[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4140 | if (Backup.Calendar[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4141 | Backup.Calendar[used+1] = NULL; | 4141 | Backup.Calendar[used+1] = NULL; |
4142 | } else { | 4142 | } else { |
4143 | printmsg(" Increase %s\n" , "GSM_MAXCALENDARTODONOTES"); | 4143 | printmsg(" Increase %s\n" , "GSM_MAXCALENDARTODONOTES"); |
4144 | GSM_Terminate(); | 4144 | GSM_Terminate(); |
4145 | exit(-1); | 4145 | exit(-1); |
4146 | } | 4146 | } |
4147 | *Backup.Calendar[used]=Calendar; | 4147 | *Backup.Calendar[used]=Calendar; |
4148 | used ++; | 4148 | used ++; |
4149 | error=Phone->GetNextCalendar(&s,&Calendar,false); | 4149 | error=Phone->GetNextCalendar(&s,&Calendar,false); |
4150 | printmsgerr("*"); | 4150 | printmsgerr("*"); |
4151 | if (gshutdown) { | 4151 | if (gshutdown) { |
4152 | GSM_Terminate(); | 4152 | GSM_Terminate(); |
4153 | exit(0); | 4153 | exit(0); |
4154 | } | 4154 | } |
4155 | } | 4155 | } |
4156 | printmsgerr("\n"); | 4156 | printmsgerr("\n"); |
4157 | } | 4157 | } |
4158 | DoBackup = false; | 4158 | DoBackup = false; |
4159 | if (Info.ToDo) { | 4159 | if (Info.ToDo) { |
4160 | printmsg("Checking ToDo\n"); | 4160 | printmsg("Checking ToDo\n"); |
4161 | error=Phone->GetToDoStatus(&s,&ToDoStatus); | 4161 | error=Phone->GetToDoStatus(&s,&ToDoStatus); |
4162 | if (error == ERR_NONE && ToDoStatus.Used != 0) { | 4162 | if (error == ERR_NONE && ToDoStatus.Used != 0) { |
4163 | if (answer_yes(" Backup ToDo")) DoBackup = true; | 4163 | if (answer_yes(" Backup ToDo")) DoBackup = true; |
4164 | } | 4164 | } |
4165 | } | 4165 | } |
4166 | if (DoBackup) { | 4166 | if (DoBackup) { |
4167 | used = 0; | 4167 | used = 0; |
4168 | error=Phone->GetNextToDo(&s,&ToDo,true); | 4168 | error=Phone->GetNextToDo(&s,&ToDo,true); |
4169 | while (error == ERR_NONE) { | 4169 | while (error == ERR_NONE) { |
4170 | if (used < GSM_MAXCALENDARTODONOTES) { | 4170 | if (used < GSM_MAXCALENDARTODONOTES) { |
4171 | Backup.ToDo[used] = malloc(sizeof(GSM_ToDoEntry)); | 4171 | Backup.ToDo[used] = malloc(sizeof(GSM_ToDoEntry)); |
4172 | if (Backup.ToDo[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4172 | if (Backup.ToDo[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4173 | Backup.ToDo[used+1] = NULL; | 4173 | Backup.ToDo[used+1] = NULL; |
4174 | } else { | 4174 | } else { |
4175 | printmsg(" Increase %s\n" , "GSM_MAXCALENDARTODONOTES"); | 4175 | printmsg(" Increase %s\n" , "GSM_MAXCALENDARTODONOTES"); |
4176 | GSM_Terminate(); | 4176 | GSM_Terminate(); |
4177 | exit(-1); | 4177 | exit(-1); |
4178 | } | 4178 | } |
4179 | *Backup.ToDo[used]=ToDo; | 4179 | *Backup.ToDo[used]=ToDo; |
4180 | used ++; | 4180 | used ++; |
4181 | error=Phone->GetNextToDo(&s,&ToDo,false); | 4181 | error=Phone->GetNextToDo(&s,&ToDo,false); |
4182 | printmsgerr("%c Reading: %i percent",13,used*100/ToDoStatus.Used); | 4182 | printmsgerr("%c Reading: %i percent",13,used*100/ToDoStatus.Used); |
4183 | if (gshutdown) { | 4183 | if (gshutdown) { |
4184 | GSM_Terminate(); | 4184 | GSM_Terminate(); |
4185 | exit(0); | 4185 | exit(0); |
4186 | } | 4186 | } |
4187 | } | 4187 | } |
4188 | printmsgerr("\n"); | 4188 | printmsgerr("\n"); |
4189 | } | 4189 | } |
4190 | DoBackup = false; | 4190 | DoBackup = false; |
4191 | if (Info.Note) { | 4191 | if (Info.Note) { |
4192 | printmsg("Checking notes\n"); | 4192 | printmsg("Checking notes\n"); |
4193 | error=Phone->GetNextNote(&s,&Note,true); | 4193 | error=Phone->GetNextNote(&s,&Note,true); |
4194 | if (error==ERR_NONE) { | 4194 | if (error==ERR_NONE) { |
4195 | if (answer_yes(" Backup notes")) DoBackup = true; | 4195 | if (answer_yes(" Backup notes")) DoBackup = true; |
4196 | } | 4196 | } |
4197 | } | 4197 | } |
4198 | if (DoBackup) { | 4198 | if (DoBackup) { |
4199 | used = 0; | 4199 | used = 0; |
4200 | printmsgerr(" Reading : "); | 4200 | printmsgerr(" Reading : "); |
4201 | while (error == ERR_NONE) { | 4201 | while (error == ERR_NONE) { |
4202 | if (used < GSM_BACKUP_MAX_NOTE) { | 4202 | if (used < GSM_BACKUP_MAX_NOTE) { |
4203 | Backup.Note[used] = malloc(sizeof(GSM_NoteEntry)); | 4203 | Backup.Note[used] = malloc(sizeof(GSM_NoteEntry)); |
4204 | if (Backup.Note[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4204 | if (Backup.Note[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4205 | Backup.Note[used+1] = NULL; | 4205 | Backup.Note[used+1] = NULL; |
4206 | } else { | 4206 | } else { |
4207 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_NOTE"); | 4207 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_NOTE"); |
4208 | GSM_Terminate(); | 4208 | GSM_Terminate(); |
4209 | exit(-1); | 4209 | exit(-1); |
4210 | } | 4210 | } |
4211 | *Backup.Note[used]=Note; | 4211 | *Backup.Note[used]=Note; |
4212 | used ++; | 4212 | used ++; |
4213 | error=Phone->GetNextNote(&s,&Note,false); | 4213 | error=Phone->GetNextNote(&s,&Note,false); |
4214 | printmsgerr("*"); | 4214 | printmsgerr("*"); |
4215 | if (gshutdown) { | 4215 | if (gshutdown) { |
4216 | GSM_Terminate(); | 4216 | GSM_Terminate(); |
4217 | exit(0); | 4217 | exit(0); |
4218 | } | 4218 | } |
4219 | } | 4219 | } |
4220 | printmsgerr("\n"); | 4220 | printmsgerr("\n"); |
4221 | } | 4221 | } |
4222 | DoBackup = false; | 4222 | DoBackup = false; |
4223 | if (Info.CallerLogos) { | 4223 | if (Info.CallerLogos) { |
4224 | printmsg("Checking caller logos\n"); | 4224 | printmsg("Checking caller logos\n"); |
4225 | Bitmap.Type = GSM_CallerGroupLogo; | 4225 | Bitmap.Type = GSM_CallerGroupLogo; |
4226 | Bitmap.Location = 1; | 4226 | Bitmap.Location = 1; |
4227 | error=Phone->GetBitmap(&s,&Bitmap); | 4227 | error=Phone->GetBitmap(&s,&Bitmap); |
4228 | if (error == ERR_NONE) { | 4228 | if (error == ERR_NONE) { |
4229 | if (answer_yes(" Backup caller groups and logos")) DoBackup = true; | 4229 | if (answer_yes(" Backup caller groups and logos")) DoBackup = true; |
4230 | } | 4230 | } |
4231 | } | 4231 | } |
4232 | if (DoBackup) { | 4232 | if (DoBackup) { |
4233 | printmsgerr(" Reading : "); | 4233 | printmsgerr(" Reading : "); |
4234 | error = ERR_NONE; | 4234 | error = ERR_NONE; |
4235 | used = 0; | 4235 | used = 0; |
4236 | while (error == ERR_NONE) { | 4236 | while (error == ERR_NONE) { |
4237 | if (used < GSM_BACKUP_MAX_CALLER) { | 4237 | if (used < GSM_BACKUP_MAX_CALLER) { |
4238 | Backup.CallerLogos[used] = malloc(sizeof(GSM_Bitmap)); | 4238 | Backup.CallerLogos[used] = malloc(sizeof(GSM_Bitmap)); |
4239 | if (Backup.CallerLogos[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4239 | if (Backup.CallerLogos[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4240 | Backup.CallerLogos[used+1] = NULL; | 4240 | Backup.CallerLogos[used+1] = NULL; |
4241 | } else { | 4241 | } else { |
4242 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_CALLER"); | 4242 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_CALLER"); |
4243 | GSM_Terminate(); | 4243 | GSM_Terminate(); |
4244 | exit(-1); | 4244 | exit(-1); |
4245 | } | 4245 | } |
4246 | *Backup.CallerLogos[used] = Bitmap; | 4246 | *Backup.CallerLogos[used] = Bitmap; |
4247 | used ++; | 4247 | used ++; |
4248 | Bitmap.Location = used + 1; | 4248 | Bitmap.Location = used + 1; |
4249 | error=Phone->GetBitmap(&s,&Bitmap); | 4249 | error=Phone->GetBitmap(&s,&Bitmap); |
4250 | printmsgerr("*"); | 4250 | printmsgerr("*"); |
4251 | if (gshutdown) { | 4251 | if (gshutdown) { |
4252 | GSM_Terminate(); | 4252 | GSM_Terminate(); |
4253 | exit(0); | 4253 | exit(0); |
4254 | } | 4254 | } |
4255 | } | 4255 | } |
4256 | printmsgerr("\n"); | 4256 | printmsgerr("\n"); |
4257 | } | 4257 | } |
4258 | DoBackup = false; | 4258 | DoBackup = false; |
4259 | if (Info.SMSC) { | 4259 | if (Info.SMSC) { |
4260 | printmsg("Checking SMS profiles\n"); | 4260 | printmsg("Checking SMS profiles\n"); |
4261 | if (answer_yes(" Backup SMS profiles")) DoBackup = true; | 4261 | if (answer_yes(" Backup SMS profiles")) DoBackup = true; |
4262 | } | 4262 | } |
4263 | if (DoBackup) { | 4263 | if (DoBackup) { |
4264 | used = 0; | 4264 | used = 0; |
4265 | printmsgerr(" Reading: "); | 4265 | printmsgerr(" Reading: "); |
4266 | while (true) { | 4266 | while (true) { |
4267 | SMSC.Location = used + 1; | 4267 | SMSC.Location = used + 1; |
4268 | error = Phone->GetSMSC(&s,&SMSC); | 4268 | error = Phone->GetSMSC(&s,&SMSC); |
4269 | if (error != ERR_NONE) break; | 4269 | if (error != ERR_NONE) break; |
4270 | if (used < GSM_BACKUP_MAX_SMSC) { | 4270 | if (used < GSM_BACKUP_MAX_SMSC) { |
4271 | Backup.SMSC[used] = malloc(sizeof(GSM_SMSC)); | 4271 | Backup.SMSC[used] = malloc(sizeof(GSM_SMSC)); |
4272 | if (Backup.SMSC[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4272 | if (Backup.SMSC[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4273 | Backup.SMSC[used + 1] = NULL; | 4273 | Backup.SMSC[used + 1] = NULL; |
4274 | } else { | 4274 | } else { |
4275 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_SMSC"); | 4275 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_SMSC"); |
4276 | GSM_Terminate(); | 4276 | GSM_Terminate(); |
4277 | exit(-1); | 4277 | exit(-1); |
4278 | } | 4278 | } |
4279 | *Backup.SMSC[used]=SMSC; | 4279 | *Backup.SMSC[used]=SMSC; |
4280 | used++; | 4280 | used++; |
4281 | printmsgerr("*"); | 4281 | printmsgerr("*"); |
4282 | } | 4282 | } |
4283 | printmsgerr("\n"); | 4283 | printmsgerr("\n"); |
4284 | } | 4284 | } |
4285 | DoBackup = false; | 4285 | DoBackup = false; |
4286 | if (Info.StartupLogo) { | 4286 | if (Info.StartupLogo) { |
4287 | printmsg("Checking startup text\n"); | 4287 | printmsg("Checking startup text\n"); |
4288 | Bitmap.Type = GSM_WelcomeNote_Text; | 4288 | Bitmap.Type = GSM_WelcomeNote_Text; |
4289 | error = Phone->GetBitmap(&s,&Bitmap); | 4289 | error = Phone->GetBitmap(&s,&Bitmap); |
4290 | if (error == ERR_NONE) { | 4290 | if (error == ERR_NONE) { |
4291 | if (answer_yes(" Backup startup logo/text")) DoBackup = true; | 4291 | if (answer_yes(" Backup startup logo/text")) DoBackup = true; |
4292 | } | 4292 | } |
4293 | } | 4293 | } |
4294 | if (DoBackup) { | 4294 | if (DoBackup) { |
4295 | Backup.StartupLogo = malloc(sizeof(GSM_Bitmap)); | 4295 | Backup.StartupLogo = malloc(sizeof(GSM_Bitmap)); |
4296 | if (Backup.StartupLogo == NULL) Print_Error(ERR_MOREMEMORY); | 4296 | if (Backup.StartupLogo == NULL) Print_Error(ERR_MOREMEMORY); |
4297 | *Backup.StartupLogo = Bitmap; | 4297 | *Backup.StartupLogo = Bitmap; |
4298 | if (Bitmap.Text[0]==0 && Bitmap.Text[1]==0) { | 4298 | if (Bitmap.Text[0]==0 && Bitmap.Text[1]==0) { |
4299 | Bitmap.Type = GSM_StartupLogo; | 4299 | Bitmap.Type = GSM_StartupLogo; |
4300 | error = Phone->GetBitmap(&s,&Bitmap); | 4300 | error = Phone->GetBitmap(&s,&Bitmap); |
4301 | if (error == ERR_NONE) *Backup.StartupLogo = Bitmap; | 4301 | if (error == ERR_NONE) *Backup.StartupLogo = Bitmap; |
4302 | } | 4302 | } |
4303 | } | 4303 | } |
4304 | DoBackup = false; | 4304 | DoBackup = false; |
4305 | if (Info.OperatorLogo) { | 4305 | if (Info.OperatorLogo) { |
4306 | printmsg("Checking operator logo\n"); | 4306 | printmsg("Checking operator logo\n"); |
4307 | Bitmap.Type = GSM_OperatorLogo; | 4307 | Bitmap.Type = GSM_OperatorLogo; |
4308 | error=Phone->GetBitmap(&s,&Bitmap); | 4308 | error=Phone->GetBitmap(&s,&Bitmap); |
4309 | if (error == ERR_NONE) { | 4309 | if (error == ERR_NONE) { |
4310 | if (strcmp(Bitmap.NetworkCode,"000 00")!=0) { | 4310 | if (strcmp(Bitmap.NetworkCode,"000 00")!=0) { |
4311 | if (answer_yes(" Backup operator logo")) DoBackup = true; | 4311 | if (answer_yes(" Backup operator logo")) DoBackup = true; |
4312 | } | 4312 | } |
4313 | } | 4313 | } |
4314 | } | 4314 | } |
4315 | if (DoBackup) { | 4315 | if (DoBackup) { |
4316 | Backup.OperatorLogo = malloc(sizeof(GSM_Bitmap)); | 4316 | Backup.OperatorLogo = malloc(sizeof(GSM_Bitmap)); |
4317 | if (Backup.OperatorLogo == NULL) Print_Error(ERR_MOREMEMORY); | 4317 | if (Backup.OperatorLogo == NULL) Print_Error(ERR_MOREMEMORY); |
4318 | *Backup.OperatorLogo = Bitmap; | 4318 | *Backup.OperatorLogo = Bitmap; |
4319 | } | 4319 | } |
4320 | DoBackup = false; | 4320 | DoBackup = false; |
4321 | if (Info.WAPBookmark) { | 4321 | if (Info.WAPBookmark) { |
4322 | printmsg("Checking WAP bookmarks\n"); | 4322 | printmsg("Checking WAP bookmarks\n"); |
4323 | Bookmark.Location = 1; | 4323 | Bookmark.Location = 1; |
4324 | error=Phone->GetWAPBookmark(&s,&Bookmark); | 4324 | error=Phone->GetWAPBookmark(&s,&Bookmark); |
4325 | if (error==ERR_NONE) { | 4325 | if (error==ERR_NONE) { |
4326 | if (answer_yes(" Backup WAP bookmarks")) DoBackup = true; | 4326 | if (answer_yes(" Backup WAP bookmarks")) DoBackup = true; |
4327 | } | 4327 | } |
4328 | } | 4328 | } |
4329 | if (DoBackup) { | 4329 | if (DoBackup) { |
4330 | used = 0; | 4330 | used = 0; |
4331 | printmsgerr(" Reading : "); | 4331 | printmsgerr(" Reading : "); |
4332 | while (error == ERR_NONE) { | 4332 | while (error == ERR_NONE) { |
4333 | if (used < GSM_BACKUP_MAX_WAPBOOKMARK) { | 4333 | if (used < GSM_BACKUP_MAX_WAPBOOKMARK) { |
4334 | Backup.WAPBookmark[used] = malloc(sizeof(GSM_WAPBookmark)); | 4334 | Backup.WAPBookmark[used] = malloc(sizeof(GSM_WAPBookmark)); |
4335 | if (Backup.WAPBookmark[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4335 | if (Backup.WAPBookmark[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4336 | Backup.WAPBookmark[used+1] = NULL; | 4336 | Backup.WAPBookmark[used+1] = NULL; |
4337 | } else { | 4337 | } else { |
4338 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_WAPBOOKMARK"); | 4338 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_WAPBOOKMARK"); |
4339 | GSM_Terminate(); | 4339 | GSM_Terminate(); |
4340 | exit(-1); | 4340 | exit(-1); |
4341 | } | 4341 | } |
4342 | *Backup.WAPBookmark[used]=Bookmark; | 4342 | *Backup.WAPBookmark[used]=Bookmark; |
4343 | used ++; | 4343 | used ++; |
4344 | Bookmark.Location = used+1; | 4344 | Bookmark.Location = used+1; |
4345 | error=Phone->GetWAPBookmark(&s,&Bookmark); | 4345 | error=Phone->GetWAPBookmark(&s,&Bookmark); |
4346 | printmsgerr("*"); | 4346 | printmsgerr("*"); |
4347 | if (gshutdown) { | 4347 | if (gshutdown) { |
4348 | GSM_Terminate(); | 4348 | GSM_Terminate(); |
4349 | exit(0); | 4349 | exit(0); |
4350 | } | 4350 | } |
4351 | } | 4351 | } |
4352 | printmsgerr("\n"); | 4352 | printmsgerr("\n"); |
4353 | } | 4353 | } |
4354 | DoBackup = false; | 4354 | DoBackup = false; |
4355 | if (Info.WAPSettings) { | 4355 | if (Info.WAPSettings) { |
4356 | printmsg("Checking WAP settings\n"); | 4356 | printmsg("Checking WAP settings\n"); |
4357 | Settings.Location = 1; | 4357 | Settings.Location = 1; |
4358 | error=Phone->GetWAPSettings(&s,&Settings); | 4358 | error=Phone->GetWAPSettings(&s,&Settings); |
4359 | if (error==ERR_NONE) { | 4359 | if (error==ERR_NONE) { |
4360 | if (answer_yes(" Backup WAP settings")) DoBackup = true; | 4360 | if (answer_yes(" Backup WAP settings")) DoBackup = true; |
4361 | } | 4361 | } |
4362 | } | 4362 | } |
4363 | if (DoBackup) { | 4363 | if (DoBackup) { |
4364 | used = 0; | 4364 | used = 0; |
4365 | printmsgerr(" Reading : "); | 4365 | printmsgerr(" Reading : "); |
4366 | while (error == ERR_NONE) { | 4366 | while (error == ERR_NONE) { |
4367 | if (used < GSM_BACKUP_MAX_WAPSETTINGS) { | 4367 | if (used < GSM_BACKUP_MAX_WAPSETTINGS) { |
4368 | Backup.WAPSettings[used] = malloc(sizeof(GSM_MultiWAPSettings)); | 4368 | Backup.WAPSettings[used] = malloc(sizeof(GSM_MultiWAPSettings)); |
4369 | if (Backup.WAPSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4369 | if (Backup.WAPSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4370 | Backup.WAPSettings[used+1] = NULL; | 4370 | Backup.WAPSettings[used+1] = NULL; |
4371 | } else { | 4371 | } else { |
4372 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_WAPSETTINGS"); | 4372 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_WAPSETTINGS"); |
4373 | GSM_Terminate(); | 4373 | GSM_Terminate(); |
4374 | exit(-1); | 4374 | exit(-1); |
4375 | } | 4375 | } |
4376 | *Backup.WAPSettings[used]=Settings; | 4376 | *Backup.WAPSettings[used]=Settings; |
4377 | used ++; | 4377 | used ++; |
4378 | Settings.Location = used+1; | 4378 | Settings.Location = used+1; |
4379 | error=Phone->GetWAPSettings(&s,&Settings); | 4379 | error=Phone->GetWAPSettings(&s,&Settings); |
4380 | printmsgerr("*"); | 4380 | printmsgerr("*"); |
4381 | if (gshutdown) { | 4381 | if (gshutdown) { |
4382 | GSM_Terminate(); | 4382 | GSM_Terminate(); |
4383 | exit(0); | 4383 | exit(0); |
4384 | } | 4384 | } |
4385 | } | 4385 | } |
4386 | printmsgerr("\n"); | 4386 | printmsgerr("\n"); |
4387 | } | 4387 | } |
4388 | DoBackup = false; | 4388 | DoBackup = false; |
4389 | if (Info.MMSSettings) { | 4389 | if (Info.MMSSettings) { |
4390 | printmsg("Checking MMS settings\n"); | 4390 | printmsg("Checking MMS settings\n"); |
4391 | Settings.Location = 1; | 4391 | Settings.Location = 1; |
4392 | error=Phone->GetMMSSettings(&s,&Settings); | 4392 | error=Phone->GetMMSSettings(&s,&Settings); |
4393 | if (error==ERR_NONE) { | 4393 | if (error==ERR_NONE) { |
4394 | if (answer_yes(" Backup MMS settings")) DoBackup = true; | 4394 | if (answer_yes(" Backup MMS settings")) DoBackup = true; |
4395 | } | 4395 | } |
4396 | } | 4396 | } |
4397 | if (DoBackup) { | 4397 | if (DoBackup) { |
4398 | used = 0; | 4398 | used = 0; |
4399 | printmsgerr(" Reading : "); | 4399 | printmsgerr(" Reading : "); |
4400 | while (error == ERR_NONE) { | 4400 | while (error == ERR_NONE) { |
4401 | if (used < GSM_BACKUP_MAX_MMSSETTINGS) { | 4401 | if (used < GSM_BACKUP_MAX_MMSSETTINGS) { |
4402 | Backup.MMSSettings[used] = malloc(sizeof(GSM_MultiWAPSettings)); | 4402 | Backup.MMSSettings[used] = malloc(sizeof(GSM_MultiWAPSettings)); |
4403 | if (Backup.MMSSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4403 | if (Backup.MMSSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4404 | Backup.MMSSettings[used+1] = NULL; | 4404 | Backup.MMSSettings[used+1] = NULL; |
4405 | } else { | 4405 | } else { |
4406 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_MMSSETTINGS"); | 4406 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_MMSSETTINGS"); |
4407 | GSM_Terminate(); | 4407 | GSM_Terminate(); |
4408 | exit(-1); | 4408 | exit(-1); |
4409 | } | 4409 | } |
4410 | *Backup.MMSSettings[used]=Settings; | 4410 | *Backup.MMSSettings[used]=Settings; |
4411 | used ++; | 4411 | used ++; |
4412 | Settings.Location = used+1; | 4412 | Settings.Location = used+1; |
4413 | error=Phone->GetMMSSettings(&s,&Settings); | 4413 | error=Phone->GetMMSSettings(&s,&Settings); |
4414 | printmsgerr("*"); | 4414 | printmsgerr("*"); |
4415 | if (gshutdown) { | 4415 | if (gshutdown) { |
4416 | GSM_Terminate(); | 4416 | GSM_Terminate(); |
4417 | exit(0); | 4417 | exit(0); |
4418 | } | 4418 | } |
4419 | } | 4419 | } |
4420 | printmsgerr("\n"); | 4420 | printmsgerr("\n"); |
4421 | } | 4421 | } |
4422 | DoBackup = false; | 4422 | DoBackup = false; |
4423 | if (Info.ChatSettings) { | 4423 | if (Info.ChatSettings) { |
4424 | printmsg("Checking Chat settings\n"); | 4424 | printmsg("Checking Chat settings\n"); |
4425 | Chat.Location = 1; | 4425 | Chat.Location = 1; |
4426 | error=Phone->GetChatSettings(&s,&Chat); | 4426 | error=Phone->GetChatSettings(&s,&Chat); |
4427 | if (error==ERR_NONE) { | 4427 | if (error==ERR_NONE) { |
4428 | if (answer_yes(" Backup Chat settings")) DoBackup = true; | 4428 | if (answer_yes(" Backup Chat settings")) DoBackup = true; |
4429 | } | 4429 | } |
4430 | } | 4430 | } |
4431 | if (DoBackup) { | 4431 | if (DoBackup) { |
4432 | used = 0; | 4432 | used = 0; |
4433 | printmsgerr(" Reading : "); | 4433 | printmsgerr(" Reading : "); |
4434 | while (error == ERR_NONE) { | 4434 | while (error == ERR_NONE) { |
4435 | if (used < GSM_BACKUP_MAX_CHATSETTINGS) { | 4435 | if (used < GSM_BACKUP_MAX_CHATSETTINGS) { |
4436 | Backup.ChatSettings[used] = malloc(sizeof(GSM_ChatSettings)); | 4436 | Backup.ChatSettings[used] = malloc(sizeof(GSM_ChatSettings)); |
4437 | if (Backup.ChatSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4437 | if (Backup.ChatSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4438 | Backup.ChatSettings[used+1] = NULL; | 4438 | Backup.ChatSettings[used+1] = NULL; |
4439 | } else { | 4439 | } else { |
4440 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_CHATSETTINGS"); | 4440 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_CHATSETTINGS"); |
4441 | GSM_Terminate(); | 4441 | GSM_Terminate(); |
4442 | exit(-1); | 4442 | exit(-1); |
4443 | } | 4443 | } |
4444 | *Backup.ChatSettings[used]=Chat; | 4444 | *Backup.ChatSettings[used]=Chat; |
4445 | used ++; | 4445 | used ++; |
4446 | Chat.Location = used+1; | 4446 | Chat.Location = used+1; |
4447 | error=Phone->GetChatSettings(&s,&Chat); | 4447 | error=Phone->GetChatSettings(&s,&Chat); |
4448 | printmsgerr("*"); | 4448 | printmsgerr("*"); |
4449 | if (gshutdown) { | 4449 | if (gshutdown) { |
4450 | GSM_Terminate(); | 4450 | GSM_Terminate(); |
4451 | exit(0); | 4451 | exit(0); |
4452 | } | 4452 | } |
4453 | } | 4453 | } |
4454 | printmsgerr("\n"); | 4454 | printmsgerr("\n"); |
4455 | } | 4455 | } |
4456 | DoBackup = false; | 4456 | DoBackup = false; |
4457 | if (Info.SyncMLSettings) { | 4457 | if (Info.SyncMLSettings) { |
4458 | printmsg("Checking SyncML settings\n"); | 4458 | printmsg("Checking SyncML settings\n"); |
4459 | SyncML.Location = 1; | 4459 | SyncML.Location = 1; |
4460 | error=Phone->GetSyncMLSettings(&s,&SyncML); | 4460 | error=Phone->GetSyncMLSettings(&s,&SyncML); |
4461 | if (error==ERR_NONE) { | 4461 | if (error==ERR_NONE) { |
4462 | if (answer_yes(" Backup SyncML settings")) DoBackup = true; | 4462 | if (answer_yes(" Backup SyncML settings")) DoBackup = true; |
4463 | } | 4463 | } |
4464 | } | 4464 | } |
4465 | if (DoBackup) { | 4465 | if (DoBackup) { |
4466 | used = 0; | 4466 | used = 0; |
4467 | printmsgerr(" Reading : "); | 4467 | printmsgerr(" Reading : "); |
4468 | while (error == ERR_NONE) { | 4468 | while (error == ERR_NONE) { |
4469 | if (used < GSM_BACKUP_MAX_SYNCMLSETTINGS) { | 4469 | if (used < GSM_BACKUP_MAX_SYNCMLSETTINGS) { |
4470 | Backup.SyncMLSettings[used] = malloc(sizeof(GSM_SyncMLSettings)); | 4470 | Backup.SyncMLSettings[used] = malloc(sizeof(GSM_SyncMLSettings)); |
4471 | if (Backup.SyncMLSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4471 | if (Backup.SyncMLSettings[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4472 | Backup.SyncMLSettings[used+1] = NULL; | 4472 | Backup.SyncMLSettings[used+1] = NULL; |
4473 | } else { | 4473 | } else { |
4474 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_SYNCMLSETTINGS"); | 4474 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_SYNCMLSETTINGS"); |
4475 | GSM_Terminate(); | 4475 | GSM_Terminate(); |
4476 | exit(-1); | 4476 | exit(-1); |
4477 | } | 4477 | } |
4478 | *Backup.SyncMLSettings[used]=SyncML; | 4478 | *Backup.SyncMLSettings[used]=SyncML; |
4479 | used ++; | 4479 | used ++; |
4480 | SyncML.Location = used+1; | 4480 | SyncML.Location = used+1; |
4481 | error=Phone->GetSyncMLSettings(&s,&SyncML); | 4481 | error=Phone->GetSyncMLSettings(&s,&SyncML); |
4482 | printmsgerr("*"); | 4482 | printmsgerr("*"); |
4483 | if (gshutdown) { | 4483 | if (gshutdown) { |
4484 | GSM_Terminate(); | 4484 | GSM_Terminate(); |
4485 | exit(0); | 4485 | exit(0); |
4486 | } | 4486 | } |
4487 | } | 4487 | } |
4488 | printmsgerr("\n"); | 4488 | printmsgerr("\n"); |
4489 | } | 4489 | } |
4490 | DoBackup = false; | 4490 | DoBackup = false; |
4491 | if (Info.Ringtone) { | 4491 | if (Info.Ringtone) { |
4492 | printmsg("Checking user ringtones\n"); | 4492 | printmsg("Checking user ringtones\n"); |
4493 | Ringtone.Location = 1; | 4493 | Ringtone.Location = 1; |
4494 | Ringtone.Format = 0; | 4494 | Ringtone.Format = 0; |
4495 | error=Phone->GetRingtone(&s,&Ringtone,false); | 4495 | error=Phone->GetRingtone(&s,&Ringtone,false); |
4496 | if (error==ERR_EMPTY || error == ERR_NONE) { | 4496 | if (error==ERR_EMPTY || error == ERR_NONE) { |
4497 | if (answer_yes(" Backup user ringtones")) DoBackup = true; | 4497 | if (answer_yes(" Backup user ringtones")) DoBackup = true; |
4498 | } | 4498 | } |
4499 | } | 4499 | } |
4500 | if (DoBackup) { | 4500 | if (DoBackup) { |
4501 | used = 0; | 4501 | used = 0; |
4502 | i= 1; | 4502 | i= 1; |
4503 | printmsgerr(" Reading : "); | 4503 | printmsgerr(" Reading : "); |
4504 | while (error == ERR_NONE || error == ERR_EMPTY) { | 4504 | while (error == ERR_NONE || error == ERR_EMPTY) { |
4505 | if (error == ERR_NONE) { | 4505 | if (error == ERR_NONE) { |
4506 | if (used < GSM_BACKUP_MAX_RINGTONES) { | 4506 | if (used < GSM_BACKUP_MAX_RINGTONES) { |
4507 | Backup.Ringtone[used] = malloc(sizeof(GSM_Ringtone)); | 4507 | Backup.Ringtone[used] = malloc(sizeof(GSM_Ringtone)); |
4508 | if (Backup.Ringtone[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4508 | if (Backup.Ringtone[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4509 | Backup.Ringtone[used+1] = NULL; | 4509 | Backup.Ringtone[used+1] = NULL; |
4510 | } else { | 4510 | } else { |
4511 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_RINGTONES"); | 4511 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_RINGTONES"); |
4512 | GSM_Terminate(); | 4512 | GSM_Terminate(); |
4513 | exit(-1); | 4513 | exit(-1); |
4514 | } | 4514 | } |
4515 | *Backup.Ringtone[used]=Ringtone; | 4515 | *Backup.Ringtone[used]=Ringtone; |
4516 | used ++; | 4516 | used ++; |
4517 | } | 4517 | } |
4518 | i++; | 4518 | i++; |
4519 | Ringtone.Location = i; | 4519 | Ringtone.Location = i; |
4520 | Ringtone.Format = 0; | 4520 | Ringtone.Format = 0; |
4521 | error=Phone->GetRingtone(&s,&Ringtone,false); | 4521 | error=Phone->GetRingtone(&s,&Ringtone,false); |
4522 | printmsgerr("*"); | 4522 | printmsgerr("*"); |
4523 | if (gshutdown) { | 4523 | if (gshutdown) { |
4524 | GSM_Terminate(); | 4524 | GSM_Terminate(); |
4525 | exit(0); | 4525 | exit(0); |
4526 | } | 4526 | } |
4527 | } | 4527 | } |
4528 | printmsgerr("\n"); | 4528 | printmsgerr("\n"); |
4529 | } | 4529 | } |
4530 | DoBackup = false; | 4530 | DoBackup = false; |
4531 | if (Info.Profiles) { | 4531 | if (Info.Profiles) { |
4532 | printmsg("Checking phone profiles\n"); | 4532 | printmsg("Checking phone profiles\n"); |
4533 | Profile.Location = 1; | 4533 | Profile.Location = 1; |
4534 | error = Phone->GetProfile(&s,&Profile); | 4534 | error = Phone->GetProfile(&s,&Profile); |
4535 | if (error == ERR_NONE) { | 4535 | if (error == ERR_NONE) { |
4536 | if (answer_yes(" Backup phone profiles")) DoBackup = true; | 4536 | if (answer_yes(" Backup phone profiles")) DoBackup = true; |
4537 | } | 4537 | } |
4538 | } | 4538 | } |
4539 | if (DoBackup) { | 4539 | if (DoBackup) { |
4540 | used = 0; | 4540 | used = 0; |
4541 | printmsgerr(" Reading: "); | 4541 | printmsgerr(" Reading: "); |
4542 | while (true) { | 4542 | while (true) { |
4543 | Profile.Location = used + 1; | 4543 | Profile.Location = used + 1; |
4544 | error = Phone->GetProfile(&s,&Profile); | 4544 | error = Phone->GetProfile(&s,&Profile); |
4545 | if (error != ERR_NONE) break; | 4545 | if (error != ERR_NONE) break; |
4546 | if (used < GSM_BACKUP_MAX_PROFILES) { | 4546 | if (used < GSM_BACKUP_MAX_PROFILES) { |
4547 | Backup.Profiles[used] = malloc(sizeof(GSM_Profile)); | 4547 | Backup.Profiles[used] = malloc(sizeof(GSM_Profile)); |
4548 | if (Backup.Profiles[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4548 | if (Backup.Profiles[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4549 | Backup.Profiles[used + 1] = NULL; | 4549 | Backup.Profiles[used + 1] = NULL; |
4550 | } else { | 4550 | } else { |
4551 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_PROFILES"); | 4551 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_PROFILES"); |
4552 | GSM_Terminate(); | 4552 | GSM_Terminate(); |
4553 | exit(-1); | 4553 | exit(-1); |
4554 | } | 4554 | } |
4555 | *Backup.Profiles[used]=Profile; | 4555 | *Backup.Profiles[used]=Profile; |
4556 | used++; | 4556 | used++; |
4557 | printmsgerr("*"); | 4557 | printmsgerr("*"); |
4558 | } | 4558 | } |
4559 | printmsgerr("\n"); | 4559 | printmsgerr("\n"); |
4560 | } | 4560 | } |
4561 | DoBackup = false; | 4561 | DoBackup = false; |
4562 | if (Info.FMStation) { | 4562 | if (Info.FMStation) { |
4563 | printmsg("Checking FM stations\n"); | 4563 | printmsg("Checking FM stations\n"); |
4564 | FMStation.Location = 1; | 4564 | FMStation.Location = 1; |
4565 | error = Phone->GetFMStation(&s,&FMStation); | 4565 | error = Phone->GetFMStation(&s,&FMStation); |
4566 | if (error == ERR_NONE || error == ERR_EMPTY) { | 4566 | if (error == ERR_NONE || error == ERR_EMPTY) { |
4567 | if (answer_yes(" Backup phone FM stations")) DoBackup=true; | 4567 | if (answer_yes(" Backup phone FM stations")) DoBackup=true; |
4568 | } | 4568 | } |
4569 | } | 4569 | } |
4570 | if (DoBackup) { | 4570 | if (DoBackup) { |
4571 | used= 0; | 4571 | used= 0; |
4572 | i = 1; | 4572 | i = 1; |
4573 | printmsgerr(" Reading: "); | 4573 | printmsgerr(" Reading: "); |
4574 | while (error == ERR_NONE || error == ERR_EMPTY) { | 4574 | while (error == ERR_NONE || error == ERR_EMPTY) { |
4575 | error = Phone->GetFMStation(&s,&FMStation); | 4575 | error = Phone->GetFMStation(&s,&FMStation); |
4576 | if (error == ERR_NONE) { | 4576 | if (error == ERR_NONE) { |
4577 | if (used < GSM_BACKUP_MAX_FMSTATIONS) { | 4577 | if (used < GSM_BACKUP_MAX_FMSTATIONS) { |
4578 | Backup.FMStation[used] = malloc(sizeof(GSM_FMStation)); | 4578 | Backup.FMStation[used] = malloc(sizeof(GSM_FMStation)); |
4579 | if (Backup.FMStation[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4579 | if (Backup.FMStation[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4580 | Backup.FMStation[used + 1] = NULL; | 4580 | Backup.FMStation[used + 1] = NULL; |
4581 | } else { | 4581 | } else { |
4582 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_FMSTATIONS"); | 4582 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_FMSTATIONS"); |
4583 | GSM_Terminate(); | 4583 | GSM_Terminate(); |
4584 | exit(-1); | 4584 | exit(-1); |
4585 | } | 4585 | } |
4586 | *Backup.FMStation[used]=FMStation; | 4586 | *Backup.FMStation[used]=FMStation; |
4587 | used++; | 4587 | used++; |
4588 | } | 4588 | } |
4589 | i++; | 4589 | i++; |
4590 | FMStation.Location = i; | 4590 | FMStation.Location = i; |
4591 | printmsgerr("*"); | 4591 | printmsgerr("*"); |
4592 | } | 4592 | } |
4593 | printmsgerr("\n"); | 4593 | printmsgerr("\n"); |
4594 | } | 4594 | } |
4595 | DoBackup = false; | 4595 | DoBackup = false; |
4596 | if (Info.GPRSPoint) { | 4596 | if (Info.GPRSPoint) { |
4597 | printmsg("Checking GPRS access points\n"); | 4597 | printmsg("Checking GPRS access points\n"); |
4598 | GPRSPoint.Location = 1; | 4598 | GPRSPoint.Location = 1; |
4599 | error = Phone->GetGPRSAccessPoint(&s,&GPRSPoint); | 4599 | error = Phone->GetGPRSAccessPoint(&s,&GPRSPoint); |
4600 | if (error == ERR_NONE || error == ERR_EMPTY) { | 4600 | if (error == ERR_NONE || error == ERR_EMPTY) { |
4601 | if (answer_yes(" Backup GPRS access points")) DoBackup = true; | 4601 | if (answer_yes(" Backup GPRS access points")) DoBackup = true; |
4602 | } | 4602 | } |
4603 | } | 4603 | } |
4604 | if (DoBackup) { | 4604 | if (DoBackup) { |
4605 | used= 0; | 4605 | used= 0; |
4606 | i = 1; | 4606 | i = 1; |
4607 | printmsgerr(" Reading: "); | 4607 | printmsgerr(" Reading: "); |
4608 | while (error == ERR_NONE || error == ERR_EMPTY) { | 4608 | while (error == ERR_NONE || error == ERR_EMPTY) { |
4609 | error = Phone->GetGPRSAccessPoint(&s,&GPRSPoint); | 4609 | error = Phone->GetGPRSAccessPoint(&s,&GPRSPoint); |
4610 | if (error == ERR_NONE) { | 4610 | if (error == ERR_NONE) { |
4611 | if (used < GSM_BACKUP_MAX_GPRSPOINT) { | 4611 | if (used < GSM_BACKUP_MAX_GPRSPOINT) { |
4612 | Backup.GPRSPoint[used] = malloc(sizeof(GSM_GPRSAccessPoint)); | 4612 | Backup.GPRSPoint[used] = malloc(sizeof(GSM_GPRSAccessPoint)); |
4613 | if (Backup.GPRSPoint[used] == NULL) Print_Error(ERR_MOREMEMORY); | 4613 | if (Backup.GPRSPoint[used] == NULL) Print_Error(ERR_MOREMEMORY); |
4614 | Backup.GPRSPoint[used + 1] = NULL; | 4614 | Backup.GPRSPoint[used + 1] = NULL; |
4615 | } else { | 4615 | } else { |
4616 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_GPRSPOINT"); | 4616 | printmsg(" Increase %s\n" , "GSM_BACKUP_MAX_GPRSPOINT"); |
4617 | GSM_Terminate(); | 4617 | GSM_Terminate(); |
4618 | exit(-1); | 4618 | exit(-1); |
4619 | } | 4619 | } |
4620 | *Backup.GPRSPoint[used]=GPRSPoint; | 4620 | *Backup.GPRSPoint[used]=GPRSPoint; |
4621 | used++; | 4621 | used++; |
4622 | } | 4622 | } |
4623 | i++; | 4623 | i++; |
4624 | GPRSPoint.Location = i; | 4624 | GPRSPoint.Location = i; |
4625 | printmsgerr("*"); | 4625 | printmsgerr("*"); |
4626 | } | 4626 | } |
4627 | printmsgerr("\n"); | 4627 | printmsgerr("\n"); |
4628 | } | 4628 | } |
4629 | 4629 | ||
4630 | GSM_Terminate(); | 4630 | GSM_Terminate(); |
4631 | 4631 | ||
4632 | GSM_SaveBackupFile(argv[2],&Backup, Info.UseUnicode); | 4632 | GSM_SaveBackupFile(argv[2],&Backup, Info.UseUnicode); |
4633 | GSM_FreeBackup(&Backup); | 4633 | GSM_FreeBackup(&Backup); |
4634 | } | 4634 | } |
4635 | 4635 | ||
4636 | static void Restore(int argc, char *argv[]) | 4636 | static void Restore(int argc, char *argv[]) |
4637 | { | 4637 | { |
4638 | GSM_Backup Backup; | 4638 | GSM_Backup Backup; |
4639 | GSM_FMStation FMStation; | 4639 | GSM_FMStation FMStation; |
4640 | GSM_DateTime date_time; | 4640 | GSM_DateTime date_time; |
4641 | GSM_CalendarEntryCalendar; | 4641 | GSM_CalendarEntryCalendar; |
4642 | GSM_Bitmap Bitmap; | 4642 | GSM_Bitmap Bitmap; |
4643 | GSM_Ringtone Ringtone; | 4643 | GSM_Ringtone Ringtone; |
4644 | GSM_MemoryEntry Pbk; | 4644 | GSM_MemoryEntry Pbk; |
4645 | GSM_MemoryStatusMemStatus; | 4645 | GSM_MemoryStatusMemStatus; |
4646 | GSM_ToDoEntry ToDo; | 4646 | GSM_ToDoEntry ToDo; |
4647 | GSM_ToDoStatus ToDoStatus; | 4647 | GSM_ToDoStatus ToDoStatus; |
4648 | GSM_Profile Profile; | 4648 | GSM_Profile Profile; |
4649 | GSM_MultiWAPSettingsSettings; | 4649 | GSM_MultiWAPSettingsSettings; |
4650 | GSM_GPRSAccessPointGPRSPoint; | 4650 | GSM_GPRSAccessPointGPRSPoint; |
4651 | GSM_WAPBookmark Bookmark; | 4651 | GSM_WAPBookmark Bookmark; |
4652 | int i, used, max = 0; | 4652 | int i, used, max = 0; |
4653 | bool Past = true; | 4653 | bool Past = true; |
4654 | bool Found, DoRestore; | 4654 | bool Found, DoRestore; |
4655 | 4655 | ||
4656 | error=GSM_ReadBackupFile(argv[2],&Backup); | 4656 | error=GSM_ReadBackupFile(argv[2],&Backup); |
4657 | if (error!=ERR_NOTIMPLEMENTED) { | 4657 | if (error!=ERR_NOTIMPLEMENTED) { |
4658 | Print_Error(error); | 4658 | Print_Error(error); |
4659 | } else { | 4659 | } else { |
4660 | printmsgerr("WARNING: Some data not read from file. It can be damaged or restoring some settings from this file format not implemented (maybe higher Gammu required ?)\n"); | 4660 | printmsgerr("WARNING: Some data not read from file. It can be damaged or restoring some settings from this file format not implemented (maybe higher Gammu required ?)\n"); |
4661 | } | 4661 | } |
4662 | 4662 | ||
4663 | signal(SIGINT, interrupt); | 4663 | signal(SIGINT, interrupt); |
4664 | printmsgerr("Press Ctrl+C to break...\n"); | 4664 | printmsgerr("Press Ctrl+C to break...\n"); |
4665 | 4665 | ||
4666 | if (Backup.DateTimeAvailable) printmsgerr("Time of backup : %s\n",OSDateTime(Backup.DateTime,false)); | 4666 | if (Backup.DateTimeAvailable) printmsgerr("Time of backup : %s\n",OSDateTime(Backup.DateTime,false)); |
4667 | if (Backup.Model[0]!=0) printmsgerr("Phone : %s\n",Backup.Model); | 4667 | if (Backup.Model[0]!=0) printmsgerr("Phone : %s\n",Backup.Model); |
4668 | if (Backup.IMEI[0]!=0) printmsgerr("IMEI : %s\n",Backup.IMEI); | 4668 | if (Backup.IMEI[0]!=0) printmsgerr("IMEI : %s\n",Backup.IMEI); |
4669 | if (Backup.Creator[0]!=0) printmsgerr("File created by : %s\n",Backup.Creator); | 4669 | if (Backup.Creator[0]!=0) printmsgerr("File created by : %s\n",Backup.Creator); |
4670 | 4670 | ||
4671 | if (Backup.MD5Calculated[0]!=0) { | 4671 | if (Backup.MD5Calculated[0]!=0) { |
4672 | dbgprintf("\"%s\"\n",Backup.MD5Original); | 4672 | dbgprintf("\"%s\"\n",Backup.MD5Original); |
4673 | dbgprintf("\"%s\"\n",Backup.MD5Calculated); | 4673 | dbgprintf("\"%s\"\n",Backup.MD5Calculated); |
4674 | if (strcmp(Backup.MD5Original,Backup.MD5Calculated)) { | 4674 | if (strcmp(Backup.MD5Original,Backup.MD5Calculated)) { |
4675 | if (!answer_yes("Checksum in backup file do not match. Continue")) return; | 4675 | if (!answer_yes("Checksum in backup file do not match. Continue")) return; |
4676 | } | 4676 | } |
4677 | } | 4677 | } |
4678 | 4678 | ||
4679 | GSM_Init(true); | 4679 | GSM_Init(true); |
4680 | 4680 | ||
4681 | DoRestore = false; | 4681 | DoRestore = false; |
4682 | if (Backup.PhonePhonebook[0] != NULL) { | 4682 | if (Backup.PhonePhonebook[0] != NULL) { |
4683 | MemStatus.MemoryType = MEM_ME; | 4683 | MemStatus.MemoryType = MEM_ME; |
4684 | error=Phone->GetMemoryStatus(&s, &MemStatus); | 4684 | error=Phone->GetMemoryStatus(&s, &MemStatus); |
4685 | if (error==ERR_NONE) { | 4685 | if (error==ERR_NONE) { |
4686 | max = 0; | 4686 | max = 0; |
4687 | while (Backup.PhonePhonebook[max]!=NULL) max++; | 4687 | while (Backup.PhonePhonebook[max]!=NULL) max++; |
4688 | printmsgerr("%i entries in backup file\n",max); | 4688 | printmsgerr("%i entries in backup file\n",max); |
4689 | if (answer_yes("Restore phone phonebook")) DoRestore = true; | 4689 | if (answer_yes("Restore phone phonebook")) DoRestore = true; |
4690 | } | 4690 | } |
4691 | } | 4691 | } |
4692 | if (DoRestore) { | 4692 | if (DoRestore) { |
4693 | used = 0; | 4693 | used = 0; |
4694 | for (i=0;i<MemStatus.MemoryUsed+MemStatus.MemoryFree;i++) { | 4694 | for (i=0;i<MemStatus.MemoryUsed+MemStatus.MemoryFree;i++) { |
4695 | Pbk.MemoryType = MEM_ME; | 4695 | Pbk.MemoryType = MEM_ME; |
4696 | Pbk.Location= i + 1; | 4696 | Pbk.Location= i + 1; |
4697 | Pbk.EntriesNum= 0; | 4697 | Pbk.EntriesNum= 0; |
4698 | if (used<max) { | 4698 | if (used<max) { |
4699 | if (Backup.PhonePhonebook[used]->Location == Pbk.Location) { | 4699 | if (Backup.PhonePhonebook[used]->Location == Pbk.Location) { |
4700 | Pbk = *Backup.PhonePhonebook[used]; | 4700 | Pbk = *Backup.PhonePhonebook[used]; |
4701 | used++; | 4701 | used++; |
4702 | dbgprintf("Location %i\n",Pbk.Location); | 4702 | dbgprintf("Location %i\n",Pbk.Location); |
4703 | if (Pbk.EntriesNum != 0) error=Phone->SetMemory(&s, &Pbk); | 4703 | if (Pbk.EntriesNum != 0) error=Phone->SetMemory(&s, &Pbk); |
4704 | } | 4704 | } |
4705 | } | 4705 | } |
4706 | if (Pbk.EntriesNum == 0) error=Phone->DeleteMemory(&s, &Pbk); | 4706 | if (Pbk.EntriesNum == 0) error=Phone->DeleteMemory(&s, &Pbk); |
4707 | Print_Error(error); | 4707 | Print_Error(error); |
4708 | printmsgerr("%cWriting: %i percent",13,(i+1)*100/(MemStatus.MemoryUsed+MemStatus.MemoryFree)); | 4708 | printmsgerr("%cWriting: %i percent",13,(i+1)*100/(MemStatus.MemoryUsed+MemStatus.MemoryFree)); |
4709 | if (gshutdown) { | 4709 | if (gshutdown) { |
4710 | GSM_Terminate(); | 4710 | GSM_Terminate(); |
4711 | exit(0); | 4711 | exit(0); |
4712 | } | 4712 | } |
4713 | } | 4713 | } |
4714 | printmsgerr("\n"); | 4714 | printmsgerr("\n"); |
4715 | } | 4715 | } |
4716 | 4716 | ||
4717 | DoRestore = false; | 4717 | DoRestore = false; |
4718 | if (Backup.SIMPhonebook[0] != NULL) { | 4718 | if (Backup.SIMPhonebook[0] != NULL) { |
4719 | MemStatus.MemoryType = MEM_SM; | 4719 | MemStatus.MemoryType = MEM_SM; |
4720 | error=Phone->GetMemoryStatus(&s, &MemStatus); | 4720 | error=Phone->GetMemoryStatus(&s, &MemStatus); |
4721 | if (error==ERR_NONE) { | 4721 | if (error==ERR_NONE) { |
4722 | max = 0; | 4722 | max = 0; |
4723 | while (Backup.SIMPhonebook[max]!=NULL) max++; | 4723 | while (Backup.SIMPhonebook[max]!=NULL) max++; |
4724 | printmsgerr("%i entries in backup file\n",max); | 4724 | printmsgerr("%i entries in backup file\n",max); |
4725 | if (answer_yes("Restore SIM phonebook")) DoRestore = true; | 4725 | if (answer_yes("Restore SIM phonebook")) DoRestore = true; |
4726 | } | 4726 | } |
4727 | } | 4727 | } |
4728 | if (DoRestore) { | 4728 | if (DoRestore) { |
4729 | used = 0; | 4729 | used = 0; |
4730 | for (i=0;i<MemStatus.MemoryUsed+MemStatus.MemoryFree;i++) { | 4730 | for (i=0;i<MemStatus.MemoryUsed+MemStatus.MemoryFree;i++) { |
4731 | Pbk.MemoryType = MEM_SM; | 4731 | Pbk.MemoryType = MEM_SM; |
4732 | Pbk.Location= i + 1; | 4732 | Pbk.Location= i + 1; |
4733 | Pbk.EntriesNum= 0; | 4733 | Pbk.EntriesNum= 0; |
4734 | if (used<max) { | 4734 | if (used<max) { |
4735 | if (Backup.SIMPhonebook[used]->Location == Pbk.Location) { | 4735 | if (Backup.SIMPhonebook[used]->Location == Pbk.Location) { |
4736 | Pbk = *Backup.SIMPhonebook[used]; | 4736 | Pbk = *Backup.SIMPhonebook[used]; |
4737 | used++; | 4737 | used++; |
4738 | dbgprintf("Location %i\n",Pbk.Location); | 4738 | dbgprintf("Location %i\n",Pbk.Location); |
4739 | if (Pbk.EntriesNum != 0) error=Phone->SetMemory(&s, &Pbk); | 4739 | if (Pbk.EntriesNum != 0) error=Phone->SetMemory(&s, &Pbk); |
4740 | } | 4740 | } |
4741 | } | 4741 | } |
4742 | if (Pbk.EntriesNum == 0) error=Phone->DeleteMemory(&s, &Pbk); | 4742 | if (Pbk.EntriesNum == 0) error=Phone->DeleteMemory(&s, &Pbk); |
4743 | Print_Error(error); | 4743 | Print_Error(error); |
4744 | printmsgerr("%cWriting: %i percent",13,(i+1)*100/(MemStatus.MemoryUsed+MemStatus.MemoryFree)); | 4744 | printmsgerr("%cWriting: %i percent",13,(i+1)*100/(MemStatus.MemoryUsed+MemStatus.MemoryFree)); |
4745 | if (gshutdown) { | 4745 | if (gshutdown) { |
4746 | GSM_Terminate(); | 4746 | GSM_Terminate(); |
4747 | exit(0); | 4747 | exit(0); |
4748 | } | 4748 | } |
4749 | } | 4749 | } |
4750 | printmsgerr("\n"); | 4750 | printmsgerr("\n"); |
4751 | } | 4751 | } |
4752 | 4752 | ||
4753 | DoRestore = false; | 4753 | DoRestore = false; |
4754 | if (Backup.CallerLogos[0] != NULL) { | 4754 | if (Backup.CallerLogos[0] != NULL) { |
4755 | Bitmap.Type = GSM_CallerGroupLogo; | 4755 | Bitmap.Type = GSM_CallerGroupLogo; |
4756 | Bitmap.Location = 1; | 4756 | Bitmap.Location = 1; |
4757 | error=Phone->GetBitmap(&s,&Bitmap); | 4757 | error=Phone->GetBitmap(&s,&Bitmap); |
4758 | if (error == ERR_NONE) { | 4758 | if (error == ERR_NONE) { |
4759 | if (answer_yes("Restore caller groups and logos")) DoRestore = true; | 4759 | if (answer_yes("Restore caller groups and logos")) DoRestore = true; |
4760 | } | 4760 | } |
4761 | } | 4761 | } |
4762 | if (DoRestore) { | 4762 | if (DoRestore) { |
4763 | max = 0; | 4763 | max = 0; |
4764 | while (Backup.CallerLogos[max]!=NULL) max++; | 4764 | while (Backup.CallerLogos[max]!=NULL) max++; |
4765 | for (i=0;i<max;i++) { | 4765 | for (i=0;i<max;i++) { |
4766 | error=Phone->SetBitmap(&s,Backup.CallerLogos[i]); | 4766 | error=Phone->SetBitmap(&s,Backup.CallerLogos[i]); |
4767 | Print_Error(error); | 4767 | Print_Error(error); |
4768 | printmsgerr("%cWriting: %i percent",13,(i+1)*100/max); | 4768 | printmsgerr("%cWriting: %i percent",13,(i+1)*100/max); |
4769 | if (gshutdown) { | 4769 | if (gshutdown) { |
4770 | GSM_Terminate(); | 4770 | GSM_Terminate(); |
4771 | exit(0); | 4771 | exit(0); |
4772 | } | 4772 | } |
4773 | } | 4773 | } |
4774 | printmsgerr("\n"); | 4774 | printmsgerr("\n"); |
4775 | } | 4775 | } |
4776 | 4776 | ||
4777 | if (!mystrncasecmp(s.CurrentConfig->SyncTime,"yes",0)) { | 4777 | if (!mystrncasecmp(s.CurrentConfig->SyncTime,"yes",0)) { |
4778 | if ( true /*LRanswer_yes("Do you want to set date/time in phone (NOTE: in some phones it's required to correctly restore calendar notes and other items)")*/) { | 4778 | if ( true /*LRanswer_yes("Do you want to set date/time in phone (NOTE: in some phones it's required to correctly restore calendar notes and other items)")*/) { |
4779 | GSM_GetCurrentDateTime(&date_time); | 4779 | GSM_GetCurrentDateTime(&date_time); |
4780 | 4780 | ||
4781 | error=Phone->SetDateTime(&s, &date_time); | 4781 | error=Phone->SetDateTime(&s, &date_time); |
4782 | Print_Error(error); | 4782 | Print_Error(error); |
4783 | } | 4783 | } |
4784 | } | 4784 | } |
4785 | DoRestore = false; | 4785 | DoRestore = false; |
4786 | if (Backup.Calendar[0] != NULL) { | 4786 | if (Backup.Calendar[0] != NULL) { |
4787 | /* N6110 doesn't support getting calendar status */ | 4787 | /* N6110 doesn't support getting calendar status */ |
4788 | error = Phone->GetNextCalendar(&s,&Calendar,true); | 4788 | error = Phone->GetNextCalendar(&s,&Calendar,true); |
4789 | if (error == ERR_NONE || error == ERR_INVALIDLOCATION || error == ERR_EMPTY) { | 4789 | if (error == ERR_NONE || error == ERR_INVALIDLOCATION || error == ERR_EMPTY) { |
4790 | max = 0; | 4790 | max = 0; |
4791 | while (Backup.Calendar[max] != NULL) max++; | 4791 | while (Backup.Calendar[max] != NULL) max++; |
4792 | printmsgerr("%i entries in backup file\n",max); | 4792 | printmsgerr("%i entries in backup file\n",max); |
4793 | // LR | 4793 | // LR |
4794 | //if (answer_yes("Restore calendar notes")) { | 4794 | //if (answer_yes("Restore calendar notes")) { |
4795 | //Past = answer_yes("Restore notes from the past"); | 4795 | //Past = answer_yes("Restore notes from the past"); |
4796 | DoRestore = true; | 4796 | DoRestore = true; |
4797 | //} | 4797 | //} |
4798 | } | 4798 | } |
4799 | } | 4799 | } |
4800 | if (DoRestore) { | 4800 | if (DoRestore) { |
4801 | printmsgerr("Deleting old notes: "); | 4801 | printmsgerr("Deleting old notes: "); |
4802 | error = Phone->DeleteAllCalendar(&s); | 4802 | error = Phone->DeleteAllCalendar(&s); |
4803 | if (error == ERR_NOTSUPPORTED || error == ERR_NOTIMPLEMENTED) { | 4803 | if (error == ERR_NOTSUPPORTED || error == ERR_NOTIMPLEMENTED) { |
4804 | while (1) { | 4804 | while (1) { |
4805 | error = Phone->GetNextCalendar(&s,&Calendar,true); | 4805 | error = Phone->GetNextCalendar(&s,&Calendar,true); |
4806 | if (error != ERR_NONE) break; | 4806 | if (error != ERR_NONE) break; |
4807 | error = Phone->DeleteCalendar(&s,&Calendar); | 4807 | error = Phone->DeleteCalendar(&s,&Calendar); |
4808 | Print_Error(error); | 4808 | Print_Error(error); |
4809 | printmsgerr("*"); | 4809 | printmsgerr("*"); |
4810 | } | 4810 | } |
4811 | printmsgerr("\n"); | 4811 | printmsgerr("\n"); |
4812 | } else { | 4812 | } else { |
4813 | printmsgerr("Done\n"); | 4813 | printmsgerr("Done\n"); |
4814 | Print_Error(error); | 4814 | Print_Error(error); |
4815 | } | 4815 | } |
4816 | 4816 | ||
4817 | for (i=0;i<max;i++) { | 4817 | for (i=0;i<max;i++) { |
4818 | if (!Past && IsCalendarNoteFromThePast(Backup.Calendar[i])) continue; | 4818 | if (!Past && IsCalendarNoteFromThePast(Backup.Calendar[i])) continue; |
4819 | 4819 | ||
4820 | Calendar = *Backup.Calendar[i]; | 4820 | Calendar = *Backup.Calendar[i]; |
4821 | error=Phone->AddCalendar(&s,&Calendar); | 4821 | error=Phone->AddCalendar(&s,&Calendar); |
4822 | Print_Error(error); | 4822 | Print_Error(error); |
diff --git a/kammu.control b/phoneaccess.control index 07559e7..07559e7 100644 --- a/kammu.control +++ b/phoneaccess.control | |||