* asn1buf.h (asn1buf_remove_octet, asn1buf_size, asn1buf_free,
asn1buf_ensure_space, asn1buf_len): Add macro versions.
(asn1buf_insert_octet) [__GNUC__ >= 2]: Ditto, using a GNU C
extension.
* asn1buf.c (asn1buf_remove_octet, asn1buf_size, asn1buf_free,
asn1buf_ensure_space, asn1buf_len, asn1buf_insert_octet): Undef
macros before defining as functions.
[Kerbnet changes made by raeburn@cygnus.com]
* asn1buf.h (asn1buf_expand): Remove "const" from int arg in
prototype.
* asn1buf.c (asn1buf_remove_charstring, asn1buf_create,
asn1buf_remove_octetstring, asn12krb5_buf): Call malloc instead of
calloc.
(asn1buf_unparse, asn1buf_hex_unparse): Ditto. Also don't
allocate extra byte, since sizeof(STRING) does count the trailing
null.
(asn1buf_expand): Adjust bound based on increment
value used, not value specified by caller.
[Kerbnet changes made by raeburn@cygnus.com]
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@10174
dc483132-0cff-0310-8789-
dd5450dbe970
+Thu Jul 31 15:38:10 1997 Ezra Peisach <epeisach@kangaroo.mit.edu>
+
+ * asn1buf.h (asn1buf_remove_octet, asn1buf_size, asn1buf_free,
+ asn1buf_ensure_space, asn1buf_len): Add macro versions.
+ (asn1buf_insert_octet) [__GNUC__ >= 2]: Ditto, using a GNU C
+ extension.
+ * asn1buf.c (asn1buf_remove_octet, asn1buf_size, asn1buf_free,
+ asn1buf_ensure_space, asn1buf_len, asn1buf_insert_octet): Undef
+ macros before defining as functions.
+ [Kerbnet changes made by raeburn@cygnus.com]
+
+Thu Jul 31 12:34:43 1997 Ezra Peisach <epeisach@mit.edu>
+
+ * asn1buf.h (asn1buf_expand): Remove "const" from int arg in
+ prototype.
+
+ * asn1buf.c (asn1buf_remove_charstring, asn1buf_create,
+ asn1buf_remove_octetstring, asn12krb5_buf): Call malloc instead of
+ calloc.
+ (asn1buf_unparse, asn1buf_hex_unparse): Ditto. Also don't
+ allocate extra byte, since sizeof(STRING) does count the trailing
+ null.
+ (asn1buf_expand): Adjust bound based on increment
+ value used, not value specified by caller.
+
+ [Kerbnet changes made by raeburn@cygnus.com]
+
Thu Jul 31 11:17:06 1997 Ezra Peisach <epeisach@mit.edu>
* Makefile.in (SRCS): Add / after $(srcdir) in SRCS line.
asn1_error_code asn1buf_create(buf)
asn1buf ** buf;
{
- *buf = (asn1buf*)calloc(1,sizeof(asn1buf));
+ *buf = (asn1buf*)malloc(sizeof(asn1buf));
if (*buf == NULL) return ENOMEM;
(*buf)->base = NULL;
(*buf)->bound = NULL;
return 0;
}
+#ifdef asn1buf_insert_octet
+#undef asn1buf_insert_octet
+#endif
asn1_error_code asn1buf_insert_octet(buf, o)
asn1buf * buf;
const int o;
return 0;
}
+#undef asn1buf_remove_octet
asn1_error_code asn1buf_remove_octet(buf, o)
asn1buf * buf;
asn1_octet * o;
*s = 0;
return 0;
}
- *s = (asn1_octet*)calloc(len,sizeof(asn1_octet));
+ *s = (asn1_octet*)malloc(len*sizeof(asn1_octet));
if (*s == NULL)
return ENOMEM;
for(i=0; i<len; i++)
*s = 0;
return 0;
}
- *s = (char*)calloc(len,sizeof(char));
+ *s = (char*)malloc(len*sizeof(char));
if (*s == NULL) return ENOMEM;
for(i=0; i<len; i++)
(*s)[i] = (char)(buf->next)[i];
(*code)->data = NULL;
(*code)->length = 0;
(*code)->length = asn1buf_len(buf);
- (*code)->data = (char*)calloc(((*code)->length)+1,sizeof(char));
+ (*code)->data = (char*)malloc((((*code)->length)+1)*sizeof(char));
for(i=0; i < (*code)->length; i++)
((*code)->data)[i] = (buf->base)[((*code)->length)-i-1];
((*code)->data)[(*code)->length] = '\0';
{
if(*s != NULL) free(*s);
if(buf == NULL){
- *s = calloc(sizeof("<NULL>")+1, sizeof(char));
+ *s = malloc(sizeof("<NULL>"));
if(*s == NULL) return ENOMEM;
strcpy(*s,"<NULL>");
}else if(buf->base == NULL){
- *s = calloc(sizeof("<EMPTY>")+1, sizeof(char));
+ *s = malloc(sizeof("<EMPTY>"));
if(*s == NULL) return ENOMEM;
strcpy(*s,"<EMPTY>");
}else{
if(*s != NULL) free(*s);
if(buf == NULL){
- *s = calloc(sizeof("<NULL>")+1, sizeof(char));
+ *s = malloc(sizeof("<NULL>"));
if(*s == NULL) return ENOMEM;
strcpy(*s,"<NULL>");
}else if(buf->base == NULL){
- *s = calloc(sizeof("<EMPTY>")+1, sizeof(char));
+ *s = malloc(sizeof("<EMPTY>"));
if(*s == NULL) return ENOMEM;
strcpy(*s,"<EMPTY>");
}else{
int length = asn1buf_len(buf);
int i;
- *s = calloc(3*length, sizeof(char));
+ *s = malloc(3*length);
if(*s == NULL) return ENOMEM;
for(i = length-1; i >= 0; i--){
(*s)[3*(length-i-1)] = hexchar(((buf->base)[i]&0xF0)>>4);
/****************************************************************/
/* Private Procedures */
+#undef asn1buf_size
int asn1buf_size(buf)
const asn1buf * buf;
{
return buf->bound - buf->base + 1;
}
+#undef asn1buf_free
int asn1buf_free(buf)
const asn1buf * buf;
{
else return buf->bound - buf->next + 1;
}
+#undef asn1buf_ensure_space
asn1_error_code asn1buf_ensure_space(buf, amount)
asn1buf * buf;
const int amount;
asn1_error_code asn1buf_expand(buf, inc)
asn1buf * buf;
- const int inc;
+ int inc;
{
#define STANDARD_INCREMENT 200
int next_offset = buf->next - buf->base;
if(buf->base == NULL) bound_offset = -1;
else bound_offset = buf->bound - buf->base;
+ if (inc < STANDARD_INCREMENT)
+ inc = STANDARD_INCREMENT;
+
if (buf->base == NULL)
- buf->base = malloc((asn1buf_size(buf)+(inc>STANDARD_INCREMENT ?
- inc : STANDARD_INCREMENT))
- * sizeof(asn1_octet));
+ buf->base = malloc((asn1buf_size(buf)+inc) * sizeof(asn1_octet));
else
buf->base = realloc(buf->base,
- (asn1buf_size(buf)+(inc>STANDARD_INCREMENT ?
- inc : STANDARD_INCREMENT))
- * sizeof(asn1_octet));
+ (asn1buf_size(buf)+inc) * sizeof(asn1_octet));
if(buf->base == NULL) return ENOMEM;
- buf->bound = (buf->base) + bound_offset + (inc > STANDARD_INCREMENT ?
- inc : STANDARD_INCREMENT);
+ buf->bound = (buf->base) + bound_offset + inc;
buf->next = (buf->base) + next_offset;
return 0;
}
+#undef asn1buf_len
int asn1buf_len(buf)
const asn1buf * buf;
{
/* requires *buf is allocated
effects Inserts o into the buffer *buf, expanding the buffer if
necessary. Returns ENOMEM memory is exhausted. */
+#if __GNUC__ >= 2
+#define asn1buf_insert_octet(BUF,O) \
+ (asn1buf_ensure_space ((BUF),1) \
+ ? /* leave this empty -- gcc returns value of first operand */ \
+ : (*(BUF)->next++ = (O), 0))
+#endif
asn1_error_code asn1buf_insert_octetstring
PROTOTYPE((asn1buf *buf, const int len, const asn1_octet *s));
effects Returns *buf's current octet in *o and advances to
the next octet.
Returns ASN1_OVERRUN if *buf has already been exhuasted. */
+#define asn1buf_remove_octet(buf,o) \
+ (((buf)->next > (buf)->bound) \
+ ? ASN1_OVERRUN \
+ : ((*(o) = (asn1_octet)(*(((buf)->next)++))),0))
asn1_error_code asn1buf_remove_octetstring
PROTOTYPE((asn1buf *buf, const int len, asn1_octet **s));
/* requires *buf has been created and not destroyed
effects Returns the total size
PROTOTYPE((in octets) of buf's octet buffer. */
+#define asn1buf_size(buf) \
+ (((buf) == NULL || (buf)->base == NULL) \
+ ? 0 \
+ : ((buf)->bound - (buf)->base + 1))
int asn1buf_free
PROTOTYPE((const asn1buf *buf));
/* requires *buf is allocated
effects Returns the number of unused, allocated octets in *buf. */
+#define asn1buf_free(buf) \
+ (((buf) == NULL || (buf)->base == NULL) \
+ ? 0 \
+ : ((buf)->bound - (buf)->next + 1))
+
asn1_error_code asn1buf_ensure_space
PROTOTYPE((asn1buf *buf, const int amount));
effects If buf has less than amount octets of free space, then it is
expanded to have at least amount octets of free space.
Returns ENOMEM memory is exhausted. */
+#define asn1buf_ensure_space(buf,amount) \
+ ((asn1buf_free(buf) < (amount)) \
+ ? (asn1buf_expand((buf), (amount)-asn1buf_free(buf))) \
+ : 0)
+
asn1_error_code asn1buf_expand
- PROTOTYPE((asn1buf *buf, const int inc));
+ PROTOTYPE((asn1buf *buf, int inc));
/* requires *buf is allocated
modifies *buf
effects Expands *buf by allocating space for inc more octets.
PROTOTYPE((const asn1buf *buf));
/* requires *buf is allocated
effects Returns the length of the encoding in *buf. */
+#define asn1buf_len(buf) ((buf)->next - (buf)->base)
#endif