mvcreate.c
来自「支持SSL v2/v3, TLS, PKCS #5, PKCS #7, PKCS」· C语言 代码 · 共 142 行
C
142 行
/* * The contents of this file are subject to the Mozilla Public * License Version 1.1 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is the Netscape security libraries. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1994-2000 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): * * Alternatively, the contents of this file may be used under the * terms of the GNU General Public License Version 2 or later (the * "GPL"), in which case the provisions of the GPL are applicable * instead of those above. If you wish to allow use of your * version of this file only under the terms of the GPL and not to * allow others to use your version of this file under the MPL, * indicate your decision by deleting the provisions above and * replace them with the notice and other provisions required by * the GPL. If you do not delete the provisions above, a recipient * may use your version of this file under either the MPL or the * GPL. */#ifdef DEBUGstatic const char CVS_ID[] = "@(#) $Source: /cvsroot/mozilla/security/nss/lib/pkix/src/RDNSequence/MVCreate.c,v $ $Revision: 1.1 $ $Date: 2000/03/31 19:14:12 $ $Name: NSS_3_1_1_RTM $";#endif /* DEBUG */#ifndef PKIX_H#include "pkix.h"#endif /* PKIX_H *//* * nss_pkix_RDNSequence_v_create */NSS_IMPLEMENT NSSPKIXRDNSequence *nss_pkix_RDNSequence_v_create( NSSArena *arenaOpt, PRUint32 count, va_list ap){ NSSArena *arena; PRBool arena_allocated = PR_FALSE; nssArenaMark *mark = (nssArenaMark *)NULL; NSSPKIXRDNSequence *rv = (NSSPKIXRDNSequence *)NULL; PRStatus status; PRUint32 i;#ifdef NSSDEBUG if( (NSSArena *)NULL != arenaOpt ) { if( PR_SUCCESS != nssArena_verifyPointer(arenaOpt) ) { return (NSSPKIXRDNSequence *)NULL; } }#endif /* NSSDEBUG */ if( (NSSArena *)NULL == arenaOpt ) { arena = nssArena_Create(); if( (NSSArena *)NULL == arena ) { goto loser; } arena_allocated = PR_TRUE; } else { arena = arenaOpt; mark = nssArena_Mark(arena); if( (nssArenaMark *)NULL == mark ) { goto loser; } } rv = nss_ZNEW(arena, NSSPKIXRDNSequence); if( (NSSPKIXRDNSequence *)NULL == rv ) { goto loser; } rv->arena = arena; rv->i_allocated_arena = arena_allocated; rv->count = count; rv->rdns = nss_ZNEWARRAY(arena, NSSPKIXRelativeDistinguishedName *, count); if( (NSSPKIXRelativeDistinguishedName **)NULL == rv->rdns ) { goto loser; } for( i = 0; i < count; i++ ) { NSSPKIXRelativeDistinguishedName *v = (NSSPKIXRelativeDistinguishedName *) va_arg(ap, NSSPKIXRelativeDistinguishedName *);#ifdef NSSDEBUG /* * It's okay to test this down here, since * supposedly these have already been checked. */ if( PR_SUCCESS != nssPKIXRelativeDistinguishedName_verifyPointer(v) ) { goto loser; }#endif /* NSSDEBUG */ rv->rdns[i] = nssPKIXRelativeDistinguishedName_Duplicate(v, arena); if( (NSSPKIXRelativeDistinguishedName *)NULL == rv->rdns[i] ) { goto loser; } } if( (nssArenaMark *)NULL != mark ) { if( PR_SUCCESS != nssArena_Unmark(arena, mark) ) { goto loser; } }#ifdef DEBUG if( PR_SUCCESS != nss_pkix_RDNSequence_add_pointer(rv) ) { goto loser; }#endif /* DEBUG */ return rv; loser: if( (nssArenaMark *)NULL != mark ) { (void)nssArena_Release(arena, mark); } if( PR_TRUE == arena_allocated ) { (void)nssArena_Destroy(arena); } return (NSSPKIXRDNSequence *)NULL;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?