X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=mymemory.h;h=4c44f5be514c4e8fdd9344f2cee7fb939ca8a3ad;hb=061b34a5d84d00df340550d75f664be5e174276c;hp=c159e532fd16b233c78ab26a4d3493f4f1e23cd2;hpb=7bec9f8bcc8c63a0be2b31f8aa01a61a50afe4f9;p=model-checker.git diff --git a/mymemory.h b/mymemory.h index c159e53..4c44f5b 100644 --- a/mymemory.h +++ b/mymemory.h @@ -7,6 +7,8 @@ #include #include +/** MEMALLOC declares the allocators for a class to allocate + * memory in the non-snapshotting heap. */ #define MEMALLOC \ void * operator new(size_t size) { \ return MYMALLOC(size);\ @@ -21,24 +23,27 @@ MYFREE(p);\ } -/* Empty define; represents opposite of MEMALLOC */ +/** SNAPSHOTALLOC declares the allocators for a class to allocate + * memory in the snapshotting heap. */ #define SNAPSHOTALLOC void *MYMALLOC(size_t size); +void *MYCALLOC(size_t count, size_t size); void MYFREE(void *ptr); void system_free( void * ptr ); void *system_malloc( size_t size ); -/* -The following code example is taken from the book -The C++ Standard Library - A Tutorial and Reference -by Nicolai M. Josuttis, Addison-Wesley, 1999 -© Copyright Nicolai M. Josuttis 1999 -Permission to copy, use, modify, sell and distribute this software -is granted provided this copyright notice appears in all copies. -This software is provided "as is" without express or implied -warranty, and with no claim as to its suitability for any purpose. -*/ + +/** @brief Provides a non-snapshotting allocator for use in STL classes. + * + * The code was adapted from a code example from the book The C++ + * Standard Library - A Tutorial and Reference by Nicolai M. Josuttis, + * Addison-Wesley, 1999 © Copyright Nicolai M. Josuttis 1999 + * Permission to copy, use, modify, sell and distribute this software + * is granted provided this copyright notice appears in all copies. + * This software is provided "as is" without express or implied + * warranty, and with no claim as to its suitability for any purpose. + */ template class MyAlloc { public: @@ -107,12 +112,14 @@ template } }; -// return that all specializations of this allocator are interchangeable +/** Return that all specializations of this allocator are interchangeable. */ template bool operator== (const MyAlloc&, const MyAlloc&) throw() { return true; } + +/** Return that all specializations of this allocator are interchangeable. */ template bool operator!= (const MyAlloc&, const MyAlloc&) throw() {