diff options
| author | Alan Mishchenko <alanmi@berkeley.edu> | 2005-07-29 08:01:00 -0700 | 
|---|---|---|
| committer | Alan Mishchenko <alanmi@berkeley.edu> | 2005-07-29 08:01:00 -0700 | 
| commit | 888e5bed5d7f56a5d86d91a6e8e88f3e5a3454dc (patch) | |
| tree | 11d48c9e9069f54dc300c3571ae63c744c802c50 /src/misc/vec | |
| parent | 7f94414388cce67bd3cc1a6d6269f0ed31ed0d06 (diff) | |
| download | abc-888e5bed5d7f56a5d86d91a6e8e88f3e5a3454dc.tar.gz abc-888e5bed5d7f56a5d86d91a6e8e88f3e5a3454dc.tar.bz2 abc-888e5bed5d7f56a5d86d91a6e8e88f3e5a3454dc.zip  | |
Version abc50729
Diffstat (limited to 'src/misc/vec')
| -rw-r--r-- | src/misc/vec/module.make | 1 | ||||
| -rw-r--r-- | src/misc/vec/vec.h | 58 | ||||
| -rw-r--r-- | src/misc/vec/vecFan.h | 361 | ||||
| -rw-r--r-- | src/misc/vec/vecInt.h | 496 | ||||
| -rw-r--r-- | src/misc/vec/vecPtr.h | 461 | ||||
| -rw-r--r-- | src/misc/vec/vecStr.h | 466 | 
6 files changed, 1843 insertions, 0 deletions
diff --git a/src/misc/vec/module.make b/src/misc/vec/module.make new file mode 100644 index 00000000..d6d908e7 --- /dev/null +++ b/src/misc/vec/module.make @@ -0,0 +1 @@ +SRC +=  diff --git a/src/misc/vec/vec.h b/src/misc/vec/vec.h new file mode 100644 index 00000000..34b0bfa2 --- /dev/null +++ b/src/misc/vec/vec.h @@ -0,0 +1,58 @@ +/**CFile**************************************************************** + +  FileName    [vec.h] + +  SystemName  [ABC: Logic synthesis and verification system.] + +  PackageName [Resizable arrays.] + +  Synopsis    [External declarations.] + +  Author      [Alan Mishchenko] +   +  Affiliation [UC Berkeley] + +  Date        [Ver. 1.0. Started - June 20, 2005.] + +  Revision    [$Id: vec.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $] + +***********************************************************************/ +  +#ifndef __VEC_H__ +#define __VEC_H__ + +//////////////////////////////////////////////////////////////////////// +///                          INCLUDES                                /// +//////////////////////////////////////////////////////////////////////// + +#ifdef _WIN32 +#define inline __inline // compatible with MS VS 6.0 +#endif + +#include "vecFan.h" +#include "vecInt.h" +#include "vecPtr.h" +#include "vecStr.h" + +//////////////////////////////////////////////////////////////////////// +///                         PARAMETERS                               /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                         BASIC TYPES                              /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                      MACRO DEFITIONS                             /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                    FUNCTION DECLARATIONS                         /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                       END OF FILE                                /// +//////////////////////////////////////////////////////////////////////// + +#endif + diff --git a/src/misc/vec/vecFan.h b/src/misc/vec/vecFan.h new file mode 100644 index 00000000..7bfded4a --- /dev/null +++ b/src/misc/vec/vecFan.h @@ -0,0 +1,361 @@ +/**CFile**************************************************************** + +  FileName    [vecFan.h] + +  SystemName  [ABC: Logic synthesis and verification system.] + +  PackageName [Resizable arrays.] + +  Synopsis    [Resizable arrays of integers (fanins/fanouts) with memory management.] + +  Author      [Alan Mishchenko] +   +  Affiliation [UC Berkeley] + +  Date        [Ver. 1.0. Started - June 20, 2005.] + +  Revision    [$Id: vecFan.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $] + +***********************************************************************/ +  +#ifndef __VEC_FAN_H__ +#define __VEC_FAN_H__ + +//////////////////////////////////////////////////////////////////////// +///                          INCLUDES                                /// +//////////////////////////////////////////////////////////////////////// + +#include <stdio.h> +#include "extra.h" + +//////////////////////////////////////////////////////////////////////// +///                         PARAMETERS                               /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                         BASIC TYPES                              /// +//////////////////////////////////////////////////////////////////////// + +typedef struct Abc_Fan_t_       Abc_Fan_t; +struct Abc_Fan_t_ // 1 word +{ +    unsigned         iFan    : 21;  // the ID of the object +    unsigned         nLats   :  3;  // the number of latches (up to 7) +    unsigned         Inits   :  7;  // the initial values of the latches +    unsigned         fCompl  :  1;  // the complemented attribute +}; + +typedef struct Vec_Fan_t_       Vec_Fan_t; +struct Vec_Fan_t_  +{ +    int              nSize; +    int              nCap; +    Abc_Fan_t *      pArray; +}; + +//////////////////////////////////////////////////////////////////////// +///                      MACRO DEFITIONS                             /// +//////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////// +///                     FUNCTION DEFITIONS                           /// +//////////////////////////////////////////////////////////////////////// + +/**Function************************************************************* + +  Synopsis    [Converts an integer into the simple fanin structure.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Abc_Fan_t Vec_Int2Fan( int iFan ) +{ +    return *((Abc_Fan_t *)&iFan); +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Abc_Fan_t * Vec_FanArray( Vec_Fan_t * p ) +{ +    return p->pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_FanSize( Vec_Fan_t * p ) +{ +    return p->nSize; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Abc_Fan_t Vec_FanEntry( Vec_Fan_t * p, int i ) +{ +    assert( i >= 0 && i < p->nSize ); +    return p->pArray[i]; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_FanWriteEntry( Vec_Fan_t * p, int i, Abc_Fan_t Entry ) +{ +    assert( i >= 0 && i < p->nSize ); +    p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Abc_Fan_t Vec_FanEntryLast( Vec_Fan_t * p ) +{ +    return p->pArray[p->nSize-1]; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_FanShrink( Vec_Fan_t * p, int nSizeNew ) +{ +    assert( p->nSize >= nSizeNew ); +    p->nSize = nSizeNew; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_FanClear( Vec_Fan_t * p ) +{ +    p->nSize = 0; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_FanPush( Extra_MmStep_t * pMemMan, Vec_Fan_t * p, Abc_Fan_t Entry ) +{ +    if ( p->nSize == p->nCap ) +    { +        Abc_Fan_t * pArray; +        int i; + +        if ( p->nSize == 0 ) +            p->nCap = 1; +        pArray = (Abc_Fan_t *)Extra_MmStepEntryFetch( pMemMan, p->nCap * 8 ); +//        pArray = ALLOC( int, p->nCap * 2 ); +        if ( p->pArray ) +        { +            for ( i = 0; i < p->nSize; i++ ) +                pArray[i] = p->pArray[i]; +            Extra_MmStepEntryRecycle( pMemMan, (char *)p->pArray, p->nCap * 4 ); +//            free( p->pArray ); +        } +        p->nCap *= 2; +        p->pArray = pArray; +    } +    p->pArray[p->nSize++] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [Returns the last entry and removes it from the list.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Abc_Fan_t Vec_FanPop( Vec_Fan_t * p ) +{ +    assert( p->nSize > 0 ); +    return p->pArray[--p->nSize]; +} + +/**Function************************************************************* + +  Synopsis    [Find entry.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_FanFindEntry( Vec_Fan_t * p, unsigned iFan ) +{ +    int i; +    for ( i = 0; i < p->nSize; i++ ) +        if ( p->pArray[i].iFan == iFan ) +            return i; +    return -1; +} + +/**Function************************************************************* + +  Synopsis    [Deletes entry.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_FanDeleteEntry( Vec_Fan_t * p, unsigned iFan ) +{ +    int i, k, fFound = 0; +    for ( i = k = 0; i < p->nSize; i++ ) +    { +        if ( p->pArray[i].iFan == iFan ) +            fFound = 1; +        else +            p->pArray[k++] = p->pArray[i]; +    } +    p->nSize = k; +    return fFound; +} + +/**Function************************************************************* + +  Synopsis    [Comparison procedure for two integers.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_FanSortCompare1( int * pp1, int * pp2 ) +{ +    // for some reason commenting out lines (as shown) led to crashing of the release version +    if ( *pp1 < *pp2 ) +        return -1; +    if ( *pp1 > *pp2 ) // +        return 1; +    return 0; // +} + +/**Function************************************************************* + +  Synopsis    [Comparison procedure for two integers.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_FanSortCompare2( int * pp1, int * pp2 ) +{ +    // for some reason commenting out lines (as shown) led to crashing of the release version +    if ( *pp1 > *pp2 ) +        return -1; +    if ( *pp1 < *pp2 ) // +        return 1; +    return 0; // +} + +/**Function************************************************************* + +  Synopsis    [Sorting the entries by their integer value.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_FanSort( Vec_Fan_t * p, int fReverse ) +{ +    if ( fReverse )  +        qsort( (void *)p->pArray, p->nSize, sizeof(int),  +                (int (*)(const void *, const void *)) Vec_FanSortCompare2 ); +    else +        qsort( (void *)p->pArray, p->nSize, sizeof(int),  +                (int (*)(const void *, const void *)) Vec_FanSortCompare1 ); +} + +//////////////////////////////////////////////////////////////////////// +///                       END OF FILE                                /// +//////////////////////////////////////////////////////////////////////// + +#endif + diff --git a/src/misc/vec/vecInt.h b/src/misc/vec/vecInt.h new file mode 100644 index 00000000..8cca2b29 --- /dev/null +++ b/src/misc/vec/vecInt.h @@ -0,0 +1,496 @@ +/**CFile**************************************************************** + +  FileName    [vecInt.h] + +  SystemName  [ABC: Logic synthesis and verification system.] + +  PackageName [Resizable arrays.] + +  Synopsis    [Resizable arrays of integers.] + +  Author      [Alan Mishchenko] +   +  Affiliation [UC Berkeley] + +  Date        [Ver. 1.0. Started - June 20, 2005.] + +  Revision    [$Id: vecInt.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $] + +***********************************************************************/ +  +#ifndef __VEC_INT_H__ +#define __VEC_INT_H__ + +//////////////////////////////////////////////////////////////////////// +///                          INCLUDES                                /// +//////////////////////////////////////////////////////////////////////// + +#include <stdio.h> +#include "extra.h" + +//////////////////////////////////////////////////////////////////////// +///                         PARAMETERS                               /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                         BASIC TYPES                              /// +//////////////////////////////////////////////////////////////////////// + +typedef struct Vec_Int_t_       Vec_Int_t; +struct Vec_Int_t_  +{ +    int              nSize; +    int              nCap; +    int *            pArray; +}; + +//////////////////////////////////////////////////////////////////////// +///                      MACRO DEFITIONS                             /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                     FUNCTION DEFITIONS                           /// +//////////////////////////////////////////////////////////////////////// + +/**Function************************************************************* + +  Synopsis    [Allocates a vector with the given capacity.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Int_t * Vec_IntAlloc( int nCap ) +{ +    Vec_Int_t * p; +    p = ALLOC( Vec_Int_t, 1 ); +    if ( nCap > 0 && nCap < 16 ) +        nCap = 16; +    p->nSize  = 0; +    p->nCap   = nCap; +    p->pArray = p->nCap? ALLOC( int, p->nCap ) : NULL; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Creates the vector from an integer array of the given size.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Int_t * Vec_IntAllocArray( int * pArray, int nSize ) +{ +    Vec_Int_t * p; +    p = ALLOC( Vec_Int_t, 1 ); +    p->nSize  = nSize; +    p->nCap   = nSize; +    p->pArray = pArray; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Creates the vector from an integer array of the given size.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Int_t * Vec_IntAllocArrayCopy( int * pArray, int nSize ) +{ +    Vec_Int_t * p; +    p = ALLOC( Vec_Int_t, 1 ); +    p->nSize  = nSize; +    p->nCap   = nSize; +    p->pArray = ALLOC( int, nSize ); +    memcpy( p->pArray, pArray, sizeof(int) * nSize ); +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Duplicates the integer array.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Int_t * Vec_IntDup( Vec_Int_t * pVec ) +{ +    Vec_Int_t * p; +    p = ALLOC( Vec_Int_t, 1 ); +    p->nSize  = pVec->nSize; +    p->nCap   = pVec->nCap; +    p->pArray = p->nCap? ALLOC( int, p->nCap ) : NULL; +    memcpy( p->pArray, pVec->pArray, sizeof(int) * pVec->nSize ); +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Transfers the array into another vector.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Int_t * Vec_IntDupArray( Vec_Int_t * pVec ) +{ +    Vec_Int_t * p; +    p = ALLOC( Vec_Int_t, 1 ); +    p->nSize  = pVec->nSize; +    p->nCap   = pVec->nCap; +    p->pArray = pVec->pArray; +    pVec->nSize  = 0; +    pVec->nCap   = 0; +    pVec->pArray = NULL; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntFree( Vec_Int_t * p ) +{ +    FREE( p->pArray ); +    FREE( p ); +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int * Vec_IntReleaseArray( Vec_Int_t * p ) +{ +    int * pArray = p->pArray; +    p->nCap = 0; +    p->nSize = 0; +    p->pArray = NULL; +    return pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int * Vec_IntArray( Vec_Int_t * p ) +{ +    return p->pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_IntSize( Vec_Int_t * p ) +{ +    return p->nSize; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_IntEntry( Vec_Int_t * p, int i ) +{ +    assert( i >= 0 && i < p->nSize ); +    return p->pArray[i]; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntWriteEntry( Vec_Int_t * p, int i, int Entry ) +{ +    assert( i >= 0 && i < p->nSize ); +    p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_IntEntryLast( Vec_Int_t * p ) +{ +    return p->pArray[p->nSize-1]; +} + +/**Function************************************************************* + +  Synopsis    [Resizes the vector to the given capacity.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntGrow( Vec_Int_t * p, int nCapMin ) +{ +    if ( p->nCap >= nCapMin ) +        return; +    p->pArray = REALLOC( int, p->pArray, nCapMin );  +    p->nCap   = nCapMin; +} + +/**Function************************************************************* + +  Synopsis    [Fills the vector with given number of entries.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntFill( Vec_Int_t * p, int nSize, int Entry ) +{ +    int i; +    Vec_IntGrow( p, nSize ); +    p->nSize = nSize; +    for ( i = 0; i < p->nSize; i++ ) +        p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntShrink( Vec_Int_t * p, int nSizeNew ) +{ +    assert( p->nSize >= nSizeNew ); +    p->nSize = nSizeNew; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntClear( Vec_Int_t * p ) +{ +    p->nSize = 0; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntPush( Vec_Int_t * p, int Entry ) +{ +    if ( p->nSize == p->nCap ) +    { +        if ( p->nCap < 16 ) +            Vec_IntGrow( p, 16 ); +        else +            Vec_IntGrow( p, 2 * p->nCap ); +    } +    p->pArray[p->nSize++] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntPushOrder( Vec_Int_t * p, int Entry ) +{ +    int i; +    if ( p->nSize == p->nCap ) +    { +        if ( p->nCap < 16 ) +            Vec_IntGrow( p, 16 ); +        else +            Vec_IntGrow( p, 2 * p->nCap ); +    } +    p->nSize++; +    for ( i = p->nSize-2; i >= 0; i-- ) +        if ( p->pArray[i] > Entry ) +            p->pArray[i+1] = p->pArray[i]; +        else +            break; +    p->pArray[i+1] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [Returns the last entry and removes it from the list.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_IntPop( Vec_Int_t * p ) +{ +    assert( p->nSize > 0 ); +    return p->pArray[--p->nSize]; +} + +/**Function************************************************************* + +  Synopsis    [Comparison procedure for two integers.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_IntSortCompare1( int * pp1, int * pp2 ) +{ +    // for some reason commenting out lines (as shown) led to crashing of the release version +    if ( *pp1 < *pp2 ) +        return -1; +    if ( *pp1 > *pp2 ) // +        return 1; +    return 0; // +} + +/**Function************************************************************* + +  Synopsis    [Comparison procedure for two integers.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_IntSortCompare2( int * pp1, int * pp2 ) +{ +    // for some reason commenting out lines (as shown) led to crashing of the release version +    if ( *pp1 > *pp2 ) +        return -1; +    if ( *pp1 < *pp2 ) // +        return 1; +    return 0; // +} + +/**Function************************************************************* + +  Synopsis    [Sorting the entries by their integer value.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_IntSort( Vec_Int_t * p, int fReverse ) +{ +    if ( fReverse )  +        qsort( (void *)p->pArray, p->nSize, sizeof(int),  +                (int (*)(const void *, const void *)) Vec_IntSortCompare2 ); +    else +        qsort( (void *)p->pArray, p->nSize, sizeof(int),  +                (int (*)(const void *, const void *)) Vec_IntSortCompare1 ); +} + +//////////////////////////////////////////////////////////////////////// +///                       END OF FILE                                /// +//////////////////////////////////////////////////////////////////////// + +#endif + diff --git a/src/misc/vec/vecPtr.h b/src/misc/vec/vecPtr.h new file mode 100644 index 00000000..0ba1bdc5 --- /dev/null +++ b/src/misc/vec/vecPtr.h @@ -0,0 +1,461 @@ +/**CFile**************************************************************** + +  FileName    [vecPtr.h] + +  SystemName  [ABC: Logic synthesis and verification system.] + +  PackageName [Resizable arrays.] + +  Synopsis    [Resizable arrays of generic pointers.] + +  Author      [Alan Mishchenko] +   +  Affiliation [UC Berkeley] + +  Date        [Ver. 1.0. Started - June 20, 2005.] + +  Revision    [$Id: vecPtr.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $] + +***********************************************************************/ +  +#ifndef __VEC_PTR_H__ +#define __VEC_PTR_H__ + +//////////////////////////////////////////////////////////////////////// +///                          INCLUDES                                /// +//////////////////////////////////////////////////////////////////////// + +#include <stdio.h> +#include "extra.h" + +//////////////////////////////////////////////////////////////////////// +///                         PARAMETERS                               /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                         BASIC TYPES                              /// +//////////////////////////////////////////////////////////////////////// + +typedef struct Vec_Ptr_t_       Vec_Ptr_t; +struct Vec_Ptr_t_  +{ +    int              nSize; +    int              nCap; +    void **          pArray; +}; + +//////////////////////////////////////////////////////////////////////// +///                      MACRO DEFITIONS                             /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                     FUNCTION DEFITIONS                           /// +//////////////////////////////////////////////////////////////////////// + +/**Function************************************************************* + +  Synopsis    [Allocates a vector with the given capacity.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Ptr_t * Vec_PtrAlloc( int nCap ) +{ +    Vec_Ptr_t * p; +    p = ALLOC( Vec_Ptr_t, 1 ); +    if ( nCap > 0 && nCap < 8 ) +        nCap = 8; +    p->nSize  = 0; +    p->nCap   = nCap; +    p->pArray = p->nCap? ALLOC( void *, p->nCap ) : NULL; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Creates the vector from an integer array of the given size.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Ptr_t * Vec_PtrAllocArray( void ** pArray, int nSize ) +{ +    Vec_Ptr_t * p; +    p = ALLOC( Vec_Ptr_t, 1 ); +    p->nSize  = nSize; +    p->nCap   = nSize; +    p->pArray = pArray; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Creates the vector from an integer array of the given size.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Ptr_t * Vec_PtrAllocArrayCopy( void ** pArray, int nSize ) +{ +    Vec_Ptr_t * p; +    p = ALLOC( Vec_Ptr_t, 1 ); +    p->nSize  = nSize; +    p->nCap   = nSize; +    p->pArray = ALLOC( void *, nSize ); +    memcpy( p->pArray, pArray, sizeof(void *) * nSize ); +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Duplicates the integer array.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Ptr_t * Vec_PtrDup( Vec_Ptr_t * pVec ) +{ +    Vec_Ptr_t * p; +    p = ALLOC( Vec_Ptr_t, 1 ); +    p->nSize  = pVec->nSize; +    p->nCap   = pVec->nCap; +    p->pArray = p->nCap? ALLOC( void *, p->nCap ) : NULL; +    memcpy( p->pArray, pVec->pArray, sizeof(void *) * pVec->nSize ); +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Transfers the array into another vector.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Ptr_t * Vec_PtrDupArray( Vec_Ptr_t * pVec ) +{ +    Vec_Ptr_t * p; +    p = ALLOC( Vec_Ptr_t, 1 ); +    p->nSize  = pVec->nSize; +    p->nCap   = pVec->nCap; +    p->pArray = pVec->pArray; +    pVec->nSize  = 0; +    pVec->nCap   = 0; +    pVec->pArray = NULL; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrFree( Vec_Ptr_t * p ) +{ +    FREE( p->pArray ); +    FREE( p ); +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void ** Vec_PtrReleaseArray( Vec_Ptr_t * p ) +{ +    void ** pArray = p->pArray; +    p->nCap = 0; +    p->nSize = 0; +    p->pArray = NULL; +    return pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void ** Vec_PtrArray( Vec_Ptr_t * p ) +{ +    return p->pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_PtrSize( Vec_Ptr_t * p ) +{ +    return p->nSize; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void * Vec_PtrEntry( Vec_Ptr_t * p, int i ) +{ +    assert( i >= 0 && i < p->nSize ); +    return p->pArray[i]; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrWriteEntry( Vec_Ptr_t * p, int i, void * Entry ) +{ +    assert( i >= 0 && i < p->nSize ); +    p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void * Vec_PtrEntryLast( Vec_Ptr_t * p ) +{ +    return p->pArray[p->nSize-1]; +} + +/**Function************************************************************* + +  Synopsis    [Resizes the vector to the given capacity.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrGrow( Vec_Ptr_t * p, int nCapMin ) +{ +    if ( p->nCap >= nCapMin ) +        return; +    p->pArray = REALLOC( void *, p->pArray, nCapMin );  +    p->nCap   = nCapMin; +} + +/**Function************************************************************* + +  Synopsis    [Fills the vector with given number of entries.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrFill( Vec_Ptr_t * p, int nSize, void * Entry ) +{ +    int i; +    Vec_PtrGrow( p, nSize ); +    p->nSize = nSize; +    for ( i = 0; i < p->nSize; i++ ) +        p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrShrink( Vec_Ptr_t * p, int nSizeNew ) +{ +    assert( p->nSize >= nSizeNew ); +    p->nSize = nSizeNew; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrClear( Vec_Ptr_t * p ) +{ +    p->nSize = 0; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrPush( Vec_Ptr_t * p, void * Entry ) +{ +    if ( p->nSize == p->nCap ) +    { +        if ( p->nCap < 16 ) +            Vec_PtrGrow( p, 16 ); +        else +            Vec_PtrGrow( p, 2 * p->nCap ); +    } +    p->pArray[p->nSize++] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_PtrPushUnique( Vec_Ptr_t * p, void * Entry ) +{ +    int i; +    for ( i = 0; i < p->nSize; i++ ) +        if ( p->pArray[i] == Entry ) +            return 1; +    Vec_PtrPush( p, Entry ); +    return 0; +} + +/**Function************************************************************* + +  Synopsis    [Returns the last entry and removes it from the list.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void * Vec_PtrPop( Vec_Ptr_t * p ) +{ +    assert( p->nSize > 0 ); +    return p->pArray[--p->nSize]; +} + +/**Function************************************************************* + +  Synopsis    [Moves the first nItems to the end.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrReorder( Vec_Ptr_t * p, int nItems ) +{ +    assert( nItems < p->nSize ); +    Vec_PtrGrow( p, nItems + p->nSize ); +    memmove( (char **)p->pArray + p->nSize, p->pArray, nItems * sizeof(void*) ); +    memmove( p->pArray, (char **)p->pArray + nItems, p->nSize * sizeof(void*) ); +} + +/**Function************************************************************* + +  Synopsis    [Sorting the entries by their integer value.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_PtrSort( Vec_Ptr_t * p, int (*Vec_PtrSortCompare)() ) +{ +    qsort( (void *)p->pArray, p->nSize, sizeof(void *),  +            (int (*)(const void *, const void *)) Vec_PtrSortCompare ); +} + + +//////////////////////////////////////////////////////////////////////// +///                       END OF FILE                                /// +//////////////////////////////////////////////////////////////////////// + +#endif + diff --git a/src/misc/vec/vecStr.h b/src/misc/vec/vecStr.h new file mode 100644 index 00000000..367304d4 --- /dev/null +++ b/src/misc/vec/vecStr.h @@ -0,0 +1,466 @@ +/**CFile**************************************************************** + +  FileName    [vecStr.h] + +  SystemName  [ABC: Logic synthesis and verification system.] + +  PackageName [Resizable arrays.] + +  Synopsis    [Resizable arrays of characters.] + +  Author      [Alan Mishchenko] +   +  Affiliation [UC Berkeley] + +  Date        [Ver. 1.0. Started - June 20, 2005.] + +  Revision    [$Id: vecStr.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $] + +***********************************************************************/ +  +#ifndef __VEC_STR_H__ +#define __VEC_STR_H__ + +//////////////////////////////////////////////////////////////////////// +///                          INCLUDES                                /// +//////////////////////////////////////////////////////////////////////// + +#include <stdio.h> +#include "extra.h" + +//////////////////////////////////////////////////////////////////////// +///                         PARAMETERS                               /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                         BASIC TYPES                              /// +//////////////////////////////////////////////////////////////////////// + +typedef struct Vec_Str_t_       Vec_Str_t; +struct Vec_Str_t_  +{ +    int              nSize; +    int              nCap; +    char *           pArray; +}; + +//////////////////////////////////////////////////////////////////////// +///                      MACRO DEFITIONS                             /// +//////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////// +///                     FUNCTION DEFITIONS                           /// +//////////////////////////////////////////////////////////////////////// + +/**Function************************************************************* + +  Synopsis    [Allocates a vector with the given capacity.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Str_t * Vec_StrAlloc( int nCap ) +{ +    Vec_Str_t * p; +    p = ALLOC( Vec_Str_t, 1 ); +    if ( nCap > 0 && nCap < 16 ) +        nCap = 16; +    p->nSize  = 0; +    p->nCap   = nCap; +    p->pArray = p->nCap? ALLOC( char, p->nCap ) : NULL; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Creates the vector from an integer array of the given size.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Str_t * Vec_StrAllocArray( char * pArray, int nSize ) +{ +    Vec_Str_t * p; +    p = ALLOC( Vec_Str_t, 1 ); +    p->nSize  = nSize; +    p->nCap   = nSize; +    p->pArray = pArray; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Creates the vector from an integer array of the given size.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Str_t * Vec_StrAllocArrayCopy( char * pArray, int nSize ) +{ +    Vec_Str_t * p; +    p = ALLOC( Vec_Str_t, 1 ); +    p->nSize  = nSize; +    p->nCap   = nSize; +    p->pArray = ALLOC( char, nSize ); +    memcpy( p->pArray, pArray, sizeof(char) * nSize ); +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Duplicates the integer array.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Str_t * Vec_StrDup( Vec_Str_t * pVec ) +{ +    Vec_Str_t * p; +    p = ALLOC( Vec_Str_t, 1 ); +    p->nSize  = pVec->nSize; +    p->nCap   = pVec->nCap; +    p->pArray = p->nCap? ALLOC( char, p->nCap ) : NULL; +    memcpy( p->pArray, pVec->pArray, sizeof(char) * pVec->nSize ); +    return p; +} + +/**Function************************************************************* + +  Synopsis    [Transfers the array into another vector.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline Vec_Str_t * Vec_StrDupArray( Vec_Str_t * pVec ) +{ +    Vec_Str_t * p; +    p = ALLOC( Vec_Str_t, 1 ); +    p->nSize  = pVec->nSize; +    p->nCap   = pVec->nCap; +    p->pArray = pVec->pArray; +    pVec->nSize  = 0; +    pVec->nCap   = 0; +    pVec->pArray = NULL; +    return p; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrFree( Vec_Str_t * p ) +{ +    FREE( p->pArray ); +    FREE( p ); +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline char * Vec_StrReleaseArray( Vec_Str_t * p ) +{ +    char * pArray = p->pArray; +    p->nCap = 0; +    p->nSize = 0; +    p->pArray = NULL; +    return pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline char * Vec_StrArray( Vec_Str_t * p ) +{ +    return p->pArray; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_StrSize( Vec_Str_t * p ) +{ +    return p->nSize; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline char Vec_StrEntry( Vec_Str_t * p, int i ) +{ +    assert( i >= 0 && i < p->nSize ); +    return p->pArray[i]; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrWriteEntry( Vec_Str_t * p, int i, char Entry ) +{ +    assert( i >= 0 && i < p->nSize ); +    p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline char Vec_StrEntryLast( Vec_Str_t * p ) +{ +    return p->pArray[p->nSize-1]; +} + +/**Function************************************************************* + +  Synopsis    [Resizes the vector to the given capacity.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrGrow( Vec_Str_t * p, int nCapMin ) +{ +    if ( p->nCap >= nCapMin ) +        return; +    p->pArray = REALLOC( char, p->pArray, nCapMin );  +    p->nCap   = nCapMin; +} + +/**Function************************************************************* + +  Synopsis    [Fills the vector with given number of entries.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrFill( Vec_Str_t * p, int nSize, char Entry ) +{ +    int i; +    Vec_StrGrow( p, nSize ); +    p->nSize = nSize; +    for ( i = 0; i < p->nSize; i++ ) +        p->pArray[i] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrShrink( Vec_Str_t * p, int nSizeNew ) +{ +    assert( p->nSize >= nSizeNew ); +    p->nSize = nSizeNew; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrClear( Vec_Str_t * p ) +{ +    p->nSize = 0; +} + +/**Function************************************************************* + +  Synopsis    [] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrPush( Vec_Str_t * p, char Entry ) +{ +    if ( p->nSize == p->nCap ) +    { +        if ( p->nCap < 16 ) +            Vec_StrGrow( p, 16 ); +        else +            Vec_StrGrow( p, 2 * p->nCap ); +    } +    p->pArray[p->nSize++] = Entry; +} + +/**Function************************************************************* + +  Synopsis    [Returns the last entry and removes it from the list.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline char Vec_StrPop( Vec_Str_t * p ) +{ +    assert( p->nSize > 0 ); +    return p->pArray[--p->nSize]; +} + +/**Function************************************************************* + +  Synopsis    [Comparison procedure for two clauses.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_StrSortCompare1( char * pp1, char * pp2 ) +{ +    // for some reason commenting out lines (as shown) led to crashing of the release version +    if ( *pp1 < *pp2 ) +        return -1; +    if ( *pp1 > *pp2 ) // +        return 1; +    return 0; // +} + +/**Function************************************************************* + +  Synopsis    [Comparison procedure for two clauses.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline int Vec_StrSortCompare2( char * pp1, char * pp2 ) +{ +    // for some reason commenting out lines (as shown) led to crashing of the release version +    if ( *pp1 > *pp2 ) +        return -1; +    if ( *pp1 < *pp2 ) // +        return 1; +    return 0; // +} + +/**Function************************************************************* + +  Synopsis    [Sorting the entries by their integer value.] + +  Description [] +                +  SideEffects [] + +  SeeAlso     [] + +***********************************************************************/ +static inline void Vec_StrSort( Vec_Str_t * p, int fReverse ) +{ +    if ( fReverse )  +        qsort( (void *)p->pArray, p->nSize, sizeof(int),  +                (int (*)(const void *, const void *)) Vec_StrSortCompare2 ); +    else +        qsort( (void *)p->pArray, p->nSize, sizeof(int),  +                (int (*)(const void *, const void *)) Vec_StrSortCompare1 ); +} + +//////////////////////////////////////////////////////////////////////// +///                       END OF FILE                                /// +//////////////////////////////////////////////////////////////////////// + +#endif +  | 
