+}
+
+void ContactDataObject::SaveNote(map<int, wxString> *NoteList, map<int, wxString> *NoteListLanguage,
+ map<int, wxString> *NoteListAltID, map<int, wxString> *NoteListPID,
+ map<int, wxString> *NoteListType, map<int, int> *NoteListPref,
+ map<int, wxString> *NoteListTokens, wxString *SaveData, wxString DataType){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator NoteIter = NoteList->begin();
+ NoteIter != NoteList->end(); NoteIter++){
+
+ ProcessData.Append("NOTE");
+
+ // Check if there is a value for TYPE.
+
+ if (DataType.size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append(DataType);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*NoteListAltID)[NoteIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*NoteListAltID)[NoteIter->first]);
+
+ }
+
+ // Check if there is a value for LANGUAGE.
+
+ if ((*NoteListLanguage)[NoteIter->first].size() > 0){
+
+ ProcessData.Append(";LANGUAGE=");
+ ProcessData.Append((*NoteListLanguage)[NoteIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*NoteListPID)[NoteIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*NoteListPID)[NoteIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*NoteListPref)[NoteIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*NoteListPref)[NoteIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*NoteListTokens)[NoteIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*NoteListTokens)[NoteIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(NoteIter->second);
+ ProcessData.Replace("\n", "\\n", true);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveCategory(map<int, wxString> *CategoryList, map<int, wxString> *CategoryListLanguage,
+ map<int, wxString> *CategoryListAltID, map<int, wxString> *CategoryListPID,
+ map<int, wxString> *CategoryListType, map<int, int> *CategoryListPref,
+ map<int, wxString> *CategoryListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator CategoryIter = CategoryList->begin();
+ CategoryIter != CategoryList->end(); CategoryIter++){
+
+ ProcessData.Append("CATEGORIES");
+
+ // Check if there is a value for TYPE.
+
+ if ((*CategoryListType)[CategoryIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*CategoryListType)[CategoryIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*CategoryListAltID)[CategoryIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*CategoryListAltID)[CategoryIter->first]);
+
+ }
+
+ // Check if there is a value for LANGUAGE.
+
+ if ((*CategoryListLanguage)[CategoryIter->first].size() > 0){
+
+ ProcessData.Append(";LANGUAGE=");
+ ProcessData.Append((*CategoryListLanguage)[CategoryIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*CategoryListPID)[CategoryIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*CategoryListPID)[CategoryIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*CategoryListPref)[CategoryIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*CategoryListPref)[CategoryIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*CategoryListTokens)[CategoryIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*CategoryListTokens)[CategoryIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(CategoryIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SavePhoto(map<int, string> *PicturesList, map<int, wxString> *PicturesListAltID,
+ map<int, wxString> *PicturesListPID, map<int, wxString> *PicturesListType,
+ map<int, wxString> *PicturesListPicEncType, map<int, wxString> *PicturesListPictureType,
+ map<int, wxString> *PicturesListMediatype, map<int, int> *PicturesListPref,
+ map<int, wxString> *PicturesListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, string>::iterator PicturesIter = PicturesList->begin();
+ PicturesIter != PicturesList->end(); PicturesIter++){
+
+ ProcessData.Append("PHOTO");
+
+ // Check if there is a value for TYPE.
+
+ if ((*PicturesListType)[PicturesIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*PicturesListType)[PicturesIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*PicturesListAltID)[PicturesIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*PicturesListAltID)[PicturesIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE..
+
+ if ((*PicturesListMediatype)[PicturesIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*PicturesListMediatype)[PicturesIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*PicturesListPID)[PicturesIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*PicturesListPID)[PicturesIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*PicturesListPref)[PicturesIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*PicturesListPref)[PicturesIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*PicturesListTokens)[PicturesIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*PicturesListTokens)[PicturesIter->first]);
+
+ }
+
+ ProcessData.Append(":data:");
+ ProcessData.Append((*PicturesListPictureType)[PicturesIter->first]);
+ ProcessData.Append(";");
+ ProcessData.Append((*PicturesListPicEncType)[PicturesIter->first]);
+ ProcessData.Append(",");
+ ProcessData.Append(PicturesIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveLogo(map<int, string> *LogosList, map<int, wxString> *LogosListAltID,
+ map<int, wxString> *LogosListPID, map<int, wxString> *LogosListType,
+ map<int, wxString> *LogosListPicEncType, map<int, wxString> *LogosListPictureType,
+ map<int, wxString> *LogosListMediatype, map<int, int> *LogosListPref,
+ map<int, wxString> *LogosListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, string>::iterator LogosIter = LogosList->begin();
+ LogosIter != LogosList->end(); LogosIter++){
+
+ ProcessData.Append("LOGO");
+
+ // Check if there is a value for TYPE.
+
+ if ((*LogosListType)[LogosIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*LogosListType)[LogosIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*LogosListAltID)[LogosIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*LogosListAltID)[LogosIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE..
+
+ if ((*LogosListMediatype)[LogosIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*LogosListMediatype)[LogosIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*LogosListPID)[LogosIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*LogosListPID)[LogosIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*LogosListPref)[LogosIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*LogosListPref)[LogosIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*LogosListTokens)[LogosIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*LogosListTokens)[LogosIter->first]);
+
+ }
+
+ ProcessData.Append(":data:");
+ ProcessData.Append((*LogosListPictureType)[LogosIter->first]);
+ ProcessData.Append(";");
+ ProcessData.Append((*LogosListPicEncType)[LogosIter->first]);
+ ProcessData.Append(",");
+ ProcessData.Append(LogosIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveSound(map<int, string> *SoundsList, map<int, wxString> *SoundsListAltID,
+ map<int, wxString> *SoundsListPID, map<int, wxString> *SoundsListType,
+ map<int, wxString> *SoundsListAudioEncType, map<int, wxString> *SoundsListAudioType,
+ map<int, wxString> *SoundsListMediatype, map<int, wxString> *SoundsListLanguage,
+ map<int, int> *SoundsListPref, map<int, wxString> *SoundsListTokens,
+ wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, string>::iterator SoundsIter = SoundsList->begin();
+ SoundsIter != SoundsList->end(); SoundsIter++){
+
+ ProcessData.Append("SOUND");
+
+ // Check if there is a value for TYPE.
+
+ if ((*SoundsListType)[SoundsIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*SoundsListType)[SoundsIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*SoundsListAltID)[SoundsIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*SoundsListAltID)[SoundsIter->first]);
+
+ }
+
+ // Check if there is a value for LANGUAGE.
+
+ if ((*SoundsListLanguage)[SoundsIter->first].size() > 0){
+
+ ProcessData.Append(";LANGUAGE=");
+ ProcessData.Append((*SoundsListLanguage)[SoundsIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE.
+
+ if ((*SoundsListMediatype)[SoundsIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*SoundsListMediatype)[SoundsIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*SoundsListPID)[SoundsIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*SoundsListPID)[SoundsIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*SoundsListPref)[SoundsIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*SoundsListPref)[SoundsIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*SoundsListTokens)[SoundsIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*SoundsListTokens)[SoundsIter->first]);
+
+ }
+
+ ProcessData.Append(":data:");
+ ProcessData.Append((*SoundsListAudioType)[SoundsIter->first]);
+ ProcessData.Append(";");
+ ProcessData.Append((*SoundsListAudioEncType)[SoundsIter->first]);
+ ProcessData.Append(",");
+ ProcessData.Append(SoundsIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveCalendarURI(map<int, wxString> *CalendarList, map<int, wxString> *CalendarListMediatype,
+ map<int, wxString> *CalendarListAltID, map<int, wxString> *CalendarListPID,
+ map<int, wxString> *CalendarListType, map<int, int> *CalendarListPref,
+ map<int, wxString> *CalendarListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator CalendarIter = CalendarList->begin();
+ CalendarIter != CalendarList->end(); CalendarIter++){
+
+ ProcessData.Append("CALURI");
+
+ // Check if there is a value for TYPE.
+
+ if ((*CalendarListType)[CalendarIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*CalendarListType)[CalendarIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*CalendarListAltID)[CalendarIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*CalendarListAltID)[CalendarIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE.
+
+ if ((*CalendarListMediatype)[CalendarIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*CalendarListMediatype)[CalendarIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*CalendarListPID)[CalendarIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*CalendarListPID)[CalendarIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*CalendarListPref)[CalendarIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*CalendarListPref)[CalendarIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*CalendarListTokens)[CalendarIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*CalendarListTokens)[CalendarIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(CalendarIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveCalendarRequestURI(map<int, wxString> *CalendarRequestList, map<int, wxString> *CalendarRequestListMediatype,
+ map<int, wxString> *CalendarRequestListAltID, map<int, wxString> *CalendarRequestListPID,
+ map<int, wxString> *CalendarRequestListType, map<int, int> *CalendarRequestListPref,
+ map<int, wxString> *CalendarRequestListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator CalendarRequestIter = CalendarRequestList->begin();
+ CalendarRequestIter != CalendarRequestList->end(); CalendarRequestIter++){
+
+ ProcessData.Append("CALADRURI");
+
+ // Check if there is a value for TYPE.
+
+ if ((*CalendarRequestListType)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*CalendarRequestListType)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*CalendarRequestListAltID)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*CalendarRequestListAltID)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE.
+
+ if ((*CalendarRequestListMediatype)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*CalendarRequestListMediatype)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*CalendarRequestListPID)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*CalendarRequestListPID)[CalendarRequestIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*CalendarRequestListPref)[CalendarRequestIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*CalendarRequestListPref)[CalendarRequestIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*CalendarRequestListTokens)[CalendarRequestIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*CalendarRequestListTokens)[CalendarRequestIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(CalendarRequestIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveFreeBusyURI(std::map<int, wxString> *FreeBusyList, std::map<int, wxString> *FreeBusyListAltID,
+ std::map<int, wxString> *FreeBusyListPID, std::map<int, wxString> *FreeBusyListType,
+ std::map<int, wxString> *FreeBusyListMediatype, std::map<int, int> *FreeBusyListPref,
+ std::map<int, wxString> *FreeBusyListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator FreeBusyIter = FreeBusyList->begin();
+ FreeBusyIter != FreeBusyList->end(); FreeBusyIter++){
+
+ ProcessData.Append("FBURL");
+
+ // Check if there is a value for TYPE.
+
+ if ((*FreeBusyListType)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*FreeBusyListType)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*FreeBusyListAltID)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*FreeBusyListAltID)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for MEDIATYPE.
+
+ if ((*FreeBusyListMediatype)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";MEDIATYPE=");
+ ProcessData.Append((*FreeBusyListMediatype)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*FreeBusyListPID)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*FreeBusyListPID)[FreeBusyIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*FreeBusyListPref)[FreeBusyIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*FreeBusyListPref)[FreeBusyIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*FreeBusyListTokens)[FreeBusyIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*FreeBusyListTokens)[FreeBusyIter->first]);
+
+ }
+
+ ProcessData.Append(":");
+ ProcessData.Append(FreeBusyIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveKey(map<int, wxString> *KeyList, map<int, wxString> *KeyListAltID,
+ map<int, wxString> *KeyListPID, map<int, wxString> *KeyListType,
+ map<int, bool> *KeyListKeyType, map<int, wxString> *KeyListDataEncType,
+ map<int, wxString> *KeyListDataType, map<int, int> *KeyListPref,
+ map<int, wxString> *KeyListTokens, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator KeyIter = KeyList->begin();
+ KeyIter != KeyList->end(); KeyIter++){
+
+ ProcessData.Append("KEY");
+
+ // Check if there is a value for TYPE.
+
+ if ((*KeyListType)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";TYPE=");
+ ProcessData.Append((*KeyListType)[KeyIter->first]);
+
+ }
+
+ // Check if there is a value for ALTID.
+
+ if ((*KeyListAltID)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";ALTID=");
+ ProcessData.Append((*KeyListAltID)[KeyIter->first]);
+
+ }
+
+ // Check if there is a value for PID.
+
+ if ((*KeyListPID)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";PID=");
+ ProcessData.Append((*KeyListPID)[KeyIter->first]);
+
+ }
+
+ // Check if there is a value for PREF.
+
+ if ((*KeyListPref)[KeyIter->first] > 0){
+
+ ProcessData.Append(";PREF=");
+ ProcessData.Append(wxString::Format("%i", (*KeyListPref)[KeyIter->first]));
+
+ }
+
+ // Check if there is a value for tokens.
+
+ if ((*KeyListTokens)[KeyIter->first].size() > 0){
+
+ ProcessData.Append(";");
+ ProcessData.Append((*KeyListTokens)[KeyIter->first]);
+
+ }
+
+ ProcessData.Append(":data:");
+ ProcessData.Append((*KeyListDataType)[KeyIter->first]);
+ ProcessData.Append(";");
+ ProcessData.Append((*KeyListDataEncType)[KeyIter->first]);
+ ProcessData.Append(",");
+ ProcessData.Append(KeyIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveVendor(map<int, wxString> *VendorList, map<int, wxString> *VendorListPEN,
+ map<int, wxString> *VendorListElement, wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator VendorIter = VendorList->begin();
+ VendorIter != VendorList->end(); VendorIter++){
+
+ ProcessData.Append("VND-");
+ ProcessData.Append((*VendorListPEN)[VendorIter->first]);
+ ProcessData.Append("-");
+ ProcessData.Append((*VendorListElement)[VendorIter->first]);
+ ProcessData.Append(":");
+ ProcessData.Append(VendorIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+
+}
+
+void ContactDataObject::SaveXToken(map<int, wxString> *XTokenList, map<int, wxString> *XTokenListTokens,
+ wxString *SaveData){
+
+ wxString ProcessData = "";
+
+ for (std::map<int, wxString>::iterator XTokenIter = XTokenList->begin();
+ XTokenIter != XTokenList->end(); XTokenIter++){
+
+ ProcessData.Append("X-");
+ ProcessData.Append((*XTokenListTokens)[XTokenIter->first]);
+ ProcessData.Append(":");
+ ProcessData.Append(XTokenIter->second);
+ ProcessData.Append("\n");
+
+ ProcessData = OutputText(&ProcessData);
+
+ SaveData->Append(ProcessData);
+ ProcessData.clear();
+
+ }
+