Home | News | Projects | Releases
Bugs | RFE | Repositories | Help
Added stub for saving REV in the SaveString function of ContactDataObject
[xestiaab/.git] / source / contacteditor / cdo / ContactDataObject-Save.cpp
index 4046edf..c3c9b4a 100644 (file)
@@ -36,25 +36,121 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
        
 #else
        
-       SaveData->Append(wxT("-//Xestia//Address Book Version "));
+       SaveData->Append(wxT("PRODID:-//Xestia//Address Book Version "));
        SaveData->Append(wxT(XSDAB_VERSION));
        SaveData->Append(wxT("//KW\n"));
        
 #endif
+
+       wxString ProcessData = "";
+
+       // Process UID.
+
+       if (UIDToken.size() > 0){
+               
+               ProcessData.Append("UID:");
+               ProcessData.Append(UIDToken);
+               ProcessData.Append("\n");
+               SaveData->Append(ProcessData);
+               ProcessData.clear();
+               
+       }
+       
+       // Process KIND.
+       
+       switch(ContactKind){
+
+               case CONTACTKIND_NONE:
+                       break;
+               case CONTACTKIND_INDIVIDUAL:
+                       SaveData->Append("KIND:individual\n");
+                       break;
+               case CONTACTKIND_GROUP:
+                       SaveData->Append("KIND:group\n");
+                       break;
+               case CONTACTKIND_ORGANISATION:
+                       SaveData->Append("KIND:org\n");
+                       break;
+               case CONTACTKIND_LOCATION:
+                       SaveData->Append("KIND:location\n");
+                       break;
+               default:
+                       break;
+               
+       }
+       
+       // TODO: Sortout REV.
+       
+       // Process XML.
+
+       for (std::map<int, wxString>::iterator XMLIter = XMLList.begin();
+               XMLIter != XMLList.end(); XMLIter++){
+       
+               ProcessData.Append("XML");
+                       
+               if (XMLListAltID[XMLIter->first].size() > 0){
+               
+                       ProcessData.Append(";ALTID=");
+                       ProcessData.Append(XMLListAltID[XMLIter->first]);
+                       
+               }
+                       
+               ProcessData.Append(":");
+               ProcessData.Append(XMLIter->second);
+               ProcessData.Append("\n");
+               
+               ProcessData = OutputText(&ProcessData);
+               
+               SaveData->Append(ProcessData);
+               ProcessData.clear();
+                       
+       }
+       
+       // Process SOURCE.
+       
+       SaveSource(&SourceList, &SourceListAltID, 
+               &SourceListPID, &SourceListType,
+               &SourceListMediatype, &SourceListPref, 
+               &SourceListTokens, SaveData);
+       
+       // Process CLIENTPIDMAP.
+       
+       for (std::map<int, wxString>::iterator CPIDIter = ClientPIDList.begin();
+               CPIDIter != ClientPIDList.end(); CPIDIter++){
+       
+               ProcessData.Append("CLIENTPIDMAP");
+                       
+               if (ClientPIDListTokens[CPIDIter->first].size() > 0){
+               
+                       ProcessData.Append(";");
+                       ProcessData.Append(ClientPIDListTokens[CPIDIter->first]);
+                       
+               }
+                       
+               ProcessData.Append(":");
+               ProcessData.Append(CPIDIter->second);
+               ProcessData.Append("\n");
+               
+               ProcessData = OutputText(&ProcessData);
+               
+               SaveData->Append(ProcessData);
+               ProcessData.clear();
+                       
+       }
        
        // Process FN.
        
        for (std::map<int, wxString>::iterator FNIter = FullNamesList.begin();
                FNIter != FullNamesList.end(); FNIter++){
                
-               SaveData->Append("FN");
+               ProcessData.Append("FN");
 
                // Check if there is a value for TYPE.
                
                if (FullNamesListType[FNIter->first].size() > 0){
                
-                       SaveData->Append(";TYPE=");
-                       SaveData->Append(FullNamesListType[FNIter->first]);
+                       ProcessData.Append(";TYPE=");
+                       ProcessData.Append(FullNamesListType[FNIter->first]);
                        
                }
 
@@ -62,8 +158,8 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
                
                if (FullNamesListLanguage[FNIter->first].size() > 0){
                
-                       SaveData->Append(";LANGUAGE=");
-                       SaveData->Append(FullNamesListLanguage[FNIter->first]);
+                       ProcessData.Append(";LANGUAGE=");
+                       ProcessData.Append(FullNamesListLanguage[FNIter->first]);
                        
                }
                
@@ -71,8 +167,8 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
                
                if (FullNamesListAltID[FNIter->first].size() > 0){
                
-                       SaveData->Append(";ALTID=");
-                       SaveData->Append(FullNamesListAltID[FNIter->first]);
+                       ProcessData.Append(";ALTID=");
+                       ProcessData.Append(FullNamesListAltID[FNIter->first]);
                        
                }
                
@@ -80,8 +176,8 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
 
                if (FullNamesListPID[FNIter->first].size() > 0){
                
-                       SaveData->Append(";PID=");
-                       SaveData->Append(FullNamesListPID[FNIter->first]);
+                       ProcessData.Append(";PID=");
+                       ProcessData.Append(FullNamesListPID[FNIter->first]);
                        
                }
 
@@ -89,8 +185,8 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
 
                if (FullNamesListPref[FNIter->first] > 0){
                
-                       SaveData->Append(";PREF=");
-                       SaveData->Append(wxString::Format("%i", FullNamesListPref[FNIter->first]));
+                       ProcessData.Append(";PREF=");
+                       ProcessData.Append(wxString::Format("%i", FullNamesListPref[FNIter->first]));
                        
                }
 
@@ -98,27 +194,36 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
 
                if (FullNamesListTokens[FNIter->first].size() > 0){
                
-                       SaveData->Append(";");
-                       SaveData->Append(FullNamesListTokens[FNIter->first]);
+                       ProcessData.Append(";");
+                       ProcessData.Append(FullNamesListTokens[FNIter->first]);
                        
                }
                
-               SaveData->Append(":");
-               SaveData->Append(FNIter->second);
-               SaveData->Append("\n");
+               ProcessData.Append(":");
+               ProcessData.Append(FNIter->second);
+               ProcessData.Append("\n");
+               
+               ProcessData = OutputText(&ProcessData);
+               
+               SaveData->Append(ProcessData);
+               ProcessData.clear();
                        
        }
        
        // Process TITLE.
 
