+ 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);
+
+ ProcessStringValue(&PropertyName, "ALTID", &SoundsListAltID, &PropertyValue, SoundCount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "PID", &SoundsListPID, &PropertyValue, SoundCount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "MEDIATYPE", &SoundsListMediatype, &PropertyValue, SoundCount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "LANGUAGE", &SoundsListLanguage, &PropertyValue, SoundCount, &PropertyMatched);
+ ProcessIntegerValue(&PropertyName, "PREF", &SoundsListPref, &PropertyValue, SoundCount, &PropertyMatched);
+
+ if (PropertyMatched == TRUE){
+
+ PropertyMatched = FALSE;
+ continue;
+
+ }
+
+ 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);
+
+ for (int i = 0; i <= intPropertyLen; i++){
+
+ intSplitSize++;
+
+ if (PropertySeg2.Mid(i, 1) == wxT(";")){
+
+ intSplitsFound++;
+ SplitPoints.insert(std::make_pair(intSplitsFound, (i + 1)));
+
+ if (intSplitsFound == 6){
+
+ SplitLength.insert(std::make_pair(intSplitsFound, (intSplitSize - 1)));
+ break;
+
+ } else {
+
+ SplitLength.insert(std::make_pair(intSplitsFound, (intSplitSize - 1)));
+
+ }
+
+ intSplitSize = 0;
+
+ }
+
+ }
+
+ wxString wxSSoundURI;
+ wxString wxSSoundMIME;
+ wxString wxSSoundEncoding;
+ wxString wxSSoundData;
+ std::string base64enc;
+
+ if (intSplitsFound == 0){
+
+ } else {
+
+ std::map<int, int>::iterator striter;
+
+ striter = SplitLength.find(1);
+
+ wxStringTokenizer wSTDataType(PropertySeg2.Mid(0, striter->second), wxT(":"));
+
+ while (wSTDataType.HasMoreTokens() == TRUE){
+
+ wxSSoundURI = wSTDataType.GetNextToken();
+ wxSSoundMIME = wSTDataType.GetNextToken();
+ break;
+
+ }
+
+ wxStringTokenizer wSTDataInfo(PropertySeg2.Mid((striter->second + 1)), wxT(","));
+
+ while (wSTDataInfo.HasMoreTokens() == TRUE){
+
+ wxSSoundEncoding = wSTDataInfo.GetNextToken();
+ wxSSoundData = wSTDataInfo.GetNextToken();
+ base64enc = wxSSoundData.mb_str();
+ break;
+
+ }
+
+ }
+
+ // Add the data to the General/Home/Work address variables.
+
+ switch(PropType){
+ case PROPERTY_NONE:
+ break;
+ case PROPERTY_HOME:
+ SoundsListType.insert(std::make_pair(*SoundCount, "home"));
+ break;
+ case PROPERTY_WORK:
+ SoundsListType.insert(std::make_pair(*SoundCount, "work"));
+ break;
+ }
+
+ SoundsList.insert(std::make_pair(*SoundCount, base64enc));
+ SoundsListAudioEncType.insert(std::make_pair(*SoundCount, wxSSoundEncoding));
+ SoundsListAudioType.insert(std::make_pair(*SoundCount, wxSSoundMIME));
+
+ if (!PropertyTokens.IsEmpty()){
+
+ SoundsListTokens.insert(std::make_pair(*SoundCount, PropertyTokens));
+
+ }
+
+}
+
+void ContactDataObject::ProcessCalendarURI(wxString PropertySeg1, wxString PropertySeg2, int *CalURICount){
+
+ 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;
+ bool PropertyMatched = FALSE;
+
+ 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);
+
+ ProcessStringValue(&PropertyName, "ALTID", &CalendarListAltID, &PropertyValue, CalURICount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "PID", &CalendarListPID, &PropertyValue, CalURICount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "MEDIATYPE", &CalendarListMediatype, &PropertyValue, CalURICount, &PropertyMatched);
+ ProcessIntegerValue(&PropertyName, "PREF", &CalendarListPref, &PropertyValue, CalURICount, &PropertyMatched);
+
+ if (PropertyMatched == TRUE){
+
+ PropertyMatched = FALSE;
+ continue;
+
+ }
+
+ 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:
+ CalendarListType.insert(std::make_pair(*CalURICount, "home"));
+ break;
+ case PROPERTY_WORK:
+ CalendarListType.insert(std::make_pair(*CalURICount, "work"));
+ break;
+ }
+
+ CalendarList.insert(std::make_pair(*CalURICount, PropertySeg2));
+
+ if (!PropertyTokens.IsEmpty()){
+
+ CalendarListTokens.insert(std::make_pair(*CalURICount, PropertyTokens));
+
+ }
+
+}
+
+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;
+ bool PropertyMatched = FALSE;
+
+ 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);
+
+ ProcessStringValue(&PropertyName, "ALTID", &CalendarRequestListAltID, &PropertyValue, CalAdrURICount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "PID", &CalendarRequestListPID, &PropertyValue, CalAdrURICount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "MEDIATYPE", &CalendarRequestListMediatype, &PropertyValue, CalAdrURICount, &PropertyMatched);
+ ProcessIntegerValue(&PropertyName, "PREF", &CalendarRequestListPref, &PropertyValue, CalAdrURICount, &PropertyMatched);
+
+ if (PropertyMatched == TRUE){
+
+ PropertyMatched = FALSE;
+ continue;
+
+ }
+
+ 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 ContactDataObject::ProcessCalendarFreeBusy(wxString PropertySeg1, wxString PropertySeg2, int *FreeBusyAddressCount){
+
+ 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 = 7;
+ int intPref = 0;
+ int intType = 0;
+
+ SplitValues(&PropertySeg1, &SplitPoints, &SplitLength, intPrevValue);
+
+ intPrevValue = 6;
+
+ PropertyType PropType = PROPERTY_NONE;
+
+ // Look for type before continuing.
+
+ CheckType(&PropertySeg1, &SplitPoints, &SplitLength, &intPrevValue, &PropType);
+
+ intPrevValue = 6;
+ bool PropertyMatched = FALSE;
+
+ 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);
+
+ ProcessStringValue(&PropertyName, "ALTID", &FreeBusyListAltID, &PropertyValue, FreeBusyAddressCount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "PID", &FreeBusyListPID, &PropertyValue, FreeBusyAddressCount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "MEDIATYPE", &FreeBusyListMediatype, &PropertyValue, FreeBusyAddressCount, &PropertyMatched);
+ ProcessIntegerValue(&PropertyName, "PREF", &FreeBusyListPref, &PropertyValue, FreeBusyAddressCount, &PropertyMatched);
+
+ if (PropertyMatched == TRUE){
+
+ PropertyMatched = FALSE;
+ continue;
+
+ }
+
+ 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:
+ FreeBusyListType.insert(std::make_pair(*FreeBusyAddressCount, "home"));
+ break;
+ case PROPERTY_WORK:
+ FreeBusyListType.insert(std::make_pair(*FreeBusyAddressCount, "work"));
+ break;
+ }
+
+ FreeBusyList.insert(std::make_pair(*FreeBusyAddressCount, PropertySeg2));
+
+ if (!PropertyTokens.IsEmpty()){
+
+ FreeBusyListTokens.insert(std::make_pair(*FreeBusyAddressCount, PropertyTokens));
+
+ }
+
+}
+
+void ContactDataObject::ProcessKey(wxString PropertySeg1, wxString PropertySeg2, int *KeyCount){
+
+ 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 = 5;
+ int intPref = 0;
+ int intType = 0;
+ long ListCtrlIndex;
+
+ SplitValues(&PropertySeg1, &SplitPoints, &SplitLength, intPrevValue);
+
+ intPrevValue = 4;
+
+ PropertyType PropType = PROPERTY_NONE;
+
+ // Look for type before continuing.
+
+ CheckType(&PropertySeg1, &SplitPoints, &SplitLength, &intPrevValue, &PropType);
+
+ intPrevValue = 4;
+ bool PropertyMatched = FALSE;
+
+ 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);
+
+ }
+
+ ProcessStringValue(&PropertyName, "ALTID", &KeyListAltID, &PropertyValue, KeyCount, &PropertyMatched);
+ ProcessStringValue(&PropertyName, "PID", &KeyListPID, &PropertyValue, KeyCount, &PropertyMatched);
+ ProcessIntegerValue(&PropertyName, "PREF", &KeyListPref, &PropertyValue, KeyCount, &PropertyMatched);
+
+ if (PropertyMatched == TRUE){
+
+ PropertyMatched = FALSE;
+ continue;
+
+ }
+
+ 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;
+
+ for (int i = 0; i <= intPropertyLen; i++){
+
+ intSplitSize++;
+
+ if (PropertySeg2.Mid(i, 1) == wxT(";") && PropertySeg2.Mid((i - 1), 1) != wxT("\\")){
+
+ intSplitsFound++;
+ SplitPoints.insert(std::make_pair(intSplitsFound, (i + 1)));
+
+ if (intSplitsFound == 6){
+
+ SplitLength.insert(std::make_pair(intSplitsFound, (intSplitSize - 1)));
+ break;
+
+ } else {
+
+ SplitLength.insert(std::make_pair(intSplitsFound, (intSplitSize - 1)));
+
+ }
+
+ intSplitSize = 0;
+
+ }
+
+ }
+
+ wxString wxSKeyURI;
+ wxString wxSKeyMIME;
+ wxString wxSKeyEncoding;
+ wxString wxSKeyData;
+ std::string base64enc;
+
+ if (intSplitsFound == 0){
+
+ } else {
+
+ std::map<int, int>::iterator striter;
+
+ striter = SplitLength.find(1);
+
+ wxStringTokenizer wSTDataType(PropertySeg2.Mid(0, striter->second), wxT(":"));
+
+ while (wSTDataType.HasMoreTokens() == TRUE){
+
+ wxSKeyURI = wSTDataType.GetNextToken();
+ wxSKeyMIME = wSTDataType.GetNextToken();
+ break;
+
+ }
+
+ if (wxSKeyURI == wxT("data")){
+
+ wxStringTokenizer wSTDataInfo(PropertySeg2.Mid((striter->second + 1)), wxT(","));
+
+ while (wSTDataInfo.HasMoreTokens() == TRUE){
+
+ wxSKeyEncoding = wSTDataInfo.GetNextToken();
+ wxSKeyData = wSTDataInfo.GetNextToken();
+ break;
+
+ }
+
+ }
+
+ }
+
+ // Add the data to the General/Home/Work address variables.
+
+ if (wxSKeyURI == wxT("data")){
+
+ KeyListDataEncType.erase(*KeyCount);
+ KeyListKeyType.erase(*KeyCount);
+ KeyListDataEncType.insert(std::make_pair(*KeyCount, wxSKeyEncoding));
+ KeyListKeyType.insert(std::make_pair(*KeyCount, TRUE));
+
+ KeyList.erase(*KeyCount);
+ KeyList.insert(std::make_pair(*KeyCount, wxSKeyData));
+
+ } else {
+
+ KeyList.erase(*KeyCount);
+ KeyList.insert(std::make_pair(*KeyCount, PropertySeg2));
+
+ }
+
+ KeyListDataType.insert(std::make_pair(*KeyCount, wxSKeyMIME));
+
+ switch (PropType){
+ case PROPERTY_NONE:
+ break;
+ case PROPERTY_HOME:
+ KeyListType.insert(std::make_pair(*KeyCount, wxT("home")));
+ break;
+ case PROPERTY_WORK:
+ KeyListType.insert(std::make_pair(*KeyCount, wxT("work")));
+ break;
+ }
+
+ if (!PropertyTokens.IsEmpty()){
+
+ KeyListTokens.insert(std::make_pair(*KeyCount, PropertyTokens));
+
+ }
+
+}
+
+void ContactDataObject::ProcessVendor(wxString PropertySeg1, wxString PropertySeg2, int *VendorCount){
+
+ // Split the Vendor three ways.
+
+ wxStringTokenizer wSTVendorDetails(PropertySeg1, wxT("-"));
+
+ wxString wxSVNDID;
+ wxString wxSVNDPropName;
+ long ListCtrlIndex;
+
+ while (wSTVendorDetails.HasMoreTokens() == TRUE){
+
+ wSTVendorDetails.GetNextToken();
+ wxSVNDID = wSTVendorDetails.GetNextToken();
+ wxSVNDPropName = wSTVendorDetails.GetNextToken();
+ break;
+
+ }
+
+ if (!wxSVNDID.IsEmpty() && !wxSVNDPropName.IsEmpty()){
+
+ // Add the data to the vendor variables.
+
+ VendorList.erase(*VendorCount);
+ VendorListPEN.erase(*VendorCount);
+ VendorListElement.erase(*VendorCount);
+
+ VendorList.insert(std::make_pair(*VendorCount, PropertySeg2));
+ VendorListPEN.insert(std::make_pair(*VendorCount, wxSVNDID));
+ VendorListElement.insert(std::make_pair(*VendorCount, wxSVNDPropName));
+
+ }
+
+}
+
+void ProcessStringValue(wxString *PropertyName,
+ wxString PropertyNameMatch,
+ std::map<int,wxString> *MapPtr,
+ wxString *PropertyValue,
+ int *ItemCount,
+ bool *PropertyMatched){
+
+ if (*PropertyName == PropertyNameMatch){
+ MapPtr->erase(*ItemCount);
+ MapPtr->insert(std::make_pair(*ItemCount, *PropertyValue));
+ *PropertyMatched = TRUE;
+ }
+
+}
+
+void ProcessIntegerValue(wxString *PropertyName,
+ wxString PropertyNameMatch,
+ std::map<int,int> *PrefPtr,
+ wxString *PropertyValue,
+ int *ItemCount,
+ bool *PropertyMatched){
+
+ if (*PropertyName == PropertyNameMatch){
+ *PropertyMatched = TRUE;
+ } else {
+ return;
+ }
+
+ int PriorityNumber = 0;
+ bool ValidNumber = TRUE;
+
+ try{
+ PriorityNumber = std::stoi(PropertyValue->ToStdString());
+ }
+
+ catch(std::invalid_argument &e){
+ ValidNumber = FALSE;
+ }
+
+ if (ValidNumber == TRUE){
+
+ PrefPtr->erase(*ItemCount);
+ PrefPtr->insert(std::make_pair(*ItemCount, PriorityNumber));
+