Today's the day

思考,自知,耐心

在插件中添加 Controller

原来以为,通过插件添加新的 Controller 很难,其实非常简单,只要建个 xxx.controller.rb 文件,然后在里面按照普通的方式定义这个 Controller:

  1. class XxxController < ActionController::Base
  2.    
  3.     ....
  4.  
  5. end

然后在插件的 init.rb 里 require 这个文件就可以了……

再按照自己喜欢的格式添加个 route:

  1. class ActionController::Routing::RouteSet
  2.   unless (instance_methods.include?('draw_with_xxx'))
  3.     class_eval <<-"end_eval", __FILE__, __LINE__
  4.       alias draw_without_xxx draw
  5.       def draw_with_xxx
  6.         draw_without_xxx do |map|
  7.           map.connect '/xxx/do_xxx', :controller => 'xxx', :action => 'do_xxx'
  8.           yield map
  9.         end
  10.       end
  11.       alias draw draw_with_xxx
  12.     end_eval
  13.   end
  14. end

搞定收工~

单机版进展 50%

小看这个工作了,比想象中工作量要大很多,现在这个 Chito 可以说是为了 is-Programmer 而写的,很多地方都对 is-Programmer 特殊化了,比如首页和注册登录界面,现在是拿了一个单独的 Controller 来实现首页,单机版肯定不能这样搞。

单用户和多用户合并在一起,也比预想中要麻烦,毕竟单用户只针对一个固定用户,而多用户要从当前的二级域名中得到当前的用户,得到当前用户的方式要区分。地址的生成也不同,多用户模式下必须生成完整的带有二级域名的地址,都快被这些东西搞晕了……

无可避免的,用户得选择一下用户模式,多用户的话还得填写一下根域名,希望不会让使用的人困扰……

Passenger (mod_rails for Apache) launches

起床后在 DHH 那里看到这篇文章,大喜~   随后转到了 Passenger 的官方网站,上面的简介:

Phusion Passenger — a.k.a. mod_rails — makes deployment of applications built on the revolutionary Ruby on Rails web framework a breeze. It follows the usual Ruby on Rails conventions, such as “Don’t-Repeat-Yourself”.

  • Deployment is only a matter of uploading application files. No Ruby on Rails-specific server configuration required!
  • Built on the industry standard Apache web server.
  • Allows Ruby on Rails applications to use about 33% less memory, when used in combination with Ruby Enterprise Edition (optional).
  • Zero maintenance. No port management, server process monitoring or stale file cleanup required. Errors are automatically recovered whenever possible.
  • Designed for performance, stability and security. Passenger should never crash Apache even in case of crashing Rails applications.
  • Well-documented, for both system administrators and developers!

岂不以后可以像部署 php 那样轻松的在 Apache 上部署 rails 的网站了,不用配置复杂的配置文件,只需像 php 那样上传你的 rails 程序即可~

官方声称速度比 Mongrel 稍快,不过部署的便捷性才是 Passenger 的重点,如果 Passenger 在安全性、稳定性之类的都没问题的话,凭借着 Apache 的占有率,对 Rails 肯定是个不错的推广,也许会有很多主机商推出 Rails 空间吧~ 想拿 Rails 赌一把的,现在着手尝试搞个基于 Passgenger 的 Rails 主机也不错~

有人已经尝试了,安装和配置很简单,运行的效果和原来无异( 那是当然…… )。

官方还有视频指导,感兴趣的朋友可以去看看~

教训唉

昨天晚上回 Windows 下看了个电影,然后重启回 Linux 发现进不去了,竟然是 Kernel Panic,LiveCD 启动,重新编译内核无数次、检查磁盘、上网查…… 搞了一个晚上,最后发现是忘记看 grub 的升级信息,把 grub 重新 setup(hd0) 一下,就 OK 了……

吸取教训了,原来对不看升级信息的后果太低估了,以为最多是个软件没发启动什么的,到时候再搞一下就好了,哪想到会连机都启动不了……

不过昨天这解决问题的过程还是值得肯定的,重编译内核无果,就排除了内核;LiveCD 下可以查看磁盘,磁盘检查也没错,就排除了硬盘;最后用 LiveCD 的 grub 启动,发现可以,这才确定问题在 grub 上,lyanry 一提醒,果然是 grub,问题才解决~

要是一开始不仔细分析错误,直接重装的话,也许可以解决问题,但是永远也不会知道问题出在哪里了,以后再出现这个问题还是没辙,还会浪费大量时间安装和恢复环境,其实硬盘根本就没有问题~

FCKEditor 2.6 终于发布了~

FCKEditor 终于发布了 2.6 的正式版,相对上次的 RC 版没有改动,白等了这么久……

尝试了一下,新的浮动窗口效果不错,速度快了很多。除了代码高亮的插件还有点问题,其他的插件运行非常正常~

