diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2011-03-21 14:48:43 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2011-03-21 14:49:07 -0700 |
commit | 88636f7195fc936421392740f980d17ebe77d701 (patch) | |
tree | d979127e5acdc3a528a816823b2d705691f7a278 /activerecord/lib | |
parent | ea8fcfb729c0bca528d2e8522585cd6d0e98ebc7 (diff) | |
download | rails-88636f7195fc936421392740f980d17ebe77d701.tar.gz rails-88636f7195fc936421392740f980d17ebe77d701.tar.bz2 rails-88636f7195fc936421392740f980d17ebe77d701.zip |
escaping binary data encoding when inserting to sqlite3. Thanks Naruse! [#6559 state:resolved]
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb b/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb index c2cd9e8d5e..c3a7b039ff 100644 --- a/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb @@ -34,6 +34,14 @@ module ActiveRecord module ConnectionAdapters #:nodoc: class SQLite3Adapter < SQLiteAdapter # :nodoc: + def quote(value, column = nil) + if value.kind_of?(String) && column && column.type == :binary && column.class.respond_to?(:string_to_binary) + s = column.class.string_to_binary(value).unpack("H*")[0] + "x'#{s}'" + else + super + end + end # Returns the current database encoding format as a string, eg: 'UTF-8' def encoding |