PSetRelativeDistinguishedNames.c
上传用户:lyxiangda
上传日期:2007-01-12
资源大小:3042k
文件大小:4k
源码类别:

CA认证

开发平台:

WINDOWS

  1. /* 
  2.  * The contents of this file are subject to the Mozilla Public
  3.  * License Version 1.1 (the "License"); you may not use this file
  4.  * except in compliance with the License. You may obtain a copy of
  5.  * the License at http://www.mozilla.org/MPL/
  6.  * 
  7.  * Software distributed under the License is distributed on an "AS
  8.  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
  9.  * implied. See the License for the specific language governing
  10.  * rights and limitations under the License.
  11.  * 
  12.  * The Original Code is the Netscape security libraries.
  13.  * 
  14.  * The Initial Developer of the Original Code is Netscape
  15.  * Communications Corporation.  Portions created by Netscape are 
  16.  * Copyright (C) 1994-2000 Netscape Communications Corporation.  All
  17.  * Rights Reserved.
  18.  * 
  19.  * Contributor(s):
  20.  * 
  21.  * Alternatively, the contents of this file may be used under the
  22.  * terms of the GNU General Public License Version 2 or later (the
  23.  * "GPL"), in which case the provisions of the GPL are applicable 
  24.  * instead of those above.  If you wish to allow use of your 
  25.  * version of this file only under the terms of the GPL and not to
  26.  * allow others to use your version of this file under the MPL,
  27.  * indicate your decision by deleting the provisions above and
  28.  * replace them with the notice and other provisions required by
  29.  * the GPL.  If you do not delete the provisions above, a recipient
  30.  * may use your version of this file under either the MPL or the
  31.  * GPL.
  32.  */
  33. #ifdef DEBUG
  34. static const char CVS_ID[] = "@(#) $Source: /cvsroot/mozilla/security/nss/lib/pkix/src/RDNSequence/PSetRelativeDistinguishedNames.c,v $ $Revision: 1.1 $ $Date: 2000/03/31 19:14:16 $ $Name: NSS_3_1_1_RTM $";
  35. #endif /* DEBUG */
  36. #ifndef PKIX_H
  37. #include "pkix.h"
  38. #endif /* PKIX_H */
  39. /*
  40.  * nssPKIXRDNSequence_SetRelativeDistinguishedNames
  41.  *
  42.  * -- fgmr comments --
  43.  * If the array pointer itself is null, the set is considered empty.
  44.  * If the count is zero but the pointer nonnull, the array will be
  45.  * assumed to be null-terminated.
  46.  *
  47.  * The error may be one of the following values:
  48.  *  NSS_ERROR_INVALID_PKIX_RDN_SEQUENCE
  49.  *  NSS_ERROR_INVALID_PKIX_RDN
  50.  *
  51.  * Return value:
  52.  *  PR_SUCCESS upon success
  53.  *  PR_FAILURE upon failure
  54.  */
  55. NSS_IMPLEMENT PRStatus
  56. nssPKIXRDNSequence_SetRelativeDistinguishedNames
  57. (
  58.   NSSPKIXRDNSequence *rdnseq,
  59.   NSSPKIXRelativeDistinguishedName *rdns[],
  60.   PRInt32 countOpt
  61. )
  62. {
  63.   NSSPKIXRelativeDistinguishedName **ip;
  64.   NSSPKIXRelativeDistinguishedName **newarray;
  65.   PRUint32 i;
  66.   nssArenaMark *mark;
  67. #ifdef NSSDEBUG
  68.   if( PR_SUCCESS != nssPKIXRDNSequence_verifyPointer(rdnseq) ) {
  69.     return PR_FAILURE;
  70.   }
  71.   if( (NSSPKIXRelativeDistinguishedName **)NULL == rdns ) {
  72.     nss_SetError(NSS_ERROR_INVALID_POINTER);
  73.     return PR_FAILURE;
  74.   }
  75.   {
  76.     PRUint32 i, count;
  77.     if( 0 == countOpt ) {
  78.       for( i = 0; i < 0x80000000; i++ ) {
  79.         if( (NSSPKIXRelativeDistinguishedName *)NULL == rdns[i] ) {
  80.           break;
  81.         }
  82.       }
  83. #ifdef PEDANTIC
  84.       if( 0x80000000 == i ) {
  85.         nss_SetError(NSS_ERROR_VALUE_OUT_OF_RANGE);
  86.         return PR_FAILURE;
  87.       }
  88. #endif /* PEDANTIC */
  89.       count = (PRUint32)i;
  90.     } else {
  91.       if( countOpt < 0 ) {
  92.         nss_SetError(NSS_ERROR_VALUE_OUT_OF_RANGE);
  93.         return PR_FAILURE;
  94.       }
  95.       count = (PRUint32)countOpt;
  96.     }
  97.     for( i = 0; i < count; i++ ) {
  98.       if( PR_SUCCESS != nssPKIXRelativeDistinguishedName_verifyPointer(rdns[i]) ) {
  99.         return PR_FAILURE;
  100.       }
  101.     }
  102.   }
  103. #endif /* NSSDEBUG */
  104.   mark = nssArena_Mark(rdnseq->mark);
  105.   if( (nssArenaMark *)NULL == mark ) {
  106.     return PR_FAILURE;
  107.   }
  108.   newarray = nss_ZNEWARRAY(rdnseq->arena, NSSPKIXRelativeDistinguishedName *, countOpt);
  109.   if( (NSSPKIXRelativeDistinguishedName **)NULL == newarray ) {
  110.     goto loser;
  111.   }
  112.   for( i = 0; i < countOpt; i++ ) {
  113.     newarray[i] = nssPKIXRelativeDistinguishedName_Duplicate(rdns[i], rdnseq->arena);
  114.     if( (NSSPKIXRelativeDistinguishedName *)NULL == newarray[i] ) {
  115.       goto loser;
  116.     }
  117.   }
  118.   for( i = 0; i < rdnseq->count; i++ ) {
  119.     if( PR_SUCCESS != nssPKIXRelativeDistinguishedName_Destroy(rdnseq->rdns[i]) ) {
  120.       goto loser;
  121.     }
  122.   }
  123.   nss_ZFreeIf(rdnseq->rdns);
  124.   rdnseq->count = countOpt;
  125.   rdnseq->rdns = newarray;
  126.   (void)nss_pkix_RDNSequence_Clear(rdnseq);
  127.   return nssArena_Unmark(rdnseq->arena, mark);
  128.  loser:
  129.   (void)nssArena_Release(a->arena, mark);
  130.   return PR_FAILURE;
  131. }