はじめに
みなさんこんにちは。Qt Champion の @task_jp です。好きなクラスは QSharedDataPointer、嫌いなクラスは QTextDocument です。
今年からはじめた Qt Advent Calendar ですが、なんといきなり全部埋まってしまうという快挙を成し遂げて密かに感動しています。12月25日まで毎日ワクワクして過ごせるなんて考えただけで幸せですね。
1日目からレベルの高い素晴らしい記事が続いてきたので、この辺でちょっとハードルを下げるために 初心者向けの記事 を書くことにしました。ソースコードを一行も書かない縛りで頑張ります。
Qt Creator の紹介
Qt Project が Qt とともに開発しているオープンソースの統合開発環境 Qt Creator 便利に使いこなしていますか?
コードエディタとして優秀なだけではなく、デバッガのフロントエンドとして非常に使いやすかったり、バージョン管理システムがシームレスに統合されていたりと、コマンドラインだと面倒くさくて敬遠しがちな機能も Qt Creator であれば簡単に使いこなせて本当にありがたいですね。
この記事では Qt Creator を使いはじめたての人に知ってほしい機能を2つほど紹介します。
補完を制する快感を味わおう!
-> と打つのはめんどくさい
「-」を打って、さらにシフトを押しながら「.」を打つのって本当に面倒くさいですよね。Qt Creator なら「.」と打っただけで、直前の変数がポインタの場合は「->」に自動的に置換して(メソッドの一覧まで出して)くれます。これだけでかなりの労力を省けますよね。(スマートポインタには試さないでね)
キャメルケース対応の補完を最大限に活用しよう
QDesignerCustomWidgetCollectionInterface というクラス名を見ると長くてそれだけで使うのをやめたくなるかと思いますが、Qt Creator であれば「QDCW」あたりまで打てば見事に補完されます。
QNAM くらい身近なクラスになると、メーリングリストやバグレポートなどでも、qnam で通じるようになって、逆に正式名称なんだっけ?って感じですね。
小文字から始まるキャメルケースのは最初は小文字で打ちはじめましょう。
みたいな感じですね。
大文字のところだけ打つのは最初は頭を使いますが、慣れたら相当便利で気持ちいいので是非積極的に立ち向かいましょう。
同じ頭文字からなる候補が複数ある場合もあると思いますが、QSLiteral
や QNReply
のように最後のかたまりは小文字のところも打つようにすることで候補が絞れる確率が飛躍的に高くなります。
この補完はクラス名や名前空間名、変数名、メソッド名、定数名、マクロ名、インクルードするファイル名など様々なところで使用できるので、是非積極的に活用して、タイプ数を半減して開発効率を向上しましょう。
Ctrl+K (Mac は ⌘+K)を極めよう!
Qt Creator を最大限に使いこなす鍵が Locator(通称 Ctrl+K) です。
この左下の小さなボックスを通して、様々な作業をキーボード操作で行うことができるのが Qt Creator の最大の特徴と言っても過言ではないでしょう。
ファイルを開く
Ctrl+K で Locator にフォーカスが当たったら、そのまま開きたいファイル名を打ちましょう。
「main.cpp」と打つと、Qt Creator で開いているプロジェクトの中にあるすべての main.cpp を検索して簡単にアクセスできるようになっています。
この機能は部分一致で検索していますので、「正式名称は忘れたけどなんとか manager だったよなー」という場合は「manager.」のように指定することができますし、ワイルドカードにも対応しているので、プロジェクトファイル関連のファイルを開きたいという場合には「*.pr?」と指定することで「*.pro」「*.pri」「*.prf」などをまとめて検索して開くことも可能です。
その他の機能を使う
Ctrl+K で Locator にフォーカスが当たると上記のように使用できる機能の一覧とプレフィックスが表示されます。
任意のコマンドを実行する
!(スペース)コマンド名(リターン)
で任意のコマンドが実行できます。
! chmod +x hoge
! grep hoge -r *
! xdg-open .
のように Qt Creator では対応していない機能の実行や、対応していてもコマンドラインの方が良い場合などにとても便利です。
いま開いているファイルの中の C++ のシンボルを検索する
.(スペース)シンボル名
あるメソッドの実装部分やクラスの定義などに簡単に移動できます。
クラス、Enum、関数の定義を検索する
:(スペース)クラス名
ドキュメントを開く
?(スペース)ドキュメント名(やクラス名など)
クラス名やメソッド名、変数名などにカーソルを合わせて F1 キーを押すとヘルプを見ることができる Qt Creator ですが、任意のドキュメントにも簡単にアクセスができます。
? QString
? Concurrent
ファイルを開く
a(スペース)ファイル名
前述のファイルを開く機能です。この機能はデフォルトがプレフィックスの省略を許可する設定になっているため、明示的にプレフィックスをつける必要は通常はありません。
クラス名を検索する
c(スペース)クラス名
ファイルの場所が分かっているファイルを開く
f(スペース)ファイル名
現在開いているファイルと同じディレクトリ(やその近辺のディレクトリの)ファイルを開く場合や、Qt Creator のプロジェクトの管理外のファイルを開く場合にとても便利です。
f ../main.cpp
f ~/Documents/test.txt
f /var/log/...
行ジャンプ
l(スペース)行番号
好きな行にジャンプできます。カラムの指定も可能です。
l 1
l 12:40
この機能はよく使用する機能のため、「Ctrl+K, l(スペース)」を短縮して「Ctrl+L」で実行することができます。
C++ のメソッド名で検索する
m(スペース)メソッド名
開いているファイルにアクセスする
o(スペース)ファイル名
現在のプロジェクト内のファイルを検索する
p(スペース)ファイル名
インターネット検索
r(スペース)検索用語
bing や google などを指定して任意の語句を検索できます。
検索サービスをカスタマイズすることでさらに便利に使うことも可能です。
マクロの実行
rm(スペース)マクロ名
Qt Creator のマクロの実行が可能です。
git タスクを実行する
git(スペース)タスク名
git の操作もここからできます。
git amend
git commit
自分用の機能を登録してさらに便利に
カスタムフィルタを登録する
自分でフィルタを作成することも可能です。
例えば、上記画像のように設定することで、Qt 5 のソースツリー以下の任意のファイルに簡単にアクセスすることができます。
q qqmlxmlhttp...
q qmake.pro
ウェブアクセス用の URL を登録
Web Search のフィルタに URL を登録することでさらに便利にできます。
のように登録をして、
r 52659 と打って、codereview. を選択して決定
r 42869 と打って、bugreports. を選択して決定
のように使います。
Qt Creator のコミット画面のレイアウトを改善しました
こんな便利な Qt Creator をさらに便利なものにするために、Qt Creator にパッチを送ってみました。
コミット画面のレイアウト
今までの Qt Creator の git (など) でコミットをする画面がこちらになります。
一見あまり問題がなさそうですが、コミットするファイルが多くなるととても使いづらくなります。
また、実行などのログペインが表示されるとまったく使い物にならなくなります。
Qt Creator の git のコミットの UI ってなんかイライラするよね
— Tasuku Suzuki (@task_jp) July 10, 2014
イライラはお肌に悪いので改善してみました
なので5分くらいで適当に改良した成果がこちらになります。/ change vcs submit editor layout https://t.co/4wWScPKfx1 #qtjp だれか試してみてくれないかしら。
— Tasuku Suzuki (@task_jp) July 10, 2014
てな感じで、かわいそうな右半分を上手に活用する形にレイアウトを変えてあげました。
これによって、画面全体を広く使うことができ、コミットするファイルが増えた際の一覧性が著しく改善されました。
この変更は Qt Creator の Visual Designer で行ったため .ui ファイルの diff を見てもなにをどう変更したかは読み取りづらいと思いますが、コードを一行も手で書かなくてもこんな改善ができるのはおもしろいですね。
この変更によりコミットメッセージの入力エリアの横幅が狭くなる関係で、コミットメッセージの折り返しがうまく機能しない問題 (https://codereview.qt-project.org/94927 で修正済み) が修正されるまでは取り込めないからちょっと待ってねと言われ、正式な採用までには少し時間がかかりましたが、2014年11月02日に無事取り込まれました。
Qt Creator 3.3 系には入れることができなかったため、みなさんの手に届くのはしばらく先の Qt Creator 3.4 までおあずけとなってしまいましたが、楽しみにお待ちください。
おわりに
軽量で高機能でとても使いやすい Qt Creator をさらに便利に使いこなすためのテクニックを大きく分けて2つほど紹介しました。この他にも便利な機能がたくさんありますので、色々探してみてください。
Qt Creator はオープンソースプロジェクトとして開発が進められていて、誰でも開発に参加することができます。
Qt Creator は Qt で作られているので Qt ユーザーのみなさんであれば違和感なく理解できると思いますし、Qt Creator の中のコードを見てみるのはいい Qt の勉強になりますよ。
この記事の後半部分が「あーなんかここをちょっとこうするだけで相当便利になるのになー」というアイディアや、「この Qt Creator のバグなんとかならないの?」とか「この翻訳したのだれだよ?」という不満を、「自分で直して取り込んでもらったらみんなのためになるんじゃない?」という発想に変えていくキッカケになればいいなぁと思います。
というわけでパッチは作ってみたけれどそれをどう本家に還元したらいいかわかんないなーという方は Qt の勉強会 に参加したり、Twitter で @task_jp に一言声を掛けてもらえればやさしくお手伝いいたします。
明日は @Atsushi4 さんによる「ETロボコンでQtシール貼って走ってきた話でもいいですか」です。期待大ですね!