]> git.ipfire.org Git - thirdparty/lxc.git/commitdiff
lxc-ps: fix order of output and fix --lxc opt
authorNatanael Copa <ncopa@alpinelinux.org>
Fri, 4 Jan 2013 08:39:04 +0000 (09:39 +0100)
committerStéphane Graber <stgraber@ubuntu.com>
Fri, 4 Jan 2013 15:11:19 +0000 (10:11 -0500)
We must output the lines from 'ps' in same order for tree views.

Fix also --lxc option to only show processes from containers.

Signed-off-by: Natanael Copa <ncopa@alpinelinux.org>
Acked-by: Stéphane Graber <stgraber@ubuntu.com>
src/lxc/lxc-ps.in

index 25e843b09319d4016600aa3298ba22d4e191bc2a..5f7cf4db33d4662b0301060d34882c1a4ad8989d 100644 (file)
@@ -114,7 +114,8 @@ for container in ${containers}; do
 done
 
 # first file is stdin, the rest are the container tasks
-ps "$@" | awk -v container_field_width="$container_field_width" '
+ps "$@" | awk -v container_field_width="$container_field_width" \
+    -v list_container_processes="$list_container_processes" '
 # first line is PS header
 NR == 1 {
     # find pid field index
@@ -133,7 +134,8 @@ NR == 1 {
 
 # store lines from ps with pid as index
 NR == FNR {
-    ps[$pididx] = $0
+    ps_line[NR] = $0
+    pid_of_line[NR] = $pididx
     next
 }
 
@@ -151,8 +153,11 @@ FNR == 1 {
 
 END {
     printf("%-" container_field_width "s %s\n", "CONTAINER", header)
-    for (pid in container_of_pid)
-        printf("%-" container_field_width "s %s\n", container_of_pid[pid], ps[pid])
+    for (i in ps_line) {
+       container = container_of_pid[pid_of_line[i]]
+        if (list_container_processes == 0 || container != "")
+            printf("%-" container_field_width "s %s\n", container, ps_line[i])
+    }
 }
 
 ' - $tasks_files