]>
git.saurik.com Git - apple/security.git/blob - SecuritySNACCRuntime/c-examples/simple/expbuf-ex.c
2 * Copyright (c) 2000-2001 Apple Computer, Inc. All Rights Reserved.
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
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.
20 * c_examples/simple/expbuf_ex.c - an example of how to call C ASN.1-BER
21 * encoders and decoders generated by snacc
22 * with the ExpBuf buffer.
27 * $Header: /cvs/Darwin/src/live/Security/SecuritySNACCRuntime/c-examples/simple/expbuf-ex.c,v 1.1.1.1 2001/05/18 23:14:07 mb Exp $
28 * $Log: expbuf-ex.c,v $
29 * Revision 1.1.1.1 2001/05/18 23:14:07 mb
30 * Move from private repository to open source repository
32 * Revision 1.3 2001/05/05 00:59:20 rmurphy
33 * Adding darwin license headers
35 * Revision 1.2 2000/06/08 20:06:59 dmitch
38 * Revision 1.1.1.1 1999/03/16 18:06:08 aram
39 * Originals from SMIME Free Library.
41 * Revision 1.5 1995/07/24 20:44:58 rj
42 * changed `_' to `-' in file names.
44 * Revision 1.4 1995/02/18 15:12:53 rj
47 * Revision 1.3 1994/08/31 23:48:29 rj
48 * more portable .h file inclusion.
50 * Revision 1.2 1994/08/31 08:59:34 rj
51 * first check-in. for a list of changes to the snacc-1.1 distribution please refer to the ChangeLog.
67 main
PARAMS ((argc
, argv
),
89 fprintf (stderr
, "Usage: %s <BER data file name>\n", argv
[0]);
90 fprintf (stderr
, " Decodes the given PersonnelRecord BER data file\n");
91 fprintf (stderr
, " and re-encodes it to stdout\n");
95 fd
= open (argv
[1], O_RDONLY
, 0);
98 perror ("main: fopen");
102 if (fstat (fd
, &sbuf
) < 0)
104 perror ("main: fstat");
109 origData
= (char*)malloc (size
);
110 if (read (fd
, origData
, size
) != size
)
112 perror ("main: read");
119 * the "1024" is the size in bytes of the data
120 * blk to allocate when writing to a buffer that
126 * the first argument (512) is the number of bytes to
127 * initially allocate for the decoder to allocate from.
128 * The second argument (512) is the size in bytes to
129 * enlarge the nibble memory by when it fills up
131 InitNibbleMem (512, 512);
134 * put the BER data read from the file
135 * into buffer format, ready for reading from the
139 ExpBufInstallDataInBuf (buf
, origData
, size
);
143 if ((val
= setjmp (env
)) == 0)
145 BDecPersonnelRecord (&buf
, &pr
, &decodedLen
, env
);
150 fprintf (stderr
, "ERROR - Decode routines returned %d\n",val
);
156 fprintf (stderr
, "decodedValue PersonnelRecord ::= ");
157 PrintPersonnelRecord (stderr
, &pr
, 0);
158 fprintf (stderr
, "\n\n");
161 * allocate a new buffer set up for writing to
163 buf
= ExpBufAllocBufAndData();
165 encodedLen
= BEncPersonnelRecord (&buf
, &pr
);
168 * Alway check for a buffer write error after encoding
170 if (ExpBufWriteError (&buf
))
172 fprintf (stderr
, "ERROR - buffer write error during encoding\n");
178 * free all of the decoded value since
179 * it has been encoded into the buffer.
180 * This is much more efficient than freeing
181 * each compontent of the value individually
186 * go through buffer (s) and write encoded value
189 buf
->curr
= buf
->dataStart
;
190 for ( tmpBuf
= buf
; tmpBuf
!= NULL
; tmpBuf
= tmpBuf
->next
)
192 fwrite (tmpBuf
->dataStart
, tmpBuf
->dataEnd
- tmpBuf
->dataStart
, 1, stdout
);