git bash 扩展tree命令

开门见山

git bashWindows 用户安装 git 时默认安装的命令行工具,不仅界面漂亮功能也不错,大多数情况下可以替代 Windows 原生的 cmd 命令行.

然而,git bash 命令行不是万金油,并不能完全替代 cmd ,详情请参考 mintty 官网的相关说明.

mintty is not a full replacement for the Windows Console window

git bash 命令行默认使用 mintty 作为终端模拟器,而 mintty 官宣表示自己不能完全替代 cmd,也就是说 git bash 可能不具备某些 cmd 命令.

举个简单的例子,如果想要查看当前目录的文件结构,最好是以目录树的形式展现,聪明的你获取已经猜到了tree 命令.

git bash 命令行中输入 tree 命令发现并无此命令.

snowdreams1006@home MINGW64 /g/sublime/test
$ tree
bash: tree: command not found

为了验证,确实没有 tree 命令,我们直接打开 git bash 支持的命令文件目录,查看到底有没有 tree.exe 文件.

git bash 桌面快捷方式右键,选择打开文件位置,当前正处于 git 的安装目录,进入.\usr\bin 文件夹.

经过验证,git bash 支持的命令文件确实没有发现 tree.exe 文件,因此真的不支持 tree 命令.

然而,cmd 自带的命令行中输入 tree 中竟然发现能够输出目录树,原来 cmd 支持 tree 命令.

G:\sublime\test>tree
 工作 的文件夹 PATH 列表
卷序列号为 00000081 CC3C:50D0
G:.
├─cmd
└─git

tree 命令其实调用的是 tree.com 并不是常见的 tree.exe 格式.

科普时间

现在我们已经知道 git bash 提供的终端模拟器不支持某些 linux 命令,但是为什么不支持以及如何才能支持这些命令呢?

这些问题必须等我们弄清楚 mintty 的朋友圈关系才能更好地解决上述问题,接下来简单科普下 mintty 的朋友圈.

关于科普知识的来源,请参考上一篇文章: <>

mintty 是什么

MinttyCygwinMSYSMsys2 的终端模拟器,派生项目和 WSL.

mintty 开源终端模拟器,基于 putty 的终端仿真和 Windows 前端页面.

mintty 作为一款优秀的终端模拟器,不仅是其他系统上默认的终端,也是 git bash 的默认终端.

$ mintty --help
Usage: mintty [OPTION]... [ PROGRAM [ARG]... | - ]

Start a new terminal session running the specified program or the user's shell.
If a dash is given instead of a program, invoke the shell as a login shell.

Options:
  -c, --config FILE     Load specified config file
  -e, --exec            Treat remaining arguments as the command to execute
  -h, --hold never|start|error|always  Keep window open after command finishes
  -i, --icon FILE[,IX]  Load window icon from file, optionally with index
  -l, --log FILE|-      Log output to file or stdout
  -o, --option OPT=VAL  Override config file option with given value
  -p, --position X,Y    Open window at specified coordinates
  -s, --size COLS,ROWS  Set screen size in characters
  -t, --title TITLE     Set window title (default: the invoked command)
  -u, --utmp            Create a utmp entry
  -w, --window normal|min|max|full|hide  Set initial window state
      --class CLASS     Set window class name (default: mintty)
  -H, --help            Display help and exit
  -V, --version         Print version information and exit

如果想要自定义 mintty 终端,在 git bash 命令行界面右键选择选项设置即可打开设置页面.

mingw 是什么

mingwMinimalist GNU for Windows 的缩写,是 Microsoft Windows 应用程序的极简主义开发环境.

msys 是什么

MSYSMinimal SYStem 的缩写,是 Bourne Shell 命令行解释器系统.作为 Microsoftcmd.exe 的替代品,它提供了一个通用的命令行环境,特别适合与 MinGW 一起使用,用于将许多开源应用程序移植到 MS-Windows平台; 它是 Cygwin-1.3 的轻量级分支,它包含一小部分 Unix 工具,可以帮助实现这一目标.

cygwin 是什么

大量 GNU 和开源工具,提供类似于 Windows 上的 Linux 发行版的功能.

gnu 是什么

GNUGNU's Not Unix 的递归缩写,是自由软件操作系统.

朋友圈关系梳理

git bash 采用 mintty 作为终端模拟器,而 mintty 终端是 mingw ,msys2cygwin的默认终端,这些"操作系统"或多或少都是 GNU 的一部分.

