commit | 6dae8108f8e6a8d3f4ccf3d92f8bb19d3933861a | [log] [download] |
---|---|---|
author | Explorer09 <explorer09@gmail.com> | Fri Jan 15 20:26:01 2016 +0800 |
committer | Explorer09 <explorer09@gmail.com> | Fri Jan 15 20:26:01 2016 +0800 |
tree | 7cb08e282337b483de387b68cf7e225eb359853f | |
parent | 195f5edbc8dd79267fa23feb5fda2a8be812abeb [diff] |
Introduce CLAMP macro. Unify all MIN(MAX(a,b),c) uses. With the CLAMP macro replacing the combination of MIN and MAX, we will have at least two advantages: 1. It's more obvious semantically. 2. There are no more mixes of confusing uses like MIN(MAX(a,b),c) and MAX(MIN(a,b),c) and MIN(a,MAX(b,c)) appearing everywhere. We unify the 'clamping' with a single macro. Note that the behavior of this CLAMP macro is different from the combination `MAX(low,MIN(x,high))`. * This CLAMP macro expands to two comparisons instead of three from MAX and MIN combination. In theory, this makes the code slightly smaller, in case that (low) or (high) or both are computed at runtime, so that compilers cannot optimize them. (The third comparison will matter if (low)>(high); see below.) * CLAMP has a side effect, that if (low)>(high) it will produce weird results. Unlike MIN & MAX which will force either (low) or (high) to win. No assertion of ((low)<=(high)) is done in this macro, for now. This CLAMP macro is implemented like described in glib <http://developer.gnome.org/glib/stable/glib-Standard-Macros.html> and does not handle weird uses like CLAMP(a++, low++, high--) .
by Hisham Muhammad hisham@gobolinux.org
2004 - 2015
This is htop, an interactive process viewer. It requires ncurses. It is developed primarily on Linux, but we also have code for running under FreeBSD and Mac OS X (help and testing are wanted for these platforms!)
This software has evolved considerably over the years, and is reasonably complete, but there is always room for improvement.
This program is distributed as a standard autotools-based package. See the INSTALL file for detailed instructions, but you are probably used to the common ./configure
/make
/make install
routine.
When fetching the code from the development repository, you need to run the ./autogen.sh
script, which in turn requires autotools to be installed.
See the manual page (man htop) or the on-line help (‘F1’ or ‘h’ inside htop) for a list of supported key commands.
if not all keys work check your curses configuration.