]> git.saurik.com Git - apple/security.git/blobdiff - SecuritySNACCRuntime/c++-lib/c++/asn-octs.cpp
Security-163.tar.gz
[apple/security.git] / SecuritySNACCRuntime / c++-lib / c++ / asn-octs.cpp
diff --git a/SecuritySNACCRuntime/c++-lib/c++/asn-octs.cpp b/SecuritySNACCRuntime/c++-lib/c++/asn-octs.cpp
deleted file mode 100644 (file)
index 0dc5351..0000000
+++ /dev/null
@@ -1,518 +0,0 @@
-/*
- * Copyright (c) 2000-2001 Apple Computer, Inc. All Rights Reserved.
- * 
- * The contents of this file constitute Original Code as defined in and are
- * subject to the Apple Public Source License Version 1.2 (the 'License').
- * You may not use this file except in compliance with the License. Please obtain
- * a copy of the License at http://www.apple.com/publicsource and read it before
- * using this file.
- * 
- * This Original Code and all software distributed under the License are
- * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
- * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
- * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
- * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
- * specific language governing rights and limitations under the License.
- */
-
-
-// file: .../c++-lib/src/asn-octs.C - ASN.1 OCTET STRING methods for AsnOcts Class
-//
-//  Mike Sample
-//  92/07/02
-// Copyright (C) 1992 Michael Sample and the University of British Columbia
-//
-// This library is free software; you can redistribute it and/or
-// modify it provided that this copyright/license information is retained
-// in original form.
-//
-// If you modify this file, you must clearly indicate your changes.
-//
-// This source code is distributed in the hope that it will be
-// useful, but WITHOUT ANY WARRANTY; without even the implied warranty
-// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-//
-// $Header: /cvs/root/Security/SecuritySNACCRuntime/c++-lib/c++/Attic/asn-octs.cpp,v 1.3 2002/03/21 05:38:44 dmitch Exp $
-// $Log: asn-octs.cpp,v $
-// Revision 1.3  2002/03/21 05:38:44  dmitch
-// Radar 2868524: no more setjmp/longjmp in SNACC-generated code.
-//
-// Revision 1.2.44.1  2002/03/20 00:36:49  dmitch
-// Radar 2868524: SNACC-generated code now uses throw/catch instead of setjmp/longjmp.
-//
-// Revision 1.2  2001/06/27 23:09:15  dmitch
-// Pusuant to Radar 2664258, avoid all cerr-based output in NDEBUG configuration.
-//
-// Revision 1.1.1.1  2001/05/18 23:14:06  mb
-// Move from private repository to open source repository
-//
-// Revision 1.3  2001/05/05 00:59:17  rmurphy
-// Adding darwin license headers
-//
-// Revision 1.2  2000/12/07 22:16:14  dmitch
-// Thread-safe mods: added a local StrStk strStkG to the routines which need it.
-//
-// Revision 1.1  2000/06/15 18:44:57  dmitch
-// These snacc-generated source files are now checked in to allow cross-platform build.
-//
-// Revision 1.2  2000/06/08 20:05:35  dmitch
-// Mods for X port. These files are actually machine generated and probably don't need to be in CVS....
-//
-// Revision 1.1.1.1  2000/03/09 01:00:06  rmurphy
-// Base Fortissimo Tree
-//
-// Revision 1.4  1999/04/08 21:21:25  aram
-// Fixed AsnOcts destructor.
-//
-// Revision 1.3  1999/03/21 02:07:36  mb
-// Added Copy to every AsnType.
-//
-// Revision 1.2  1999/02/26 00:23:40  mb
-// Fixed for Mac OS 8
-//
-// Revision 1.1  1999/02/25 05:21:53  mb
-// Added snacc c++ library
-//
-// Revision 1.6  1997/02/28 13:39:45  wan
-// Modifications collected for new version 1.3: Bug fixes, tk4.2.
-//
-// Revision 1.5  1995/08/17 15:33:33  rj
-// augment binify()'s error message
-//
-// Revision 1.4  1995/07/24  20:23:32  rj
-// use memcmpeq that is defined in .../snacc.h to use either memcmp or bcmp.
-//
-// code extracted from AsnOcts::TclGetVal and AsnOcts::TclSetVal into ::debinify and ::binify in meta.C
-//
-// #if TCL ... #endif wrapped into #if META ... #endif
-//
-// call constructor with additional pdu and create arguments.
-//
-// changed `_' to `-' in file names.
-//
-// Revision 1.3  1994/10/08  04:18:27  rj
-// code for meta structures added (provides information about the generated code itself).
-//
-// code for Tcl interface added (makes use of the above mentioned meta code).
-//
-// virtual inline functions (the destructor, the Clone() function, BEnc(), BDec() and Print()) moved from inc/*.h to src/*.C because g++ turns every one of them into a static non-inline function in every file where the .h file gets included.
-//
-// made Print() const (and some other, mainly comparison functions).
-//
-// several `unsigned long int' turned into `size_t'.
-//
-// Revision 1.2  1994/08/28  10:01:16  rj
-// comment leader fixed.
-//
-// Revision 1.1  1994/08/28  09:21:05  rj
-// first check-in. for a list of changes to the snacc-1.1 distribution please refer to the ChangeLog.
-
-#include "asn-config.h"
-#include "asn-len.h"
-#include "asn-tag.h"
-#include "asn-type.h"
-#include "asn-bits.h" /* for TO_HEX */
-#include "asn-octs.h"
-#include "str-stk.h"
-
-#ifndef        __APPLE__
-extern StrStk strStkG;
-#endif
-
-AsnOcts::~AsnOcts()
-{
-  Asn1Free( octs );
-}
-
-AsnType *AsnOcts::Clone() const
-{
-  return new AsnOcts;
-}
-
-AsnType *AsnOcts::Copy() const
-{
-  return new AsnOcts (*this);
-}
-
-// Initialize the AsnOcts with a char * and length.
-// copies the string str.
-void AsnOcts::Set (const char *str, size_t len)
-{
-    octetLen = len;
-#ifndef _IBM_ENC_
-    octs = new char[octetLen];
-#else
-    octs = (char *) mem_mgr_ptr->Get (octetLen+1);          /* Guido Grassel, 11.8.93 */
-#endif /* _IBM_ENC_ */
-    memcpy (octs, str, octetLen);
-}
-
-// Initialize the AsnOcts from another AsnOcts
-// copies the string from o.
-void AsnOcts::Set (const AsnOcts &o)
-{
-    if (&o != this) // avoid o = o;
-    {
-        octetLen = o.octetLen;
-#ifndef _IBM_ENC_
-        octs = new char[octetLen];
-#else
-       octs = (char *) mem_mgr_ptr->Get (octetLen+1);         /* Guido Grassel, 11.8.93 */
-#endif /* _IBM_ENC_ */
-        memcpy (octs, o.octs, octetLen);
-    }
-}
-
-// Initialize the AsnOcts from a Null terminated string.
-// copies the string str.
-void AsnOcts::Set (const char *str)
-{
-    octetLen = strlen (str);
-#ifndef _IBM_ENC_
-    octs = new char[octetLen];
-#else
-    octs = (char *) mem_mgr_ptr->Get (octetLen+1);         /* Guido Grassel, 11.8.93 */
-#endif /* _IBM_ENC_ */
-    memcpy (octs, str, octetLen);
-}
-
-
-// free old octs value and tehn set the new
-// octs and octetLen values with the given char *and length.
-// copies the string str.
-void AsnOcts::ReSet (const char *str, size_t len)
-{
-    if (str != octs)
-    {
-#ifndef _IBM_ENC_
-        delete octs;
-        Set (str, len);
-#else
-      mem_mgr_ptr->Put ((void *)octs);                /* Guido Grassel, 11.8.93 */
-      Set (str, len);
-#endif /* _IBM_ENC_ */
-    }
-}
-
-// Free old octs value and then set the new
-// octs and octetLen from the given AsnOcts
-// copies the string in o.
-void AsnOcts::ReSet (const AsnOcts &o)
-{
-    if (&o != this) // avoid s = s;
-    {
-#ifndef _IBM_ENC_
-        delete octs;
-        Set (o);
-#else
-      mem_mgr_ptr->Put ((void *)octs);               /* Guido Grassel, 11.8.93 */
-      Set (o);
-#endif /* _IBM_ENC_ */
-    }
-}
-
-// Free old octs value and then set the new
-// octs and octetLen values from a null terminated string.
-// copies the string str.
-void AsnOcts::ReSet (const char *str)
-{
-    if (str != octs)
-    {
-#ifndef _IBM_ENC_
-        delete octs;
-        Set (str);
-#else
-      mem_mgr_ptr->Put ((void *)octs);                /* Guido Grassel, 11.8.93 */
-      Set (str);
-#endif /* _IBM_ENC_ */
-    }
-}
-
-
-// Prints the AsnOcts to the given ostream in Value Notation.
-void AsnOcts::Print (ostream &os) const
-{
-#ifndef        NDEBUG
-    unsigned i;
-    os << "'";
-    for (i = 0; i < octetLen; i++)
-        os << TO_HEX (octs[i] >> 4) << (TO_HEX (octs[i]));
-
-    os << "'H  -- \"";
-
-    /* put printable parts in ASN.1 comment */
-    for (i = 0; i < octetLen; i++)
-    {
-        if (isspace (octs[i]))
-            os << " ";  /* newlines->space (so don't screw up ASN.1 comment) */
-        else if (isprint (octs[i]))
-            os <<octs[i];
-        else
-            os << ".";
-    }
-    os << "\" --";
-#endif /* NDEBUG */
-} /* AsnOcts::Print */
-
-
-AsnLen AsnOcts::BEncContent (BUF_TYPE b)
-{
-    b.PutSegRvs (octs, octetLen);
-    return octetLen;
-}
-
-// Decodes a BER OCTET STRING value and puts it in this object.
-// Constructed OCTET STRINGs are always concatenated into primitive ones.
-void AsnOcts::BDecContent (BUF_TYPE b, AsnTag tagId, AsnLen elmtLen, AsnLen &bytesDecoded, ENV_TYPE env)
-{
-    /*
-     * tagId is encoded tag shifted into long int.
-     * if CONS bit is set then constructed octet string
-     */
-    if (tagId & 0x20000000)
-        BDecConsOcts (b, elmtLen, bytesDecoded, env);
-
-    else /* primitive octet string */
-    {
-        octetLen = elmtLen;
-#ifndef _IBM_ENC_
-        octs =  Asn1Alloc (elmtLen+1);
-#else
-      octs = (char *) mem_mgr_ptr->Get (elmtLen+1);                /* Guido Grassel, 11.8.93 */
-#endif /* _IBM_ENC_ */
-        b.CopyOut (octs, elmtLen);
-
-        if (b.ReadError())
-        {
-            Asn1Error << "BDecOctetString: ERROR - decoded past end of data" << endl;
-                       #if SNACC_EXCEPTION_ENABLE
-                       SnaccExcep::throwMe(-14);
-                       #else
-            longjmp (env, -14);
-                       #endif
-        }
-
-        /* add null terminator - this is not included in the str's len */
-        octs[elmtLen] = '\0';
-        bytesDecoded += elmtLen;
-    }
-
-} /* AsnOcts::BDecContent */
-
-AsnLen AsnOcts::BEnc (BUF_TYPE b)
-{
-    AsnLen l;
-    l =  BEncContent (b);
-    l += BEncDefLen (b, l);
-    l += BEncTag1 (b, UNIV, PRIM, OCTETSTRING_TAG_CODE);
-    return l;
-}
-
-void AsnOcts::BDec (BUF_TYPE b, AsnLen &bytesDecoded, ENV_TYPE env)
-{
-    AsnLen elmtLen;
-    AsnTag tag;
-
-    tag = BDecTag (b, bytesDecoded, env);
-    if ((tag != MAKE_TAG_ID (UNIV, PRIM, OCTETSTRING_TAG_CODE)) &&
-       (tag != MAKE_TAG_ID (UNIV, CONS, OCTETSTRING_TAG_CODE)))
-    {
-       Asn1Error << "AsnOcts::BDec: ERROR tag on OCTET STRING is wrong." << endl;
-       #if SNACC_EXCEPTION_ENABLE
-       SnaccExcep::throwMe(-56);
-       #else
-       longjmp (env,-56);
-       #endif
-    }
-    elmtLen = BDecLen (b, bytesDecoded, env);
-    BDecContent (b, tag, elmtLen, bytesDecoded, env);
-}
-
-
-
-/*
- * Used for concatenating constructed OCTET STRING values when decoding
- *
- * fills string stack with references to the pieces of a
- * construced octet string
- */
-#ifdef __APPLE__
-static void
-FillOctetStringStk (BUF_TYPE b, AsnLen elmtLen0, AsnLen &bytesDecoded, ENV_TYPE env, StrStk &strStkG)
-#else
-static void
-FillOctetStringStk (BUF_TYPE b, AsnLen elmtLen0, AsnLen &bytesDecoded, ENV_TYPE env)
-#endif
-{
-    size_t refdLen;
-    size_t totalRefdLen;
-    char *strPtr;
-    AsnLen totalElmtsLen1 = 0;
-    unsigned long int tagId1;
-    AsnLen elmtLen1;
-
-    for (; (totalElmtsLen1 < elmtLen0) || (elmtLen0 == INDEFINITE_LEN);)
-    {
-        tagId1 = BDecTag (b, totalElmtsLen1, env);
-
-        if ((tagId1 == EOC_TAG_ID) && (elmtLen0 == INDEFINITE_LEN))
-        {
-            BDEC_2ND_EOC_OCTET (b, totalElmtsLen1, env);
-            break;
-        }
-
-        elmtLen1 = BDecLen (b, totalElmtsLen1, env);
-        if (tagId1 == MAKE_TAG_ID (UNIV, PRIM, OCTETSTRING_TAG_CODE))
-        {
-            /*
-             * primitive part of string, put references to piece (s) in
-             * str stack
-             */
-            totalRefdLen = 0;
-            refdLen = elmtLen1;
-            while (1)
-            {
-                strPtr = b.GetSeg (&refdLen);
-
-                strStkG.Push (strPtr, refdLen);
-                totalRefdLen += refdLen;
-                if (totalRefdLen == elmtLen1)
-                    break; /* exit this while loop */
-
-                if (refdLen == 0) /* end of data */
-                {
-                    Asn1Error << "BDecConsOctetString: ERROR - attempt to decode past end of data" << endl;
-                                       #if SNACC_EXCEPTION_ENABLE
-                                       SnaccExcep::throwMe(-15);
-                                       #else
-                    longjmp (env, -15);
-                                       #endif
-                }
-                refdLen = elmtLen1 - totalRefdLen;
-            }
-            totalElmtsLen1 += elmtLen1;
-        }
-
-
-        else if (tagId1 == MAKE_TAG_ID (UNIV, CONS, OCTETSTRING_TAG_CODE))
-        {
-            /*
-             * constructed octets string embedding in this constructed
-             * octet string. decode it.
-             */
-                       #ifdef  __APPLE__
-            FillOctetStringStk (b, elmtLen1, totalElmtsLen1, env,
-                               strStkG);
-                       #else
-            FillOctetStringStk (b, elmtLen1, totalElmtsLen1, env);
-                       #endif
-        }
-        else  /* wrong tag */
-        {
-            Asn1Error << "BDecConsOctetString: ERROR - decoded non-OCTET STRING tag inside a constructed OCTET STRING" << endl;
-                       #if SNACC_EXCEPTION_ENABLE
-                       SnaccExcep::throwMe(-16);
-                       #else
-            longjmp (env, -16);
-                       #endif
-        }
-    } /* end of for */
-
-    bytesDecoded += totalElmtsLen1;
-
-}  /* AsnOcts::FillOctetStringStk */
-
-
-
-/*
- * decodes a seq of universally tagged octets until either EOC is
- * encountered or the given len decoded.  Return them in a
- * single concatenated octet string
- */
-void AsnOcts::BDecConsOcts (BUF_TYPE b, AsnLen elmtLen, AsnLen &bytesDecoded, ENV_TYPE env)
-{
-       #ifdef  __APPLE__
-       StrStk strStkG(128, 64);
-       #endif
-    strStkG.Reset();
-
-    /*
-     * decode each piece of the octet string, puting
-     * an entry in the octet/bit string stack for each
-     */
-       #ifdef  __APPLE__
-    FillOctetStringStk (b, elmtLen, bytesDecoded, env, strStkG);
-       #else
-    FillOctetStringStk (b, elmtLen, bytesDecoded, env);
-       #endif
-       
-    /* alloc single str long enough for combined octetstring */
-    octetLen = strStkG.totalByteLen;
-
-#ifndef _IBM_ENC_
-    octs = Asn1Alloc (octetLen);
-#else
-    octs = (char *) mem_mgr_ptr->Get (octetLen);                /* Guido Grassel, 11.8.93 */
-#endif /* _IBM_ENC_ */
-
-    strStkG.CopyOut (octs);
-
-}  /* BDecConsOcts */
-
-int AsnOcts::OctsEquiv (const AsnOcts &o) const
-{
-    return o.octetLen == octetLen && !memcmpeq (o.octs, octs, octetLen);
-}
-
-#if META
-
-const AsnOctsTypeDesc AsnOcts::_desc (NULL, NULL, false, AsnTypeDesc::OCTET_STRING, NULL);
-
-const AsnTypeDesc *AsnOcts::_getdesc() const
-{
-  return &_desc;
-}
-
-#if TCL
-
-int AsnOcts::TclGetVal (Tcl_Interp *interp) const
-{
-  return debinify (interp, octs, octetLen);
-}
-
-int AsnOcts::TclSetVal (Tcl_Interp *interp, const char *valstr)
-{
-  char*                buf;
-  size_t       len;
-  int          result = TCL_OK;
-
-#ifndef _IBM_ENC_
-    buf = new char[strlen (valstr)];
-#else
-    buf = (char *) mem_mgr_ptr->Get (strlen (valstr)+1);
-#endif /* _IBM_ENC_ */
-
-  if (!buf)
-  {
-    Tcl_AppendResult (interp, "Malloc failed for type ", _getdesc()->getmodule()->name, ".", _getdesc()->getname(), NULL);
-    return TCL_ERROR;
-  }
-  if (binify (interp, valstr, buf, &len) != TCL_OK)
-  {
-    Tcl_AppendResult (interp, " for type ", _getdesc()->getmodule()->name, ".", _getdesc()->getname(), NULL);
-    result = TCL_ERROR;
-  }
-  else
-    ReSet (buf, len);
-
-#ifndef _IBM_ENC_
-  delete buf;
-#else
-  mem_mgr_ptr->Put ((void*) buf);
-#endif /* _IBM_ENC_ */
-
-  return result;
-}
-
-#endif /* TCL */
-#endif /* META */