GNU 是自由软件运动的成果,提出自由软件以及自由软件操作系统概念,源码开源发布.

正因如此,江山代有才人出,前人栽树后人乘凉,Cygwin 作为 GNU 一员,提出了要在 Windows 打造出 Linux 的感觉,开发出一套完整的解决方案.

或许由于这套方案太完整,功能齐全因而软件包体积庞大,因此 MinGWMSYS 分别在其基于上进行精简重构,保留最简功能,发展出"极简主义的GNU".

开源的力量是可持续的,慢慢的,这些操作系统的内置终端功能也被单独提取出来,mintty 作为他们的默认终端也逐渐独立提供终端模拟器服务,轻松和各个系统进行安装集成.

说到开源,自然是少不了 git 的身影,分布式版本控制系统这种优秀工具应该造福全人类,然而 git 本身仅支持类 Unix 系统,并不提供 WIndows 系统的支持.

Git For Windows 组织出手增加了 gitWindows 系统的支持,背后的技术多半离不开上述介绍的 GNU 操作系统.

Git Bash Here 则是 Git For Windows 的命令行工具,使用的终端模拟器就是明星模拟器 mintty.

回到正题

弄清楚事情的来龙去脉后,对我们解决问题有什么帮助呢?

帮助可大了去了,刨根问题找到了源头,问题自然迎刃而解!

我劝少年放弃吧

你确定不是在逗我?让我直接放弃?

亲,真的抱歉呢,放弃是解决问题的最快途径!

...

谈一谈为什么要放弃?

git bash 命令行使用的是 mintty 终端,而 mintty 终端并不能完全替代 cmd ,也没有提供包管理工具供我们扩展第三方命令.

所以默认情况下,如果没有提供某些命令,那我们只好放弃在 git bash 命令行中使用这些命令.

此路不通,自然会寻求其他解决途径,比如可以借助 cmd 命令行或者其他第三方软件等,没必要非要坚持使用git bash!

既然本文是 tree 命令引发的讨论,那就谈点和主题有关的技能点,不然岂不是跑题了?

tree 命令虽然 git bash 不提供,但是 cmd 却已经内置了.

值得注意的是,cmd 提供的 tree 命令比较特殊,并不是常见的 .exe 结尾文件,而是 .com 结尾的文件.

所以 git bash 中输入 tree 命令时,自身 /usr/bin 中没有 tree.exe 文件,而系统中也没有 tree.exe 命令,那么就会提示找不到命令了啊!

手动补全命令

那么第一种调用方法便是补全后缀名,这样自然能够调用 cmdtree.com 命令.

git bash 并不识别 .com 后缀的命令,输入 tree 命令时以为是 tree.exe ,实际上 tree 命令应该是 tree.com 的简写.

我擦,竟然出现乱码,根据我多年的开发经验来看,乱码问题多半是编码问题导致的,那么修改下终端的编码设置应该就能解决问题.

在命令行窗口内右键弹出 mintty 终端的设置页面,选择文本(Text)中本地化(Locale)配置,选择中文简体(zh_CN),字符集(Character set)设置为UTF-8.

瞬间被打脸,无论是原来的git bash 命令行窗口还是新开的命令行窗口,仍然还是乱码!

然而,我是不会承认被打脸的,世人皆醉我独醒,肯定是 bug,哈哈!

其实,中文乱码真的是 bug ,还是官方认可的 bug 哟,我并没有被打脸呢,后续会介绍.

调用 cmd 程序

既然git bash 没有提供 tree 命令,而恰巧 cmd 提供了 tree 命令,那为何不假借他人之手实现自己的目的呢?

cmd 中使用 tree 命令直接输入即可得到目录树结构,但是现在需要在 git bash 中调用 cmd 中的 tree 命令.

# 直接输入 `tree` 命令,正确响应并且无中文乱码.
G:\sublime\test>tree
 工作 的文件夹 PATH 列表
卷序列号为 00000093 CC3C:50D0
G:.
├─cmd
└─git

# 输入 `cmd tree` 命令,虽无报错,但也没有正确响应.
G:\sublime\test>cmd tree
Microsoft Windows [版本 6.3.9600]
(c) 2013 Microsoft Corporation。保留所有权利。

