LoginSignup
33
59

More than 3 years have passed since last update.

Sourcetrail使ってみる(Windows, Visual Studio2019, c++)

Last updated at Posted at 2019-11-24

背景/目的

  • Sourcetrailが2019/11/18にoss化された、ということで早速使ってみます。
  • C++のプロジェクトで使いたいので、Visual Studio 2019と連携させてみます。
  • 単に使ってみるだけなく、開発フローにどのように組み込むべきかも記述しておきます(考察レベル)

環境

  • Windows 10 Home
  • Visual Studio 2019 Community Edition

解析対象言語

  • C++

準備

  • まずはVisual Studio 2019 Community Edition(以下、VS2019)をインストール
    • ここらへんの説明は省略します
      • C++のビルド環境を忘れずに入れること
      • 参照例 
  • Sourcetrailで解析するC++のプロジェクトを予め作っておきます。

  • VS2019にSourceTrailプラグインをインストール

    • 「拡張機能」メニューで「Sourcetrail」を検索して「Download」ボタン押下
    • 私の環境では、VS2019を終了させた後にインストールが開始されました。 image.png
  • VS2019を起動して、C++のプロジェクトを開いた状態にしておきます。

    • ここでは「SourcetrailSample」というプロジェクトを作って、開いています。

導入方法

  • githubからrelease版をダウンロードする

    • github
    • 現時点での最新版(portable)をダウンロードします。
      • Sourcetrail_2019_4_61_Windows_64bit_Portable.zip
      • portable or installerはお好みで   image.png
  • 解凍してアプリ起動

    • 実行ファイル: Sourcetrail.exe

使い方

  • アプリ起動後、「New Project」を選択
    image.png

  • 「Sourcetrail Project Name」と「Source Project Location」を適当に入力して下部の「Add Source Group」ボタンを押下する
    image.png

  • 「C/C++ from Visual Studio」を選択して「Next」ボタンを押下します。 image.png

  • Create Compilation Databaseボタンを押下します

image.png

  • 予め作っておいた「SourceTrailSample」を選択して「Create」ボタンを押下してcompile_commands.jsonファイルを生成します。作成後にポッポアップが出るで「import」を選択します
    image.png

  • 「New Source Group」ダイアログに戻って、「Header Files & Directories to Index」にソースコードがある場所を追加して、「Next」ボタンを押下します。
    image.png

  • 「New Project」ダイアログに戻って「Create」ボタン押下すると、下記のダイアログが表示されるので、そのまま「Start」ボタンを押下します。
    image.png

  • そのまま進んでいけば結果が表示されます。
    image.png
    image.png
    image.png

情報更新方法

  • VS2019側でコードを編集した場合、Sourcetrail側でも更新操作(F5)すれば、編集内容を反映してくれます。
    • ファイルを追加した場合でも問題なく反映してくれます(compile_commands.jsonは更新されていませんが、Sourcetrail側は正常に更新されます)

開発環境、CIへの統合(考察レベル)

  • VS2019と一緒に、Sourcetrailも立ち上げておいて、コーディング中に他の人が書いたコードを理解したいときなど、Sourcetrailのほうでチェックする、という流れで効率良く開発できそうです。
    • VS2019で選択した部分からSourcetrailの該当箇所にジャンプできますし、逆もできます。
    • 手動で更新すれば常に最新コードの結果を見ることができます。 image.png
  • 開発メンバー全員でSourcetrailを使う場合、何か効率のいい方法がありそうでしょうか。
    • Sourcetrailが出力する各ファイルをプロジェクトと同じレポジトリに含めてバージョン管理ツールで共有しておけば、各自が設定する必要はなくなりそうです。
      • Sourcetrailの出力ファイルは、srctrlbm、srctrldb, srctrlprjファイルの3つで、srctrlprjファイルだけがあれば設定を共有できます、ただしVS2019が出力したcompile_commands.jsonも必要になってきて、絶対パスも含まれているので、開発環境をメンバー間でパスも含めて共通化させていないと厳しそうです。
  • CIについて、あくまでコードの見るときの補助的なツールだとしたら、CIに組み込み必要はないのかもしれません。
    • 強いてやるとすれば、
      • リリース時にSourcetrailの出力ファイルも一緒に含めておき、後でソースコードまで見たくない他の人でも簡単に見れるようにしておく、ぐらいでしょうか。
        • srctrlbm、srctrldb, srctrlprjのみあって、あとはSourcetrailをインストールすれば、Sourcetrailの結果を見ることができます。
    • 試していませんが、commandlineが用意されているようです。
33
59
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
33
59