--- /dev/null
+From a867d7705c78cce909bb05496339cd84b08fbaf3 Mon Sep 17 00:00:00 2001
+From: Cameron Katri <me@cameronkatri.com>
+Date: Tue, 20 Jul 2021 13:25:03 -0400
+Subject: [PATCH] man(1): Remove FreeBSD's man(1) and use the man util from
+ mandoc
+
+This still includes manpath(1), because mandoc doesn't read
+configuration files from /usr/local/etc/man.d/*
+---
+ usr.bin/Makefile | 2 +-
+ usr.bin/man/Makefile | 8 -
+ usr.bin/man/man.1 | 411 ---------
+ usr.bin/man/man.sh | 1032 ----------------------
+ usr.bin/mandoc/Makefile | 4 +-
+ usr.bin/manpath/Makefile | 7 +
+ usr.bin/{man => manpath}/Makefile.depend | 0
+ usr.bin/{man => manpath}/man.conf.5 | 0
+ usr.bin/{man => manpath}/manpath.1 | 0
+ usr.bin/manpath/manpath.sh | 289 ++++++
+ 10 files changed, 300 insertions(+), 1453 deletions(-)
+ delete mode 100644 usr.bin/man/Makefile
+ delete mode 100644 usr.bin/man/man.1
+ delete mode 100755 usr.bin/man/man.sh
+ create mode 100644 usr.bin/manpath/Makefile
+ rename usr.bin/{man => manpath}/Makefile.depend (100%)
+ rename usr.bin/{man => manpath}/man.conf.5 (100%)
+ rename usr.bin/{man => manpath}/manpath.1 (100%)
+ create mode 100755 usr.bin/manpath/manpath.sh
+
+diff --git a/usr.bin/Makefile b/usr.bin/Makefile
+index 206da7154ac..072cf1122b8 100644
+--- a/usr.bin/Makefile
++++ b/usr.bin/Makefile
+@@ -235,7 +235,7 @@ SUBDIR.${MK_MAIL}+= from
+ SUBDIR.${MK_MAIL}+= mail
+ SUBDIR.${MK_MAIL}+= msgs
+ SUBDIR.${MK_MAKE}+= bmake
+-SUBDIR.${MK_MAN_UTILS}+= man
++SUBDIR.${MK_MAN_UTILS}+= manpath
+ SUBDIR.${MK_NETCAT}+= nc
+ SUBDIR.${MK_NIS}+= ypcat
+ SUBDIR.${MK_NIS}+= ypmatch
+diff --git a/usr.bin/man/Makefile b/usr.bin/man/Makefile
+deleted file mode 100644
+index dc3748e2627..00000000000
+--- a/usr.bin/man/Makefile
++++ /dev/null
+@@ -1,8 +0,0 @@
+-# $FreeBSD$
+-
+-SCRIPTS= man.sh
+-LINKS= ${BINDIR}/man ${BINDIR}/manpath
+-
+-MAN= man.1 manpath.1 man.conf.5
+-
+-.include <bsd.prog.mk>
+diff --git a/usr.bin/man/man.1 b/usr.bin/man/man.1
+deleted file mode 100644
+index 42fd60a8616..00000000000
+--- a/usr.bin/man/man.1
++++ /dev/null
+@@ -1,411 +0,0 @@
+-.\"-
+-.\" Copyright (c) 2010 Gordon Tetlow
+-.\" All rights reserved.
+-.\"
+-.\" Redistribution and use in source and binary forms, with or without
+-.\" modification, are permitted provided that the following conditions
+-.\" are met:
+-.\" 1. Redistributions of source code must retain the above copyright
+-.\" notice, this list of conditions and the following disclaimer.
+-.\" 2. Redistributions in binary form must reproduce the above copyright
+-.\" notice, this list of conditions and the following disclaimer in the
+-.\" documentation and/or other materials provided with the distribution.
+-.\"
+-.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+-.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+-.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+-.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+-.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+-.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+-.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+-.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+-.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+-.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+-.\" SUCH DAMAGE.
+-.\"
+-.\" $FreeBSD$
+-.\"
+-.Dd January 9, 2021
+-.Dt MAN 1
+-.Os
+-.Sh NAME
+-.Nm man
+-.Nd display online manual documentation pages
+-.Sh SYNOPSIS
+-.Nm
+-.Op Fl adho
+-.Op Fl t | w
+-.Op Fl M Ar manpath
+-.Op Fl P Ar pager
+-.Op Fl S Ar mansect
+-.Op Fl m Ar arch Ns Op : Ns Ar machine
+-.Op Fl p Op Ar eprtv
+-.Op Ar mansect
+-.Ar page ...
+-.Nm
+-.Fl f
+-.Ar keyword ...
+-.Nm
+-.Fl k
+-.Ar keyword ...
+-.Sh DESCRIPTION
+-The
+-.Nm
+-utility finds and displays online manual documentation pages.
+-If
+-.Ar mansect
+-is provided,
+-.Nm
+-restricts the search to the specific section of the manual.
+-.Pp
+-The sections of the manual are:
+-.Bl -enum -offset indent -compact
+-.It
+-.Fx
+-General Commands Manual
+-.It
+-.Fx
+-System Calls Manual
+-.It
+-.Fx
+-Library Functions Manual
+-.It
+-.Fx
+-Kernel Interfaces Manual
+-.It
+-.Fx
+-File Formats Manual
+-.It
+-.Fx
+-Games Manual
+-.It
+-.Fx
+-Miscellaneous Information Manual
+-.It
+-.Fx
+-System Manager's Manual
+-.It
+-.Fx
+-Kernel Developer's Manual
+-.El
+-.Pp
+-Options that
+-.Nm
+-understands:
+-.Bl -tag -width indent
+-.It Fl M Ar manpath
+-Forces a specific colon separated manual path instead of the default
+-search path.
+-See
+-.Xr manpath 1 .
+-Overrides the
+-.Ev MANPATH
+-environment variable.
+-.It Fl P Ar pager
+-Use specified pager.
+-Defaults to
+-.Dq Li "less -sR"
+-if color support is enabled, or
+-.Dq Li "less -s" .
+-Overrides the
+-.Ev MANPAGER
+-environment variable, which in turn overrides the
+-.Ev PAGER
+-environment variable.
+-.It Fl S Ar mansect
+-Restricts manual sections searched to the specified colon delimited list.
+-Defaults to
+-.Dq Li 1:8:2:3:3lua:n:4:5:6:7:9:l .
+-Overrides the
+-.Ev MANSECT
+-environment variable.
+-.It Fl a
+-Display all manual pages instead of just the first found for each
+-.Ar page
+-argument.
+-.It Fl d
+-Print extra debugging information.
+-Repeat for increased verbosity.
+-Does not display the manual page.
+-.It Fl f
+-Emulate
+-.Xr whatis 1 .
+-.It Fl h
+-Display short help message and exit.
+-.It Fl k
+-Emulate
+-.Xr apropos 1 .
+-.It Fl m Ar arch Ns Op : Ns Ar machine
+-Override the default architecture and machine settings allowing lookup of
+-other platform specific manual pages.
+-See
+-.Sx IMPLEMENTATION NOTES
+-for how this option changes the default behavior.
+-Overrides the
+-.Ev MACHINE_ARCH
+-and
+-.Ev MACHINE
+-environment variables.
+-.It Fl o
+-Force use of non-localized manual pages.
+-See
+-.Sx IMPLEMENTATION NOTES
+-for how locale specific searches work.
+-Overrides the
+-.Ev LC_ALL , LC_CTYPE ,
+-and
+-.Ev LANG
+-environment variables.
+-.It Fl p Op Cm eprtv
+-Use the list of given preprocessors before running
+-.Xr nroff 1
+-or
+-.Xr troff 1 .
+-Valid preprocessors arguments:
+-.Pp
+-.Bl -tag -width indent -compact
+-.It Cm e
+-.Xr eqn 1
+-.It Cm p
+-.Xr pic 1
+-.It Cm r
+-.Xr refer 1
+-.It Cm t
+-.Xr tbl 1
+-.It Cm v
+-.Xr vgrind 1
+-.El
+-.Pp
+-Overrides the
+-.Ev MANROFFSEQ
+-environment variable.
+-.It Fl t
+-Send manual page source through
+-.Xr troff 1
+-allowing transformation of the manual pages to other formats.
+-.It Fl w
+-Display the location of the manual page instead of the contents of
+-the manual page.
+-.El
+-.Sh IMPLEMENTATION NOTES
+-.Ss Locale Specific Searches
+-The
+-.Nm
+-utility supports manual pages in different locales.
+-The search behavior is dictated by the first of three
+-environment variables with a nonempty string:
+-.Ev LC_ALL , LC_CTYPE ,
+-or
+-.Ev LANG .
+-If set,
+-.Nm
+-will search for locale specific manual pages using the following logic:
+-.Pp
+-.Bl -item -offset indent -compact
+-.It
+-.Va lang Ns _ Ns Va country Ns . Ns Va charset
+-.It
+-.Va lang Ns . Ns Va charset
+-.It
+-.Li en Ns . Ns Va charset
+-.El
+-.Pp
+-For example, if
+-.Ev LC_ALL
+-is set to
+-.Dq Li ja_JP.eucJP ,
+-.Nm
+-will search the following paths when considering section 1 manual pages in
+-.Pa /usr/share/man :
+-.Pp
+-.Bl -item -offset indent -compact
+-.It
+-.Pa /usr/share/man/ja_JP.eucJP/man1
+-.It
+-.Pa /usr/share/man/ja.eucJP/man1
+-.It
+-.Pa /usr/share/man/en.eucJP/man1
+-.It
+-.Pa /usr/share/man/man1
+-.El
+-.Ss Platform Specific Searches
+-The
+-.Nm
+-utility supports platform specific manual pages.
+-The search behavior is dictated by the
+-.Fl m
+-option or the
+-.Ev MACHINE_ARCH
+-and
+-.Ev MACHINE
+-environment variables.
+-For example, if
+-.Ev MACHINE_ARCH
+-is set to
+-.Dq Li aarch64
+-and
+-.Ev MACHINE
+-is set to
+-.Dq Li arm64 ,
+-.Nm
+-will search the following paths when considering section 4 manual pages in
+-.Pa /usr/share/man :
+-.Pp
+-.Bl -item -offset indent -compact
+-.It
+-.Pa /usr/share/man/man4/aarch64
+-.It
+-.Pa /usr/share/man/man4/arm64
+-.It
+-.Pa /usr/share/man/man4
+-.El
+-.Ss Displaying Specific Manual Files
+-The
+-.Nm
+-utility also supports displaying a specific manual page if passed a path
+-to the file as long as it contains a
+-.Ql /
+-character.
+-.Sh ENVIRONMENT
+-The following environment variables affect the execution of
+-.Nm :
+-.Bl -tag -width ".Ev MANROFFSEQ"
+-.It Ev LC_ALL , LC_CTYPE , LANG
+-Used to find locale specific manual pages.
+-Valid values can be found by running the
+-.Xr locale 1
+-command.
+-See
+-.Sx IMPLEMENTATION NOTES
+-for details.
+-Influenced by the
+-.Fl o
+-option.
+-.It Ev MACHINE_ARCH , MACHINE
+-Used to find platform specific manual pages.
+-If unset, the output of
+-.Dq Li "sysctl hw.machine_arch"
+-and
+-.Dq Li "sysctl hw.machine"
+-is used respectively.
+-See
+-.Sx IMPLEMENTATION NOTES
+-for details.
+-Corresponds to the
+-.Fl m
+-option.
+-.It Ev MANPATH
+-The standard search path used by
+-.Xr man 1
+-may be changed by specifying a path in the
+-.Ev MANPATH
+-environment variable.
+-Invalid paths, or paths without manual databases, are ignored.
+-Overridden by
+-.Fl M .
+-If
+-.Ev MANPATH
+-begins with a colon, it is appended to the default list;
+-if it ends with a colon, it is prepended to the default list;
+-or if it contains two adjacent colons,
+-the standard search path is inserted between the colons.
+-If none of these conditions are met, it overrides the
+-standard search path.
+-.It Ev MANROFFSEQ
+-Used to determine the preprocessors for the manual source before running
+-.Xr nroff 1
+-or
+-.Xr troff 1 .
+-If unset, defaults to
+-.Xr tbl 1 .
+-Corresponds to the
+-.Fl p
+-option.
+-.It Ev MANSECT
+-Restricts manual sections searched to the specified colon delimited list.
+-Corresponds to the
+-.Fl S
+-option.
+-.It Ev MANWIDTH
+-If set to a numeric value, used as the width manpages should be displayed.
+-Otherwise, if set to a special value
+-.Dq Li tty ,
+-and output is to a terminal,
+-the pages may be displayed over the whole width of the screen.
+-.It Ev MANCOLOR
+-If set, enables color support.
+-.It Ev MANPAGER
+-Program used to display files.
+-.Pp
+-If unset, and color support is enabled,
+-.Dq Li "less -sR"
+-is used.
+-.Pp
+-If unset, and color support is disabled, then
+-.Ev PAGER
+-is used.
+-If that has no value either,
+-.Dq Li "less -s"
+-is used.
+-.El
+-.Sh FILES
+-.Bl -tag -width indent -compact
+-.It Pa /etc/man.conf
+-System configuration file.
+-.It Pa /usr/local/etc/man.d/*.conf
+-Local configuration files.
+-.El
+-.Sh EXIT STATUS
+-.Ex -std
+-.Sh EXAMPLES
+-Show the manual page for
+-.Xr stat 2 :
+-.Bd -literal -offset indent
+-$ man 2 stat
+-.Ed
+-.Pp
+-Show all manual pages for
+-.Ql stat .
+-.Bd -literal -offset indent
+-$ man -a stat
+-.Ed
+-.Pp
+-List manual pages which match the regular expression either in the title or in
+-the body:
+-.Bd -literal -offset indent
+-$ man -k '\e<copy\e>.*archive'
+-.Ed
+-.Pp
+-Show the manual page for
+-.Xr ls 1
+-and use
+-.Xr cat 1
+-as pager:
+-.Bd -literal -offset indent
+-$ man -P cat ls
+-.Ed
+-.Pp
+-Show the location of the
+-.Xr ls 1
+-manual page:
+-.Bd -literal -offset indent
+-$ man -w ls
+-.Ed
+-.Pp
+-.Sh SEE ALSO
+-.Xr apropos 1 ,
+-.Xr intro 1 ,
+-.Xr mandoc 1 ,
+-.Xr manpath 1 ,
+-.Xr whatis 1 ,
+-.Xr intro 2 ,
+-.Xr intro 3 ,
+-.Xr intro 3lua ,
+-.Xr intro 4 ,
+-.Xr intro 5 ,
+-.Xr man.conf 5 ,
+-.Xr intro 6 ,
+-.Xr intro 7 ,
+-.Xr mdoc 7 ,
+-.Xr intro 8 ,
+-.Xr intro 9
+diff --git a/usr.bin/man/man.sh b/usr.bin/man/man.sh
+deleted file mode 100755
+index f31c464fcc8..00000000000
+--- a/usr.bin/man/man.sh
++++ /dev/null
+@@ -1,1032 +0,0 @@
+-#! /bin/sh
+-#
+-# SPDX-License-Identifier: BSD-2-Clause-FreeBSD
+-#
+-# Copyright (c) 2010 Gordon Tetlow
+-# All rights reserved.
+-#
+-# Redistribution and use in source and binary forms, with or without
+-# modification, are permitted provided that the following conditions
+-# are met:
+-# 1. Redistributions of source code must retain the above copyright
+-# notice, this list of conditions and the following disclaimer.
+-# 2. Redistributions in binary form must reproduce the above copyright
+-# notice, this list of conditions and the following disclaimer in the
+-# documentation and/or other materials provided with the distribution.
+-#
+-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+-# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+-# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+-# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+-# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+-# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+-# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+-# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+-# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+-# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+-# SUCH DAMAGE.
+-#
+-# $FreeBSD$
+-
+-# Usage: add_to_manpath path
+-# Adds a variable to manpath while ensuring we don't have duplicates.
+-# Returns true if we were able to add something. False otherwise.
+-add_to_manpath() {
+- case "$manpath" in
+- *:$1) decho " Skipping duplicate manpath entry $1" 2 ;;
+- $1:*) decho " Skipping duplicate manpath entry $1" 2 ;;
+- *:$1:*) decho " Skipping duplicate manpath entry $1" 2 ;;
+- *) if [ -d "$1" ]; then
+- decho " Adding $1 to manpath"
+- manpath="$manpath:$1"
+- return 0
+- fi
+- ;;
+- esac
+-
+- return 1
+-}
+-
+-# Usage: build_manlocales
+-# Builds a correct MANLOCALES variable.
+-build_manlocales() {
+- # If the user has set manlocales, who are we to argue.
+- if [ -n "$MANLOCALES" ]; then
+- return
+- fi
+-
+- parse_configs
+-
+- # Trim leading colon
+- MANLOCALES=${manlocales#:}
+-
+- decho "Available manual locales: $MANLOCALES"
+-}
+-
+-# Usage: build_manpath
+-# Builds a correct MANPATH variable.
+-build_manpath() {
+- local IFS
+-
+- # If the user has set a manpath, who are we to argue.
+- if [ -n "$MANPATH" ]; then
+- case "$MANPATH" in
+- *:) PREPEND_MANPATH=${MANPATH} ;;
+- :*) APPEND_MANPATH=${MANPATH} ;;
+- *::*)
+- PREPEND_MANPATH=${MANPATH%%::*}
+- APPEND_MANPATH=${MANPATH#*::}
+- ;;
+- *) return ;;
+- esac
+- fi
+-
+- if [ -n "$PREPEND_MANPATH" ]; then
+- IFS=:
+- for path in $PREPEND_MANPATH; do
+- add_to_manpath "$path"
+- done
+- unset IFS
+- fi
+-
+- search_path
+-
+- decho "Adding default manpath entries"
+- IFS=:
+- for path in $man_default_path; do
+- add_to_manpath "$path"
+- done
+- unset IFS
+-
+- parse_configs
+-
+- if [ -n "$APPEND_MANPATH" ]; then
+- IFS=:
+- for path in $APPEND_MANPATH; do
+- add_to_manpath "$path"
+- done
+- unset IFS
+- fi
+- # Trim leading colon
+- MANPATH=${manpath#:}
+-
+- decho "Using manual path: $MANPATH"
+-}
+-
+-# Usage: check_cat catglob
+-# Checks to see if a cat glob is available.
+-check_cat() {
+- if exists "$1"; then
+- use_cat=yes
+- catpage=$found
+- setup_cattool $catpage
+- decho " Found catpage $catpage"
+- return 0
+- else
+- return 1
+- fi
+-}
+-
+-# Usage: check_man manglob catglob
+-# Given 2 globs, figures out if the manglob is available, if so, check to
+-# see if the catglob is also available and up to date.
+-check_man() {
+- if exists "$1"; then
+- # We have a match, check for a cat page
+- manpage=$found
+- setup_cattool $manpage
+- decho " Found manpage $manpage"
+-
+- if [ -n "${use_width}" ]; then
+- # non-standard width
+- unset use_cat
+- decho " Skipping catpage: non-standard page width"
+- elif exists "$2" && is_newer $found $manpage; then
+- # cat page found and is newer, use that
+- use_cat=yes
+- catpage=$found
+- setup_cattool $catpage
+- decho " Using catpage $catpage"
+- else
+- # no cat page or is older
+- unset use_cat
+- decho " Skipping catpage: not found or old"
+- fi
+- return 0
+- fi
+-
+- return 1
+-}
+-
+-# Usage: decho "string" [debuglevel]
+-# Echoes to stderr string prefaced with -- if high enough debuglevel.
+-decho() {
+- if [ $debug -ge ${2:-1} ]; then
+- echo "-- $1" >&2
+- fi
+-}
+-
+-# Usage: exists glob
+-# Returns true if glob resolves to a real file.
+-exists() {
+- local IFS
+-
+- # Don't accidentally inherit callers IFS (breaks perl manpages)
+- unset IFS
+-
+- # Use some globbing tricks in the shell to determine if a file
+- # exists or not.
+- set +f
+- set -- "$1" $1
+- set -f
+-
+- if [ "$1" != "$2" -a -r "$2" ]; then
+- found="$2"
+- return 0
+- fi
+-
+- return 1
+-}
+-
+-# Usage: find_file path section subdir pagename
+-# Returns: true if something is matched and found.
+-# Search the given path/section combo for a given page.
+-find_file() {
+- local manroot catroot mann man0 catn cat0
+-
+- manroot="$1/man$2"
+- catroot="$1/cat$2"
+- if [ -n "$3" ]; then
+- manroot="$manroot/$3"
+- catroot="$catroot/$3"
+- fi
+-
+- if [ ! -d "$manroot" -a ! -d "$catroot" ]; then
+- return 1
+- fi
+- decho " Searching directory $manroot" 2
+-
+- mann="$manroot/$4.$2*"
+- man0="$manroot/$4.0*"
+- catn="$catroot/$4.$2*"
+- cat0="$catroot/$4.0*"
+-
+- # This is the behavior as seen by the original man utility.
+- # Let's not change that which doesn't seem broken.
+- if check_man "$mann" "$catn"; then
+- return 0
+- elif check_man "$man0" "$cat0"; then
+- return 0
+- elif check_cat "$catn"; then
+- return 0
+- elif check_cat "$cat0"; then
+- return 0
+- fi
+-
+- return 1
+-}
+-
+-# Usage: is_newer file1 file2
+-# Returns true if file1 is newer than file2 as calculated by mtime.
+-is_newer() {
+- if ! [ "$1" -ot "$2" ]; then
+- decho " mtime: $1 not older than $2" 3
+- return 0
+- else
+- decho " mtime: $1 older than $2" 3
+- return 1
+- fi
+-}
+-
+-# Usage: manpath_parse_args "$@"
+-# Parses commandline options for manpath.
+-manpath_parse_args() {
+- local cmd_arg
+-
+- while getopts 'Ldq' cmd_arg; do
+- case "${cmd_arg}" in
+- L) Lflag=Lflag ;;
+- d) debug=$(( $debug + 1 )) ;;
+- q) qflag=qflag ;;
+- *) manpath_usage ;;
+- esac
+- done >&2
+-}
+-
+-# Usage: manpath_usage
+-# Display usage for the manpath(1) utility.
+-manpath_usage() {
+- echo 'usage: manpath [-Ldq]' >&2
+- exit 1
+-}
+-
+-# Usage: manpath_warnings
+-# Display some warnings to stderr.
+-manpath_warnings() {
+- if [ -n "$Lflag" -a -n "$MANLOCALES" ]; then
+- echo "(Warning: MANLOCALES environment variable set)" >&2
+- fi
+-}
+-
+-# Usage: man_check_for_so page path
+-# Returns: True if able to resolve the file, false if it ended in tears.
+-# Detects the presence of the .so directive and causes the file to be
+-# redirected to another source file.
+-man_check_for_so() {
+- local IFS line tstr
+-
+- unset IFS
+- if [ -n "$catpage" ]; then
+- return 0
+- fi
+-
+- # We need to loop to accommodate multiple .so directives.
+- while true
+- do
+- line=$($cattool $manpage | head -1)
+- case "$line" in
+- .so*) trim "${line#.so}"
+- decho "$manpage includes $tstr"
+- # Glob and check for the file.
+- if ! check_man "$path/$tstr*" ""; then
+- decho " Unable to find $tstr"
+- return 1
+- fi
+- ;;
+- *) break ;;
+- esac
+- done
+-
+- return 0
+-}
+-
+-# Usage: man_display_page
+-# Display either the manpage or catpage depending on the use_cat variable
+-man_display_page() {
+- local IFS pipeline testline
+-
+- # We are called with IFS set to colon. This causes really weird
+- # things to happen for the variables that have spaces in them.
+- unset IFS
+-
+- # If we are supposed to use a catpage and we aren't using troff(1)
+- # just zcat the catpage and we are done.
+- if [ -z "$tflag" -a -n "$use_cat" ]; then
+- if [ -n "$wflag" ]; then
+- echo "$catpage (source: $manpage)"
+- ret=0
+- else
+- if [ $debug -gt 0 ]; then
+- decho "Command: $cattool $catpage | $MANPAGER"
+- ret=0
+- else
+- eval "$cattool $catpage | $MANPAGER"
+- ret=$?
+- fi
+- fi
+- return
+- fi
+-
+- # Okay, we are using the manpage, do we just need to output the
+- # name of the manpage?
+- if [ -n "$wflag" ]; then
+- echo "$manpage"
+- ret=0
+- return
+- fi
+-
+- if [ -n "$use_width" ]; then
+- mandoc_args="-O width=${use_width}"
+- fi
+- testline="mandoc -Tlint -Wunsupp >/dev/null 2>&1"
+- if [ -n "$tflag" ]; then
+- pipeline="mandoc -Tps $mandoc_args"
+- else
+- pipeline="mandoc $mandoc_args | $MANPAGER"
+- fi
+-
+- if ! eval "$cattool $manpage | $testline" ;then
+- if which -s groff; then
+- man_display_page_groff
+- else
+- echo "This manpage needs groff(1) to be rendered" >&2
+- echo "First install groff(1): " >&2
+- echo "pkg install groff " >&2
+- ret=1
+- fi
+- return
+- fi
+-
+- if [ $debug -gt 0 ]; then
+- decho "Command: $cattool $manpage | $pipeline"
+- ret=0
+- else
+- eval "$cattool $manpage | $pipeline"
+- ret=$?
+- fi
+-}
+-
+-# Usage: man_display_page_groff
+-# Display the manpage using groff
+-man_display_page_groff() {
+- local EQN NROFF PIC TBL TROFF REFER VGRIND
+- local IFS l nroff_dev pipeline preproc_arg tool
+-
+- # So, we really do need to parse the manpage. First, figure out the
+- # device flag (-T) we have to pass to eqn(1) and groff(1). Then,
+- # setup the pipeline of commands based on the user's request.
+-
+- # If the manpage is from a particular charset, we need to setup nroff
+- # to properly output for the correct device.
+- case "${manpage}" in
+- *.${man_charset}/*)
+- # I don't pretend to know this; I'm just copying from the
+- # previous version of man(1).
+- case "$man_charset" in
+- KOI8-R) nroff_dev="koi8-r" ;;
+- ISO8859-1) nroff_dev="latin1" ;;
+- ISO8859-15) nroff_dev="latin1" ;;
+- UTF-8) nroff_dev="utf8" ;;
+- *) nroff_dev="ascii" ;;
+- esac
+-
+- NROFF="$NROFF -T$nroff_dev"
+- EQN="$EQN -T$nroff_dev"
+-
+- # Iff the manpage is from the locale and not just the charset,
+- # then we need to define the locale string.
+- case "${manpage}" in
+- */${man_lang}_${man_country}.${man_charset}/*)
+- NROFF="$NROFF -dlocale=$man_lang.$man_charset"
+- ;;
+- */${man_lang}.${man_charset}/*)
+- NROFF="$NROFF -dlocale=$man_lang.$man_charset"
+- ;;
+- esac
+-
+- # Allow language specific calls to override the default
+- # set of utilities.
+- l=$(echo $man_lang | tr [:lower:] [:upper:])
+- for tool in EQN NROFF PIC TBL TROFF REFER VGRIND; do
+- eval "$tool=\${${tool}_$l:-\$$tool}"
+- done
+- ;;
+- *) NROFF="$NROFF -Tascii"
+- EQN="$EQN -Tascii"
+- ;;
+- esac
+-
+- if [ -z "$MANCOLOR" ]; then
+- NROFF="$NROFF -P-c"
+- fi
+-
+- if [ -n "${use_width}" ]; then
+- NROFF="$NROFF -rLL=${use_width}n -rLT=${use_width}n"
+- fi
+-
+- if [ -n "$MANROFFSEQ" ]; then
+- set -- -$MANROFFSEQ
+- while getopts 'egprtv' preproc_arg; do
+- case "${preproc_arg}" in
+- e) pipeline="$pipeline | $EQN" ;;
+- g) ;; # Ignore for compatibility.
+- p) pipeline="$pipeline | $PIC" ;;
+- r) pipeline="$pipeline | $REFER" ;;
+- t) pipeline="$pipeline | $TBL" ;;
+- v) pipeline="$pipeline | $VGRIND" ;;
+- *) usage ;;
+- esac
+- done
+- # Strip the leading " | " from the resulting pipeline.
+- pipeline="${pipeline#" | "}"
+- else
+- pipeline="$TBL"
+- fi
+-
+- if [ -n "$tflag" ]; then
+- pipeline="$pipeline | $TROFF"
+- else
+- pipeline="$pipeline | $NROFF | $MANPAGER"
+- fi
+-
+- if [ $debug -gt 0 ]; then
+- decho "Command: $cattool $manpage | $pipeline"
+- ret=0
+- else
+- eval "$cattool $manpage | $pipeline"
+- ret=$?
+- fi
+-}
+-
+-# Usage: man_find_and_display page
+-# Search through the manpaths looking for the given page.
+-man_find_and_display() {
+- local found_page locpath p path sect
+-
+- # Check to see if it's a file. But only if it has a '/' in
+- # the filename.
+- case "$1" in
+- */*) if [ -f "$1" -a -r "$1" ]; then
+- decho "Found a usable page, displaying that"
+- unset use_cat
+- manpage="$1"
+- setup_cattool $manpage
+- if man_check_for_so $manpage $(dirname $manpage); then
+- found_page=yes
+- man_display_page
+- fi
+- return
+- fi
+- ;;
+- esac
+-
+- IFS=:
+- for sect in $MANSECT; do
+- decho "Searching section $sect" 2
+- for path in $MANPATH; do
+- for locpath in $locpaths; do
+- p=$path/$locpath
+- p=${p%/.} # Rid ourselves of the trailing /.
+-
+- # Check if there is a MACHINE specific manpath.
+- if find_file $p $sect $MACHINE "$1"; then
+- if man_check_for_so $manpage $p; then
+- found_page=yes
+- man_display_page
+- if [ -n "$aflag" ]; then
+- continue 2
+- else
+- return
+- fi
+- fi
+- fi
+-
+- # Check if there is a MACHINE_ARCH
+- # specific manpath.
+- if find_file $p $sect $MACHINE_ARCH "$1"; then
+- if man_check_for_so $manpage $p; then
+- found_page=yes
+- man_display_page
+- if [ -n "$aflag" ]; then
+- continue 2
+- else
+- return
+- fi
+- fi
+- fi
+-
+- # Check plain old manpath.
+- if find_file $p $sect '' "$1"; then
+- if man_check_for_so $manpage $p; then
+- found_page=yes
+- man_display_page
+- if [ -n "$aflag" ]; then
+- continue 2
+- else
+- return
+- fi
+- fi
+- fi
+- done
+- done
+- done
+- unset IFS
+-
+- # Nothing? Well, we are done then.
+- if [ -z "$found_page" ]; then
+- echo "No manual entry for $1" >&2
+- ret=1
+- return
+- fi
+-}
+-
+-# Usage: man_parse_args "$@"
+-# Parses commandline options for man.
+-man_parse_args() {
+- local IFS cmd_arg
+-
+- while getopts 'M:P:S:adfhkm:op:tw' cmd_arg; do
+- case "${cmd_arg}" in
+- M) MANPATH=$OPTARG ;;
+- P) MANPAGER=$OPTARG ;;
+- S) MANSECT=$OPTARG ;;
+- a) aflag=aflag ;;
+- d) debug=$(( $debug + 1 )) ;;
+- f) fflag=fflag ;;
+- h) man_usage 0 ;;
+- k) kflag=kflag ;;
+- m) mflag=$OPTARG ;;
+- o) oflag=oflag ;;
+- p) MANROFFSEQ=$OPTARG ;;
+- t) tflag=tflag ;;
+- w) wflag=wflag ;;
+- *) man_usage ;;
+- esac
+- done >&2
+-
+- shift $(( $OPTIND - 1 ))
+-
+- # Check the args for incompatible options.
+- case "${fflag}${kflag}${tflag}${wflag}" in
+- fflagkflag*) echo "Incompatible options: -f and -k"; man_usage ;;
+- fflag*tflag*) echo "Incompatible options: -f and -t"; man_usage ;;
+- fflag*wflag) echo "Incompatible options: -f and -w"; man_usage ;;
+- *kflagtflag*) echo "Incompatible options: -k and -t"; man_usage ;;
+- *kflag*wflag) echo "Incompatible options: -k and -w"; man_usage ;;
+- *tflagwflag) echo "Incompatible options: -t and -w"; man_usage ;;
+- esac
+-
+- # Short circuit for whatis(1) and apropos(1)
+- if [ -n "$fflag" ]; then
+- do_whatis "$@"
+- exit
+- fi
+-
+- if [ -n "$kflag" ]; then
+- do_apropos "$@"
+- exit
+- fi
+-
+- IFS=:
+- for sect in $man_default_sections; do
+- if [ "$sect" = "$1" ]; then
+- decho "Detected manual section as first arg: $1"
+- MANSECT="$1"
+- shift
+- break
+- fi
+- done
+- unset IFS
+-
+- pages="$*"
+-}
+-
+-# Usage: man_setup
+-# Setup various trivial but essential variables.
+-man_setup() {
+- # Setup machine and architecture variables.
+- if [ -n "$mflag" ]; then
+- MACHINE_ARCH=${mflag%%:*}
+- MACHINE=${mflag##*:}
+- fi
+- if [ -z "$MACHINE_ARCH" ]; then
+- MACHINE_ARCH=$($SYSCTL -n hw.machine_arch)
+- fi
+- if [ -z "$MACHINE" ]; then
+- MACHINE=$($SYSCTL -n hw.machine)
+- fi
+- decho "Using architecture: $MACHINE_ARCH:$MACHINE"
+-
+- setup_pager
+-
+- # Setup manual sections to search.
+- if [ -z "$MANSECT" ]; then
+- MANSECT=$man_default_sections
+- fi
+- decho "Using manual sections: $MANSECT"
+-
+- build_manpath
+- man_setup_locale
+- man_setup_width
+-}
+-
+-# Usage: man_setup_width
+-# Set up page width.
+-man_setup_width() {
+- local sizes
+-
+- unset use_width
+- case "$MANWIDTH" in
+- [0-9]*)
+- if [ "$MANWIDTH" -gt 0 2>/dev/null ]; then
+- use_width=$MANWIDTH
+- fi
+- ;;
+- [Tt][Tt][Yy])
+- if { sizes=$($STTY size 0>&3 2>/dev/null); } 3>&1; then
+- set -- $sizes
+- if [ $2 -gt 80 ]; then
+- use_width=$(($2-2))
+- fi
+- fi
+- ;;
+- esac
+- if [ -n "$use_width" ]; then
+- decho "Using non-standard page width: ${use_width}"
+- else
+- decho 'Using standard page width'
+- fi
+-}
+-
+-# Usage: man_setup_locale
+-# Setup necessary locale variables.
+-man_setup_locale() {
+- local lang_cc
+- local locstr
+-
+- locpaths='.'
+- man_charset='US-ASCII'
+-
+- # Setup locale information.
+- if [ -n "$oflag" ]; then
+- decho 'Using non-localized manpages'
+- else
+- # Use the locale tool to give us proper locale information
+- eval $( $LOCALE )
+-
+- if [ -n "$LANG" ]; then
+- locstr=$LANG
+- else
+- locstr=$LC_CTYPE
+- fi
+-
+- case "$locstr" in
+- C) ;;
+- C.UTF-8) ;;
+- POSIX) ;;
+- [a-z][a-z]_[A-Z][A-Z]\.*)
+- lang_cc="${locstr%.*}"
+- man_lang="${locstr%_*}"
+- man_country="${lang_cc#*_}"
+- man_charset="${locstr#*.}"
+- locpaths="$locstr"
+- locpaths="$locpaths:$man_lang.$man_charset"
+- if [ "$man_lang" != "en" ]; then
+- locpaths="$locpaths:en.$man_charset"
+- fi
+- locpaths="$locpaths:."
+- ;;
+- *) echo 'Unknown locale, assuming C' >&2
+- ;;
+- esac
+- fi
+-
+- decho "Using locale paths: $locpaths"
+-}
+-
+-# Usage: man_usage [exitcode]
+-# Display usage for the man utility.
+-man_usage() {
+- echo 'Usage:'
+- echo ' man [-adho] [-t | -w] [-M manpath] [-P pager] [-S mansect]'
+- echo ' [-m arch[:machine]] [-p [eprtv]] [mansect] page [...]'
+- echo ' man -f page [...] -- Emulates whatis(1)'
+- echo ' man -k page [...] -- Emulates apropos(1)'
+-
+- # When exit'ing with -h, it's not an error.
+- exit ${1:-1}
+-}
+-
+-# Usage: parse_configs
+-# Reads the end-user adjustable config files.
+-parse_configs() {
+- local IFS file files
+-
+- if [ -n "$parsed_configs" ]; then
+- return
+- fi
+-
+- unset IFS
+-
+- # Read the global config first in case the user wants
+- # to override config_local.
+- if [ -r "$config_global" ]; then
+- parse_file "$config_global"
+- fi
+-
+- # Glob the list of files to parse.
+- set +f
+- files=$(echo $config_local)
+- set -f
+-
+- for file in $files; do
+- if [ -r "$file" ]; then
+- parse_file "$file"
+- fi
+- done
+-
+- parsed_configs='yes'
+-}
+-
+-# Usage: parse_file file
+-# Reads the specified config files.
+-parse_file() {
+- local file line tstr var
+-
+- file="$1"
+- decho "Parsing config file: $file"
+- while read line; do
+- decho " $line" 2
+- case "$line" in
+- \#*) decho " Comment" 3
+- ;;
+- MANPATH*) decho " MANPATH" 3
+- trim "${line#MANPATH}"
+- add_to_manpath "$tstr"
+- ;;
+- MANLOCALE*) decho " MANLOCALE" 3
+- trim "${line#MANLOCALE}"
+- manlocales="$manlocales:$tstr"
+- ;;
+- MANCONFIG*) decho " MANCONFIG" 3
+- trim "${line#MANCONFIG}"
+- config_local="$tstr"
+- ;;
+- # Set variables in the form of FOO_BAR
+- *_*[\ \ ]*) var="${line%%[\ \ ]*}"
+- trim "${line#$var}"
+- eval "$var=\"$tstr\""
+- decho " Parsed $var" 3
+- ;;
+- esac
+- done < "$file"
+-}
+-
+-# Usage: search_path
+-# Traverse $PATH looking for manpaths.
+-search_path() {
+- local IFS p path
+-
+- decho "Searching PATH for man directories"
+-
+- IFS=:
+- for path in $PATH; do
+- if add_to_manpath "$path/man"; then
+- :
+- elif add_to_manpath "$path/MAN"; then
+- :
+- else
+- case "$path" in
+- */bin) p="${path%/bin}/share/man"
+- add_to_manpath "$p"
+- p="${path%/bin}/man"
+- add_to_manpath "$p"
+- ;;
+- esac
+- fi
+- done
+- unset IFS
+-
+- if [ -z "$manpath" ]; then
+- decho ' Unable to find any manpaths, using default'
+- manpath=$man_default_path
+- fi
+-}
+-
+-# Usage: search_whatis cmd [arglist]
+-# Do the heavy lifting for apropos/whatis
+-search_whatis() {
+- local IFS bad cmd f good key keywords loc opt out path rval wlist
+-
+- cmd="$1"
+- shift
+-
+- whatis_parse_args "$@"
+-
+- build_manpath
+- build_manlocales
+- setup_pager
+-
+- if [ "$cmd" = "whatis" ]; then
+- opt="-w"
+- fi
+-
+- f='whatis'
+-
+- IFS=:
+- for path in $MANPATH; do
+- if [ \! -d "$path" ]; then
+- decho "Skipping non-existent path: $path" 2
+- continue
+- fi
+-
+- if [ -f "$path/$f" -a -r "$path/$f" ]; then
+- decho "Found whatis: $path/$f"
+- wlist="$wlist $path/$f"
+- fi
+-
+- for loc in $MANLOCALES; do
+- if [ -f "$path/$loc/$f" -a -r "$path/$loc/$f" ]; then
+- decho "Found whatis: $path/$loc/$f"
+- wlist="$wlist $path/$loc/$f"
+- fi
+- done
+- done
+- unset IFS
+-
+- if [ -z "$wlist" ]; then
+- echo "$cmd: no whatis databases in $MANPATH" >&2
+- exit 1
+- fi
+-
+- rval=0
+- for key in $keywords; do
+- out=$(grep -Ehi $opt -- "$key" $wlist)
+- if [ -n "$out" ]; then
+- good="$good\\n$out"
+- else
+- bad="$bad\\n$key: nothing appropriate"
+- rval=1
+- fi
+- done
+-
+- # Strip leading carriage return.
+- good=${good#\\n}
+- bad=${bad#\\n}
+-
+- if [ -n "$good" ]; then
+- echo -e "$good" | $MANPAGER
+- fi
+-
+- if [ -n "$bad" ]; then
+- echo -e "$bad" >&2
+- fi
+-
+- exit $rval
+-}
+-
+-# Usage: setup_cattool page
+-# Finds an appropriate decompressor based on extension
+-setup_cattool() {
+- case "$1" in
+- *.bz) cattool='/usr/bin/bzcat' ;;
+- *.bz2) cattool='/usr/bin/bzcat' ;;
+- *.gz) cattool='/usr/bin/zcat' ;;
+- *.lzma) cattool='/usr/bin/lzcat' ;;
+- *.xz) cattool='/usr/bin/xzcat' ;;
+- *) cattool='/usr/bin/zcat -f' ;;
+- esac
+-}
+-
+-# Usage: setup_pager
+-# Correctly sets $MANPAGER
+-setup_pager() {
+- # Setup pager.
+- if [ -z "$MANPAGER" ]; then
+- if [ -n "$MANCOLOR" ]; then
+- MANPAGER="less -sR"
+- else
+- if [ -n "$PAGER" ]; then
+- MANPAGER="$PAGER"
+- else
+- MANPAGER="less -s"
+- fi
+- fi
+- fi
+- decho "Using pager: $MANPAGER"
+-}
+-
+-# Usage: trim string
+-# Trims whitespace from beginning and end of a variable
+-trim() {
+- tstr=$1
+- while true; do
+- case "$tstr" in
+- [\ \ ]*) tstr="${tstr##[\ \ ]}" ;;
+- *[\ \ ]) tstr="${tstr%%[\ \ ]}" ;;
+- *) break ;;
+- esac
+- done
+-}
+-
+-# Usage: whatis_parse_args "$@"
+-# Parse commandline args for whatis and apropos.
+-whatis_parse_args() {
+- local cmd_arg
+- while getopts 'd' cmd_arg; do
+- case "${cmd_arg}" in
+- d) debug=$(( $debug + 1 )) ;;
+- *) whatis_usage ;;
+- esac
+- done >&2
+-
+- shift $(( $OPTIND - 1 ))
+-
+- keywords="$*"
+-}
+-
+-# Usage: whatis_usage
+-# Display usage for the whatis/apropos utility.
+-whatis_usage() {
+- echo "usage: $cmd [-d] keyword [...]"
+- exit 1
+-}
+-
+-
+-
+-# Supported commands
+-do_apropos() {
+- [ $(stat -f %i /usr/bin/man) -ne $(stat -f %i /usr/bin/apropos) ] && \
+- exec apropos "$@"
+- search_whatis apropos "$@"
+-}
+-
+-do_man() {
+- man_parse_args "$@"
+- if [ -z "$pages" ]; then
+- echo 'What manual page do you want?' >&2
+- exit 1
+- fi
+- man_setup
+-
+- for page in $pages; do
+- decho "Searching for $page"
+- man_find_and_display "$page"
+- done
+-
+- exit ${ret:-0}
+-}
+-
+-do_manpath() {
+- manpath_parse_args "$@"
+- if [ -z "$qflag" ]; then
+- manpath_warnings
+- fi
+- if [ -n "$Lflag" ]; then
+- build_manlocales
+- echo $MANLOCALES
+- else
+- build_manpath
+- echo $MANPATH
+- fi
+- exit 0
+-}
+-
+-do_whatis() {
+- [ $(stat -f %i /usr/bin/man) -ne $(stat -f %i /usr/bin/whatis) ] && \
+- exec whatis "$@"
+- search_whatis whatis "$@"
+-}
+-
+-# User's PATH setting decides on the groff-suite to pick up.
+-EQN=eqn
+-NROFF='groff -S -P-h -Wall -mtty-char -man'
+-PIC=pic
+-REFER=refer
+-TBL=tbl
+-TROFF='groff -S -man'
+-VGRIND=vgrind
+-
+-LOCALE=/usr/bin/locale
+-STTY=/bin/stty
+-SYSCTL=/sbin/sysctl
+-
+-debug=0
+-man_default_sections='1:8:2:3:3lua:n:4:5:6:7:9:l'
+-man_default_path='/usr/share/man:/usr/share/openssl/man:/usr/local/share/man:/usr/local/man'
+-cattool='/usr/bin/zcat -f'
+-
+-config_global='/etc/man.conf'
+-
+-# This can be overridden via a setting in /etc/man.conf.
+-config_local='/usr/local/etc/man.d/*.conf'
+-
+-# Set noglobbing for now. I don't want spurious globbing.
+-set -f
+-
+-case "$0" in
+-*apropos) do_apropos "$@" ;;
+-*manpath) do_manpath "$@" ;;
+-*whatis) do_whatis "$@" ;;
+-*) do_man "$@" ;;
+-esac
+diff --git a/usr.bin/mandoc/Makefile b/usr.bin/mandoc/Makefile
+index 55e13fa6485..7b323e4ee55 100644
+--- a/usr.bin/mandoc/Makefile
++++ b/usr.bin/mandoc/Makefile
+@@ -10,10 +10,12 @@ MAN= mandoc.1 eqn.7 mandoc_char.7 tbl.7 man.7 mdoc.7 roff.7
+ MLINKS= mandoc.1 mdocml.1
+ .if ${MK_MAN_UTILS} != no
+ MAN+= apropos.1 makewhatis.8
++MAN+= man.1
+ MLINKS+= apropos.1 whatis.1
+ LINKS= ${BINDIR}/mandoc ${BINDIR}/whatis \
+ ${BINDIR}/mandoc ${BINDIR}/makewhatis \
+- ${BINDIR}/mandoc ${BINDIR}/apropos
++ ${BINDIR}/mandoc ${BINDIR}/apropos \
++ ${BINDIR}/mandoc ${BINDIR}/man
+ .elif defined(BOOTSTRAPPING)
+ .error "MK_MAN_UTILS should be set to yes when bootstrapping"
+ .endif
+diff --git a/usr.bin/manpath/Makefile b/usr.bin/manpath/Makefile
+new file mode 100644
+index 00000000000..20a05f68a62
+--- /dev/null
++++ b/usr.bin/manpath/Makefile
+@@ -0,0 +1,7 @@
++# $FreeBSD$
++
++SCRIPTS= manpath.sh
++
++MAN= manpath.1 man.conf.5
++
++.include <bsd.prog.mk>
+diff --git a/usr.bin/man/Makefile.depend b/usr.bin/manpath/Makefile.depend
+similarity index 100%
+rename from usr.bin/man/Makefile.depend
+rename to usr.bin/manpath/Makefile.depend
+diff --git a/usr.bin/man/man.conf.5 b/usr.bin/manpath/man.conf.5
+similarity index 100%
+rename from usr.bin/man/man.conf.5
+rename to usr.bin/manpath/man.conf.5
+diff --git a/usr.bin/man/manpath.1 b/usr.bin/manpath/manpath.1
+similarity index 100%
+rename from usr.bin/man/manpath.1
+rename to usr.bin/manpath/manpath.1
+diff --git a/usr.bin/manpath/manpath.sh b/usr.bin/manpath/manpath.sh
+new file mode 100755
+index 00000000000..1bec8ef4882
+--- /dev/null
++++ b/usr.bin/manpath/manpath.sh
+@@ -0,0 +1,289 @@
++#! /bin/sh
++#
++# SPDX-License-Identifier: BSD-2-Clause-FreeBSD
++#
++# Copyright (c) 2010 Gordon Tetlow
++# All rights reserved.
++#
++# Redistribution and use in source and binary forms, with or without
++# modification, are permitted provided that the following conditions
++# are met:
++# 1. Redistributions of source code must retain the above copyright
++# notice, this list of conditions and the following disclaimer.
++# 2. Redistributions in binary form must reproduce the above copyright
++# notice, this list of conditions and the following disclaimer in the
++# documentation and/or other materials provided with the distribution.
++#
++# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
++# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
++# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
++# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
++# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
++# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
++# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
++# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
++# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
++# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
++# SUCH DAMAGE.
++#
++# $FreeBSD$
++
++# Usage: add_to_manpath path
++# Adds a variable to manpath while ensuring we don't have duplicates.
++# Returns true if we were able to add something. False otherwise.
++add_to_manpath() {
++ case "$manpath" in
++ *:$1) decho " Skipping duplicate manpath entry $1" 2 ;;
++ $1:*) decho " Skipping duplicate manpath entry $1" 2 ;;
++ *:$1:*) decho " Skipping duplicate manpath entry $1" 2 ;;
++ *) if [ -d "$1" ]; then
++ decho " Adding $1 to manpath"
++ manpath="$manpath:$1"
++ return 0
++ fi
++ ;;
++ esac
++
++ return 1
++}
++
++# Usage: build_manlocales
++# Builds a correct MANLOCALES variable.
++build_manlocales() {
++ # If the user has set manlocales, who are we to argue.
++ if [ -n "$MANLOCALES" ]; then
++ return
++ fi
++
++ parse_configs
++
++ # Trim leading colon
++ MANLOCALES=${manlocales#:}
++
++ decho "Available manual locales: $MANLOCALES"
++}
++
++# Usage: build_manpath
++# Builds a correct MANPATH variable.
++build_manpath() {
++ local IFS
++
++ # If the user has set a manpath, who are we to argue.
++ if [ -n "$MANPATH" ]; then
++ case "$MANPATH" in
++ *:) PREPEND_MANPATH=${MANPATH} ;;
++ :*) APPEND_MANPATH=${MANPATH} ;;
++ *::*)
++ PREPEND_MANPATH=${MANPATH%%::*}
++ APPEND_MANPATH=${MANPATH#*::}
++ ;;
++ *) return ;;
++ esac
++ fi
++
++ if [ -n "$PREPEND_MANPATH" ]; then
++ IFS=:
++ for path in $PREPEND_MANPATH; do
++ add_to_manpath "$path"
++ done
++ unset IFS
++ fi
++
++ search_path
++
++ decho "Adding default manpath entries"
++ IFS=:
++ for path in $man_default_path; do
++ add_to_manpath "$path"
++ done
++ unset IFS
++
++ parse_configs
++
++ if [ -n "$APPEND_MANPATH" ]; then
++ IFS=:
++ for path in $APPEND_MANPATH; do
++ add_to_manpath "$path"
++ done
++ unset IFS
++ fi
++ # Trim leading colon
++ MANPATH=${manpath#:}
++
++ decho "Using manual path: $MANPATH"
++}
++
++# Usage: decho "string" [debuglevel]
++# Echoes to stderr string prefaced with -- if high enough debuglevel.
++decho() {
++ if [ $debug -ge ${2:-1} ]; then
++ echo "-- $1" >&2
++ fi
++}
++
++# Usage: manpath_parse_args "$@"
++# Parses commandline options for manpath.
++manpath_parse_args() {
++ local cmd_arg
++
++ while getopts 'Ldq' cmd_arg; do
++ case "${cmd_arg}" in
++ L) Lflag=Lflag ;;
++ d) debug=$(( $debug + 1 )) ;;
++ q) qflag=qflag ;;
++ *) manpath_usage ;;
++ esac
++ done >&2
++}
++
++# Usage: manpath_usage
++# Display usage for the manpath(1) utility.
++manpath_usage() {
++ echo 'usage: manpath [-Ldq]' >&2
++ exit 1
++}
++
++# Usage: manpath_warnings
++# Display some warnings to stderr.
++manpath_warnings() {
++ if [ -n "$Lflag" -a -n "$MANLOCALES" ]; then
++ echo "(Warning: MANLOCALES environment variable set)" >&2
++ fi
++}
++
++# Usage: parse_configs
++# Reads the end-user adjustable config files.
++parse_configs() {
++ local IFS file files
++
++ if [ -n "$parsed_configs" ]; then
++ return
++ fi
++
++ unset IFS
++
++ # Read the global config first in case the user wants
++ # to override config_local.
++ if [ -r "$config_global" ]; then
++ parse_file "$config_global"
++ fi
++
++ # Glob the list of files to parse.
++ set +f
++ files=$(echo $config_local)
++ set -f
++
++ for file in $files; do
++ if [ -r "$file" ]; then
++ parse_file "$file"
++ fi
++ done
++
++ parsed_configs='yes'
++}
++
++# Usage: parse_file file
++# Reads the specified config files.
++parse_file() {
++ local file line tstr var
++
++ file="$1"
++ decho "Parsing config file: $file"
++ while read line; do
++ decho " $line" 2
++ case "$line" in
++ \#*) decho " Comment" 3
++ ;;
++ MANPATH*) decho " MANPATH" 3
++ trim "${line#MANPATH}"
++ add_to_manpath "$tstr"
++ ;;
++ MANLOCALE*) decho " MANLOCALE" 3
++ trim "${line#MANLOCALE}"
++ manlocales="$manlocales:$tstr"
++ ;;
++ MANCONFIG*) decho " MANCONFIG" 3
++ trim "${line#MANCONFIG}"
++ config_local="$tstr"
++ ;;
++ # Set variables in the form of FOO_BAR
++ *_*[\ \ ]*) var="${line%%[\ \ ]*}"
++ trim "${line#$var}"
++ eval "$var=\"$tstr\""
++ decho " Parsed $var" 3
++ ;;
++ esac
++ done < "$file"
++}
++
++# Usage: search_path
++# Traverse $PATH looking for manpaths.
++search_path() {
++ local IFS p path
++
++ decho "Searching PATH for man directories"
++
++ IFS=:
++ for path in $PATH; do
++ if add_to_manpath "$path/man"; then
++ :
++ elif add_to_manpath "$path/MAN"; then
++ :
++ else
++ case "$path" in
++ */bin) p="${path%/bin}/share/man"
++ add_to_manpath "$p"
++ p="${path%/bin}/man"
++ add_to_manpath "$p"
++ ;;
++ esac
++ fi
++ done
++ unset IFS
++
++ if [ -z "$manpath" ]; then
++ decho ' Unable to find any manpaths, using default'
++ manpath=$man_default_path
++ fi
++}
++
++# Usage: trim string
++# Trims whitespace from beginning and end of a variable
++trim() {
++ tstr=$1
++ while true; do
++ case "$tstr" in
++ [\ \ ]*) tstr="${tstr##[\ \ ]}" ;;
++ *[\ \ ]) tstr="${tstr%%[\ \ ]}" ;;
++ *) break ;;
++ esac
++ done
++}
++
++do_manpath() {
++ manpath_parse_args "$@"
++ if [ -z "$qflag" ]; then
++ manpath_warnings
++ fi
++ if [ -n "$Lflag" ]; then
++ build_manlocales
++ echo $MANLOCALES
++ else
++ build_manpath
++ echo $MANPATH
++ fi
++ exit 0
++}
++
++debug=0
++man_default_path='/usr/share/man:/usr/share/openssl/man:/usr/local/share/man:/usr/local/man'
++
++config_global='/etc/man.conf'
++
++# This can be overridden via a setting in /etc/man.conf.
++config_local='/usr/local/etc/man.d/*.conf'
++
++# Set noglobbing for now. I don't want spurious globbing.
++set -f
++
++do_manpath "$@"
+--
+2.32.0
+