ruby-changes:11596
From: yugui <ko1@a...>
Date: Sun, 19 Apr 2009 22:36:07 +0900 (JST)
Subject: [ruby-changes:11596] Ruby:r23233 (ruby_1_9_1): merges r23129 from trunk into ruby_1_9_1.
yugui 2009-04-19 22:35:47 +0900 (Sun, 19 Apr 2009) New Revision: 23233 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=23233 Log: merges r23129 from trunk into ruby_1_9_1. -- * lib/irb/completion.rb (IRB::InputCompletor::Operators): Add overloadable negative operators. * lib/irb/ruby-lex.rb (RubyLex#lex_init): Support overloadable negative operators. * lib/irb/ruby-lex.rb (RubyLex#identify_identifier): Minus signs need to be escaped in regexp character class. * misc/ruby-mode.el (ruby-font-lock-keywords, ruby-parse-partial): Support overloadable negative operators. Modified files: branches/ruby_1_9_1/ChangeLog branches/ruby_1_9_1/lib/irb/completion.rb branches/ruby_1_9_1/lib/irb/ruby-lex.rb branches/ruby_1_9_1/misc/ruby-mode.el Index: ruby_1_9_1/ChangeLog =================================================================== --- ruby_1_9_1/ChangeLog (revision 23232) +++ ruby_1_9_1/ChangeLog (revision 23233) @@ -1,3 +1,17 @@ +Fri Apr 3 14:02:42 2009 Akinori MUSHA <knu@i...> + + * lib/irb/completion.rb (IRB::InputCompletor::Operators): Add + overloadable negative operators. + + * lib/irb/ruby-lex.rb (RubyLex#lex_init): Support overloadable + negative operators. + + * lib/irb/ruby-lex.rb (RubyLex#identify_identifier): Minus signs + need to be escaped in regexp character class. + + * misc/ruby-mode.el (ruby-font-lock-keywords, ruby-parse-partial): + Support overloadable negative operators. + Wed Apr 1 20:37:49 2009 Tanaka Akira <akr@f...> * configure.in (rb_cv_fork_with_pthread): fail if the child process Index: ruby_1_9_1/misc/ruby-mode.el =================================================================== --- ruby_1_9_1/misc/ruby-mode.el (revision 23232) +++ ruby_1_9_1/misc/ruby-mode.el (revision 23233) @@ -646,7 +646,7 @@ ((looking-at ":\\(['\"]\\)") (goto-char (match-beginning 1)) (ruby-forward-string (buffer-substring (match-beginning 1) (match-end 1)) end)) - ((looking-at ":\\([-,.+*/%&|^~<>]=?\\|===?\\|<=>\\)") + ((looking-at ":\\([-,.+*/%&|^~<>]=?\\|===?\\|<=>\\|![~=]?\\)") (goto-char (match-end 0))) ((looking-at ":\\([a-zA-Z_][a-zA-Z_0-9]*[!?=]?\\)?") (goto-char (match-end 0))) @@ -1386,7 +1386,7 @@ '("\\(^\\|[^_]\\)\\b\\([A-Z]+\\(\\w\\|_\\)*\\)" 2 font-lock-type-face) ;; symbols - '("\\(^\\|[^:]\\)\\(:\\([-+~]@?\\|[/%&|^`]\\|\\*\\*?\\|<\\(<\\|=>?\\)?\\|>[>=]?\\|===?\\|=~\\|\\[\\]=?\\|\\(\\w\\|_\\)+\\([!?=]\\|\\b_*\\)\\|#{[^}\n\\\\]*\\(\\\\.[^}\n\\\\]*\\)*}\\)\\)" + '("\\(^\\|[^:]\\)\\(:\\([-+~]@?\\|[/%&|^`]\\|\\*\\*?\\|<\\(<\\|=>?\\)?\\|>[>=]?\\|===?\\|=~\\|![~=]?\\|\\[\\]=?\\|\\(\\w\\|_\\)+\\([!?=]\\|\\b_*\\)\\|#{[^}\n\\\\]*\\(\\\\.[^}\n\\\\]*\\)*}\\)\\)" 2 font-lock-reference-face) ;; expression expansion '("#\\({[^}\n\\\\]*\\(\\\\.[^}\n\\\\]*\\)*}\\|\\(\\$\\|@\\|@@\\)\\(\\w\\|_\\)+\\)" Index: ruby_1_9_1/lib/irb/ruby-lex.rb =================================================================== --- ruby_1_9_1/lib/irb/ruby-lex.rb (revision 23232) +++ ruby_1_9_1/lib/irb/ruby-lex.rb (revision 23233) @@ -389,7 +389,8 @@ "=", "==", "===", "=~", "<=>", "<", "<=", - ">", ">=", ">>") do + ">", ">=", ">>", + "!", "!=", "!~") do |op, io| case @lex_state when EXPR_FNAME, EXPR_DOT @@ -400,12 +401,6 @@ Token(op) end - @OP.def_rules("!", "!=", "!~") do - |op, io| - @lex_state = EXPR_BEG - Token(op) - end - @OP.def_rules("<<") do |op, io| tk = nil @@ -822,11 +817,11 @@ when "class" valid = false unless peek_match?(/^\s*(<<|\w|::)/) when "def" - valid = false if peek_match?(/^\s*(([+-\/*&\|^]|<<|>>|\|\||\&\&)=|\&\&|\|\|)/) + valid = false if peek_match?(/^\s*(([+\-\/*&\|^]|<<|>>|\|\||\&\&)=|\&\&|\|\|)/) when "do" - valid = false if peek_match?(/^\s*([+-\/*]?=|\*|<|>|\&)/) + valid = false if peek_match?(/^\s*([+\-\/*]?=|\*|<|>|\&)/) when *ENINDENT_CLAUSE - valid = false if peek_match?(/^\s*([+-\/*]?=|\*|<|>|\&|\|)/) + valid = false if peek_match?(/^\s*([+\-\/*]?=|\*|<|>|\&|\|)/) else # no nothing end Index: ruby_1_9_1/lib/irb/completion.rb =================================================================== --- ruby_1_9_1/lib/irb/completion.rb (revision 23232) +++ ruby_1_9_1/lib/irb/completion.rb (revision 23233) @@ -184,7 +184,7 @@ Operators = ["%", "&", "*", "**", "+", "-", "/", "<", "<<", "<=", "<=>", "==", "===", "=~", ">", ">=", ">>", - "[]", "[]=", "^",] + "[]", "[]=", "^", "!", "!=", "!~"] def self.select_message(receiver, message, candidates) candidates.grep(/^#{message}/).collect do |e| -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/