]> www.ginac.de Git - cln.git/blobdiff - src/vector/cl_SV_number.cc
bump library version, since CLN doesn't export global object ctors any more.
[cln.git] / src / vector / cl_SV_number.cc
index af455345a5eb6557681743765727de2e5901ea03..87e45c6366609b0984eb05c4a3666e625c111e28 100644 (file)
@@ -3,16 +3,12 @@
 // General includes.
 #include "cl_sysdep.h"
 
-CL_PROVIDE(cl_SV_number)
-
 // Specification.
-#include "cl_SV_number.h"
-
+#include "cln/SV_number.h"
 
 // Implementation.
 
-#include "cl_abort.h"
-
+namespace cln {
 
 static void cl_svector_number_destructor (cl_heap* pointer)
 {
@@ -23,33 +19,55 @@ static void cl_svector_number_destructor (cl_heap* pointer)
 #endif
 }
 
-cl_class cl_class_svector_number = {
-       cl_svector_number_destructor,
-       0
-};
+// XXX: ugh, this needs to be non-static (and non-const) so redefining
+// debugging function is possible (see cl_SV_number_debug.cc) 
+cl_class& cl_class_svector_number()
+{
+       static cl_class instance = {
+               cl_svector_number_destructor,
+               0
+       };
+       return instance;
+}
 
-cl_heap_SV_number* cl_make_heap_SV_number_uninit (uintL len)
+cl_heap_SV_number* cl_make_heap_SV_number_uninit (uintC len)
 {
-       var cl_heap_SV_number* hv = (cl_heap_SV_number*) cl_malloc_hook(sizeof(cl_heap_SV_number)+sizeof(cl_number)*len);
+       var cl_heap_SV_number* hv = (cl_heap_SV_number*) malloc_hook(sizeof(cl_heap_SV_number)+sizeof(cl_number)*len);
        hv->refcount = 1;
-       hv->type = &cl_class_svector_number;
+       hv->type = &cl_class_svector_number();
        new (&hv->v) cl_SV_inner<cl_number> (len);
        // Have to fill hv->v[i] (0 <= i < len) yourself.
        return hv;
 }
 
-cl_heap_SV_number* cl_make_heap_SV_number (uintL len)
+cl_heap_SV_number* cl_make_heap_SV_number (uintC len)
 {
-       var cl_heap_SV_number* hv = (cl_heap_SV_number*) cl_malloc_hook(sizeof(cl_heap_SV_number)+sizeof(cl_number)*len);
+       var cl_heap_SV_number* hv = (cl_heap_SV_number*) malloc_hook(sizeof(cl_heap_SV_number)+sizeof(cl_number)*len);
        hv->refcount = 1;
-       hv->type = &cl_class_svector_number;
+       hv->type = &cl_class_svector_number();
        new (&hv->v) cl_SV_inner<cl_number> (len);
-       for (var uintL i = 0; i < len; i++)
+       for (var uintC i = 0; i < len; i++)
                init1(cl_number, hv->v[i]) (0);
        return hv;
 }
 
 // An empty vector.
-const cl_SV_number cl_null_SV_number = cl_SV_number((uintL)0);
+const cl_SV_number cl_null_SV_number = cl_null_SV_number;
+
+int cl_SV_number_init_helper::count = 0;
+
+cl_SV_number_init_helper::cl_SV_number_init_helper()
+{
+       if (count++ == 0)
+               new ((void *)&cl_null_SV_number) cl_SV_number((uintC)0);
+}
+
+cl_SV_number_init_helper::~cl_SV_number_init_helper()
+{
+       if (--count == 0) {
+               // Nothing to clean up
+       }
+}
+
+}  // namespace cln
 
-CL_PROVIDE_END(cl_SV_number)