]> git.saurik.com Git - apple/security.git/blame - SecuritySNACCRuntime/c-lib/inc/asn-any.h
Security-54.1.9.tar.gz
[apple/security.git] / SecuritySNACCRuntime / c-lib / inc / asn-any.h
CommitLineData
bac41a7b
A
1/*
2 * Copyright (c) 2000-2001 Apple Computer, Inc. All Rights Reserved.
3 *
4 * The contents of this file constitute Original Code as defined in and are
5 * subject to the Apple Public Source License Version 1.2 (the 'License').
6 * You may not use this file except in compliance with the License. Please obtain
7 * a copy of the License at http://www.apple.com/publicsource and read it before
8 * using this file.
9 *
10 * This Original Code and all software distributed under the License are
11 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
12 * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
13 * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14 * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
15 * specific language governing rights and limitations under the License.
16 */
17
18
19/*
20 * asn_any.h
21 *
22 * MS 92
23 * Copyright (C) 1992 Michael Sample and the University of British Columbia
24 *
25 * This library is free software; you can redistribute it and/or
26 * modify it provided that this copyright/license information is retained
27 * in original form.
28 *
29 * If you modify this file, you must clearly indicate your changes.
30 *
31 * This source code is distributed in the hope that it will be
32 * useful, but WITHOUT ANY WARRANTY; without even the implied warranty
33 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
34 *
a66d0d4a 35 * $Header: /cvs/root/Security/SecuritySNACCRuntime/c-lib/inc/Attic/asn-any.h,v 1.1.1.1 2001/05/18 23:14:08 mb Exp $
bac41a7b
A
36 * $Log: asn-any.h,v $
37 * Revision 1.1.1.1 2001/05/18 23:14:08 mb
38 * Move from private repository to open source repository
39 *
40 * Revision 1.2 2001/05/05 00:59:22 rmurphy
41 * Adding darwin license headers
42 *
43 * Revision 1.1.1.1 1999/03/16 18:06:19 aram
44 * Originals from SMIME Free Library.
45 *
46 * Revision 1.3 1997/02/28 13:39:49 wan
47 * Modifications collected for new version 1.3: Bug fixes, tk4.2.
48 *
49 * Revision 1.2 1995/07/24 21:01:07 rj
50 * changed `_' to `-' in file names.
51 *
52 * Revision 1.1 1994/08/28 09:21:22 rj
53 * first check-in. for a list of changes to the snacc-1.1 distribution please refer to the ChangeLog.
54 *
55 */
56
57#ifndef _asn_any_h_
58#define _asn_any_h_
59
60#include "hash.h"
61
62/*
63 * 1 hash table for integer keys
64 * 1 hash table for oid keys
65 */
66extern Table *anyOidHashTblG;
67extern Table *anyIntHashTblG;
68
69typedef AsnLen (*EncodeFcn) PROTO ((BUF_TYPE b, void *value));
70typedef void (*DecodeFcn) PROTO ((BUF_TYPE b, void *value, AsnLen *bytesDecoded, ENV_TYPE env));
71typedef void (*FreeFcn) PROTO ((void *v));
72typedef void (*PrintFcn) PROTO ((FILE *f, void *v));
73
74/*
75 * this is put into the hash table with the
76 * int or oid as the key
77 */
78typedef struct AnyInfo
79{
80 int anyId; /* will be a value from the AnyId enum */
81 AsnOid oid; /* will be zero len/null if intId is valid */
82 AsnInt intId;
83 unsigned int size; /* size of the C data type (ie as ret'd by sizeof) */
84 EncodeFcn Encode;
85 DecodeFcn Decode;
86 FreeFcn Free;
87 PrintFcn Print;
88} AnyInfo;
89
90
91typedef struct AsnAny
92{
93 AnyInfo *ai; /* point to entry in hash tbl that has routine ptrs */
94 void *value; /* points to the value */
95} AsnAny;
96
97/*
98 * Returns anyId value for the given ANY type.
99 * Use this to determine to the type of an ANY after decoding
100 * it. Returns -1 if the ANY info is not available
101 */
102#define GetAsnAnyId( a) (((a)->ai)? (a)->ai->anyId: -1)
103
104/*
105 * used before encoding or decoding a type so the proper
106 * encode or decode routine is used.
107 */
108void SetAnyTypeByInt PROTO ((AsnAny *v, AsnInt id));
109void SetAnyTypeByOid PROTO ((AsnAny *v, AsnOid *id));
110
111
112/*
113 * used to initialize the hash table (s)
114 */
115void InstallAnyByInt PROTO ((int anyId, AsnInt intId, unsigned int size, EncodeFcn encode, DecodeFcn decode, FreeFcn free, PrintFcn print));
116
117void InstallAnyByOid PROTO ((int anyId, AsnOid *oid, unsigned int size, EncodeFcn encode, DecodeFcn decode, FreeFcn free, PrintFcn print));
118
119
120/*
121 * Standard enc, dec, free, & print routines
122 * for the AsnAny type.
123 * These call the routines referenced from the
124 * given value's hash table entry.
125 */
126void FreeAsnAny PROTO ((AsnAny *v));
127
128AsnLen BEncAsnAny PROTO ((BUF_TYPE b, AsnAny *v));
129
130void BDecAsnAny PROTO ((BUF_TYPE b, AsnAny *result, AsnLen *bytesDecoded, ENV_TYPE env));
131
132void PrintAsnAny PROTO ((FILE *f, AsnAny *v, unsigned short indent));
133
134
135
136/* AnyDefinedBy is currently the same as AsnAny */
137
138typedef AsnAny AsnAnyDefinedBy;
139
140#define FreeAsnAnyDefinedBy FreeAsnAny
141
142#define BEncAsnAnyDefinedBy BEncAsnAny
143
144#define BDecAsnAnyDefinedBy BDecAsnAny
145
146#define PrintAsnAnyDefinedBy PrintAsnAny
147
148
149#endif /* conditional include */