diff options
author | Steve Block <steveblock@google.com> | 2011-06-08 08:26:01 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-06-08 08:26:01 -0700 |
commit | 3742ac093d35d923c81693096ab6671e9b147700 (patch) | |
tree | c2add9100f789dad45ef1ec5328bddde02c47a4c /Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp | |
parent | 901401d90459bc22580842455d4588b9a697514d (diff) | |
parent | e5926f4a0d6adc9ad4a75824129f117181953560 (diff) | |
download | external_webkit-3742ac093d35d923c81693096ab6671e9b147700.zip external_webkit-3742ac093d35d923c81693096ab6671e9b147700.tar.gz external_webkit-3742ac093d35d923c81693096ab6671e9b147700.tar.bz2 |
Merge changes I55c6d71a,Ifb3277d4,Ia1b847a2,I7ba9cf3f,Ida2b2a8a,I1280ec90,I72f818d5,I2e3b588b,I9a4e6289,Ia724c78b,Icd8612c8,Ie31b15d7,Ie125edae,I77941a88,I89dae78b,I3516e5ca,I1a4c17b5,I2c4ecc1a,I9c8e6537,Ifac13115,Ie1f80e09,Ia541ed77,I60ce9d78
* changes:
Merge WebKit at r82507: Update ThirdPartyProject.prop
Merge WebKit at r82507: Cherry-pick change r88166 to add INSPECTOR guards to ScriptProfiler
Merge WebKit at r82507: Work around a V8 bug
Merge WebKit at r82507: JNIType renamed to JavaType
Merge WebKit at r82507: IconDatabaseClient interface expanded
Merge WebKit at r82507: Don't use new loss-free code path in HTMLCanvasElement::toDataURL()
Merge WebKit at r82507: IcondDatabaseBase::iconForPageURL() renamed
Merge WebKit at r82507: IconDatabaseBase::Open() signature changed
Merge WebKit at r82507: Node::isContentEditable() renamed
Merge WebKit at r82507: Use icon database through IconDatabaseBase
Merge WebKit at r82507: toInputElement() is now a member of Node
Merge WebKit at r82507: FrameLoaderClient::objectContentType() signature changed
Merge WebKit at r82507: StringImpl::computeHash() removed
Merge WebKit at r82507: Stub out FontPlatformData::setOrientation()
Merge WebKit at r82507: Path::strokeBoundingRect() is now const
Merge WebKit at r82507: Add missing UnusedParam.h include in ApplicationCacheGroup.cpp
Merge WebKit at r82507: Continue to use Android's version of FontPlatformData.h
Merge WebKit at r82507: Update signature of FontCustomPlatformData::fontPlatformData()
Merge WebKit at r82507: Fix conflicts due to JNI refactoring
Merge WebKit at r82507: Fix conflicts due to new StorageTracker
Merge WebKit at r82507: Fix conflicts
Merge WebKit at r82507: Fix makefiles
Merge WebKit at r82507: Initial merge by git
Diffstat (limited to 'Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp')
-rw-r--r-- | Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp | 40 |
1 files changed, 39 insertions, 1 deletions
diff --git a/Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp b/Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp index 936b6b3..c762d5b 100644 --- a/Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp +++ b/Source/WebKit2/Shared/cf/ArgumentCodersCF.cpp @@ -48,6 +48,9 @@ enum CFType { CFNumber, CFString, CFURL, +#if PLATFORM(MAC) + SecCertificate, +#endif Null, Unknown, }; @@ -76,6 +79,10 @@ static CFType typeFromCFTypeRef(CFTypeRef type) return CFString; if (typeID == CFURLGetTypeID()) return CFURL; +#if PLATFORM(MAC) + if (typeID == SecCertificateGetTypeID()) + return SecCertificate; +#endif ASSERT_NOT_REACHED(); return Unknown; @@ -110,6 +117,11 @@ static void encode(ArgumentEncoder* encoder, CFTypeRef typeRef) case CFURL: encode(encoder, static_cast<CFURLRef>(typeRef)); return; +#if PLATFORM(MAC) + case SecCertificate: + encode(encoder, (SecCertificateRef)typeRef); + return; +#endif case Null: return; case Unknown: @@ -178,6 +190,15 @@ static bool decode(ArgumentDecoder* decoder, RetainPtr<CFTypeRef>& result) result.adoptCF(url.leakRef()); return true; } +#if PLATFORM(MAC) + case SecCertificate: { + RetainPtr<SecCertificateRef> certificate; + if (!decode(decoder, certificate)) + return false; + result.adoptCF(certificate.leakRef()); + return true; + } +#endif case Null: result = tokenNullTypeRef(); return true; @@ -459,5 +480,22 @@ bool decode(ArgumentDecoder* decoder, RetainPtr<CFURLRef>& result) return true; } -} // namespace CoreIPC +#if PLATFORM(MAC) +void encode(ArgumentEncoder* encoder, SecCertificateRef certificate) +{ + RetainPtr<CFDataRef> data(AdoptCF, SecCertificateCopyData(certificate)); + encode(encoder, data.get()); +} +bool decode(ArgumentDecoder* decoder, RetainPtr<SecCertificateRef>& result) +{ + RetainPtr<CFDataRef> data; + if (!decode(decoder, data)) + return false; + + result.adoptCF(SecCertificateCreateWithData(0, data.get())); + return true; +} +#endif + +} // namespace CoreIPC |