cmd 中直接输入 tree 命令即可,无需通过 cmd tree 这种方式,还以为你要调用 cmd 命令呢!

因此,我们需要告诉git bash 要通过 cmd 去调用下 tree 命令.

# 注意看前缀是 `snowdreams1006@home MINGW64` 表明当前处于 `git bash` 环境
snowdreams1006@home MINGW64 /g/sublime/test
# 输入 `cmd tree` 命令,虽无报错,但也没有正确响应,并且仍然有中文乱码.
$ cmd tree
Microsoft Windows [▒汾 6.3.9600]
(c) 2013 Microsoft Corporation▒▒▒▒▒▒▒▒▒▒Ȩ▒▒▒▒
# 输出 `tree` 命令,正确响应但有中文乱码.此时命令行前缀已经更改为 `G:\sublime\test>` 表明当前不再处于`git bash` 环境!
G:\sublime\test>tree
tree
▒▒ ▒▒▒▒ ▒▒▒ļ▒▒▒ PATH ▒б▒
▒▒▒▒▒к▒Ϊ 0000006B CC3C:50D0
G:.
▒▒▒▒cmd
▒▒▒▒git

通过上述操作结果来看,不难发现以下问题.

  • cmd tree 命令切换到 cmd 环境,并且tree 命令并没有执行.

    换句话说,cmd treecmd dir 或者 cmd 的作用相同,都是切换了当前 bash 环境.

  • 进入 cmd 命令行运行 tree 能够得到正确响应,但存在中文乱码.

  • 想要退出 cmd 环境,Ctrl + C 组合即可重新回到 git bash 环境.

由此可见,不加任何参数冒昧进入到 cmd 环境还是比较麻烦的,因此下面提供带参数的命令帮助我们阅后即焚.

cmd //c tree 命令,阅后即焚,表示执行完立即退出.

snowdreams1006@home MINGW64 /g/sublime/test
$ cmd //c tree
▒▒ ▒▒▒▒ ▒▒▒ļ▒▒▒ PATH ▒б▒
▒▒▒▒▒к▒Ϊ 00000008 CC3C:50D0
G:.
▒▒▒▒cmd
▒▒▒▒git
snowdreams1006@home MINGW64 /g/sublime/test
$

执行命令前后我们都在 git bash 环境并且在 cmd 中得到正确响应结果,唯一的区别就是多加了 //c 参数,表示执行完命令立即退出 cmd 环境.

优雅调用 cmd

简单总结下,如何在 git bash 中借助 cmd 实现 tree 命令.

  • tree.com : 补全调用命令后缀名,直接调用系统命令.

  • cmd //c tree : 借助 cmd 运行 tree 命令,从而实现调用 tree 的目的.

  • 这两种方式都存在中文乱码问题,即使设置了终端的编码方式也没有解决乱码.

调用 tree 命令的目的已经达到,没有解决的问题是中文乱码.

解决问题最快速的方式是百度一下或者从官网寻求帮助,这次我选择后者,因为百度一下人人都会,不用我再讲了吧!

简单解释下这段话的意思:

如果在 mintty 终端调用原生 cmd 程序,简单的输出指令没有什么问题,交互指令可能存在问题. 因此建议使用 winpty 进行包装再调用原生 cmd 程序.

winpty 是一种提供与cmd 通信的软件包,详情请参考https://github.com/rprichard/winpty

有什么神奇之处?不妨加上 winpty 试试看!

snowdreams1006@home MINGW64 /g/sublime/test
# `winpty` + `tree.com` : 正常输出且无中文乱码 
$ winpty tree.com
 工作 的文件夹 PATH 列表
卷序列号为 00000074 CC3C:50D0
G:.
├─cmd
└─git

snowdreams1006@home MINGW64 /g/sublime/test
# `winpty` + `cmd //c tree` : 正常输出且无中文乱码
$ winpty cmd //c tree
 工作 的文件夹 PATH 列表
卷序列号为 000000B3 CC3C:50D0
G:.
├─cmd
└─git

snowdreams1006@home MINGW64 /g/sublime/test
$

果然是神药,一下子就治好了我多年的老寒腿啊!

  • winpty tree.com : 不叫小名而叫全称,直接调用系统命令

  • winpty cmd //c tree : 假借他人之手,变相调用系统命令

上文中说设置文件编码应该能够解决中文乱码问题结果仍然有乱码,猜测是 bug ,现在没有打脸吧?

