int PhotoCount = 0;
int LogoCount = 0;
int SoundCount = 0;
- int CalAdrCount = 0;
+ int CalendarCount = 0;
+ int CalendarAddressCount = 0;
wxString ContactLine;
wxString PropertyLine;
wxString PropertySeg1;
// See frmContactEditor-LoadCalendar.cpp
- ProcessCalendarURI(PropertySeg1, PropertySeg2, &CalAdrCount);
- CalAdrCount++;
+ ProcessCalendarURI(PropertySeg1, PropertySeg2, &CalendarCount);
+ CalendarCount++;
+
+ } else if (Property == wxT("CALADRURI")){
+
+ ProcessCalendarAddressURI(PropertySeg1, PropertySeg2, &CalendarAddressCount);
+ CalendarAddressCount++;
}
}
+void ContactDataObject::ProcessCalendarAddressURI(wxString PropertySeg1, wxString PropertySeg2, int *CalAdrURICount){
+
+ size_t intPropertyLen = PropertySeg1.Len();
+ std::map<int, int> SplitPoints;
+ std::map<int, int> SplitLength;
+ std::map<int, int>::iterator SLiter;
+ wxString PropertyData;
+ wxString PropertyName;
+ wxString PropertyValue;
+ wxString PropertyTokens;
+ bool FirstToken = TRUE;
+ int intSplitsFound = 0;
+ int intSplitSize = 0;
+ int intPrevValue = 8;
+ int intPref = 0;
+ int intType = 0;
+
+ SplitValues(&PropertySeg1, &SplitPoints, &SplitLength, intPrevValue);
+
+ intPrevValue = 7;
+
+ PropertyType PropType = PROPERTY_NONE;
+
+ // Look for type before continuing.
+
+ CheckType(&PropertySeg1, &SplitPoints, &SplitLength, &intPrevValue, &PropType);
+
+ intPrevValue = 7;
+
+ for (std::map<int, int>::iterator intiter = SplitPoints.begin();
+ intiter != SplitPoints.end(); ++intiter){
+
+ SLiter = SplitLength.find(intiter->first);
+
+ PropertyData = PropertySeg1.Mid(intPrevValue, (SLiter->second));
+
+ wxStringTokenizer PropertyElement (PropertyData, wxT("="));
+ PropertyName = PropertyElement.GetNextToken();
+ PropertyValue = PropertyElement.GetNextToken();
+
+ intPrevValue = intiter->second;
+
+ // Process properties.
+
+ size_t intPropertyValueLen = PropertyValue.Len();
+
+ if (PropertyValue.Mid((intPropertyValueLen - 1), 1) == wxT("\"")){
+
+ PropertyValue.Trim();
+ PropertyValue.RemoveLast();
+
+ }
+
+ if (PropertyValue.Mid(0, 1) == wxT("\"")){
+
+ PropertyValue.Remove(0, 1);
+
+ }
+
+ CaptureString(&PropertyValue, FALSE);
+
+ if (PropertyName == wxT("ALTID")){
+
+ CalendarRequestListAltID.erase(*CalAdrURICount);
+ CalendarRequestListAltID.insert(std::make_pair(*CalAdrURICount, PropertyValue));
+
+ } else if (PropertyName == wxT("PID")){
+
+ CalendarRequestListPID.erase(*CalAdrURICount);
+ CalendarRequestListPID.insert(std::make_pair(*CalAdrURICount, PropertyValue));
+
+ } else if (PropertyName == wxT("PREF")){
+
+ int PriorityNumber = 0;
+ bool ValidNumber = TRUE;
+
+ try{
+ PriorityNumber = std::stoi(PropertyValue.ToStdString());
+ }
+
+ catch(std::invalid_argument &e){
+ ValidNumber = FALSE;
+ }
+
+ if (ValidNumber == TRUE){
+
+ CalendarRequestListPref.erase(*CalAdrURICount);
+ CalendarRequestListPref.insert(std::make_pair(*CalAdrURICount, PriorityNumber));
+
+ }
+
+ } else if (PropertyName == wxT("MEDIATYPE")){
+
+ CalendarRequestListMediatype.erase(*CalAdrURICount);
+ CalendarRequestListMediatype.insert(std::make_pair(*CalAdrURICount, PropertyValue));
+
+ } else {
+
+ // Something else we don't know about so append
+ // to the tokens variable.
+
+ if (!PropertyName.IsEmpty() && !PropertyValue.IsEmpty() && PropertyName != wxT("TYPE")){
+
+ if (FirstToken == TRUE){
+
+ PropertyTokens.Append(PropertyName + wxT("=") + PropertyValue);
+ FirstToken = FALSE;
+
+ } else {
+
+ PropertyTokens.Append(wxT(";") + PropertyName + wxT("=") + PropertyValue);
+
+ }
+
+ }
+
+ }
+
+ }
+
+ intPropertyLen = PropertySeg2.Len();
+ SplitPoints.clear();
+ SplitLength.clear();
+ intSplitsFound = 0;
+ intSplitSize = 0;
+ intPrevValue = 0;
+
+ CaptureString(&PropertySeg2, FALSE);
+
+ // Add the data to the General/Home/Work address variables.
+
+ switch(PropType){
+ case PROPERTY_NONE:
+ break;
+ case PROPERTY_HOME:
+ CalendarRequestListType.insert(std::make_pair(*CalAdrURICount, "home"));
+ break;
+ case PROPERTY_WORK:
+ CalendarRequestListType.insert(std::make_pair(*CalAdrURICount, "work"));
+ break;
+ }
+
+ CalendarRequestList.insert(std::make_pair(*CalAdrURICount, PropertySeg2));
+
+ if (!PropertyTokens.IsEmpty()){
+
+ CalendarRequestListTokens.insert(std::make_pair(*CalAdrURICount, PropertyTokens));
+
+ }
+
+}
+
void SplitValues(wxString *PropertyLine,
std::map<int,int> *SplitPoints,
std::map<int,int> *SplitLength,
TEST(ContactLoad, CalendarURITests){
- // Setup the sound files first.
-
ContactDataObject TestFile;
// Check that the vCard 4.0 file loads OK.
}
+TEST(ContactLoad, CalendarAddressURITests){
+
+ ContactDataObject TestFile;
+
+ // Check that the vCard 4.0 file loads OK.
+
+ ASSERT_EQ(CONTACTLOAD_OK, TestFile.LoadFile("LoadCheck-Load4.vcf"));
+
+ std::map<int,wxString>::iterator TestFileIter;
+ std::map<int,int>::iterator TestFileIntIter;
+
+ // Start with a general calendar request address.
+
+ TestFileIter = TestFile.CalendarRequestList.find(0);
+ ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+ ASSERT_EQ("http://example.com/request", TestFileIter->second);
+
+ // Check the TYPE section.
+
+ TestFileIter = TestFile.CalendarRequestListType.find(0);
+ ASSERT_EQ(TestFile.CalendarRequestListType.end(), TestFileIter);
+
+ // Check the ALTID section.
+
+ TestFileIter = TestFile.CalendarRequestListAltID.find(0);
+ ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+ ASSERT_EQ("14", TestFileIter->second);
+
+ // Check the PID section.
+
+ TestFileIter = TestFile.CalendarRequestListPID.find(0);
+ ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter);
+ ASSERT_EQ("11", TestFileIter->second);
+
+ // Check the MEDIATYPE section.
+
+ TestFileIter = TestFile.CalendarRequestListMediatype.find(0);
+ ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter);
+ ASSERT_EQ("text/plain", TestFileIter->second);
+
+ // Check the PREF section.
+
+ TestFileIntIter = TestFile.CalendarRequestListPref.find(0);
+ ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+ ASSERT_EQ(12, TestFileIntIter->second);
+
+ // Check the extra tokens.
+
+ TestFileIter = TestFile.CalendarRequestListTokens.find(0);
+ ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+ ASSERT_EQ("REQUEST=YES", TestFileIter->second);
+
+ // Start with a home calendar request address.
+
+ TestFileIter = TestFile.CalendarRequestList.find(1);
+ ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+ ASSERT_EQ("http://example.com/home/request", TestFileIter->second);
+
+ // Check the TYPE section.
+
+ TestFileIter = TestFile.CalendarRequestListType.find(1);
+ ASSERT_NE(TestFile.CalendarRequestListType.end(), TestFileIter);
+ ASSERT_EQ("home", TestFileIter->second);
+
+ // Check the ALTID section.
+
+ TestFileIter = TestFile.CalendarRequestListAltID.find(1);
+ ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+ ASSERT_EQ("24", TestFileIter->second);
+
+ // Check the PID section.
+
+ TestFileIter = TestFile.CalendarRequestListPID.find(1);
+ ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter);
+ ASSERT_EQ("21", TestFileIter->second);
+
+ // Check the MEDIATYPE section.
+
+ TestFileIter = TestFile.CalendarRequestListMediatype.find(1);
+ ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter);
+ ASSERT_EQ("text/dryplain", TestFileIter->second);
+
+ // Check the PREF section.
+
+ TestFileIntIter = TestFile.CalendarRequestListPref.find(1);
+ ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+ ASSERT_EQ(22, TestFileIntIter->second);
+
+ // Check the extra tokens.
+
+ TestFileIter = TestFile.CalendarRequestListTokens.find(1);
+ ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+ ASSERT_EQ("REQUEST=MAYBE", TestFileIter->second);
+
+ // Start with a business calendar request address.
+
+ TestFileIter = TestFile.CalendarRequestList.find(2);
+ ASSERT_NE(TestFile.CalendarRequestList.end(), TestFileIter);
+ ASSERT_EQ("http://example.com/business/request", TestFileIter->second);
+
+ // Check the TYPE section.
+
+ TestFileIter = TestFile.CalendarRequestListType.find(2);
+ ASSERT_NE(TestFile.CalendarRequestListType.end(), TestFileIter);
+ ASSERT_EQ("work", TestFileIter->second);
+
+ // Check the ALTID section.
+
+ TestFileIter = TestFile.CalendarRequestListAltID.find(2);
+ ASSERT_NE(TestFile.CalendarRequestListAltID.end(), TestFileIter);
+ ASSERT_EQ("34", TestFileIter->second);
+
+ // Check the PID section.
+
+ TestFileIter = TestFile.CalendarRequestListPID.find(2);
+ ASSERT_NE(TestFile.CalendarRequestListPID.end(), TestFileIter);
+ ASSERT_EQ("31", TestFileIter->second);
+
+ // Check the MEDIATYPE section.
+
+ TestFileIter = TestFile.CalendarRequestListMediatype.find(2);
+ ASSERT_NE(TestFile.CalendarRequestListMediatype.end(), TestFileIter);
+ ASSERT_EQ("text/stillwetink", TestFileIter->second);
+
+ // Check the PREF section.
+
+ TestFileIntIter = TestFile.CalendarRequestListPref.find(2);
+ ASSERT_NE(TestFile.CalendarRequestListPref.end(), TestFileIntIter);
+ ASSERT_EQ(32, TestFileIntIter->second);
+
+ // Check the extra tokens.
+
+ TestFileIter = TestFile.CalendarRequestListTokens.find(2);
+ ASSERT_NE(TestFile.CalendarRequestListTokens.end(), TestFileIter);
+ ASSERT_EQ("REQUEST=NO", TestFileIter->second);
+
+
+}
+
// TODO: Add tests for the Contact Loading process.
\ No newline at end of file