# @melody-core/melody-cli

@melody-core 组织是一个年轻团队组成的开源组织,寓意旋律之主。@melody-core/melody-cli 是由组织内@六弦 @wxydesign 开发的命令行集成管理工具,它的能力来源于它集成的外部套件。

一个强大的、便捷的命令行集成管理工具,支持插拔式的命令工具集成,拥有完善的文档,支持自定义套件开发与集成。

# 特性

  • 自动化管理自身 - 每次运行 melody-cli 时,它会告诉你是否需要更新它。
  • 插拔式管理套件 - 方便的集成和管理套件。
  • 关注点分离 - melody-cli 与套件之间几乎是完全解耦的,每个套件都可以是独立的。
  • 便捷自由的套件开发 - 如果你想开发一个套件,建议直接使用 leo 的 cli 套件模板哦。

# 背景故事

小明是某大厂的程序员,他善于使用各种命令行工具来实现他的某些需求———但随着公司以及社区的命令行工具安装的越来越多,他开始烦恼于如何记忆他们、管理他们; 而小明正在烦恼的时候,却不知道隔壁业务线又产出了新的命令行工具。

  • 小明期望有一个统一的入口,来集成和管理所有命令
  • 小明期望能方便的统一观察所有公司内产出的命令行工具,而不是单独的一个个了解它们

而小明期望的,就是@melody-core/melody-cli 的存在意义。

# 快速使用

node 版本支持: >=8.0.0 本地需要安装 yarn

    # 安装
    yarn global add @melody-core/melody-cli
    # 运行 melody 命令 即可查看帮助和文档

# 概念

# 命令行管理工具

melody-cli,是用来管理命令行工具的命令行工具。这么说可能有点绕,也许下面的两个例子可以让你明白:

@melody-core/leo 是旋律组织开发的模板脚手架命令工具,它的作用是快速生成项目——类似”create-raect -app“、”@vue/cli“,但@melody-core/leo 集成的模板更加丰富,因为它的模板是不断增加的。

    #  @melody-core/leo 可以单独安装使用,但也可以将其作为melody-cli的一个套件;
    # 我们可以通过 melody search 或者 melody search @melody-core/leo来获取到leo的信息
    melody search
    # 安装套件
    melody install @melody-core/leo
    # 即可使用套件
    melody leo

http-server 是一个比较知名的开源包,我们经常使用它来启动一个 http-server 服务。

    # 它当然也可以作为melody的套件。我们首先安装它
    melody install http-server
    # 这时我们运行melody发现, 已经拓展了http-server命令
    melody

    🎵 @melody-core/melody-cli版本检索完毕, 已是最新版本: 1.0.13
    Usage: melody [options] [command]

    Options:
    -V, --version      output the version number
    -v, --version      查看当前版本
    -h, --help         display help for command

    Commands:
    search             列出官方所有套件
    list               列出已安装的套件列表
    install <package>  安装套件
    remove <package>   删除套件
    update [package]   更新套件
    desc  <package>    更改套件描述
    leo                初始化项目的脚手架命令工具
    http-server        未知套件, 您可以通过命令 melody des \<pluginName\> \<description\> 来更改它的描述
    help [command]     display help for command

    # 我们可以更改对它的描述以便对它进行管理
    melody desc http-server

    > 用来启动http服务的套件。
    # 我们可以通过 melody http-server来运行它的相关功能
    melody http-server -h

    # 在当前目录下启动一个http-server服务。
    melody http-server -c

# 套件

每个符合 melody-cli 套件规范的 npm 包,都可以被视作为它的套件。套件可以理解为插件,可以扩展 melody 的命令,从而扩展 melody 的功能。

例如 @melody-core/leo

而每个套件都是独立的 npm 包,因此它们当然也可以被单独安装使用。

    # 单独安装 @melody-core/leo
    yarn global add @melody-core/leo
    # 使用它
    leo

然而就像背景里讲的那样,我们为了方便集成管理,更期望用一个统一的入口去集成所有的命令,这让我们可以更方便的管理所有包,更可以随时了解组织内产出的包。

# 套件类别

为了更方便的管理套件,我们给每个套件定义一个类别,方便用户们进一步分类和了解该套件。

# 基础命令

命令 描述 具体使用 补充
melody search 查询官方套件列表 melody search 列出所有 melody-cli 官方套件
melody list 查询已安装套件列表 melody list 列出所有已安装的套件
melody install 安装套件 melody install <package> package 必填,例:melody install @melody-core/leo
melody remove 删除套件 melody remove <package> package 必填,例:melody remove @melody-core/leo
melody update 更新套件 melody update [package] 不填参数时,默认更新所有 melody-cli 套件
melody desc 更改套件的描述 melody desc <package> package 必填, 例: melody desc http-server

# 官方套件

运行命令 melody search 即可查看所有官方命令行套件哦

命令 描述 具体使用 补充
@melody-core/leo leo 生成模板的脚手架命令 melody leo [command][options] 一个便捷集成和管理项目模板的脚手架命令行工具

# 外界套件

理论上任何全局包,都可以作为 melody 的插件。 比如 http-server 是一个启动 http-server 服务的包,我们可以通过 melody 去安装/管理/使用它

    # 安装
    melody install http-server
    # 查看命令里 已拓展了http-server
    melody -h
    # 查看http-server的使用帮助
    melody http-server -h

    # 我们可以给它加一个描述
    melody desc http-server
    >请输入对http-server的描述:
    : 用来启动http服务的包。

    # 当前目录下使用它启动一个http-server服务
    melody http-server -c

# 自定义套件/套件开发

# 套件开发

你可以自由的开发自定义套件并在 melody-cli 中集成它,我们为您提供了 melody-kit-template 模板,您可以用过 leo 来选择它快速生成您的项目

   # 前置,安装了leo套件,并且在联网环境(为了拉下模板)。
   melody leo init
   # 此处选择  melody-plugin-template 即可。

# 使用开发模式来调试您的套件

在你进入了项目的根目录后,即开启 melody 套件开发模式

    # 前置,在自定义套件项目的根目录下
    node ./index.js
    # 这时候你就能在test命令分类下查看到您自定义的套件命令,并可以运行它

# 发布套件

    # 套件项目根目录下运行:
    melody publish

# 开发文档

# commander

如果你想开发套件,甚至参与 melody-cli 的开发,建议你先玩一下 commander,因为 melody-cli 和套件原则上都是基于它开发的。
它的官方文档地址: https://github.com/tj/commander.js/blob/HEAD/Readme_zh-CN.md