我正在编写大量的 Bash 函数,这些函数能够从使用位置参数或命名参数(由 提供getopts
)传递的命令行获取不同的信息。这个想法是位置参数主要用于快速和直接的人工控制,而命名参数主要用于其他功能的清晰度和控制。为了说明我的想法,考虑一个可以从一件事转换为另一件事的函数。从广义上讲,可以在快速模式或高级模式中使用此功能。在快速模式中,指定的参数很少,通常是位置参数,而在高级模式中,可以指定许多参数,通常是命名参数。举些例子...
快速模式
可以通过以下方式使用此模式:
function fileName1 fileName2
它使用内部假设和自主进行的测量将一个文件转换为另一个文件。
高级模式
可以通过以下方式使用此模式:
function -i fileName1 -o fileName2 -m -r 100 -v
此模式也可以通过以下方式使用:
function -m -v fileName1 fileName2 -r 100
请注意,-v
不接受任何参数。它只是一个选项(指定诸如详细程度之类的内容)。
因此,这种情况下的逻辑是假定第一个位置参数是,fileName1
并且假定第二个位置参数是,fileName2
除非使用-i
or-o
选项指定这些文件名中的任何一个,在这种情况下使用它们是因为它们是给定的更高的优先级(忽略第一个和第二个位置参数)。
我要求以尽可能一般的方式实现这些类型的需求的建议和指导,因为这种方法将应用于包含 150 多个函数的库。