例如,我一直看到称为String#split的方法,但从未见过String.split,这似乎更合乎逻辑。或者甚至可能是String::split,因为您可以认为#split位于String的命名空间中。当假定/隐含类(#split)时,我什至单独看到了该方法。我知道这是ri中识别方法的方式。哪个先出现?例如,这是为了区分方法和字段吗?我还听说这有助于区分实例方法和类方法。但这从哪里开始呢? 最佳答案 不同之处在于您如何访问这些方法。类方法使用::分隔符来表示消息可以发送到类/模块对象,而实例方法使用#分隔符表示消息可以发送到实例对
上周,在一些gem安装或gem更新操作中,我收到了与这些类似的错误:ERROR:Whilegeneratingdocumentationforsinatra-1.3.1...MESSAGE:errorgeneratingC:/RailsInstaller/Ruby1.9.2/lib/ruby/gems/1.9.1/doc/sinatra-1.3.1/rdoc/README_de_rdoc.html:incompatibleencodingregexpmatch(UTF-8regexpwithIBM437string)(Encoding::CompatibilityError)类似的:E
我使用bdoc(使用hanna进行格式化)作为查看我系统上安装的gem的rdoc文档的快速方法。但是,因为bundler在安装gem时不会安装rdoc,所以每当我开始使用新gem或更新现有gem时,我都必须不断地手动生成它们。有谁知道在安装gems时是否有配置bundler让它安装rdoc的方法,以避免我必须手动进行?我在bundler源代码中和configmanual中都看不到任何提及。. 最佳答案 如果你使用rvm,试试“rvmrdocsgenerate...” 关于ruby-Bun
例如,$geminstallnetaddrFetching:netaddr-1.5.1.gem(100%)Successfullyinstallednetaddr-1.5.1ERROR:Whileexecutinggem...(NoMethodError)undefinedmethod`reset'forRDoc::TopLevel:Class当我安装任何新的gem时,NoMethodError异常不断出现。我用谷歌搜索并搜索了RDoc和RubyGemsGitHub存储库中的问题,但一无所获。我的Ruby版本是$ruby-vruby2.3.0p0(2015-12-25revision5
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Howtomake--no-ri--no-rdocthedefaultforgeminstall?我从不使用ri或rdoc,它们的安装时间太长。有没有什么地方可以让我这样做的配置文件
Rubyinside提到ablogpost关于如何通过不安装RI或RDoc来加速gem安装。是否可以安装一个gem并在以后安装文档,这样您就可以快速破解RTFM并从容应对? 最佳答案 >gemhelprdocUsage:gemrdoc[args][options]Options:--allGenerateRDoc/RIdocumentationforallinstalledgems--[no-]rdocIncludeRDocgenerateddocuments--[no-]riIncludeRIgenerateddocuments-
我可以sudogemrdocactiverecord--no-ri和sudogemrdocactionpack--no-ri两者都给我很好的文档。但是sudogemrdocrails--no-ri几乎没有给我任何东西,因为Railsgem本身实际上只是其他gem的持有者。我怎样才能生成相当于http://api.rubyonrails.org/的? 最佳答案 sudogemrdoc--all--overwrite 关于ruby-on-rails-如何为(所有)Rails生成RDOC?,我
我在多个位置安装了多个gem。生成/重新生成的困难/简单方法是什么:所有这些已安装的gem的rdoc,一次全部?所有这些已安装的gem的yardoc,一次全部? 最佳答案 你试过其中之一吗?gemrdoc--allgemrdoc--all--overwrite 关于ruby-如何为所有已安装的gem重建rdoc?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/3152857/
似乎很多库/插件都使用这种语法:defself.included(base)#:nodoc:base.extendClassMethodsend为什么:nodoc:部分是必需的? 最佳答案 没有必要。如果应用于一个类,它只会抑制类扩展中所有方法的文档(rdoc)。在ProgrammingRuby中描述为::nodoc:-Don'tincludethiselementinthedocumentation.Forclassesandmodules,themethods,aliases,constants,andattributesdir
如果我错了请纠正我,是YARD与RDoc不同?它不是基于RDoc,而是完全重写?所以如果我使用YARD,我就不必为RDoc而烦恼,对吧? 最佳答案 简而言之:是的。(针对所有三个问题。)请注意,YARD在很大程度上与RDoc向后兼容,至少就标记而言是这样。(RDoc插件OTOH不适用于YARD。)因此,您实际上可以使用YARD来处理遗留RDoc文件。YARD主要是RDoc的适当超集。 关于ruby-YARD和RDoc不一样?,我们在StackOverflow上找到一个类似的问题: