Tag Archives: fcitx
fcitx utf8完全化
修改的很起劲……哈哈 目前结果还算不错哦,基本utf8化了 测试还是需要的,不过目前还没有发现什么问题 而且估计内存好了不少,因为不用管理那么多字符转换策略喽! 好处是,大字符集的支持变好了,另外惊喜的发现fcitx-remote都能很好的工作了! 貌似性能也有不小的提升,真是可喜可贺…… 需要测试一下内存是否有泄漏问题? 根据系统监视器来看,没有:) 可喜可贺可喜可贺 下一步可能引入gettext搞些翻译了?:)
国际化真是难事
昨日与yuking在gtalk聊了聊fcitx 4的想法 今天白天研究了一下国际化的方法,还是十分困惑。 fcitx的配置文件是中文的,这里就有一些问题,中文的要怎么编码呢……主要是考虑到这个问题,所以迟迟无法下手,我的想法是不用中文好了…… 不用中文带来的问题就是配置略微困难,那么有一个好用的配置工具就是迫在眉睫的了,这个其实好办,gtk,qt各写一个,万事大吉。 贴一个地址:ini文件读写,和fcitx的配置文件格式实际上是一样的吧,把这个库引入估计会方便不少 http://www.cppblog.com/dyj057/archive/2007/12/07/37958.html 现在一个疑问就是如何存储那些常量字符串,我个人认为还是引入gettext的好,联合locale一起上,万事大吉。 不知道那些正规开发者是怎么做的,不过恐怕一个基本的共识是字符串是英文的吧。 大概的整体想法就是词库UTF8或者Unicode化,字符串英文化,引入gettext,翻译另算
valgrind使用后记
貌似真的是那个错误……就算不是那也是需要修正的 然后怎么解决这个问题呢,第一这个变量存储的是字符串,所以需要变长,有时值为一个常字符串,有时值为一个转换后的字符串(malloc的,需要free)。怎么办呢……于是搞了个全局变量(其实直接malloc也行),然后每次strcpy进去。 已经提交了,在r311
valgrind的调试fcitx的记录
今天调fcitx和kimpanel,以前杯具的sigpipe再度出现,幸好不使用dbus时不会出现这个问题,要不我还不被骂死…… 上网查了查dbus的sigpipe,信息不多,感觉一头雾水无从选择……相关的一个信息就是dbus的多线程问题,需要用dbus_threads_init_default,这个问题在当年决定用另外的线程来接收dbus信息时就用上了,所以导致我更加百思不得其解…… 幸好这个问题不甚多见,我能reproduce的情况就是,打开拼音,按left ctrl进英文模式,按shift+space切换全半角,然后就sigpipe。甚是杯具。我猜很多人也不这么用,甚至全角都完全不用,所以有幸躲过了。 回到这个问题上来,今天不断的测试之后还是没有解决,倒是有的时候segfault了。赶快看一看,发现问题总是出在property2string这个函数上面,很奇怪,于是祭出valgrind大神救我。 valgrind大神真是好,当年fcitx的dbus功能内存泄露大大滴……用了这个,真是腰不酸了,背不疼了,走路也有劲了,顺道还查出了个fcitx原来隐藏的内存泄露问题。 单纯记录经历就没啥意思了,也说说怎么用上它的,基本上这个命令总是这么敲就好了: valgrind –trace-children=yes –leak-check=full –log-file=filename commands args 其中第一个参数是记录子进程,第二个是显示完整的内存泄露信息,第三个是制定记录输出的文件,默认是重定向到stderr的。 于是乎,果然让我发现了一个问题,是新写的函数updatePropertyByConnectID有个问题,logo_prop这个变量记录了kimpanel第一个图标的信息,这里我在赋值之后将它free掉了……也许就是这个原因导致的,不过再我改过来之前就被亲爱的打发走了…… 回去之后看看是否能解决这个问题。 余下的是杂谈: 话说回来,我还是需要吐吐嘈,dbus实际上大家都在用dbus和glib的绑定(或者qt),这也无可厚非,但是我实在不想为fcitx加入新的依赖,dbus毕竟还是人人都安装的嘛。(什么,你不装dbus,主流桌面你还想用吗,你真的用linux做桌面吗)所以一直只用了dbus的核心部分,结果就没有办法做一个好的事件处理,这让人很苦恼。另外由于开了多线程,幸好有个dbus有个加锁的功能所以才能解决。fcitx确实很轻量级,带来的问题就是可扩展性上的缺失,这也算是一个feature吧……不用kimpanel的人大可以放心不用重新编译,在配置文件里面写上使用dbus接口=0就好,而且默认是不用的,不会带来啥性能和崩溃问题(基本确定,我check过屏蔽的还是很好的)。 用dbus底层接口带来的问题就是得自己搞个轮询……试了试sleep起码没有带来啥性能问题,就暂且放过。 fcitx的界面逻辑和核心逻辑混杂在一起,所以带来了很多问题……但是拆开来难得要做第二个ibus不成吗?……而且恐怕工程量巨大,也没有啥精力去搞这个了…… 其实说起来我还给fcitx搞过整体的utf8化哦……当时倒是有初步结果,只不过最后无疾而终了…… 说起来我为什么一直执着于fcitx,很多人也执着于fcitx呢?其实我执着的原因还蛮简单的,就是兼容性啊,纯底层x写的输入法,没有gtk,qt的依赖,真是很好的输入法。大多数人可能看重的是轻量吧。 fcitx的拼音输入其实还不错,只不过默认的词库小了点,具体的处理也是hand made的。有时候总会觉得有点遗憾,用了附加词库当然好了很多,不过貌似是最近匹配的算法?有时候输入有点小问题。 如果有人port一个新输入法算法过来可能会好很多。其实fcitx有很多人性化的地方,删除用户词库,record,等等都很方便。 不知道yuking对于小企鹅输入法的将来怎么看,活跃着的开发者貌似只有yuking?…… 不知道联系一下学校的协会怎么样
kimpanel fcitx 常见问题
Changelog Update issue 12 Changelog Update issue 10,11,12 Changelog Update issue 3 首先说明一下4.4.0的kimpanel 对应svn版本 = 1087679将要到来的4.4.1的kimpanel 对应svn版本 > 1097687 fcitx 3.6.3 = svn 303 1、用了kimpanel之后plasma的tooltip消失了! 额,这是kimpanel的问题,请使用这个patch重新编译吧 http://aur.archlinux.org/packages/kimpanel-plasmoid-svn/kimpanel-plasmoid-svn/collapse.patch 这个patch非常ugly,但是有效… 2、fcitx的cpu占用100%,杯具啊! 请确保使用fcitx的svn最新版本,如仍有问题请在code.google.com/p/fcitx留下bug report 3、 输入框在桌面边缘总是跳动,好烦啊 这个问题已经找到具体解决方案,是kimpanel在移动窗口的时候采用了两个不同的方式计算边界,一个计算了panel一个没有,可以使用这个 patch修正 http://aur.archlinux.org/packages/kimpanel-plasmoid-svn/kimpanel-plasmoid-svn/position.patch 这个问题我已经扔到bugs.kde.org上面去了,不知道啥时候会修正 AUR已经有这个补丁 4、kimpanel不能保存icon filter吗? … Continue reading