On Wed, 25 Nov 2009, Przemysław Czerpak wrote: Hi,
> Yes, but these are very good propositions and quite easy to implement > so maybe I'll add it soon at least partially. I've just committed it: 2009-11-26 03:45 UTC+0100 Przemyslaw Czerpak (druzus/at/priv.onet.pl) * harbour/include/hbapi.h * harbour/include/hbvm.h * harbour/include/hbvmpub.h * harbour/include/hbstack.h * harbour/src/vm/hvm.c * harbour/src/vm/estack.c * harbour/src/vm/fm.c * harbour/src/vm/garbage.c + added new function hb_xclean() executed by GC just before resuming suspended threads - it can be used by memory manager to clean internal structures and release unused memory to OS. % release unused memory to OS in hb_xclean() when DLMALLOC is used % release unused memory in all mspaces to OS in hb_xclean() when HB_FM_DLMT_ALLOC is used % release unused memory in mspace when last thread detach it % balance used mspaces between threads in hb_xclean() when HB_FM_DLMT_ALLOC is used Please look at it. I think it should address most important problems. We can extend it and detect thread activity (number of allocations in given mspace) for better mspace balancing but it will begin to be really more complicated. Now it's still very simple. best regards, Przemek _______________________________________________ Harbour mailing list (attachment size limit: 40KB) Harbour@harbour-project.org http://lists.harbour-project.org/mailman/listinfo/harbour