Monotone-Parent: 8e14613f7e0332410a0bb4de6eea4181b3432372
Monotone-Revision: 98421a1eccc93a8048d8f3c640bc4cf0e6743764 Monotone-Author: wsourdeau@inverse.ca Monotone-Date: 2011-08-02T18:56:17 Monotone-Branch: ca.inverse.sogomaint-2.0.2
parent
6a67a2ff30
commit
c12e7cdd20
10
ChangeLog
10
ChangeLog
|
@ -1,7 +1,15 @@
|
|||
2011-08-02 Wolfgang Sourdeau <wsourdeau@inverse.ca>
|
||||
|
||||
* OpenChange/MAPIStoreContactsMessageTable.m
|
||||
(-evaluateContentRestriction:intoQualifier:): overriden method in
|
||||
order to evaluate PR_MESSAGE_CLASS_UNICODE.
|
||||
(-evaluatePropertyRestriction:intoQualifier:): added stub support for
|
||||
PidLidAddressBookProviderArrayType,
|
||||
PidLidAddressBookProviderEmailList and real support for
|
||||
PidLidEmail[123]OriginalDisplayName.
|
||||
|
||||
* OpenChange/MAPIStoreTable.m (-operatorFromRestrictionOperator):
|
||||
code split from evaluatePropertyRestriction:intoQualifier: and
|
||||
code split from -evaluatePropertyRestriction:intoQualifier: and
|
||||
exposed for external use.
|
||||
|
||||
2011-08-01 Wolfgang Sourdeau <wsourdeau@inverse.ca>
|
||||
|
|
|
@ -20,11 +20,14 @@
|
|||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#import <Foundation/NSData.h>
|
||||
#import <Foundation/NSDictionary.h>
|
||||
#import <Foundation/NSException.h>
|
||||
#import <Foundation/NSString.h>
|
||||
|
||||
#import <EOControl/EOQualifier.h>
|
||||
|
||||
#import <NGMail/NGMailAddress.h>
|
||||
#import <NGMail/NGMailAddressParser.h>
|
||||
#import <NGCards/NSArray+NGCards.h>
|
||||
#import <NGCards/NGVCard.h>
|
||||
|
||||
|
@ -41,13 +44,16 @@
|
|||
|
||||
#include <mapistore/mapistore_nameid.h>
|
||||
|
||||
static Class MAPIStoreContactsMessageK;
|
||||
static Class MAPIStoreContactsMessageK, NGMailAddressK, NSDataK, NSStringK;
|
||||
|
||||
@implementation MAPIStoreContactsMessageTable
|
||||
|
||||
+ (void) initialize
|
||||
{
|
||||
MAPIStoreContactsMessageK = [MAPIStoreContactsMessage class];
|
||||
NSDataK = [NSData class];
|
||||
NSStringK = [NSString class];
|
||||
NGMailAddressK = [NGMailAddress class];
|
||||
}
|
||||
|
||||
+ (Class) childObjectClass
|
||||
|
@ -83,7 +89,11 @@ static Class MAPIStoreContactsMessageK;
|
|||
intoQualifier: (EOQualifier **) qualifier
|
||||
{
|
||||
MAPIRestrictionState rc;
|
||||
id value;
|
||||
EOAndQualifier *andQualifier;
|
||||
EOKeyValueQualifier *fullNameQualifier, *emailQualifier;
|
||||
NSString *fullName, *email;
|
||||
SEL operator;
|
||||
id value, ngAddress;
|
||||
|
||||
value = NSObjectFromMAPISPropValue (&res->lpProp);
|
||||
switch ((uint32_t) res->ulPropTag)
|
||||
|
@ -94,6 +104,51 @@ static Class MAPIStoreContactsMessageK;
|
|||
else
|
||||
rc = MAPIRestrictionStateAlwaysFalse;
|
||||
break;
|
||||
|
||||
case PidLidAddressBookProviderArrayType:
|
||||
case PidLidAddressBookProviderEmailList:
|
||||
/* FIXME: this is a hack. We should return a real qualifier here */
|
||||
rc = MAPIRestrictionStateAlwaysTrue;
|
||||
break;
|
||||
|
||||
case PidLidEmail1OriginalDisplayName:
|
||||
case PidLidEmail2OriginalDisplayName:
|
||||
case PidLidEmail3OriginalDisplayName:
|
||||
rc = MAPIRestrictionStateAlwaysFalse;
|
||||
value = NSObjectFromMAPISPropValue (&res->lpProp);
|
||||
if (value && [value isKindOfClass: NSStringK])
|
||||
{
|
||||
rc = MAPIRestrictionStateNeedsEval;
|
||||
ngAddress = [[NGMailAddressParser mailAddressParserWithString: value]
|
||||
parse];
|
||||
if ([ngAddress isKindOfClass: NGMailAddressK])
|
||||
{
|
||||
operator = [self operatorFromRestrictionOperator: res->relop];
|
||||
fullName = [ngAddress displayName];
|
||||
email = [ngAddress address];
|
||||
emailQualifier = [[EOKeyValueQualifier alloc]
|
||||
initWithKey: @"c_mail"
|
||||
operatorSelector: operator
|
||||
value: email];
|
||||
if ([fullName length] > 0)
|
||||
{
|
||||
fullNameQualifier = [[EOKeyValueQualifier alloc]
|
||||
initWithKey: @"c_cn"
|
||||
operatorSelector: operator
|
||||
value: fullName];
|
||||
andQualifier = [[EOAndQualifier alloc]
|
||||
initWithQualifiers:
|
||||
emailQualifier, fullNameQualifier, nil];
|
||||
[fullNameQualifier release];
|
||||
[emailQualifier release];
|
||||
*qualifier = andQualifier;
|
||||
}
|
||||
else
|
||||
*qualifier = emailQualifier;
|
||||
[*qualifier autorelease];
|
||||
}
|
||||
}
|
||||
break;
|
||||
case PidLidEmail1AddressType:
|
||||
case PidLidEmail2AddressType:
|
||||
case PidLidEmail3AddressType:
|
||||
|
@ -110,6 +165,39 @@ static Class MAPIStoreContactsMessageK;
|
|||
return rc;
|
||||
}
|
||||
|
||||
- (MAPIRestrictionState) evaluateContentRestriction: (struct mapi_SContentRestriction *) res
|
||||
intoQualifier: (EOQualifier **) qualifier
|
||||
{
|
||||
MAPIRestrictionState rc;
|
||||
id value;
|
||||
|
||||
value = NSObjectFromMAPISPropValue (&res->lpProp);
|
||||
if ([value isKindOfClass: NSDataK])
|
||||
{
|
||||
value = [[NSString alloc] initWithData: value
|
||||
encoding: NSUTF8StringEncoding];
|
||||
[value autorelease];
|
||||
}
|
||||
else if (![value isKindOfClass: NSStringK])
|
||||
[NSException raise: @"MAPIStoreTypeConversionException"
|
||||
format: @"unhandled content restriction for class '%@'",
|
||||
NSStringFromClass ([value class])];
|
||||
|
||||
switch (res->ulPropTag)
|
||||
{
|
||||
case PR_MESSAGE_CLASS_UNICODE: /* FIXME: should make use of c_component here */
|
||||
if ([value isEqualToString: @"IPM.Contact"])
|
||||
rc = MAPIRestrictionStateAlwaysTrue;
|
||||
else
|
||||
rc = MAPIRestrictionStateAlwaysFalse;
|
||||
break;
|
||||
default:
|
||||
rc = [super evaluateContentRestriction: res intoQualifier: qualifier];
|
||||
}
|
||||
|
||||
return rc;
|
||||
}
|
||||
|
||||
/* sorting */
|
||||
|
||||
- (NSString *) sortIdentifierForProperty: (enum MAPITAGS) property
|
||||
|
|
Loading…
Reference in New Issue