我正在阅读Ruby的"man"页面,我看到了下面对"-S"旗帜的描述:

-S   Makes Ruby use the PATH environment variable to search for script, unless its name begins with a slash.  This is used to emulate #! on
     machines that don't support it, in the following manner:

           #! /usr/local/bin/ruby
           # This line makes the next one a comment in Ruby \
           exec /usr/local/bin/ruby -S $0 $*

     On some systems $0 does not always contain the full pathname, so you need the -S switch to tell Ruby to search for the script if necessary
     (to handle embedded spaces and such).  A better construct than $* would be ${1+"$@"}, but it does not work if the script is being
     interpreted by csh(1).

让我感到困惑的是这一部分:

# This line makes the next one a comment in Ruby \
exec /usr/local/bin/ruby -S $0 $*

这听起来像是man条目的意思是,\字符导致它后面的行将被视为注释.

为了测试这一点,我try 创建了一个名为"foo.rb"的新Ruby脚本,其中包括这两行代码和一个简单的"PUTS"语句:

# This line makes the next one a comment in Ruby \
exec /usr/bin/env ruby -S $0 $*

puts "Hi"

我将脚本从/usr/local/bin/ruby更改为/usr/bin/env ruby,因为我没有位于/usr/local/binruby可执行文件.我认为这不应该以一种有意义的方式影响结果,因为(根据文档)该行应该被视为注释,而不是可执行代码.

如果我对man条目的解释是正确的,那么当我运行"ruby foo.rb"时,我希望看到Hi输出到终端.但事实并非如此.相反,我看到了以下几点:

$ ruby foo.rb
foo.rb:2: unknown regexp option - b
exec /usr/bin/env ruby -S $0 $*
foo.rb:2: syntax error, unexpected local variable or method, expecting `do' or '{' or '('
exec /usr/bin/env ruby -S $0 $*
foo.rb:2: syntax error, unexpected global variable, expecting `do' or '{' or '('
exec /usr/bin/env ruby -S $0 $*

我做错了什么?

推荐答案

看起来Ruby手册页的这一特定部分严重过时了.事实上,它最初被添加到Ruby的(当时的)SVN库中.

当时,Ruby的解析器显然在注释末尾使用反斜杠进行了indeed support次行连续操作,如手册页的语法示例所示.

然而,这个特性于1999年3月2日从Ruby中移除(差异相当大,默认情况下不会在GitHub中呈现;请查看parse.y文件的第2433行).

更改的ChangeLog entry为:

Tue Mar  2 17:04:19 1999  Yukihiro Matsumoto  <matz@netlab.co.jp>

    * parse.y (yylex): backslashes do not concatenate comment lines
      anymore.

此更改是在1999年8月随Ruby 1.4.0发布的.从那时起,也就是24多年前,手册页中的示例不再有效.

后来的(但仍然相当旧的)文档suggests a different approach:

#!/bin/sh
exec ruby -S -x $0 "$@"
#! ruby
puts 'Hello World'

在这里,总是执行exec,并且您仍然使用-S标志来执行Ruby解释器中的当前文件.然而,我们也使用-x标志,它指示Ruby跳过文件中的所有行,直到它找到包含#!ruby(或显然是#! ruby)的行.这在今天仍然有效.

Ruby相关问答推荐

如何用 yield_self 断链

如何在 Ruby 中验证来自多项 Select 提示的命令行输入?

回声ABC | ruby -p -e "sub('a','A').sub('b', 'B')": 为什么不是 "ABc"?

Procs的绑定

Sinatra 与 EventMachine WebSockets 一起工作是否成功?

Ruby 中的内联注释

冒号:和粗箭头=>有什么区别

我在哪里可以找到积极开发的 Ruby lint 工具?

使用 Bundler 时,为什么要关心 RVM 的 Gemset 功能?

如何拯救 Ruby 中的 eval?

来自 Linux 上的命令队列的并行处理(bash、python、ruby ......随便)

判断 Ruby HTTP 响应是否成功

符号到字符串问题

使用 `?`(问号)在 Ruby 中获取 ASCII 字符代码失败

在本地覆盖 Vagrant 配置设置(每个开发人员)

Ruby 异常 - 为什么是else?

如何计算Ruby日期的星期几?

Ruby:如何为数组和哈希制作 IRB 打印 struct

将字符串与Ruby中的数字连接起来

严格将字符串转换为整数(或 nil)