この記事はMaya-Pythonアドベントカレンダー12月4日の記事です。
前編からの続きです。
MayaとPyCharmの連携についてですが、今日は思うところあってのエディット機能についての再確認をしていきます。
今日触れる機能については無料のCommunity版でもすべて使用できると思います。
PyCharm 2016.3 Professional
Maya 2016 Extension2
VIM愛
昨今自分が使うプログラム言語は
- Python
- HTML
- CSS(lessで書いてるけども)
- JavaScript(近々TypeScriptに移行予定)
- DosBatch
- C++
といったところです。軽く調べてみるとPyCharmはこれらほとんどをサポートしてるんですよね。TypeScriptなんて特に気合入ってる。
私はVIMを長年使ってます。主に使用しているプラグインの中で無いと悲しいのは、
- Unite
- Jedi
- Syntastic
くらいで、基本的にはhjklでの移動など基本機能が便利で使ってます。単純にタイプ数、視線の移動、などが少なくて楽なのです。
つまり自分でvimscriptを書くほどのユーザーではありません。
詳しい方は、ちょっと古いプラグイン使ってない?とお気づきかもしれません。
そう、ちょっと設定ファイルを書くことに疲れてます・・・NEOVIMも挫折。
使用中のプラグインの中でもJediっていうプラグインが強力なPythonサポートになります。
かなり賢くて、メソッドの候補などをプルダウンメニューで表示してくれます。
こういった機能の代替えになるのかを検証していこうと思います。
Mayaのスクリプトエディターの自動補完
まずは改めてMayaのスクリプトエディターの機能確認。
スクリプトエディターにはCommand Completionというオプションがあります。
MELコマンドを入力する際に、自動補完やオプションの説明が表示されます。非常に便利。
Pythonでも同様にMELコマンドやPython標準モジュールに関しては自動補完が効きます。
でもaliasには反応しません。pymel.coreのMELコマンドにも対応していないようです。ちょっと厳しい。
PyCharmはどうなんだ
さて、PyCharmです。
pm(pymel.coreのalias)を入力すると、MELコマンドは表示されませんでした。listHistoryだけが候補に挙がっているのはこのソースコード中で使用しているためです。
Maya組み込みPythonでしか有効にならないモジュールは通常のPythonでは読み込めないのが原因だと思います。
しかしMayaに関してはmayapyというインタープリターが用意されています。オートデスクさんは非常に分かってる。
Settingsからデフォルトインタープリターを変更してみましょう。
なんということでしょう。候補が表示されました。
ただ、オプションについては動的に解釈してるから(?)何も表示されません。
ちなみにこのような設定だと、PyCharm内のPython Consoleもmayapyになります。
さて編集中に良く行う動作としては、関数の定義部分にジャンプしたり。
もちろん強力なリファクタリングツールも作業効率アップ間違いなしです。
VIM愛ふたたび
ここまでくると非の打ちどころがありません。すでに最強と言えるでしょう。
しかし私の心をむしばむ愛という名の悪魔がささやきます。
「十字キーなんてタッチタイプできるのかい?・・・」
JetBrainsなめんな。そのくらいのプラグインあるわ。
うぐぐ・・・VIM操作ほとんどできた・・・
Uniteに代わるスニペット管理、syntasticに代わるコードチェックがあれば愛を捨てることができそうです。
スニペット管理
syntasticが行ってくれてたコードチェックはPyCharmだとある程度リアルタイムに行ってくれるのでよしとして、スニペットだけはしっかり確認が必要です。
Live Templatesという機能だそうです。
お決まりのロガー初期化とロガー取得をスニペット登録してみましょう。
import logging
if $ISDEBUG$:
LOG_FORMAT = r"%(asctime)s %(name)s [%(levelname)s] %(filename)s:%(lineno)d %(message)s"
LOG_LEVEL = logging.DEBUG
else:
LOG_FORMAT = r"[%(levelname)s] %(message)s"
LOG_LEVEL = logging.INFO
_logger = logging.getLogger(u'$NAME$')
_logger.handlers = []
_stream_handler = logging.StreamHandler()
_formatter = logging.Formatter(LOG_FORMAT)
_stream_handler.setFormatter(_formatter)
_logger.addHandler(_stream_handler)
_logger.setLevel(LOG_LEVEL)
from logging import getLogger
logger = getLogger(u'$NAME$')
Settings/Editor/Live Templateから追加します。あらかじめ内包表記とか登録されてますね。話がそれますが、条件付き内包表記、永遠に覚えれれませんよね(あ、私だけ?・・・)
「+」ボタンを押して新規グループにスニペットを作ってみました。毎回入力したい可変の部分は$NAME$
のように$
で括るルールのようです。
settingsのダイアログではペーストできないようですので、%USERPROFILE%\.PyCharm2016.3\config\templates\Python.xml
を直接編集してもいいようですが、私はうまくいきませんでした。特殊文字のエスケープとかに失敗してるんでしょうけども、調べる気にもなりません。XMLって。
大きめのスニペットを登録するのはちょっと辛いですね。小分けにしましょう。
登録はちょっとめんどくささを感じましたが、ともあれ、Ctrl+Jでスニペットを呼び出せます。候補から選択するために十字キーを使わなくてはいけないってのが嗚呼VIM・・・と思わせる瞬間だったりします。
以上、スニペット登録から呼び出しをやってみましたが、おおむねLive Template機能も問題ないような気がします。よくできてます。
無料でここまでの環境が手に入るって本当にすごい時代です。
まとめ
PyCharmすさまじい。
さてどうしたものか。