-- Copyright (c) 2013, Thomas Goyne -- -- Permission to use, copy, modify, and distribute this software for any -- purpose with or without fee is hereby granted, provided that the above -- copyright notice and this permission notice appear in all copies. -- -- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -- WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -- MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -- ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -- WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -- ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -- OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. unicode = require 'aegisub.unicode' describe 'charwidth', -> it 'should return 1 for an ascii character', -> assert.is.equal 1, unicode.charwidth 'a' it 'should return 2 for a two byte character', -> assert.is.equal 2, unicode.charwidth 'Ɵ' it 'should return 3 for a three byte character', -> assert.is.equal 3, unicode.charwidth 'ļ½ƒ' it 'should return 4 for a four byte character', -> assert.is.equal 4, unicode.charwidth 'šŸ„“' describe 'char_iterator', -> it 'should iterator over multi-byte codepoints', -> chars = [c for c in unicode.chars 'aƟļ½ƒšŸ„“'] assert.is.equal 4, #chars assert.is.equal chars[1], 'a' assert.is.equal chars[2], 'Ɵ' assert.is.equal chars[3], 'ļ½ƒ' assert.is.equal chars[4], 'šŸ„“' describe 'len', -> it 'should give length in codepoints', -> assert.is.equal 4, unicode.len 'aƟļ½ƒšŸ„“' describe 'codepoint', -> it 'should give codepoint as an integer for a string', -> assert.is.equal 97, unicode.codepoint 'a' assert.is.equal 223, unicode.codepoint 'Ɵ' assert.is.equal 0xFF43, unicode.codepoint 'ļ½ƒ' assert.is.equal 0x1F113, unicode.codepoint 'šŸ„“' it 'should give ignore codepoints after the first', -> assert.is.equal 97, unicode.codepoint 'abc'