gpt4 book ai didi

node.js - 关于自定义 node.js CLI 工具配置文件的建议/最佳实践 : location & naming?

转载 作者:搜寻专家 更新时间:2023-10-31 22:24:24 26 4
gpt4 key购买 nike

我会尽量让这个问题简短,但它分为两部分,请:

  1. nodejs/npm CLI 工具的配置文件应该保存在哪里?
  2. 他们应该叫什么?

假设我编写了一个 node.js CLI 工具,例如,它可以获取今天的天气并将其显示在终端中。我称它为 weather-getter。请注意,主要目标是不是以编程方式调用,而是像 BASH 一样输入终端。它旨在通过在全局安装后键入其简单名称来运行,通过用户本地/bin 中的目录。 (安装不需要 Sudo。)

该项目将通过 npm 正常安装。它可以通过如下参数接收邮政编码:

gavin@localhost:~$ weather-getter -z "12345"

好的,程序可以像这样正常工作。我的下一步是允许用户在某处 保存一个配置文件,并从该配置文件中提取默认值。类似于 .vimrc 文件。此配置可能如下所示:

{
"zipcode": "12345",
"language": "en",
"unit": "fahrenheit"
}

我想它应该以点开头。我还认为它应该位于 npm 模块安装中,而不是 ~/。或者我应该考虑使用 ~//etc/~/.config~/.local 之类的许多其他程序? Node 程序是否应该尝试使用公共(public)目录,例如 ~/.config/node/~/.config/npm/?如果文件在那里,它是否应该在没有点的情况下开始?

注意:我的问题不是关于用 node.js 读/写文件,只是关于配置位置和命名约定的建议。谢谢!

最佳答案

由于这是安装到系统路径中的通用 CLI 应用程序(恰好在 Node.js 中实现),您应该遵循为目标操作系统建立的最佳实践或规则。

Unix/Linux/OS X,类似

按照优先顺序,这些将是(但不限于):

  • ~(用户的主文件夹)- 许多程序将用户级配置存储在它们的主目录中,通常在以点为前缀的文件中,后跟应用程序的名称(或类似名称)-即 ~/.weather-getter

  • /usr/local/etc, /etc - 系统级配置文件。这些通常适用于系统中的所有用户,因此优先级低于主文件夹中的设置。这两个 etc 路径的区别通常是前者用于用户安装的程序,而后者用于系统级程序(对于使用 Homebrew 的 Mac 用户尤其如此)。然而,这种区别并不总是得到尊重,因此应该检查两个位置的配置文件(最好使用具有较低优先级的 /etc 目录)。

  • 您的应用程序的根 - 这些应该是您的应用程序的默认设置,当没有找到用户或系统配置时的回退。

  • 如果需要,可以考虑其他地点。

window

如果您的应用允许 GUI 或至少 CLI 配置管理,或者 Windows 注册表(例如,使用 winreg),这通常位于 %APPDATA% 目录中的某个位置。我个人在 Windows 开发/CLI 方面的经验很少,因此欢迎就此主题发表任何进一步的评论或回答。我相信使用用户的主文件夹也是可以接受的,只要该文件可以被标记为隐藏(这样它就不会使 View 困惑)。

一些一般注意事项

  • 许多 CLI 应用程序将其默认配置安装到上述位置之一,以便用户在配置您的应用程序时有一个良好的起点
  • 当存在多个配置文件时如何处理配置选项(它们是否按某种顺序合并?只使用一个?哪个优先?)完全取决于您,但您应该在文档中明确说明,甚至可能在配置文件中提到它
  • 如果您的应用程序需要多个配置文件,最好将它们分组在自己的文件夹中

关于点文件的更新

某些文件或文件夹以点为前缀的原因是为了在用户的正常 View 中隐藏它们(即当通过 GUI 浏览它们的主目录时)。因此,通常的做法是在用户通常操作的目录中存储配置文件时使用点前缀的文件/文件夹名称,但在系统级文件夹中存储配置文件时这样做。

关于node.js - 关于自定义 node.js CLI 工具配置文件的建议/最佳实践 : location & naming?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28708037/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com