From: Craig Small Date: Sun, 1 May 2016 06:50:25 +0000 (+1000) Subject: library: procps_uptime() return value is a status X-Git-Tag: v4.0.0~929 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6b5cb345c5be6beeec74409657c8ebf9e8869d92;p=procps-ng library: procps_uptime() return value is a status procps_uptime, previously just plain uptime() used to put the uptime (as a double) in the first argument and return uptime (as an int). It meant if you ran myuptime2 = procps_uptime(&myuptime1, NULL); You might get different results for myuptime1 and myuptime2 because they are different types. Most library calls use the return value to return the status, procps_uptime was in the middle. Until now. This function will return 0 on success. If you want (for whatever reason) uptime as an int then cast it. All of the procps binaries didn't use the return value for uptime except ps which set a variable to it but never used it anywhere. --- diff --git a/doc/procps_uptime.3 b/doc/procps_uptime.3 index 912aa3c7..61e70fbd 100644 --- a/doc/procps_uptime.3 +++ b/doc/procps_uptime.3 @@ -16,7 +16,7 @@ .\" Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA .\" %%%LICENSE_END .\" -.TH PROCPS_UPTIME 3 2016-04-16 "libproc-2" +.TH PROCPS_UPTIME 3 2016-05-01 "libproc-2" .\" Please adjust this date whenever revising the manpage. .\" .SH NAME @@ -35,7 +35,7 @@ fills the location of the two double points with the current sytem uptime and idle time. .SH RETURN VALUE .BR procps_uptime () -returns a positive integer which is the uptime on success. On failure, it +returns 0 on success. On failure, it returns a negative integer to one of the values defined below. .TP .B -ERANGE diff --git a/proc/test_uptime.c b/proc/test_uptime.c index 5058294b..c9d4fb85 100644 --- a/proc/test_uptime.c +++ b/proc/test_uptime.c @@ -30,7 +30,7 @@ int check_uptime(void *data) double up=0, idle=0; int rc; rc = procps_uptime(&up, &idle); - return (rc > 0 && up > 0 && idle > 0); + return (rc == 0 && up > 0 && idle > 0); } int check_uptime_nullup(void *data) @@ -39,7 +39,7 @@ int check_uptime_nullup(void *data) int rc; testname = "procps_uptime() (up=NULL)"; rc = procps_uptime(NULL, &idle); - return (rc > 0 && idle > 0); + return (rc == 0 && idle > 0); } int check_uptime_nullidle(void *data) @@ -48,7 +48,7 @@ int check_uptime_nullidle(void *data) int rc; testname = "procps_uptime() (idle=NULL)"; rc = procps_uptime(&up, NULL); - return (rc > 0 && up > 0); + return (rc == 0 && up > 0); } int check_uptime_nullall(void *data) @@ -56,7 +56,7 @@ int check_uptime_nullall(void *data) int rc; testname = "procps_uptime() (up,idle=NULL)"; rc = procps_uptime(NULL, NULL); - return (rc > 0); + return (rc == 0); } int check_uptime_sprint(void *data) diff --git a/proc/uptime.c b/proc/uptime.c index c692fd0e..f91d227f 100644 --- a/proc/uptime.c +++ b/proc/uptime.c @@ -63,7 +63,7 @@ static int count_users(void) * Unlike other procps functions this closes the file each time * Either uptime_secs or idle_secs can be null * - * Returns: uptime_secs on success and <0 on failure + * Returns: 0 on success and <0 on failure */ PROCPS_EXPORT int procps_uptime( double *restrict uptime_secs, @@ -91,7 +91,7 @@ PROCPS_EXPORT int procps_uptime( *uptime_secs = up; if (idle_secs) *idle_secs = idle; - return up; + return 0; } /* diff --git a/ps/common.h b/ps/common.h index fc1b160c..5c862dc9 100644 --- a/ps/common.h +++ b/ps/common.h @@ -434,7 +434,6 @@ extern int prefer_bsd_defaults; extern int running_only; extern int screen_cols; extern int screen_rows; -extern time_t seconds_since_boot; extern selection_node *selection_list; extern unsigned simple_select; extern sort_node *sort_list; diff --git a/ps/global.c b/ps/global.c index 21c4e419..733b924f 100644 --- a/ps/global.c +++ b/ps/global.c @@ -172,7 +172,6 @@ unsigned personality = 0xffffffff; int prefer_bsd_defaults = -1; int screen_cols = -1; int screen_rows = -1; -time_t seconds_since_boot = -1; selection_node *selection_list = (selection_node *)0xdeadbeef; unsigned simple_select = 0xffffffff; sort_node *sort_list = (sort_node *)0xdeadbeef; /* ready-to-use sort list */ @@ -502,7 +501,6 @@ void reset_global(void){ negate_selection = 0; page_size = getpagesize(); running_only = 0; - seconds_since_boot = procps_uptime(0,0); selection_list = NULL; simple_select = 0; sort_list = NULL;