草庐IT

CLASS_EXISTS

全部标签

ruby - `File::exist?` 和 `File::exists?` 之间的区别

关于ruby-doc,File::exist?和File::exists?的文档条目以不同的语义重复:一个条目说returnstrueiffile_name是一个目录;另一个说如果file_name是一个文件,则返回true。我认为这两个条目都不正确。这两种方法似乎都在file.c中实现使用rb_file_exist_p,如果传递的值是一个IO,它似乎会尝试调用fstat(),如果它是一个字符串,则似乎会尝试调用stat().fstat()和stat()都返回0成功和-1错误,这是通过返回到rb_file_exist_p,并转为bool结果。在我看来有两种方法可以使代码更容易阅读;没有

ruby-on-rails - ruby /rails : Reopening vs Overwriting a Class

我想向Rails模型添加一个方法,用于测试。如果我这样做classModeldefsomething_newdo_somethingendend在Rails控制台或在运行时加载的文件中,模型被覆盖而不是被修改。如果我在上面的行之前放置类似v=Model.class的内容,新方法将成功添加到现有类中。显然需要引用来表示现有类(class)正在重新开放。另一方面,可以向Fixnum添加一个方法,而无需首先引用它。这是怎么回事,确保现有类被重新打开和修改而不是被覆盖的通常方法是什么?谢谢。 最佳答案 听起来你在使用它之前不需要这个类。当您

ruby-on-rails - rails : rbenv rehash not working (rbenv-shim exists)

我正在尝试在安装新gem后重新哈希rbenv它在我的ubuntu服务器上给了我这些错误rbenv:cannotrehash:/home/deployer/.rbenv/shims/.rbenv-shimexists但是.rbenv-shims不存在 最佳答案 可能是issuewithdirectorypermissions@sstephenson/rbenv:FWIW-Ialsohadthisproblem,andhadtochangepermissionsonthedirwhereitwascheckingforthe.rbenv

ruby - 是否可以让 class.property = x 返回 x 以外的东西?

假设我有一个Ruby类:classMyClassdefself.propertyreturn"someVal"enddefself.property=(newVal)#dosomethingtoset"property"success=truereturnsuccess#successisabooleanendend如果我尝试执行MyClass.property=x,整个语句的返回值始终是x。许多基于C/受启发的语言都习惯于返回bool“成功”值-是否可以使用Ruby中的“等于语法”为setter执行此操作?此外-如果这不可能,为什么不呢?允许“equalssetter”操作返回一个值

ruby-on-rails - rails : How to test if an attribute of a class object is required in the model policy?

简单地说,我有一个模型用户,其中包含名称、电子邮件和评论作为属性。validates_presence_of:namevalidates_presence_of:email所以“姓名”和“电子邮件”是必需的,但不是“评论”。my_user=User.new我想找到一种方法来测试像my_user.name.required?或User.name.required?类似的东西。我的目标是创建一个表单,并根据该项目是否设置为“validates_presence_of”,将特定类动态添加到表单项目span或td我试图搜索它,但没有找到任何相关信息。有没有简单的方法可以做到这一点?谢谢

ruby - Rubocop 错误 'Class definition is too long ruby'

我收到rubocop错误“类定义太长。[236/100]'。我的类(class)如下所示:classSomeClassNameincludeHelperModuleattr_accessor:aaa,:bbb,:ccc....methods.....end可能会出现什么问题?rubocop文档ClassLength说“一个类(class)的长度超过了某个最大值”。什么意思? 最佳答案 是的,这是因为rubucop认为整体线路太多。我同意类(class)不应该太长,但认为最终应该由以下因素决定:类(class)是否有单一职责,方法是否

ruby - alias_method 和 class_methods 不混合?

我一直在尝试修补全局缓存模块,但我不明白为什么它不起作用。有人有什么建议吗?这是错误:NameError:undefinedmethod`get'formodule`Cache'from(irb):21:in`alias_method'...由此代码生成:moduleCachedefself.getputs"original"endendmoduleCachedefself.get_modifiedputs"Newget"endenddefpeek_a_booCache.module_evaldo#make:get_not_modifiedalias_method:get_not_mo

ruby-on-rails - Capistrano::Configuration:Class 的未定义方法 `instance'

我正在尝试在Rails应用程序中首次启动并运行Capistrano。我有一台运行Ubuntu12.04、nginx、unicorn和rails的linux服务器,但是,我似乎遇到了一些问题。我还使用RVM使用Capistrano3.0.0、rails3.2.14、bundler1.4.0和ruby​​1.9.3p448。我只设置了一个生产阶段,此时我只关心Capistrano与我的服务器通信并从github推送我的代码(目前还没有迁移和捆绑等)。当我使用下面的设置尝试命令capproductiondeploy:check或capproductiondeploy:setup(这似乎已被弃

Ruby 动态类。如何修复 "warning: class variable access from toplevel"

我正在尝试编写一个程序,根据从文件中读取的配置动态定义ruby​​类。我知道我可以使用Class.new来做到这一点。这是一个示例程序:x=[1,2,3]Test=Class.newdo@@mylist=xdeffooputs@@mylistendendTest.new.foo当我运行它时,我得到以下输出(使用ruby​​1.9.3p0运行):c:/utils/test.rb:4:warning:classvariableaccessfromtoplevelc:/utils/test.rb:7:warning:classvariableaccessfromtoplevel123Does

Ruby class_eval 方法

我正在尝试弄清楚如何动态创建方法classMyClassdefinitialize(dynamic_methods)@arr=Array.new(dynamic_methods)@arr.each{|m|self.class.class_evaldodefm(*value)putsvalueendend}endendtmp=MyClass.new['method1','method2','method3']不幸的是,这只会创建方法m但我需要根据m的值创建方法,想法? 最佳答案 有两种可接受的方式:使用define_method:@a