comparison src/emacs.c @ 5158:9e0b43d3095c

more cleanups to object-memory-usage stuff -------------------- ChangeLog entries follow: -------------------- lisp/ChangeLog addition: 2010-03-19 Ben Wing <ben@xemacs.org> * diagnose.el (show-object-memory-usage-stats): Rewrite to take into account non-lisp-storage statistics returned by garbage-collect-1 and friends. src/ChangeLog addition: 2010-03-19 Ben Wing <ben@xemacs.org> * alloc.c: * alloc.c (struct): * alloc.c (tick_lrecord_stats): * alloc.c (gc_sweep_1): * alloc.c (finish_object_memory_usage_stats): * alloc.c (object_memory_usage_stats): * alloc.c (compute_memusage_stats_length): Call new memory-usage mechanism at sweep time to compute extra memory utilization for all objects. Add up the values element-by- element to get an aggregrate set of statistics, where each is the sum of the values of a single statistic across different objects of the same type. At end of sweep time, call finish_object_memory_usage_stats() to add up all the aggreggrate stats that are related to non-Lisp memory storage to compute a single value, and add it to the list of values returned by `garbage-collect' and `object-memory-usage-stats'. * buffer.c (compute_buffer_text_usage): Don't crash on buffers without text (killed buffers?) and don't double-count indirect buffers. * elhash.c: * elhash.c (hash_table_objects_create): * elhash.c (vars_of_elhash): * symsinit.h: Add memory-usage method to count the size of `hentries'. * emacs.c (main_1): Call new functions in elhash.c, frame.c at init. * frame.c: * frame.c (compute_frame_usage): * frame.c (frame_memory_usage): * frame.c (frame_objects_create): * symsinit.h: Add memory-usage method to count gutter display structures, subwindow exposures. * gc.c (gc_finish): * lisp.h: Declare finish_object_memory_usage_stats(), call it in gc_finish(). * lrecord.h (struct lrecord_implementation): * lrecord.h (INIT_MEMORY_USAGE_STATS): New value in implementation struct to track number of non-Lisp-memory statistics. Computed in alloc.c.
author Ben Wing <ben@xemacs.org>
date Fri, 19 Mar 2010 14:47:44 -0500
parents 1fae11d56ad2
children ab9ee10a53e4
comparison
equal deleted inserted replaced
5157:1fae11d56ad2 5158:9e0b43d3095c
1761 ) 1761 )
1762 { 1762 {
1763 buffer_objects_create (); 1763 buffer_objects_create ();
1764 extent_objects_create (); 1764 extent_objects_create ();
1765 face_objects_create (); 1765 face_objects_create ();
1766 frame_objects_create ();
1766 glyph_objects_create (); 1767 glyph_objects_create ();
1768 hash_table_objects_create ();
1767 lstream_objects_create (); 1769 lstream_objects_create ();
1768 mule_charset_objects_create (); 1770 mule_charset_objects_create ();
1769 #ifdef HAVE_GTK 1771 #ifdef HAVE_GTK
1770 ui_gtk_objects_create (); 1772 ui_gtk_objects_create ();
1771 #endif 1773 #endif
2106 vars_of_doc (); 2108 vars_of_doc ();
2107 #ifdef HAVE_DRAGNDROP 2109 #ifdef HAVE_DRAGNDROP
2108 vars_of_dragdrop (); 2110 vars_of_dragdrop ();
2109 #endif 2111 #endif
2110 vars_of_editfns (); 2112 vars_of_editfns ();
2113 vars_of_elhash ();
2111 vars_of_emacs (); 2114 vars_of_emacs ();
2112 vars_of_eval (); 2115 vars_of_eval ();
2113 2116
2114 #ifdef HAVE_X_WINDOWS 2117 #ifdef HAVE_X_WINDOWS
2115 vars_of_event_Xt (); 2118 vars_of_event_Xt ();