这两天就更新上来~

犯迷糊了: 对 && 的错误理解

&& 符号在 Ruby 中不仅仅是逻辑运算符 and,而且还常常拿来连接语句的执行,比方说:

  1. @user = User.find(params[:id]) && @user.someattr = somevalue

这样只有前面的语句执行成功,找到了 @user,才会执行后面的设置语句,非常实用~

因为 Ruby 中在逻辑判断中等同于假的只有 nil 和 false,大部分语句只要成功执行,都不会返回 nil 或 false,所以一直以来,我就以为 && 之前的语句执行成功了,就会执行后面的语句,直到昨天写出了下面的代码:

  1. @user.show_navbar_admin = false && @user.save

天真的我以为,前面的赋值语句执行成功,就会执行后面的保存,还顺便 One liner 了一把,哪知道,赋值语句的返回值就是被赋予的值, a = false 的返回值就是 false,所以后面的 @user.save 根本就没执行,纳闷了半天才醒过来……

以后再用 && 之前一定想清楚,语句间没有什么逻辑关系的,还是老老实实分成两行写吧,实在想 One liner,用分号分割一行内的语句:

  1. @user.show_navbar_admin = false ; @user.save

Chito 准备加入“页面”功能

了解 WordPress 的人肯定对“页面”非常熟悉,Chito 也准备加入这个功能,本想在单机版之后再考虑,不过想到在把 is-Programmer 迁移到单机版之上的时候,需要页面的功能,就着手开始做了~

说白了页面就是可以显示在导航栏的文章,所以 Model 还是文章的 Model,根本不用建新表,添加个标识和普通的文章区分即可,再加上原来在做 Textile 编辑插件的时候,就实现了“编辑模式”的结构,这次只要添加一个“Page 模式“就 OK 了,剩下的就是显示上和排序的问题了~

这样,目前导航栏中“关于 XXX”的栏目就显得有些多余了,移除预定~

Chito 代码整理完毕

终于把 Chito 的代码整理了一遍,清理无用代码无数,修复 n 个隐性 bug ( 不知道会不会带来新 bug ),扔掉了几个不需要的第三方插件,尽最大努力把代码理得清楚了一些,看上去舒服多了~

目前的 rake stats:

Code LOC 只有 1341,不得不惊叹于 Ruby 语法的简练和 Rails 的简洁性,要是用 PHP 或者 Java 来做个简单的 Blog 程序的话,就没这么轻松了~

接下去是严峻的单机版工作,终于要开始了……

带有默认值的 to_i

Ruby 中的 to_i 方法可以把对象转换成数字,"123".to_i 就返回 123,用来将用户输入的文本转换成数字非常实用。

不过如果对象无法转换成数字,to_i 就返回 0 了,假如我想在用户的输入无意义的情况下,取一个默认值 ( 比如 50 ),而不是 0,就要:

  1. if input.to_i == 0
  2.    return 50
  3. else
  4.    input.to_i
  5. end

这样的代码很让人郁闷……  更好的办法是利用 Ruby 方便的语法特性,定义一个 to_num 方法:

  1. module Kernel
  2.     def to_num(default=0)
  3.         self.to_i == 0 ? default : self.to_i
  4.     end
  5. end

这样,所有的对象都可以应用这个带有默认值的 to_num 方法了~

  1. irb > "123".to_num
  2. => 123
  3. irb > "abc".to_num
  4. => 0
  5. irb > "abc".to_num(50)
  6. => 50

完全可以取代 to_i 方法。

改善了 Chito 插件的实现方式

昨天夜里改善了一下 Chito 插件的实现方式,原来直接把方法 include 到 Rails 的框架里去,现在放在 module 中在程序中 include 进来,当初脑子脱线了就是没有想到这个简单的方法……   这样方法的查找速度快了很多,而且还可以在插件中修改过滤器什么的。

  1. class BlogController < ApplicationController 
  2.     include BlogControllerPlugin
  3.     ...
  4.  
  5. module BlogHelper
  6.     include BlogViewPlugin
  7.     ...

另外,原来是每次请求都要获取一遍插件,现在改成在启动的时候,把插件都注册到一个插件类中去,大大提高了效率~    插件也可以有诸如作者、版本、Web、简介这类的属性了~

  1. plugin = ChitoPlugin.new do
  2.     self.id = "hot_posts"
  3.     self.name = "热门文章"
  4.     self.version = "1.0.0"
  5.     self.writer = "galeki"
  6.     self.web = "http://galeki.net"
  7.     self.contributers = ""
  8.     self.category = ""
  9.     self.info = "Show hot posts bar"
  10. end
  11. ChitoPlugin.add(plugin)

还把插件的配置页面位置统一化了,这样就不用费力在每个插件中都要指明配置页面位置,基本上每个插件的代码因此减少了近一半~