still some performance enhancements
[lttv.git] / ltt / branches / poly / lttv / modules / gui / controlflow / processlist.h
index 96ce16338e3ce3069433f60ce83fd0ef7975c6de..437110a16c3f5b7d6449540755149a51da0bac70 100644 (file)
 typedef struct _ProcessInfo {
   
   guint pid;
-  GQuark cpu; /* only for PID 0 */
+  guint cpu;
   guint ppid;
   LttTime birth;
   guint trace_num;
 
-  gint height_cache;
// gint height_cache;
 
 } ProcessInfo;
 
@@ -87,6 +87,10 @@ struct _ProcessList {
   
   guint number_of_process;
   gint cell_height_cache;
+
+  /* Current process, one per cpu */
+  HashedProcessData **current_hash_data;
+
 };
 
 
@@ -102,21 +106,19 @@ void processlist_clear(ProcessList *process_list);
 /* CPU num is only used for PID 0 */
 int processlist_add(ProcessList *process_list, guint pid, guint cpu, guint ppid,
     LttTime *birth, guint trace_num, const gchar *name, guint *height,
+    ProcessInfo **process_info,
     HashedProcessData **hashed_process_data);
 // out : success (0) and height
 int processlist_remove(ProcessList *process_list, guint pid, guint cpu, 
     LttTime *birth, guint trace_num);
 
-guint processlist_get_height(ProcessList *process_list);
+__inline__ guint processlist_get_height(ProcessList *process_list);
 
-// Returns 0 on success
-__inline gint processlist_get_process_pixels(ProcessList *process_list,
-        guint pid, guint cpu, LttTime *birth, guint trace_num,
-        guint *y, guint *height,
-        HashedProcessData **hashed_process_data);
+__inline__ HashedProcessData *processlist_get_process_data(
+        ProcessList *process_list,
+        guint pid, guint cpu, LttTime *birth, guint trace_num);
 
-__inline gint processlist_get_pixels_from_data(  ProcessList *process_list,
-          ProcessInfo *process_info,
+__inline__ gint processlist_get_pixels_from_data(  ProcessList *process_list,
           HashedProcessData *hashed_process_data,
           guint *y,
           guint *height);
This page took 0.022972 seconds and 4 git commands to generate.