Github url

Sourcetrail

by CoatiSoftware

CoatiSoftware /Sourcetrail

Sourcetrail - free and open-source interactive source explorer

8.6K Stars 528 Forks Last release: about 1 month ago (2020.2.43) GNU General Public License v3.0 2.7K Commits 46 Releases

Available items

No Items, yet!

The developer of this repository has not created any items for sale yet. Need a bug fixed? Help with integration? A different license? Create a request here:

Sourcetrail

Sourcetrail is a free and open-source cross-platform source explorer that helps you get productive on unfamiliar source code.

Windows: Build status

Linux: Build Status

Links* Website* Download* Quick Start Guide* Documentation* Changelog* Slack Channel* Mailing List* Patreon

"Sourcetrail User Interface"

Sourcetrail is: * free * working offline * operating on Windows, macOS and Linux * supporting C, C++, Java and Python * offering an SDK (SourcetrailDB) to write custom language extensions

Support Sourcetrail via Patreon

The ongoing development and regular software releases are made possible entirely by the support of these awesome patrons! If you'd like to join them, please consider becoming a patron of Sourcetrail.

Using Sourcetrail

To setup Sourcetrail on your machine, you can either download the respective build for your operating system from our list of Releases and install it on your machine, or use one of the following package managers:

After your installation is complete, follow our Quick Start Guide to get to know Sourcetrail.

How to Report Issues

You can post all your feature requests and bug reports on our issue tracker.

Reporting

Use the following template:

  • platform version:
  • Sourcetrail version:
  • description of the problem:
  • steps to reproduce the problem:

Supporting

If you want to support a certain feature request or you have the same bug that another user already reported, please let us know: * post a comment with "+1" to the issue * or send an email to [email protected] with the issue ID

How to Contribute

  • Please read and follow the steps in CONTRIBUTING.md file.
  • You may want to look out for issues labeled good first issue to find some initial tasks to tackle.
  • If you are looking for more information about Sourcetrail software development, please refer to our wiki.

How to Build

Building Sourcetrail requires several dependencies to be in place on your machine. However, our CMake based setup allows to disable indexing support for specific languages which reduces the number of dependencies to a minimum.

Building the Base Application

Required Tools

  • CMake v3.12 (required for Windows, Linux and MacOS)*

Git (required for Windows, Linux and MacOS)

  • Reason: Used for version control and to automatically generate the Sourcetrail version number from commits and tags
  • Download: https://git-scm.com/download
  • Remarks: Make sure
    git
    is added to your
    PATH

    environment variable before running CMake

Visual Studio (required for Windows)

ccache (optional for Linux and MacOS)

Required dependencies

  • Boost 1.67*

    • Reason: Used for file system access and interprocess communication
    • Prebuilt Download for Windows: https://sourceforge.net/projects/boost/files/boost-binaries/
    • Building for Unix:
      $ ./bootstrap.sh --with-libraries=filesystem,program\_options,system,date\_time $ ./b2 --link=static --variant=release --threading=multi --runtime-link=static --cxxflags=-fPIC

Qt 5.12.3

Building

On Windows

  • To set up your build environment run:

$ git clone https://github.com/CoatiSoftware/Sourcetrail.git $ cd Sourcetrail $ mkdir -p build/win64 $ cd build/win64 $ cmake -G "Visual Studio 15 2017 Win64" -DBOOST\_ROOT=<path> -DQt5_DIR=<path> ../..
</path></path>

Hint: If you are using the CMake GUI, we recommend that you activate advanced mode. Also you may be required to add some of the defines via the "Add Entry" button.

  • After generating the build configuration, just open the Sourcetrail.sln file that was generated by CMake and build the Sourcetrail project.

On Unix

  • To set up your build environment run:
    $ cd Sourcetrail $ mkdir -p build/Release $ cd build/Release $ cmake -DCMAKE\_BUILD\_TYPE="Release" -DBOOST\_ROOT=<path> -DQt5_DIR=<path> ../..
    </path></path>
  • Now start the build with:
    $ make Sourcetrail

