File: README

package info (click to toggle)
snacc 1.3.1-9
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,132 kB
  • sloc: ansic: 33,001; cpp: 5,163; yacc: 2,217; sh: 2,146; makefile: 839; lex: 517; sed: 4
file content (129 lines) | stat: -rw-r--r-- 4,904 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
(RCS control information is at the end of this file.)


C Simple Example README
-----------------------

This directory should have 8 files in it:

README       - this file
genber.c     - C source code for a program that creates and encodes
               a PersonnelRecord value to a file.
expbuf_ex.c  - C source code for a program that calls the generated
               PersonnelRecord encoder and decoder routines
               using the ExpBuf buffer type
minbuf_ex.c  - C source code for program that calls the generated
               PersonnelRecord encoder and decoder routines
               using the MinBuf buffer type
sbuf_ex.c    - C source code for a program that calls the generated
               PersonnelRecord encoder and decoder routines
               using the MinBuf buffer type
makefile     - compiles the example programs
good_pr.ber  - BER encoding of a Personnel Record (all definite lengths)



Type "make" to generate the 7 example programs:
        genber
        expbuf_def
        expbuf_indef
        minbuf_def
        minbuf_indef
        sbuf_def
        sbuf_indef


snacc is called from the makefile on snacc/asn1specs/p_rec.asn1 to
generate the following files:

p_rec.h  - C data structs for PersonnelRecord and prototypes for
           the generated encode, decode, print and free routines.
p_rec.c  - C source code for the PersonnelRecord encode, decode,
           print, and free routines.

These source files are then compiled with *_ex.c and genber.c files to
make 7 programs.  Each program takes 1 argument (except genber), the
name of a file containing an BER encoded PersonnelRecord value.


Try the following: (or use the makefile's `check' phony target)

eg% ./genber				# create a file called pr.ber
eg% uudecode -o good-pr.ber good-pr.ber.uu
eg% ./sbuf_indef good-pr.ber > indef-pr.ber
eg% ./sbuf_def indef-pr.ber > def-pr.ber
eg% diff good-pr.ber def-pr.ber		# should be no differences


The above commands decode the BER value in "good_pr.ber" and
indef_pr.ber respectively and then re-encode then to stdout.
Both programs will decode any valid BER representation of a
PersonnelRecord value but, the sbuf_def program will re-encode the
given data using only the definite length BER format and the
sbuf_indef program will re-encode the given data using only the
indefinite length BER format.

Compare the lengths of the def_pr.ber and indef_pr.ber files,
indefinite length encodings are usually larger.



Things to Note
--------------


Look at genber.c to see how to build a C value and then encode it.
look at the *_ex.c files to see the different types of buffer
manipulation.  Read the comments in the code.

It should be relatively simple to change the memory and buffer
management to fit your target environment.
(see snacc/c_include/asn_config.h.)


Snacc ASN.1 comment commands

Notice the special "--snacc" ASN.1 comment in snacc/asn1specs/p_rec.asn1.

PersonnelRecord ::= --snacc isPdu:"TRUE" -- [APPLICATION 0] IMPLICIT SET
 { ... etc. ... }

The "isPdu" flag tells snacc that the PersonnelRecord is a PDU type
that you will be calling the encoding and decoding routines directly
from your code.  This causes snacc to generate the
"BEncPersonnelRecord" and "BDecPersonnelRecord" routines in addition
to the standard "BEncPersonnelRecordContent" and
"BDecPersonnelRecordContent".

The Content encoding and decoding routines only deal with the content
of the type, ignoring all of the tag and length pairs on the given
type (in this case the APPLICATION (CONSTRUCTED) 0 tag and the length
for the SET).  The "BEncPersonnelRecord" and "BDecPersonnelRecord"
routines do encode the APPLICATION tag and the SET's length.  This
design is motivated by IMPLICIT tagging.

The compiler generated routines generally only call the content
oriented routines except in the case of ANY and ANY DEFINED BY types.
For ANY and ANY DEFINED BY types the PDU form of the rouine is called
since the tags are not known by the containing type.


Length formats

Each pair of *_def and *_indef programs were generated from the same
source file, *_ex.c.  Indefinite length encoders can be created by
giving the -DUSE_INDEF_LEN flag to the C compiler when compiling.
Currently the indefinite/definite length encoder choice is made a
compile time.  To change this to a run-time decision, a simple
solution would be to modify BerEncodeConsLen and BerEncodeEocIfNec
macros in snacc/c_lib/asn_len.h to check a global flag.

#-------------------------------------------------------------------------------
# $Header: /usr/app/odstb/CVS/snacc/c-examples/simple/README,v 1.2 1995/02/17 16:17:24 rj Exp $
# $Log: README,v $
# Revision 1.2  1995/02/17 16:17:24  rj
# reflect the test script's integration into the makefile.
#
# Revision 1.1  1994/08/31  08:46:22  rj
# first check-in. for a list of changes to the snacc-1.1 distribution please refer to the ChangeLog.
#