author | zautrix <zautrix> | 2004-10-10 16:00:04 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-10-10 16:00:04 (UTC) |
commit | ee6e29a5092d32165b7bf6b39069bd8a1dcd5b0a (patch) (unidiff) | |
tree | 1d908bfc23b8a49d43a58bbeadd82c4e08faeff6 /gammu/emb | |
parent | 213a9d993e5a4751b64e18320cfbebb000681d13 (diff) | |
download | kdepimpi-ee6e29a5092d32165b7bf6b39069bd8a1dcd5b0a.zip kdepimpi-ee6e29a5092d32165b7bf6b39069bd8a1dcd5b0a.tar.gz kdepimpi-ee6e29a5092d32165b7bf6b39069bd8a1dcd5b0a.tar.bz2 |
many phone AB sync fixes
-rw-r--r-- | gammu/emb/common/service/gsmmisc.c | 4 | ||||
-rw-r--r-- | gammu/emb/common/service/gsmpbk.c | 17 | ||||
-rw-r--r-- | gammu/emb/gammu/gammu.c | 2 |
3 files changed, 12 insertions, 11 deletions
diff --git a/gammu/emb/common/service/gsmmisc.c b/gammu/emb/common/service/gsmmisc.c index 6959a22..1c6ec8b 100644 --- a/gammu/emb/common/service/gsmmisc.c +++ b/gammu/emb/common/service/gsmmisc.c | |||
@@ -157,101 +157,101 @@ void GSM_IdentifyFileFormat(GSM_File *File) | |||
157 | File->Type = GSM_File_Image_JPG; | 157 | File->Type = GSM_File_Image_JPG; |
158 | } else if (memcmp(File->Buffer, "MThd",4)==0) { | 158 | } else if (memcmp(File->Buffer, "MThd",4)==0) { |
159 | File->Type = GSM_File_Sound_MIDI; | 159 | File->Type = GSM_File_Sound_MIDI; |
160 | } else if (File->Buffer[0] == 0x00 && File->Buffer[1] == 0x02) { | 160 | } else if (File->Buffer[0] == 0x00 && File->Buffer[1] == 0x02) { |
161 | File->Type = GSM_File_Sound_NRT; | 161 | File->Type = GSM_File_Sound_NRT; |
162 | } | 162 | } |
163 | } | 163 | } |
164 | } | 164 | } |
165 | 165 | ||
166 | void SaveVCALDateTime(char *Buffer, int *Length, GSM_DateTime *Date, char *Start) | 166 | void SaveVCALDateTime(char *Buffer, int *Length, GSM_DateTime *Date, char *Start) |
167 | { | 167 | { |
168 | if (Start != NULL) { | 168 | if (Start != NULL) { |
169 | *Length+=sprintf(Buffer+(*Length), "%s:",Start); | 169 | *Length+=sprintf(Buffer+(*Length), "%s:",Start); |
170 | } | 170 | } |
171 | *Length+=sprintf(Buffer+(*Length), "%04d%02d%02dT%02d%02d%02d%c%c", | 171 | *Length+=sprintf(Buffer+(*Length), "%04d%02d%02dT%02d%02d%02d%c%c", |
172 | Date->Year, Date->Month, Date->Day, | 172 | Date->Year, Date->Month, Date->Day, |
173 | Date->Hour, Date->Minute, Date->Second,13,10); | 173 | Date->Hour, Date->Minute, Date->Second,13,10); |
174 | } | 174 | } |
175 | 175 | ||
176 | void ReadVCALDateTime(char *Buffer, GSM_DateTime *dt) | 176 | void ReadVCALDateTime(char *Buffer, GSM_DateTime *dt) |
177 | { | 177 | { |
178 | char year[5]="", month[3]="", day[3]="", hour[3]="", minute[3]="", second[3]=""; | 178 | char year[5]="", month[3]="", day[3]="", hour[3]="", minute[3]="", second[3]=""; |
179 | 179 | ||
180 | memset(dt,0,sizeof(dt)); | 180 | memset(dt,0,sizeof(dt)); |
181 | 181 | ||
182 | strncpy(year, Buffer, 4); | 182 | strncpy(year, Buffer, 4); |
183 | strncpy(month, Buffer+4, 2); | 183 | strncpy(month, Buffer+4, 2); |
184 | strncpy(day, Buffer+6, 2); | 184 | strncpy(day, Buffer+6, 2); |
185 | strncpy(hour, Buffer+9,2); | 185 | strncpy(hour, Buffer+9,2); |
186 | strncpy(minute, Buffer+11,2); | 186 | strncpy(minute, Buffer+11,2); |
187 | strncpy(second, Buffer+13,2); | 187 | strncpy(second, Buffer+13,2); |
188 | 188 | ||
189 | /* FIXME: Should check ranges... */ | 189 | /* FIXME: Should check ranges... */ |
190 | dt->Year= atoi(year); | 190 | dt->Year= atoi(year); |
191 | dt->Month= atoi(month); | 191 | dt->Month= atoi(month); |
192 | dt->Day = atoi(day); | 192 | dt->Day = atoi(day); |
193 | dt->Hour= atoi(hour); | 193 | dt->Hour= atoi(hour); |
194 | dt->Minute= atoi(minute); | 194 | dt->Minute= atoi(minute); |
195 | dt->Second= atoi(second); | 195 | dt->Second= atoi(second); |
196 | /* FIXME */ | 196 | /* FIXME */ |
197 | dt->Timezone= 0; | 197 | dt->Timezone= 0; |
198 | } | 198 | } |
199 | 199 | ||
200 | void SaveVCALText(char *Buffer, int *Length, char *Text, char *Start) | 200 | void SaveVCALText(char *Buffer, int *Length, char *Text, char *Start) |
201 | { | 201 | { |
202 | char buffer[1000]; | 202 | char buffer[1000]; |
203 | 203 | ||
204 | if (UnicodeLength(Text) != 0) { | 204 | if (UnicodeLength(Text) != 0) { |
205 | EncodeUTF8QuotedPrintable(buffer,Text); | 205 | EncodeUTF8(buffer,Text); |
206 | if (UnicodeLength(Text)==strlen(buffer)) { | 206 | if (UnicodeLength(Text)==strlen(buffer)) { |
207 | *Length+=sprintf(Buffer+(*Length), "%s:%s%c%c",Start,DecodeUnicodeString(Text),13,10); | 207 | *Length+=sprintf(Buffer+(*Length), "%s:%s%c%c",Start,DecodeUnicodeString(Text),13,10); |
208 | } else { | 208 | } else { |
209 | *Length+=sprintf(Buffer+(*Length), "%s;CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:%s%c%c",Start,buffer,13,10); | 209 | *Length+=sprintf(Buffer+(*Length), "%s:%s%c%c",Start,buffer,13,10); |
210 | } | 210 | } |
211 | } | 211 | } |
212 | } | 212 | } |
213 | 213 | ||
214 | bool ReadVCALText(char *Buffer, char *Start, char *Value) | 214 | bool ReadVCALText(char *Buffer, char *Start, char *Value) |
215 | { | 215 | { |
216 | unsigned char buff[200]; | 216 | unsigned char buff[200]; |
217 | 217 | ||
218 | Value[0] = 0x00; | 218 | Value[0] = 0x00; |
219 | Value[1] = 0x00; | 219 | Value[1] = 0x00; |
220 | 220 | ||
221 | strcpy(buff,Start); | 221 | strcpy(buff,Start); |
222 | strcat(buff,":"); | 222 | strcat(buff,":"); |
223 | if (!strncmp(Buffer,buff,strlen(buff))) { | 223 | if (!strncmp(Buffer,buff,strlen(buff))) { |
224 | EncodeUnicode(Value,Buffer+strlen(Start)+1,strlen(Buffer)-(strlen(Start)+1)); | 224 | EncodeUnicode(Value,Buffer+strlen(Start)+1,strlen(Buffer)-(strlen(Start)+1)); |
225 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); | 225 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); |
226 | return true; | 226 | return true; |
227 | } | 227 | } |
228 | /* SE T68i */ | 228 | /* SE T68i */ |
229 | strcpy(buff,Start); | 229 | strcpy(buff,Start); |
230 | strcat(buff,";ENCODING=QUOTED-PRINTABLE:"); | 230 | strcat(buff,";ENCODING=QUOTED-PRINTABLE:"); |
231 | if (!strncmp(Buffer,buff,strlen(buff))) { | 231 | if (!strncmp(Buffer,buff,strlen(buff))) { |
232 | DecodeUTF8QuotedPrintable(Value,Buffer+strlen(Start)+27,strlen(Buffer)-(strlen(Start)+27)); | 232 | DecodeUTF8QuotedPrintable(Value,Buffer+strlen(Start)+27,strlen(Buffer)-(strlen(Start)+27)); |
233 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); | 233 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); |
234 | return true; | 234 | return true; |
235 | } | 235 | } |
236 | strcpy(buff,Start); | 236 | strcpy(buff,Start); |
237 | strcat(buff,";CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:"); | 237 | strcat(buff,";CHARSET=UTF-8;ENCODING=QUOTED-PRINTABLE:"); |
238 | if (!strncmp(Buffer,buff,strlen(buff))) { | 238 | if (!strncmp(Buffer,buff,strlen(buff))) { |
239 | DecodeUTF8QuotedPrintable(Value,Buffer+strlen(Start)+41,strlen(Buffer)-(strlen(Start)+41)); | 239 | DecodeUTF8QuotedPrintable(Value,Buffer+strlen(Start)+41,strlen(Buffer)-(strlen(Start)+41)); |
240 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); | 240 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); |
241 | return true; | 241 | return true; |
242 | } | 242 | } |
243 | strcpy(buff,Start); | 243 | strcpy(buff,Start); |
244 | strcat(buff,";CHARSET=UTF-8:"); | 244 | strcat(buff,";CHARSET=UTF-8:"); |
245 | if (!strncmp(Buffer,buff,strlen(buff))) { | 245 | if (!strncmp(Buffer,buff,strlen(buff))) { |
246 | DecodeUTF8(Value,Buffer+strlen(Start)+15,strlen(Buffer)-(strlen(Start)+15)); | 246 | DecodeUTF8(Value,Buffer+strlen(Start)+15,strlen(Buffer)-(strlen(Start)+15)); |
247 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); | 247 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); |
248 | return true; | 248 | return true; |
249 | } | 249 | } |
250 | strcpy(buff,Start); | 250 | strcpy(buff,Start); |
251 | strcat(buff,";CHARSET=UTF-7:"); | 251 | strcat(buff,";CHARSET=UTF-7:"); |
252 | if (!strncmp(Buffer,buff,strlen(buff))) { | 252 | if (!strncmp(Buffer,buff,strlen(buff))) { |
253 | DecodeUTF7(Value,Buffer+strlen(Start)+15,strlen(Buffer)-(strlen(Start)+15)); | 253 | DecodeUTF7(Value,Buffer+strlen(Start)+15,strlen(Buffer)-(strlen(Start)+15)); |
254 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); | 254 | dbgprintf("ReadVCalText is \"%s\"\n",DecodeUnicodeConsole(Value)); |
255 | return true; | 255 | return true; |
256 | } | 256 | } |
257 | return false; | 257 | return false; |
diff --git a/gammu/emb/common/service/gsmpbk.c b/gammu/emb/common/service/gsmpbk.c index 05e5cb9..f7cf7d7 100644 --- a/gammu/emb/common/service/gsmpbk.c +++ b/gammu/emb/common/service/gsmpbk.c | |||
@@ -86,144 +86,145 @@ void GSM_PhonebookFindDefaultNameNumberGroup(GSM_MemoryEntry *entry, int *Name, | |||
86 | if ((*Name) == -1) { | 86 | if ((*Name) == -1) { |
87 | for (i = 0; i < entry->EntriesNum; i++) { | 87 | for (i = 0; i < entry->EntriesNum; i++) { |
88 | if (entry->Entries[i].EntryType != PBK_Text_LastName) continue; | 88 | if (entry->Entries[i].EntryType != PBK_Text_LastName) continue; |
89 | *Name = i; | 89 | *Name = i; |
90 | break; | 90 | break; |
91 | } | 91 | } |
92 | } | 92 | } |
93 | if ((*Name) == -1) { | 93 | if ((*Name) == -1) { |
94 | for (i = 0; i < entry->EntriesNum; i++) { | 94 | for (i = 0; i < entry->EntriesNum; i++) { |
95 | if (entry->Entries[i].EntryType != PBK_Text_FirstName) continue; | 95 | if (entry->Entries[i].EntryType != PBK_Text_FirstName) continue; |
96 | *Name = i; | 96 | *Name = i; |
97 | break; | 97 | break; |
98 | } | 98 | } |
99 | } | 99 | } |
100 | } | 100 | } |
101 | 101 | ||
102 | void GSM_EncodeVCARD(char *Buffer, int *Length, GSM_MemoryEntry *pbk, bool header, GSM_VCardVersion Version) | 102 | void GSM_EncodeVCARD(char *Buffer, int *Length, GSM_MemoryEntry *pbk, bool header, GSM_VCardVersion Version) |
103 | { | 103 | { |
104 | int Name, Number, Group, i; | 104 | int Name, Number, Group, i; |
105 | bool ignore; | 105 | bool ignore; |
106 | 106 | ||
107 | GSM_PhonebookFindDefaultNameNumberGroup(pbk, &Name, &Number, &Group); | 107 | GSM_PhonebookFindDefaultNameNumberGroup(pbk, &Name, &Number, &Group); |
108 | 108 | ||
109 | if (Version == Nokia_VCard10) { | 109 | if (Version == Nokia_VCard10) { |
110 | if (header) *Length+=sprintf(Buffer+(*Length),"BEGIN:VCARD%c%c",13,10); | 110 | if (header) *Length+=sprintf(Buffer+(*Length),"BEGIN:VCARD%c%c",13,10); |
111 | if (Name != -1) { | 111 | if (Name != -1) { |
112 | *Length+=sprintf(Buffer+(*Length),"N:%s%c%c",DecodeUnicodeString(pbk->Entries[Name].Text),13,10); | 112 | *Length+=sprintf(Buffer+(*Length),"N:%s%c%c",DecodeUnicodeString(pbk->Entries[Name].Text),13,10); |
113 | } | 113 | } |
114 | if (Number != -1) { | 114 | if (Number != -1) { |
115 | *Length +=sprintf(Buffer+(*Length),"TEL:%s%c%c",DecodeUnicodeString(pbk->Entries[Number].Text),13,10); | 115 | *Length +=sprintf(Buffer+(*Length),"TEL:%s%c%c",DecodeUnicodeString(pbk->Entries[Number].Text),13,10); |
116 | } | 116 | } |
117 | if (header) *Length+=sprintf(Buffer+(*Length),"END:VCARD%c%c",13,10); | 117 | if (header) *Length+=sprintf(Buffer+(*Length),"END:VCARD%c%c",13,10); |
118 | } else if (Version == Nokia_VCard21) { | 118 | } else if (Version == Nokia_VCard21) { |
119 | if (header) *Length+=sprintf(Buffer+(*Length),"BEGIN:VCARD%c%cVERSION:2.1%c%c",13,10,13,10); | 119 | if (header) *Length+=sprintf(Buffer+(*Length),"BEGIN:VCARD%c%cVERSION:2.1%c%c",13,10,13,10); |
120 | if (Name != -1) { | 120 | if (Name != -1) { |
121 | SaveVCALText(Buffer, Length, pbk->Entries[Name].Text, "N"); | 121 | SaveVCALText(Buffer, Length, pbk->Entries[Name].Text, "N"); |
122 | } | 122 | } |
123 | for (i=0; i < pbk->EntriesNum; i++) { | 123 | for (i=0; i < pbk->EntriesNum; i++) { |
124 | if (i != Name) { | 124 | if (i != Name) { |
125 | ignore = false; | 125 | ignore = false; |
126 | switch(pbk->Entries[i].EntryType) { | 126 | switch(pbk->Entries[i].EntryType) { |
127 | case PBK_Text_Name : | 127 | case PBK_Text_Name : |
128 | case PBK_Date : | 128 | case PBK_Date : |
129 | case PBK_Caller_Group : | 129 | case PBK_Caller_Group : |
130 | ignore = true; | 130 | ignore = true; |
131 | break; | 131 | break; |
132 | case PBK_Number_General : | 132 | case PBK_Number_General : |
133 | *Length+=sprintf(Buffer+(*Length),"TEL"); | 133 | *Length+=sprintf(Buffer+(*Length),"TEL"); |
134 | if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); | 134 | (*Length)+=sprintf(Buffer+(*Length),";PREF"); |
135 | break; | 135 | break; |
136 | case PBK_Number_Mobile : | 136 | case PBK_Number_Mobile : |
137 | *Length+=sprintf(Buffer+(*Length),"TEL"); | 137 | *Length+=sprintf(Buffer+(*Length),"TEL"); |
138 | if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); | 138 | //if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); |
139 | *Length+=sprintf(Buffer+(*Length),";CELL"); | 139 | *Length+=sprintf(Buffer+(*Length),";CELL"); |
140 | break; | 140 | break; |
141 | case PBK_Number_Work : | 141 | case PBK_Number_Work : |
142 | *Length+=sprintf(Buffer+(*Length),"TEL"); | 142 | *Length+=sprintf(Buffer+(*Length),"TEL"); |
143 | if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); | 143 | //if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); |
144 | *Length+=sprintf(Buffer+(*Length),";WORK;VOICE"); | 144 | *Length+=sprintf(Buffer+(*Length),";WORK"); |
145 | break; | 145 | break; |
146 | case PBK_Number_Fax : | 146 | case PBK_Number_Fax : |
147 | *Length+=sprintf(Buffer+(*Length),"TEL"); | 147 | *Length+=sprintf(Buffer+(*Length),"TEL"); |
148 | if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); | 148 | //if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); |
149 | *Length+=sprintf(Buffer+(*Length),";FAX"); | 149 | *Length+=sprintf(Buffer+(*Length),";FAX"); |
150 | break; | 150 | break; |
151 | case PBK_Number_Home : | 151 | case PBK_Number_Home : |
152 | *Length+=sprintf(Buffer+(*Length),"TEL"); | 152 | *Length+=sprintf(Buffer+(*Length),"TEL"); |
153 | if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); | 153 | //if (Number == i) (*Length)+=sprintf(Buffer+(*Length),";PREF"); |
154 | *Length+=sprintf(Buffer+(*Length),";HOME;VOICE"); | 154 | *Length+=sprintf(Buffer+(*Length),";HOME"); |
155 | break; | 155 | break; |
156 | case PBK_Text_Note : | 156 | case PBK_Text_Note : |
157 | *Length+=sprintf(Buffer+(*Length),"NOTE"); | 157 | *Length+=sprintf(Buffer+(*Length),"NOTE"); |
158 | break; | 158 | break; |
159 | case PBK_Text_Postal : | 159 | case PBK_Text_Postal : |
160 | /* Don't ask why. Nokia phones save postal address | 160 | /* Don't ask why. Nokia phones save postal address |
161 | * double - once like LABEL, second like ADR | 161 | * double - once like LABEL, second like ADR |
162 | */ | 162 | */ |
163 | SaveVCALText(Buffer, Length, pbk->Entries[i].Text, "LABEL"); | 163 | //SaveVCALText(Buffer, Length, pbk->Entries[i].Text, "LABEL"); |
164 | *Length+=sprintf(Buffer+(*Length),"ADR"); | 164 | *Length+=sprintf(Buffer+(*Length),"ADR"); |
165 | break; | 165 | break; |
166 | case PBK_Text_Email : | 166 | case PBK_Text_Email : |
167 | case PBK_Text_Email2 : | 167 | case PBK_Text_Email2 : |
168 | *Length+=sprintf(Buffer+(*Length),"EMAIL"); | 168 | *Length+=sprintf(Buffer+(*Length),"EMAIL"); |
169 | break; | 169 | break; |
170 | case PBK_Text_URL : | 170 | case PBK_Text_URL : |
171 | *Length+=sprintf(Buffer+(*Length),"URL"); | 171 | *Length+=sprintf(Buffer+(*Length),"URL"); |
172 | break; | 172 | break; |
173 | default : | 173 | default : |
174 | ignore = true; | 174 | ignore = true; |
175 | break; | 175 | break; |
176 | } | 176 | } |
177 | if (!ignore) { | 177 | if (!ignore) { |
178 | SaveVCALText(Buffer, Length, pbk->Entries[i].Text, ""); | 178 | SaveVCALText(Buffer, Length, pbk->Entries[i].Text, ""); |
179 | } | 179 | } |
180 | } | 180 | } |
181 | } | 181 | } |
182 | *Length+=sprintf(Buffer+(*Length), "X-KADDRESSBOOK-X-ExternalID:%d%c%c",pbk->Location,13,10); | ||
182 | if (header) *Length+=sprintf(Buffer+(*Length),"END:VCARD%c%c",13,10); | 183 | if (header) *Length+=sprintf(Buffer+(*Length),"END:VCARD%c%c",13,10); |
183 | } | 184 | } |
184 | } | 185 | } |
185 | 186 | ||
186 | GSM_Error GSM_DecodeVCARD(unsigned char *Buffer, int *Pos, GSM_MemoryEntry *Pbk, GSM_VCardVersion Version) | 187 | GSM_Error GSM_DecodeVCARD(unsigned char *Buffer, int *Pos, GSM_MemoryEntry *Pbk, GSM_VCardVersion Version) |
187 | { | 188 | { |
188 | unsigned char Line[2000],Buff[2000]; | 189 | unsigned char Line[2000],Buff[2000]; |
189 | int Level = 0; | 190 | int Level = 0; |
190 | 191 | ||
191 | Buff[0] = 0; | 192 | Buff[0] = 0; |
192 | Pbk->EntriesNum = 0; | 193 | Pbk->EntriesNum = 0; |
193 | 194 | ||
194 | while (1) { | 195 | while (1) { |
195 | MyGetLine(Buffer, Pos, Line, strlen(Buffer)); | 196 | MyGetLine(Buffer, Pos, Line, strlen(Buffer)); |
196 | if (strlen(Line) == 0) break; | 197 | if (strlen(Line) == 0) break; |
197 | switch (Level) { | 198 | switch (Level) { |
198 | case 0: | 199 | case 0: |
199 | if (strstr(Line,"BEGIN:VCARD")) Level = 1; | 200 | if (strstr(Line,"BEGIN:VCARD")) Level = 1; |
200 | break; | 201 | break; |
201 | case 1: | 202 | case 1: |
202 | if (strstr(Line,"END:VCARD")) { | 203 | if (strstr(Line,"END:VCARD")) { |
203 | if (Pbk->EntriesNum == 0) return ERR_EMPTY; | 204 | if (Pbk->EntriesNum == 0) return ERR_EMPTY; |
204 | return ERR_NONE; | 205 | return ERR_NONE; |
205 | } | 206 | } |
206 | if (ReadVCALText(Line, "N", Buff)) { | 207 | if (ReadVCALText(Line, "N", Buff)) { |
207 | CopyUnicodeString(Pbk->Entries[Pbk->EntriesNum].Text,Buff); | 208 | CopyUnicodeString(Pbk->Entries[Pbk->EntriesNum].Text,Buff); |
208 | Pbk->Entries[Pbk->EntriesNum].EntryType = PBK_Text_Name; | 209 | Pbk->Entries[Pbk->EntriesNum].EntryType = PBK_Text_Name; |
209 | Pbk->EntriesNum++; | 210 | Pbk->EntriesNum++; |
210 | } | 211 | } |
211 | if (ReadVCALText(Line, "TEL", Buff) || | 212 | if (ReadVCALText(Line, "TEL", Buff) || |
212 | ReadVCALText(Line, "TEL;VOICE", Buff) || | 213 | ReadVCALText(Line, "TEL;VOICE", Buff) || |
213 | ReadVCALText(Line, "TEL;PREF", Buff) || | 214 | ReadVCALText(Line, "TEL;PREF", Buff) || |
214 | ReadVCALText(Line, "TEL;PREF;VOICE", Buff)) { | 215 | ReadVCALText(Line, "TEL;PREF;VOICE", Buff)) { |
215 | CopyUnicodeString(Pbk->Entries[Pbk->EntriesNum].Text,Buff); | 216 | CopyUnicodeString(Pbk->Entries[Pbk->EntriesNum].Text,Buff); |
216 | Pbk->Entries[Pbk->EntriesNum].EntryType = PBK_Number_General; | 217 | Pbk->Entries[Pbk->EntriesNum].EntryType = PBK_Number_General; |
217 | Pbk->EntriesNum++; | 218 | Pbk->EntriesNum++; |
218 | } | 219 | } |
219 | if (ReadVCALText(Line, "TEL;CELL", Buff) || | 220 | if (ReadVCALText(Line, "TEL;CELL", Buff) || |
220 | ReadVCALText(Line, "TEL;CELL;VOICE", Buff) || | 221 | ReadVCALText(Line, "TEL;CELL;VOICE", Buff) || |
221 | ReadVCALText(Line, "TEL;PREF;CELL", Buff) || | 222 | ReadVCALText(Line, "TEL;PREF;CELL", Buff) || |
222 | ReadVCALText(Line, "TEL;PREF;CELL;VOICE", Buff)) { | 223 | ReadVCALText(Line, "TEL;PREF;CELL;VOICE", Buff)) { |
223 | CopyUnicodeString(Pbk->Entries[Pbk->EntriesNum].Text,Buff); | 224 | CopyUnicodeString(Pbk->Entries[Pbk->EntriesNum].Text,Buff); |
224 | Pbk->Entries[Pbk->EntriesNum].EntryType = PBK_Number_Mobile; | 225 | Pbk->Entries[Pbk->EntriesNum].EntryType = PBK_Number_Mobile; |
225 | Pbk->EntriesNum++; | 226 | Pbk->EntriesNum++; |
226 | } | 227 | } |
227 | if (ReadVCALText(Line, "TEL;WORK", Buff) || | 228 | if (ReadVCALText(Line, "TEL;WORK", Buff) || |
228 | ReadVCALText(Line, "TEL;PREF;WORK", Buff) || | 229 | ReadVCALText(Line, "TEL;PREF;WORK", Buff) || |
229 | ReadVCALText(Line, "TEL;WORK;VOICE", Buff) || | 230 | ReadVCALText(Line, "TEL;WORK;VOICE", Buff) || |
diff --git a/gammu/emb/gammu/gammu.c b/gammu/emb/gammu/gammu.c index 8db9afb..684e67c 100644 --- a/gammu/emb/gammu/gammu.c +++ b/gammu/emb/gammu/gammu.c | |||
@@ -4641,97 +4641,97 @@ static void Restore(int argc, char *argv[]) | |||
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 | /* LR 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++; |