2 * Copyright (c) 2013-2014 Apple Inc. All Rights Reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
26 @header SOSDigestVector.h
27 The functions provided in SOSDigestVector.h provide an interface doing
28 cheap appending, lazy sorting and delta math on sorted arrays of same
32 #ifndef _SEC_SOSDIGESTVECTOR_H_
33 #define _SEC_SOSDIGESTVECTOR_H_
35 #include <corecrypto/ccsha1.h>
36 #include <CoreFoundation/CFError.h>
37 #include <sys/types.h>
42 kSOSDigestVectorRemovalsLeftError
= 1,
43 kSOSDigestVectorUnorderedAddError
= 2,
46 extern CFStringRef kSOSDigestVectorErrorDomain
;
48 #define SOSDigestSize ((size_t)CCSHA1_OUTPUT_SIZE)
50 #define SOSDigestVectorInit { .digest = NULL, .count = 0, .capacity = 0, .unsorted = false }
52 typedef uint8_t (*SOSDigestVectorDigestPtr
)[SOSDigestSize
];
54 struct SOSDigestVector
{
55 uint8_t (*digest
)[SOSDigestSize
];
61 typedef void (^SOSDigestVectorApplyBlock
)(const uint8_t digest
[SOSDigestSize
], bool *stop
);
63 /* SOSDigestVector. */
64 void SOSDigestVectorAppend(struct SOSDigestVector
*dv
, const uint8_t *digest
);
65 void SOSDigestVectorAppendMultipleOrdered(struct SOSDigestVector
*dv
, size_t count
,
66 const uint8_t *digests
);
67 void SOSDigestVectorSort(struct SOSDigestVector
*dv
);
68 void SOSDigestVectorSwap(struct SOSDigestVector
*dva
, struct SOSDigestVector
*dvb
);
69 size_t SOSDigestVectorIndexOf(struct SOSDigestVector
*dv
, const uint8_t *digest
);
70 size_t SOSDigestVectorIndexOfSorted(const struct SOSDigestVector
*dv
, const uint8_t *digest
);
71 bool SOSDigestVectorContains(struct SOSDigestVector
*dv
, const uint8_t *digest
);
72 bool SOSDigestVectorContainsSorted(const struct SOSDigestVector
*dv
, const uint8_t *digest
);
73 void SOSDigestVectorFree(struct SOSDigestVector
*dv
);
75 void SOSDigestVectorApply(struct SOSDigestVector
*dv
, SOSDigestVectorApplyBlock with
);
76 void SOSDigestVectorApplySorted(const struct SOSDigestVector
*dv
, SOSDigestVectorApplyBlock with
);
77 void SOSDigestVectorIntersectSorted(const struct SOSDigestVector
*dv1
, const struct SOSDigestVector
*dv2
,
78 struct SOSDigestVector
*dvintersect
);
79 void SOSDigestVectorUnionSorted(const struct SOSDigestVector
*dv1
, const struct SOSDigestVector
*dv2
,
80 struct SOSDigestVector
*dvunion
);
81 void SOSDigestVectorUniqueSorted(struct SOSDigestVector
*dv
);
83 void SOSDigestVectorDiffSorted(const struct SOSDigestVector
*dv1
, const struct SOSDigestVector
*dv2
,
84 struct SOSDigestVector
*dv1_2
, struct SOSDigestVector
*dv2_1
);
85 void SOSDigestVectorDiff(struct SOSDigestVector
*dv1
, struct SOSDigestVector
*dv2
,
86 struct SOSDigestVector
*dv1_2
, struct SOSDigestVector
*dv2_1
);
87 void SOSDigestVectorComplementSorted(const struct SOSDigestVector
*dvA
, const struct SOSDigestVector
*dvB
,
88 struct SOSDigestVector
*dvcomplement
);
89 bool SOSDigestVectorPatchSorted(const struct SOSDigestVector
*base
, const struct SOSDigestVector
*removals
,
90 const struct SOSDigestVector
*additions
, struct SOSDigestVector
*dv
,
92 bool SOSDigestVectorPatch(struct SOSDigestVector
*base
, struct SOSDigestVector
*removals
,
93 struct SOSDigestVector
*additions
, struct SOSDigestVector
*dv
,
98 #endif /* !_SEC_SOSDIGESTVECTOR_H_ */