既然已经提供了解决方案,那文章是不是应该到此为止了呢?

不不不,远远还没结束,这只是开胃小菜,好戏还在后头呢.

更何况这命令也忒长了,记不住啊!

很简单,可以设置别名啊,把常用命令设置成别名,这样就记住啦!

输入 alias 命令没有报错,说明目前环境是支持设置别名的.

snowdreams1006@home MINGW64 /g/sublime/test
$ alias
alias ll='ls -l'
alias ls='ls -F --color=auto --show-control-chars'
alias node='winpty node.exe'

按照 linux 的操作习惯,命令行设置的一般都是临时性的,想要永久生效,都要写入到文件中,别名这种当然要一劳永逸设置成永久文件.

snowdreams1006@home MINGW64 /g/sublime/test
$ cat /etc/bashrc
cat: /etc/bashrc: No such file or directory

snowdreams1006@home MINGW64 /g/sublime/test
$ cat ~/.bashrc
cat: /c/Users/snowdreams1006/.bashrc: No such file or directory

竟然配置文件都不存在?

当然不存在了啊!快醒醒,你是在 Windows 系统上并不是 Linux 系统,上哪给你弄这些配置文件去?

脑海中迅速闪现哲学基本问题: 我是谁,我在那,我在干什么?

我是 Windows 系统用户,正在 git bash 命令行中试图设置别名,没有找到类似于 linux 配置文件.

既然你明白你何出来,那你去那里看看有没有什么发现?

snowdreams1006@home MINGW64 /g/sublime/test
$ cd /e/git
snowdreams1006@home MINGW64 /e/git
$ winpty tree.com
 软件 的文件夹 PATH 列表
卷序列号为 00000063 223E:7300
E:.
├─bin
├─cmd
├─dev
  ├─mqueue
  └─shm
├─etc
  ├─pkcs11
  ├─pki
    └─ca-trust
        ├─extracted
          ├─java
          ├─openssl
          └─pem
        └─source
            └─anchors
  ├─profile.d
  └─ssh
├─mingw64
  ├─bin
  ├─doc
    └─git-credential-manager
  ├─etc
    ├─pkcs11
    └─pki
        └─ca-trust
            └─extracted
                ├─java
                ├─openssl
                └─pem
  ├─lib
    ├─dde1.4
    ├─engines
    ├─itcl4.0.4
    ├─p11-kit
    ├─pkcs11
    ├─reg1.3
    ├─sqlite3.11.0
    ├─tcl8
      ├─8.4
        └─platform
      ├─8.5
      └─8.6
          └─tdbc
    ├─tcl8.6
      ├─encoding
      ├─http1.0
      ├─msgs
      ├─opt0.4
      └─tzdata
          ├─Africa
          ├─America
            ├─Argentina
            ├─Indiana
            ├─Kentucky
            └─North_Dakota
          ├─Antarctica
          ├─Arctic
          ├─Asia
          ├─Atlantic
          ├─Australia
          ├─Brazil
          ├─Canada
          ├─Chile
          ├─Etc
          ├─Europe
          ├─Indian
          ├─Mexico
          ├─Pacific
          ├─SystemV
          └─US
    ├─thread2.7.3
    └─tk8.6
        ├─demos
          └─images
        ├─images
        ├─msgs
        └─ttk
  ├─libexec
    └─git-core
        └─mergetools
  ├─share
    ├─antiword
    ├─doc
      ├─connect
      ├─git-doc
        ├─howto
        └─technical
      └─nghttp2
    ├─gettext-0.19.7
      └─its
    ├─git
      ├─bindimage.txt
      └─completion
    ├─git-core
      └─templates
          ├─hooks
          └─info
    ├─git-gui
      └─lib
    ├─gitweb
      └─static
    ├─licenses
      ├─bzip2
      ├─expat
      ├─gcc-libs
      ├─gettext
        ├─gettext-runtime
          ├─intl
          └─libasprintf
        ├─gettext-tools
          └─gnulib-lib
              └─libxml
        └─gnulib-local
            └─lib
                └─libxml
      ├─libffi
      ├─libiconv
        └─libcharset
      ├─libssh2
      ├─libsystre
      ├─libtasn1
      ├─libtre
      ├─libwinpthread
        └─mingw-w64-libraries
            └─winpthreads
      ├─openssl
      ├─wineditline
      └─zlib
    ├─nghttp2
    ├─p11-kit
      └─modules
    ├─perl5
      └─site_perl
          └─Git
              └─SVN
                  └─Memoize
    └─pki
        └─ca-trust-source
  └─ssl
      └─certs
