summaryrefslogtreecommitdiff
path: root/data/rbot
diff options
context:
space:
mode:
authordmitry kim <jason@nichego.net>2008-03-28 02:49:35 +0300
committerdmitry kim <jason@nichego.net>2008-03-28 02:49:35 +0300
commit5f25e65756ff3428226559e301e9074a4b660e69 (patch)
tree69ac06adb696499a6c5b64cf995a01acee46c7ec /data/rbot
parent1e9373e223fe142fb412f268d33e993a09d4d818 (diff)
* plugins/unicode -> core/unicode; don't require "jcode"
Diffstat (limited to 'data/rbot')
-rw-r--r--data/rbot/plugins/unicode.rb96
1 files changed, 0 insertions, 96 deletions
diff --git a/data/rbot/plugins/unicode.rb b/data/rbot/plugins/unicode.rb
deleted file mode 100644
index 957f5bff..00000000
--- a/data/rbot/plugins/unicode.rb
+++ /dev/null
@@ -1,96 +0,0 @@
-#-- vim:sw=4:et
-#++
-#
-# :title: Unicode plugin
-#
-# Author:: jsn (Dmitry Kim) <dmitry dot kim at gmail dot org>
-# Copyright:: (C) 2007 Dmitry Kim
-# License:: public domain
-#
-# This plugin adds unicode-awareness to rbot. When it's loaded, all the
-# character strings inside of rbot are assumed to be in proper utf-8
-# encoding. The plugin takes care of translation to/from utf-8 on server IO,
-# if necessary (translation charsets are configurable).
-
-# TODO do we actually want this?
-require 'jcode'
-
-require 'iconv'
-
-class UnicodePlugin < Plugin
- Config.register Config::BooleanValue.new(
- 'encoding.enable', :default => true,
- :desc => "Support for non-ascii charsets",
- :on_change => Proc.new { |bot, v| reconfigure_filter(bot) })
-
- Config.register Config::ArrayValue.new(
- 'encoding.charsets', :default => ['utf-8', 'cp1252', 'iso-8859-15'],
- :desc => "Ordered list of iconv(3) charsets the bot should try",
- :on_change => Proc.new { |bot, v| reconfigure_filter(bot) })
-
- class UnicodeFilter
- def initialize(oenc, *iencs)
- o = oenc.dup
- o += '//ignore' if !o.include?('/')
- i = iencs[0].dup
- # i += '//ignore' if !i.include?('/')
- @iencs = iencs.dup
- @iconvs = @iencs.map { |_| Iconv.new('utf-8', _) }
- debug "*** o = #{o}, i = #{i}, iencs = #{iencs.inspect}"
- @default_in = Iconv.new('utf-8//ignore', i)
- @default_out = Iconv.new(o, 'utf-8//ignore')
- end
-
- def in(data)
- rv = nil
- @iconvs.each_with_index { |ic, idx|
- begin
- debug "trying #{@iencs[idx]}"
- rv = ic.iconv(data)
- break
- rescue
- end
- }
-
- rv = @default_in.iconv(data) if !rv
- debug ">> #{rv.inspect}"
- return rv
- end
-
- def out(data)
- rv = @default_out.iconv(data) rescue data # XXX: yeah, i know :/
- debug "<< #{rv}"
- rv
- end
- end
-
-
- def initialize(*a)
- super
- @old_kcode = $KCODE
- self.class.reconfigure_filter(@bot)
- end
-
- def cleanup
- debug "cleaning up encodings"
- @bot.socket.filter = nil
- $KCODE = @old_kcode
- super
- end
-
- def UnicodePlugin.reconfigure_filter(bot)
- debug "configuring encodings"
- enable = bot.config['encoding.enable']
- if not enable
- bot.socket.filter = nil
- $KCODE = @old_kcode
- return
- end
- charsets = bot.config['encoding.charsets']
- charsets = ['utf-8'] if charsets.empty?
- bot.socket.filter = UnicodeFilter.new(charsets[0], *charsets)
- $KCODE = 'u'
- end
-end
-
-UnicodePlugin.new