X-Git-Url: https://git.saurik.com/apple/security.git/blobdiff_plain/5dd5f9ec28f304ca377c42fd7f711d6cf12b90e1..5c19dc3ae3bd8e40a9c028b0deddd50ff337692c:/Security/libsecurity_codesigning/lib/Requirements.cpp diff --git a/Security/libsecurity_codesigning/lib/Requirements.cpp b/Security/libsecurity_codesigning/lib/Requirements.cpp deleted file mode 100644 index d2fb04fe..00000000 --- a/Security/libsecurity_codesigning/lib/Requirements.cpp +++ /dev/null @@ -1,92 +0,0 @@ -/* - * Copyright (c) 2006,2011,2014 Apple Inc. All Rights Reserved. - * - * @APPLE_LICENSE_HEADER_START@ - * - * This file contains Original Code and/or Modifications of Original Code - * as defined in and that are subject to the Apple Public Source License - * Version 2.0 (the 'License'). You may not use this file except in - * compliance with the License. Please obtain a copy of the License at - * http://www.opensource.apple.com/apsl/ and read it before using this - * file. - * - * The Original Code and all software distributed under the License are - * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER - * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, - * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. - * Please see the License for the specific language governing rights and - * limitations under the License. - * - * @APPLE_LICENSE_HEADER_END@ - */ - -// -// Requirements - SecRequirement API objects -// -#include "Requirements.h" - -namespace Security { -namespace CodeSigning { - - -// -// Create from a Requirement blob in memory -// -SecRequirement::SecRequirement(const void *data, size_t length) - : mReq(NULL) -{ - const Requirement *req = (const Requirement *)data; - if (!req->validateBlob(length)) - MacOSError::throwMe(errSecCSReqInvalid); - mReq = req->clone(); -} - - -// -// Create from a genuine Requirement object -// -SecRequirement::SecRequirement(const Requirement *req, bool transferOwnership) - : mReq(NULL) -{ - if (!req->validateBlob()) - MacOSError::throwMe(errSecCSReqInvalid); - - if (transferOwnership) - mReq = req; - else - mReq = req->clone(); -} - - -// -// Clean up a SecRequirement object -// -SecRequirement::~SecRequirement() throw() -try { - ::free((void *)mReq); -} catch (...) { - return; -} - - -// -// CF-level comparison of SecRequirement objects compares the entire requirement -// structure for equality. This means that two requirement programs are recognized -// as equal if they're written identically (modulo comments and syntactic sugar). -// Obviously, equality of outcome is not in the cards. :-) -// -bool SecRequirement::equal(SecCFObject &secOther) -{ - SecRequirement *other = static_cast(&secOther); - return !memcmp(this->requirement(), other->requirement(), this->requirement()->length()); -} - -CFHashCode SecRequirement::hash() -{ - return CFHash(CFTempDataWrap(*this->requirement())); -} - - -} // end namespace CodeSigning -} // end namespace Security