├─tmp
└─usr
    ├─bin
      ├─core_perl
      └─vendor_perl
    ├─lib
      ├─awk
      ├─coreutils
      ├─gawk
      ├─gnupg
        └─gnupg
      ├─openssl
        └─engines
      ├─p11-kit
      ├─perl5
        ├─core_perl
          ├─auto
            ├─arybase
            ├─attributes
            ├─B
            ├─Compress
              └─Raw
                  ├─Bzip2
                  └─Zlib
            ├─Cwd
            ├─Data
              └─Dumper
            ├─DB_File
            ├─Devel
              ├─Peek
              └─PPPort
            ├─Digest
              ├─MD5
              └─SHA
            ├─Encode
              ├─Byte
              ├─CN
              ├─EBCDIC
              ├─JP
              ├─KR
              ├─Symbol
              ├─TW
              └─Unicode
            ├─Fcntl
            ├─File
              ├─DosGlob
              └─Glob
            ├─Filter
              └─Util
                  └─Call
            ├─GDBM_File
            ├─Hash
              └─Util
                  └─FieldHash
            ├─I18N
              └─Langinfo
            ├─IO
            ├─IPC
              └─SysV
            ├─List
              └─Util
            ├─Math
              └─BigInt
                  └─FastCalc
            ├─MIME
              └─Base64
            ├─mro
            ├─NDBM_File
            ├─ODBM_File
            ├─Opcode
            ├─PerlIO
              ├─encoding
              ├─mmap
              ├─scalar
              └─via
            ├─POSIX
            ├─re
            ├─SDBM_File
            ├─Socket
            ├─Storable
            ├─Sys
              ├─Hostname
              └─Syslog
            ├─threads
              └─shared
            ├─Tie
              └─Hash
                  └─NamedCapture
            ├─Time
              ├─HiRes
              └─Piece
            ├─Unicode
              └─Collate
            ├─Win32
            ├─Win32API
              └─File
            └─Win32CORE
          ├─B
          ├─Compress
            └─Raw
          ├─CORE
          ├─Data
          ├─Devel
          ├─Digest
          ├─Encode
            ├─CN
            ├─JP
            ├─KR
            ├─MIME
              └─Header
            └─Unicode
          ├─File
            └─Spec
          ├─Filter
            └─Util
          ├─Hash
            └─Util
          ├─I18N
          ├─IO
            └─Socket
          ├─IPC
          ├─List
            └─Util
          ├─Math
            └─BigInt
          ├─MIME
          ├─PerlIO
          ├─Scalar
          ├─Sub
          ├─Sys
          ├─threads
          ├─Tie
            └─Hash
          ├─Time
          ├─Unicode
            └─Collate
          └─Win32API
        └─vendor_perl
            ├─auto
              ├─HTML
                └─Parser
              ├─Net
                └─SSLeay
              ├─SVN
                ├─_Client
                ├─_Core
                ├─_Delta
                ├─_Fs
                ├─_Ra
                ├─_Repos
                └─_Wc
              └─Term
                  └─ReadKey
            ├─HTML
            ├─Net
              └─SSLeay
            ├─SVN
            └─Term
      ├─pkcs11
      ├─sasl2
      ├─ssh
      ├─tar
      └─terminfo
          ├─63
          ├─64
          └─78
    ├─libexec
    ├─share
      ├─bash-completion
        └─completions
      ├─cygwin
      ├─git
      ├─gnupg
      ├─licenses
        ├─curl
        ├─dos2unix
        ├─expat
        ├─file
        ├─gcc-libs
        ├─libffi
        ├─libsasl
        ├─libsqlite
        ├─libssh2
        ├─mintty
        ├─ncurses
        ├─openssh
        ├─openssl
        ├─p11-kit
        ├─perl-Net-SSLeay
        ├─perl-TermReadKey
        ├─unzip
        ├─vim
        └─zlib
      ├─misc
      ├─p11-kit
        └─modules
      ├─perl5
        ├─core_perl
          ├─App
            └─Prove
                └─State
                    └─Result
          ├─Archive
            └─Tar
          ├─Attribute
          ├─autodie
            ├─exception
            └─Scope
          ├─B
          ├─Carp
          ├─Class
          ├─Compress
          ├─Config
            └─Perl
          ├─CPAN
            ├─Exception
            ├─FTP
            ├─HTTP
            ├─Kwalify
            ├─LWP
            ├─Meta
            └─Plugin
          ├─DBM_Filter
          ├─Devel
          ├─Digest
          ├─Encode
          ├─encoding
          ├─Exporter
          ├─ExtUtils
            ├─CBuilder
              └─Platform
                  └─Windows
            ├─Command
            ├─Constant
            ├─Liblist
            ├─MakeMaker
              └─version
            ├─ParseXS
            └─Typemaps
          ├─File
          ├─Filter
          ├─Getopt
          ├─HTTP
          ├─I18N
            └─LangTags
          ├─IO
            ├─Compress
              ├─Adapter
              ├─Base
              ├─Gzip
              ├─Zip
              └─Zlib
            ├─Socket
            └─Uncompress
                └─Adapter
          ├─IPC
          ├─JSON
            └─PP
          ├─Locale
            ├─Codes
            └─Maketext
          ├─Math
            ├─BigFloat
            └─BigInt
          ├─Memoize
          ├─Module
            ├─CoreList
            └─Load
          ├─Net
            └─FTP
          ├─overload
          ├─Params
          ├─Parse
            └─CPAN
          ├─Perl
          ├─PerlIO
            └─via
          ├─Pod
            ├─Perldoc
            ├─Simple
            └─Text
          ├─Search
          ├─TAP
            ├─Formatter
              ├─Console
              └─File
            ├─Harness
            └─Parser
                ├─Iterator
                ├─Result
                ├─Scheduler
                ├─SourceHandler
                └─YAMLish
          ├─Term
          ├─Test
            ├─Builder
              ├─IO
              └─Tester
            ├─Tester
            └─use
          ├─Text
          ├─Thread
          ├─Tie
          ├─Time
          ├─Unicode
            └─Collate
                └─CJK
          ├─unicore
            ├─lib
              ├─Age
              ├─Alpha
              ├─Bc
              ├─BidiC
              ├─BidiM
              ├─Blk
              ├─Bpt
              ├─Cased
              ├─Ccc
              ├─CE
              ├─CI
              ├─CompEx
              ├─CWCF
              ├─CWCM
              ├─CWKCF
              ├─CWL
              ├─CWT
              ├─CWU
              ├─Dash
              ├─Dep
              ├─DI
              ├─Dia
              ├─Dt
              ├─Ea
              ├─Ext
              ├─Gc
              ├─GCB
              ├─GrBase
              ├─Hex
              ├─Hst
              ├─Hyphen
              ├─IDC
              ├─Ideo
              ├─IDS
              ├─In
              ├─Jg
              ├─Jt
              ├─Lb
              ├─LOE
              ├─Lower
              ├─Math
              ├─NChar
              ├─NFCQC
              ├─NFDQC
              ├─NFKCQC
              ├─NFKDQC
              ├─Nt
              ├─Nv
              ├─PatSyn
              ├─PatWS
              ├─Perl
              ├─QMark
              ├─SB
              ├─Sc
              ├─Scx
              ├─SD
              ├─STerm
              ├─Term
              ├─UIdeo
              ├─Upper
              ├─WB
              ├─XIDC
              └─XIDS
            └─To
          ├─User
          ├─version
          ├─warnings
          └─Win32API
              └─File
        └─vendor_perl
            ├─Authen
              └─SASL
                  └─Perl
            ├─Convert
            ├─Date
              └─Language
            ├─Encode
            ├─Error
            ├─File
            ├─HTML
            ├─HTTP
              ├─Cookies
              ├─Headers
              └─Request
            ├─IO
              └─Socket
                  └─SSL
            ├─LWP
              ├─Authen
              └─Protocol
            ├─Mail
              ├─Field
              └─Mailer
            ├─MIME
              ├─Decoder
              ├─Field
              └─Parser
            ├─Net
              ├─HTTP
              └─SMTP
            ├─Time
            ├─URI
              ├─file
              └─urn
            └─WWW
                └─RobotRules
      ├─pki
        └─ca-trust-source
      ├─tabset
      ├─terminfo
        ├─63
        ├─64
        └─78
      └─vim