-       for (std::map<int, wxString>::iterator TitleIter = GeneralTitleList.begin();
-               TitleIter != GeneralTitleList.end(); TitleIter++){
-               
-               SaveData->Append("TITLE:");
-               SaveData->Append(TitleIter->second);
-               SaveData->Append("\n");
-                       
-       }
+       SaveTitle(&GeneralTitleList, &GeneralTitleListLanguage,
+               &GeneralTitleListAltID, &GeneralTitleListPID,
+               &GeneralTitleListType, &GeneralTitleListPref,
+               &GeneralTitleListTokens, SaveData, "");
+       SaveTitle(&HomeTitleList, &HomeTitleListLanguage,
+               &HomeTitleListAltID, &HomeTitleListPID,
+               &HomeTitleListType, &HomeTitleListPref,
+               &HomeTitleListTokens, SaveData, "home");
+       SaveTitle(&BusinessTitleList, &BusinessTitleListLanguage,
+               &BusinessTitleListAltID, &BusinessTitleListPID,
+               &BusinessTitleListType, &BusinessTitleListPref,
+               &BusinessTitleListTokens, SaveData, "work");
        
        // Write the end part of the vCard data file.
        
@@ -128,4 +233,162 @@ ContactSaveStatus ContactDataObject::SaveString(wxString *SaveData){
        
        return SaveDataStatus;
        
+}
+
+void ContactDataObject::SaveTitle(map<int, wxString> *TitleList, map<int, wxString> *TitleListLanguage,
+       map<int, wxString> *TitleListAltID, map<int, wxString> *TitleListPID,
+       map<int, wxString> *TitleListType, map<int, int> *TitleListPref,
+       map<int, wxString> *TitleListTokens, wxString *SaveData, wxString DataType){
+
+       wxString ProcessData = "";
+               
+       for (std::map<int, wxString>::iterator TitleIter = TitleList->begin();
+               TitleIter != TitleList->end(); TitleIter++){
+
+               ProcessData.Append("TITLE");
+                       
+               // 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 ((*TitleListAltID)[TitleIter->first].size() > 0){
+               
+                       ProcessData.Append(";ALTID=");
+                       ProcessData.Append((*TitleListAltID)[TitleIter->first]);
+                       
+               }
+
+               // Check if there is a value for LANGUAGE.
+               
+               if ((*TitleListLanguage)[TitleIter->first].size() > 0){
+               
+                       ProcessData.Append(";LANGUAGE=");
+                       ProcessData.Append((*TitleListLanguage)[TitleIter->first]);
+                       
+               }
+               
+               // Check if there is a value for PID.
+
+               if ((*TitleListPID)[TitleIter->first].size() > 0){
+               
+                       ProcessData.Append(";PID=");
+                       ProcessData.Append((*TitleListPID)[TitleIter->first]);
+                       
+               }
+
+               // Check if there is a value for PREF.
+
+               if ((*TitleListPref)[TitleIter->first] > 0){
+               
+                       ProcessData.Append(";PREF=");
+                       ProcessData.Append(wxString::Format("%i", (*TitleListPref)[TitleIter->first]));
+                       
+               }
+
+               // Check if there is a value for tokens.
+
+               if ((*TitleListTokens)[TitleIter->first].size() > 0){
+               
+                       ProcessData.Append(";");
+                       ProcessData.Append((*TitleListTokens)[TitleIter->first]);
+                       
+               }
+                       
+               ProcessData.Append(":");
+               ProcessData.Append(TitleIter->second);
+               ProcessData.Append("\n");
+
+               ProcessData = OutputText(&ProcessData);
+                       
+               SaveData->Append(ProcessData);
+               ProcessData.clear();
+                       
+       }
+               
+}
+
+void ContactDataObject::SaveSource(map<int, wxString> *SourceList, map<int, wxString> *SourceListAltID, 
+       map<int, wxString> *SourceListPID, map<int, wxString> *SourceListType,
+       map<int, wxString> *SourceListMediatype, map<int, int> *SourceListPref, 
+       map<int, wxString> *SourceListTokens, wxString *SaveData){
+
+       wxString ProcessData = "";
+       
+       for (std::map<int, wxString>::iterator SourceIter = SourceList->begin();
+               SourceIter != SourceList->end(); SourceIter++){
+
+               ProcessData.Append("SOURCE");
+                       
+               // Check if there is a value for TYPE.
+               
+               if ((*SourceListType)[SourceIter->first].size() > 0){
+               
+                       ProcessData.Append(";TYPE=");
+                       ProcessData.Append((*SourceListType)[SourceIter->first]);
+                       
+               }
+               
+               // Check if there is a value for ALTID.
+               
+               if ((*SourceListAltID)[SourceIter->first].size() > 0){
+               
+                       ProcessData.Append(";ALTID=");
+                       ProcessData.Append((*SourceListAltID)[SourceIter->first]);
+                       
+               }
+
+               // Check if there is a value for LANGUAGE.
+               
+               if ((*SourceListMediatype)[SourceIter->first].size() > 0){
+               
+                       ProcessData.Append(";MEDIATYPE=");
+                       ProcessData.Append((*SourceListMediatype)[SourceIter->first]);
+                       
+               }
+               
+               // Check if there is a value for PID.
+
+               if ((*SourceListPID)[SourceIter->first].size() > 0){
+               
+                       ProcessData.Append(";PID=");
+                       ProcessData.Append((*SourceListPID)[SourceIter->first]);
+                       
+               }
+
+               // Check if there is a value for PREF.
+
+               if ((*SourceListPref)[SourceIter->first] > 0){
+               
+                       ProcessData.Append(";PREF=");
+                       ProcessData.Append(wxString::Format("%i", (*SourceListPref)[SourceIter->first]));
+                       
+               }
+
+               // Check if there is a value for tokens.
+
+               if ((*SourceListTokens)[SourceIter->first].size() > 0){
+               
+                       ProcessData.Append(";");
+                       ProcessData.Append((*SourceListTokens)[SourceIter->first]);
+                       
+               }
+                       
+               ProcessData.Append(":");
+               ProcessData.Append(SourceIter->second);
+               ProcessData.Append("\n");
+
+               ProcessData = OutputText(&ProcessData);
+                       
+               SaveData->Append(ProcessData);
+               ProcessData.clear();
+                       
+       }
+               
 }
\ No newline at end of file
Xestia Software Development
Yn Maystri
© 2006 - 2019 Xestia Software Development
Software

Xestia Address Book
Xestia Calendar
Development

Xestia Gelforn
Everything else

About
News
Privacy Policy