Jim Warner 3e7a70396c top: give inspect search algorithm a significant boost
The Inspect find algorithm has always been challenging
given the possibility that 'rows' might contain binary
data. Be that as it may, two small changes have proven
to dramatically improve the performance of such scans.

The first involves the case wherein if no match on the
'substring' portion of a row was found, then a pointer
representing the substring was increased by the length
of the search string, not the better/longer substring.
Thus, portions of the substring were always rescanned!

The second performance boost was achieved in this way:
pre-scanning each raw row for just the first character
in the search string now determines if a full match is
even possible. Therefore, repeated unproductive strstr
calls on individual substrings within that row will be
avoided. In a nutshell, 1 'if' with '}' did the trick!

(now that we know a '.' + 2 spaces is squeezed to one)
(everything's perfectly justified, but it's just luck)

Signed-off-by: Jim Warner <james.warner@comcast.net>
2012-12-02 13:39:53 +11:00
2012-11-06 22:28:30 +11:00
2012-11-06 22:30:02 +11:00
2012-05-29 22:20:36 +10:00
2012-01-13 22:42:38 +01:00
2012-03-04 08:04:24 +11:00
2012-03-04 08:04:24 +11:00
2012-04-16 12:55:53 +02:00
2012-04-16 12:55:53 +02:00
2012-11-21 22:11:17 +11:00
2012-11-21 22:11:17 +11:00
2002-02-01 22:47:29 +00:00
2012-09-27 22:08:04 +10:00
2012-11-06 22:30:01 +11:00
2012-04-16 12:55:53 +02:00
2012-06-14 22:33:49 +10:00
2012-03-03 18:28:52 +11:00
2012-04-16 12:55:53 +02:00
2012-11-06 22:28:30 +11:00
2012-04-16 12:55:53 +02:00
2002-02-01 22:47:29 +00:00
2012-05-07 09:01:10 +02:00
2012-11-06 22:30:01 +11:00
2012-04-16 12:55:53 +02:00
2012-04-16 12:55:53 +02:00
2012-04-16 12:55:53 +02:00
2012-11-06 22:30:02 +11:00
w.1
2012-05-29 22:20:36 +10:00
2012-04-16 12:55:53 +02:00
2012-11-06 22:30:02 +11:00

COMPATIBILITY

    This code is intended for use with Linux 2.6.xx, 3.x and
    hopefully all future kernels.

INSTALLATION

    If you are using git version of the project you need extra step.

    ./autogen.sh

    After that, and everyone using .tar.xz version of procps-ng, can
    do normal build.  Read './configure --help' to select options for
    your needs.

    ./configure
    make
    make install

    If you have DejaGNU installed you can run optional test suite.

    make check

HOW TO CONTRIBUTE

    See Documentation/BUGS file.

PACKAGING

    If you are a downstream maintainer (packager) for a Linux
    distribution, please avoid causing troubles.  This section
    applies to you.

    Avoid maintaining distribution specific patches.  Send your
    patches to upstream, where they are at least reviewed, if not
    included.

    Please forward bug reports. If your bug database is public and
    busy enough to bother with, please make this known.  Follow
    Debian's lead in making the bug database easy to comment on via
    email without need for an account.

    For normal packages, ensure that you do not add debugging flags
    to the CFLAGS variable.

UPSTREAM & BUG REPORTS

    procps-ng <procps@freelists.org>
Description
Command line and full screen utilities for browsing procfs, a "pseudo" file system dynamically generated by Linux to provide information about the status of entries in its process table.
Readme 15 MiB
Languages
C 97.2%
Makefile 1%
Shell 0.9%
M4 0.9%