Running

  • Run Sourcetrail from within the build directory. During execution Sourcetrail needs resources from
    bin/app/data
    and
    bin/app/user
    . CMake creates symlinks within the build directory that make these directories accessible.

Enable C/C++ Language Support

Required dependencies

  • LLVM/Clang 10.0.0
    • Reason: Used for running the preprocessor on the indexedes source code, building and traversing an Abstract Syntax Tree and generating error messages.
    • Building: Make sure to check out the correct tag:
      git checkout llvmorg-10.0.0
    • Building for Windows: Follow these steps to build the project. Run the cmake command exactly as described.
    • Building for Unix: Follow this installation guide to build the project. Make sure to build with ```
  • DLLVM_ENABLE_RTTI=ON
    .
    

Building

  • Run CMake with these additional options: ```
  • DClang_DIR=/lib/cmake/clang
  • DBUILD_CXX_LANGUAGE_PACKAGE=ON ```
  • Build Sourcetrail as described above.

Enable Java Language Support

Required dependencies

  • JDK 1.8*

    • Reason: Used to build the Java indexer and make it callable from the C++ code via JNI.
    • Remarks: Make sure that
      <jdk_root>/bin</jdk_root>
      is available in your
      PATH
      environmen variable and that the
      JAVA\_HOME
      environment variable is set:
      JAVA\_HOME=<path>/jdk1.x.x_xxx
      </path>

Maven

  • REASON: Used within Sourcetrail's automated tests.
  • Remarks: Make sure
    .../apache-maven-x.x.x/bin
    is available in your
    PATH
    environmen variable and that both
    M2\_HOME
    and
    MAVEN\_HOME
    environment variables are set:
    M2\_HOME=.../apache-maven-x.x.x MAVEN\_HOME=.../apache-maven-x.x.x

Building

  • Run CMake with these additional options: ```
  • DBUILD_JAVA_LANGUAGE_PACKAGE=ON ```
  • Build Sourcetrail as described above.

Enable Python Language Support

Required Tools

  • WinRAR (required for Windows)
    • REASON: Used to extract the prebuilt SourcetrailPythonIndexer which is downloaded automatically during build execution.

Building

  • Run CMake with these additional options: ```
  • DBUILD_PYTHON_LANGUAGE_PACKAGE=ON ```
  • Build Sourcetrail as described above.

Creating the deployment Package

Windows

Required Tools

  • Visual Studio (required for Windows)*

Wix 3.11

  • Reason: Used to build the
    sourcetrail.msi
    Windows installer.
  • Remarks: Make sure to add
    <path>/WiX Toolset v3.11/bin</path>
    to your
    PATH
    environment variable.
  • Download: https://wixtoolset.org/releases/

Wix extension for Visual Studio

JRE

  • Reason: Used for indexing the java sample project that ships with the package.

WinRAR

  • Reason: Used for creating the final zip files for the installer and the portable package.
  • Remarks: Make sure to add
    <path>/WinRAR</path>
    to your
    PATH
    environment variable.

Building

  • Run
    ./script/deploy\_windows.sh
    from your Developer Command Prompt for Visual Studio. The script which will generate a 64bit build and packages it into a portable
    .zip
    file and a Wix-based Windows installer, each.

macOS

After building, run the

bundle\_install.sh

script within the build directory which will create a

Sourcetrail.app

bundle and generate a

Sourcetrail\_<version>.dmg</version>

container.

Linux

Run

./setup/Linux/createPackages.sh

from the main directory, which creates both a

.tar.gz

and a

.AppImage

package in the main directory. Packaging depends on linuxdeployqt.

How to Run the Tests

The automated test suite of Sourcetrail is powered by Catch2. To run the tests, simply execute the

Sourcetrail\_test

binary. Before executing, please make sure to set the working directory to

./bin/test

.

License

Sourcetrail is licensed under the GNU General Public License Version 3.

Trademark

The "Sourcetrail" name is a trademark owned by Coati Software and is not included within the assets licensed under the GNU GPLv3.

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.