Mercurial > projects > ldc
view dmd2/mem.h @ 1219:a0844cc67840
Tweak some optimizations.
Delegates passed to inlined functions now also stand a chance of being inlined.
This should make opApply as efficient as a regular loop, as long as both opApply
and the foreachbody are eligible for inlining; which is to say most non-virtual
opApply invocations will likely get fully inlined now.
(Note: above requires -O2 -enable-inlining or -O3)
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Thu, 16 Apr 2009 11:58:43 +0200 |
parents | f04dde6e882c |
children |
line wrap: on
line source
// Copyright (C) 2000-2001 by Chromium Communications // All Rights Reserved #ifndef ROOT_MEM_H #define ROOT_MEM_H #include <stddef.h> // for size_t typedef void (*FINALIZERPROC)(void* pObj, void* pClientData); struct GC; // thread specific allocator struct Mem { GC *gc; // pointer to our thread specific allocator Mem() { gc = NULL; } void init(); // Derive from Mem to get these storage allocators instead of global new/delete void * operator new(size_t m_size); void * operator new(size_t m_size, Mem *mem); void * operator new(size_t m_size, GC *gc); void operator delete(void *p); void * operator new[](size_t m_size); void operator delete[](void *p); char *strdup(const char *s); void *malloc(size_t size); void *malloc_uncollectable(size_t size); void *calloc(size_t size, size_t n); void *realloc(void *p, size_t size); void free(void *p); void free_uncollectable(void *p); void *mallocdup(void *o, size_t size); void error(); void check(void *p); // validate pointer void fullcollect(); // do full garbage collection void fullcollectNoStack(); // do full garbage collection, no scan stack void mark(void *pointer); void addroots(char* pStart, char* pEnd); void removeroots(char* pStart); void setFinalizer(void* pObj, FINALIZERPROC pFn, void* pClientData); void setStackBottom(void *bottom); GC *getThreadGC(); // get apartment allocator for this thread }; extern Mem mem; #endif /* ROOT_MEM_H */