SYNOPSIS

\*(n) [ -p ] first\[hy]string second\[hy]string

\*(n) -w first\[hy]string second\[hy]string

\*(n) -a first\[hy]file second\[hy]file

\*(n) -s needle haystack...

\*(n) --version

DESCRIPTION

The \*(n) command is used to make fuzzy comparisons between strings. The \[lq]edit distance\[rq] between the strings is printed, with 0.0 meaning the strings are utterly un\[hy]alike, and 1.0 meaning the strings are identical.

You may need to quote the string to insulate them from the shell.

OPTIONS

The \*(n) command understands the following options:

-a

--files-as-bytes

This option is used to compare two files as arrays of bytes. See fmemcmp(3) for more information.

-p

--pair

This option is used to compare two strings as arrays of bytes. This is the default. See fstrcmp(3) for more information.

-s

--select

This option is used to select the closest needle from the provided haystack alternatives. The most similar (single) choice is printed. If none are particularly similar, nothing is printed. See fstrcmp(3) for more information. See below for example.

-V

--version

This option may be used to print the version of the \*(n) command, and then exit.

-w

--wide-pair

This option is used to compare two multi\[hy]byte character strings. See fstrcoll(3) for more information.

EXIT STATUS

The \*(n) command exits with status 1 on any error. The \*(n) command only exits with status 0 if there are no errors.

EXAMPLE

The \*(n) --select option may be used in a shell script to improve error messages.

case "$action" in
start)
    start
    ;;
stop)
    stop
    ;;
restart)
    stop
    start
    ;;
*)
    echo "$0: action \"$action\" unknown" 1>&2
    guess=`fstrcmp --select "$action" stop start restart`
    if [ "$guess" ]
    then
        echo "$0: did you mean \"$guess\" instead?" 1>&2
    fi
    exit 1
    ;;
esac

Thus, the error message frequently suggests the correct action in the face of simple finger problems on the command line.

RELATED TO fstrcmp…

fstrcmp(3)

fuzzy comparison of strings

fstrcoll(3)

fuzzy comparison of two multi\[hy]byte character strings

fstrcmpi(3)

fuzzy comparison of strings, integer variation

COPYRIGHT

fstrcmp version \*(v)

Copyright \*(C) 2009 Peter Miller

Peter Miller <[email protected]>

The comparison code is derived from the fuzzy comparison functions in GNU Gettext 0.17. The GNU Gettext comparison functions were, in turn, derived from GNU Diff 2.7.

Copyright \*(C) 1988-2009 Free Software Foundation