Comments (6)
報告ありがとうございます。
OS: OSX Marvericks
Ruby: ruby 2.1.3p242
で試してみたのですが、'File.open("z/\xff", "w")'
でも各gemもイントール出来ました。
OSによって不正なローケルの扱いが違うのかもしれません。
仮想マシン環境で試してみたいので、
可能でしたらお使いのLinuxディストリビュージョンを教えて頂けないでしょうか?
from milkode.
Debian GNU/Linux (jessie) です。
% lsb_release -idrc
Distributor ID: Debian
Description: Debian GNU/Linux testing (jessie)
Release: testing
Codename: jessie
ついでに書いておくと、locale は以下のとおりです。
% locale
LANG=ja_JP.utf8
LANGUAGE=
LC_CTYPE="ja_JP.utf8"
LC_NUMERIC="ja_JP.utf8"
LC_TIME=C
LC_COLLATE="ja_JP.utf8"
LC_MONETARY="ja_JP.utf8"
LC_MESSAGES="ja_JP.utf8"
LC_PAPER="ja_JP.utf8"
LC_NAME="ja_JP.utf8"
LC_ADDRESS="ja_JP.utf8"
LC_TELEPHONE="ja_JP.utf8"
LC_MEASUREMENT="ja_JP.utf8"
LC_IDENTIFICATION="ja_JP.utf8"
LC_ALL=
from milkode.
9af10a1 で修正して 1.8.2 をリリースしました。
Dockerfile で環境を作って検証しました。が、エラーメッセージがakrさんの環境と少し違っていたのが気になってます。
そちらの環境でMilkode1.8.2だとどうなるか試してもらってよいでしょうか?
from milkode.
残念ながら、症状は改善されませんでした。
% rm -rf ~/.milkode; bin/milk --version; bin/milk init; bin/milk add z
milk 1.8.2
create : /home/akr/.milkode/milkode.yaml
create : /home/akr/.milkode/db/milkode.db created.
package : z
["/home/ruby/all-ruby/2.1.3/z/\xFF", #<Encoding:UTF-8>]
/home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/common/grenfiletest.rb:13:in `match': invalid byte sequence in UTF-8 (ArgumentError)
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/common/grenfiletest.rb:13:in `ignoreFile?'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:236:in `ignoreFile?'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:219:in `block in searchDirectory'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:198:in `foreach'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:198:in `searchDirectory'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:163:in `db_add_dir'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:156:in `update_dir'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/database/updater.rb:39:in `exec'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:1154:in `updater_exec'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:1132:in `update_dir_in'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:151:in `block (2 levels) in add'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:132:in `each'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:132:in `block in add'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:1210:in `print_result'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cdstk/cdstk.rb:126:in `add'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cli.rb:52:in `add'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/thor-0.19.1/lib/thor/command.rb:27:in `run'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/thor-0.19.1/lib/thor/invocation.rb:126:in `invoke_command'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/lib/milkode/cli.rb:249:in `invoke_command'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/thor-0.19.1/lib/thor.rb:359:in `dispatch'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/thor-0.19.1/lib/thor/base.rb:440:in `start'
from /home/ruby/all-ruby/2.1.3/lib/ruby/gems/2.1.0/gems/milkode-1.8.2/bin/milk:9:in `<top (required)>'
from bin/milk:23:in `load'
from bin/milk:23:in `<main>'
上記で、["/home/ruby/all-ruby/2.1.3/z/\xFF", #Encoding:UTF-8] と出ているのは試しに grenfiletest.rb の ignoreFile? の先頭に p [fpath, fpath.encoding] とつけてみたからで、
UTF-8 としては正しくないファイル名がそのままこのメソッドに渡されていることが確認できます。
from milkode.
再現させることが出来ました。ロケールにUTF8が設定されていると起きるエラーでした。
Milkode1.8.3で修正しました。不正なファイル名の場合は以下のメッセージを出して無視(追加を諦める)ようになります。
[skip] /root/bukovina-0.0.3/мѣсѧцесловъ/10/30/Стефан Дечанский/Стефану Дечанскому с�: invalid byte sequence in UTF-8
from milkode.
ありがとうございます。動作を確認しました。
from milkode.
Related Issues (20)
- Windowsで1.3を1.4に上書きインストールした場合のエラー HOT 1
- Permission deniedで中断してしまう HOT 5
- 検索結果が多すぎる場合 HOT 8
- 資源の最新化 HOT 7
- milkコマンドの実行 HOT 6
- gmilk で Ctrl+C 押下時のスタックトレースを表示しないで欲しい HOT 3
- データベースの容量が肥大化する HOT 9
- パッケージを完全一致で検索する方法 HOT 2
- milk web -n でthinのArgumentErrorとなり起動できない。 HOT 4
- Windows版でファイルのパスが長い(259文字+null)場合、エラーになる。 HOT 4
- gmilkでの検索結果のファイルのパス HOT 5
- test HOT 1
- C#のシンタックスハイライト HOT 3
- milk web実行時にSECURITY WARNINGが発生する
- milk command with NameError: uninitialized constant Groonga::Posting HOT 8
- Redmine 2.6.7のリポジトリよりmilkodeを使用して検索を行いたい(エラーとなる) HOT 2
- etc ディレクトリ配下のファイルが登録されない
- Windows環境で特定のディレクトリを探索したときにエラーが発生することがある
- milk web で --db=を指定しても、環境変数HOMEが無いとエラーになる
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from milkode.