Skip to content

Commit

Permalink
INSTALL.md: Formatting, markdown cleanup
Browse files Browse the repository at this point in the history
  • Loading branch information
ferdnyc committed Mar 31, 2020
1 parent 166f693 commit 140e082
Showing 1 changed file with 111 additions and 71 deletions.
182 changes: 111 additions & 71 deletions INSTALL.md
Expand Up @@ -2,90 +2,120 @@

Operating system specific install instructions are located in:

* doc/INSTALL-LINUX.md
* doc/INSTALL-MAC.md
* doc/INSTALL-WINDOWS.md
* [doc/INSTALL-LINUX.md][INSTALL-LINUX]
* [doc/INSTALL-MAC.md][INSTALL-MAC]
* [doc/INSTALL-WINDOWS.md][INSTALL-WINDOWS]

## Getting Started

The best way to get started with libopenshot, is to learn about our build system, obtain all the source code,
install a development IDE and tools, and better understand our dependencies. So, please read through the
following sections, and follow the instructions. And keep in mind, that your computer is likely different
than the one used when writing these instructions. Your file paths and versions of applications might be
The best way to get started with libopenshot, is to learn about our build system, obtain all the source code,
install a development IDE and tools, and better understand our dependencies. So, please read through the
following sections, and follow the instructions. And keep in mind, that your computer is likely different
than the one used when writing these instructions. Your file paths and versions of applications might be
slightly different, so keep an eye out for subtle file path differences in the commands you type.

## Build Tools

CMake is the backbone of our build system. It is a cross-platform build system, which checks for dependencies,
locates header files and libraries, generates makefiles, and supports the cross-platform compiling of
libopenshot and libopenshot-audio. CMake uses an out-of-source build concept, where all temporary build
files, such as makefiles, object files, and even the final binaries, are created outside of the source
code folder, inside a /build/ sub-folder. This prevents the build process from cluttering up the source
code. These instructions have only been tested with the GNU compiler (including MSYS2/MinGW for Windows).
CMake is the backbone of our build system.
It is a cross-platform build system, which checks for dependencies,
locates header files and libraries, and generates a build system in various formats.
We use CMake's Makefile generators to compile libopenshot and libopenshot-audio.

## Dependencies
CMake uses an out-of-source build concept.
This means that the build system, all temporary files, and all generated products are kept separate from the source code.
This includes Makefiles, object files, and even the final binaries.
While it is possible to build in-tree, we highly recommend you use a `/build/` sub-folder to compile each library.
This prevents the build process from cluttering up the source
code.
These instructions have only been tested with the GNU compiler suite (including MSYS2/MinGW for Windows), and the Clang compiler (including AppleClang on MacOS).

The following libraries are required to build libopenshot. Instructions on how to install these
dependencies vary for each operating system. Libraries and Executables have been labeled in the
list below to help distinguish between them.
### Dependencies

* ### FFmpeg (libavformat, libavcodec, libavutil, libavdevice, libavresample, libswscale)
* http://www.ffmpeg.org/ `(Library)`
The following libraries are required to build libopenshot.
Instructions on how to install these dependencies vary for each operating system.
Libraries and Executables have been labeled in the list below to help distinguish between them.

#### FFmpeg (libavformat, libavcodec, libavutil, libavdevice, libavresample, libswscale)

* http://www.ffmpeg.org/ **(Library)**
* This library is used to decode and encode video, audio, and image files. It is also used to obtain information about media files, such as frame rate, sample rate, aspect ratio, and other common attributes.

* ### ImageMagick++ (libMagick++, libMagickWand, libMagickCore)
* http://www.imagemagick.org/script/magick++.php `(Library)`
#### ImageMagick++ (libMagick++, libMagickWand, libMagickCore)
* http://www.imagemagick.org/script/magick++.php **(Library)**
* This library is **optional**, and used to decode and encode images.

* ### OpenShot Audio Library (libopenshot-audio)
* https://github.com/OpenShot/libopenshot-audio/ `(Library)`
#### OpenShot Audio Library (libopenshot-audio)
* https://github.com/OpenShot/libopenshot-audio/ **(Library)**
* This library is used to mix, resample, host plug-ins, and play audio. It is based on the JUCE project, which is an outstanding audio library used by many different applications

* ### Qt 5 (libqt5)
* http://www.qt.io/qt5/ `(Library)`
#### Qt 5 (libqt5)
* http://www.qt.io/qt5/ **(Library)**
* Qt5 is used to display video, store image data, composite images, apply image effects, and many other utility functions, such as file system manipulation, high resolution timers, etc...

* ### CMake (cmake)
* http://www.cmake.org/ `(Executable)`
#### ZeroMQ (libzmq)
* http://zeromq.org/ **(Library)**
* This library is used to communicate between libopenshot and other applications (publisher / subscriber). Primarily used to send debug data from libopenshot.

#### OpenMP (`-fopenmp`)
* http://openmp.org/wp/ **(Compiler Flag)**
* If your compiler supports this flag (GCC, Clang, and most other compilers), it provides libopenshot with easy methods of using parallel programming techniques to improve performance and take advantage of multi-core processors.

#### CMake (`cmake`)
* http://www.cmake.org/ **(Executable)**
* This executable is used to automate the generation of Makefiles, check for dependencies, and is the backbone of libopenshot’s cross-platform build process.

* ### SWIG (swig)
* http://www.swig.org/ `(Executable)`
#### SWIG (`swig`)
* http://www.swig.org/ **(Executable)**
* This executable is used to generate the Python and Ruby bindings for libopenshot. It is a simple and powerful wrapper for C++ libraries, and supports many languages.

* ### Python 3 (libpython)
* http://www.python.org/ `(Executable and Library)`
#### Python 3 (libpython)
* http://www.python.org/ **(Executable and Library)**
* This library is used by swig to create the Python (version 3+) bindings for libopenshot. This is also the official language used by OpenShot Video Editor (a graphical interface to libopenshot).

* ### Doxygen (doxygen)
* http://www.stack.nl/~dimitri/doxygen/ `(Executable)`
#### Doxygen (doxygen)
* http://www.stack.nl/~dimitri/doxygen/ **(Executable)**
* This executable is used to auto-generate the documentation used by libopenshot.

* ### UnitTest++ (libunittest++)
* https://github.com/unittest-cpp/ `(Library)`
#### UnitTest++ (libunittest++)
* https://github.com/unittest-cpp/ **(Library)**
* This library is used to execute unit tests for libopenshot. It contains many macros used to keep our unit testing code very clean and simple.

* ### ZeroMQ (libzmq)
* http://zeromq.org/ `(Library)`
* This library is used to communicate between libopenshot and other applications (publisher / subscriber). Primarily used to send debug data from libopenshot.

* ### OpenMP (-fopenmp)
* http://openmp.org/wp/ `(Compiler Flag)`
* If your compiler supports this flag (GCC, Clang, and most other compilers), it provides libopenshot with easy methods of using parallel programming techniques to improve performance and take advantage of multi-core processors.
### CMake Flags (Optional)
There are many different build flags that can be passed to cmake to adjust how libopenshot is compiled. Some of these flags might be required when compiling on certain OSes, just depending on how your build environment is setup.

## CMake Flags (Optional)
There are many different build flags that can be passed to cmake to adjust how libopenshot is compiled. Some of these flags might be required when compiling on certain OSes, just depending on how your build environment is setup. To add a build flag, follow this general syntax: $ cmake -DMAGICKCORE_HDRI_ENABLE=1 -DENABLE_TESTS=1 ../
To add a build flag, follow this general syntax:

* MAGICKCORE_HDRI_ENABLE (default 0)
* MAGICKCORE_QUANTUM_DEPTH (default 0)
* OPENSHOT_IMAGEMAGICK_COMPATIBILITY (default 0)
* DISABLE_TESTS (default 0)
* CMAKE_PREFIX_PATH (`/location/to/missing/library/`)
* PYTHON_INCLUDE_DIR (`/location/to/python/include/`)
* PYTHON_LIBRARY (`/location/to/python/lib.a`)
* PYTHON_FRAMEWORKS (`/usr/local/Cellar/python3/3.3.2/Frameworks/Python.framework/`)
* CMAKE_CXX_COMPILER (`/location/to/mingw/g++`)
* CMAKE_C_COMPILER (`/location/to/mingw/gcc`)
```sh
$ cmake -DMAGICKCORE_HDRI_ENABLE=1 -DENABLE_TESTS=1 ..
```

Following are some of the flags you might need to set when generating your build system.

##### Optional behavior:
* `-DENABLE_TESTS=0` (default: `ON`)
* `-DENABLE_COVERAGE=1` (default: `OFF`)
* `-DENABLE_DOCS=0` (default: `ON` if doxygen found)

##### Compiler configuration:
* `-DCMAKE_BUILD_TYPE=Debug` (default: `Release`)
* `-DCMAKE_CXX_FLAGS="-Wall -Wextra"` (default: auto for build type)
* `-DCMAKE_CXX_COMPILER=/path/to/g++`
* `-DCMAKE_C_COMPILER=/path/to/gcc` (used by CMake for OS probes)

##### Dependency configuration:
* `-DCMAKE_PREFIX_PATH=/extra/path/to/search/for/libraries/`
* `-DUSE_SYSTEM_JSONCPP=0` (default: auto if discovered)
* `-DImageMagick_FOUND=0` (default: auto if discovered)

##### To compile bindings for a specific Python installation:
* `-DPYTHON_INCLUDE_DIR=/location/of/python/includes/`
* `-DPYTHON_LIBRARY=/location/of/libpython*.so`
* `-DPYTHON_FRAMEWORKS=/usr/local/Cellar/python3/3.3.2/Frameworks/Python.framework/` (MacOS only)

##### Only used when building with ImageMagick enabled:
* `-DMAGICKCORE_HDRI_ENABLE=1` (default `0`)
* `-DMAGICKCORE_QUANTUM_DEPTH=8` (default `16`)

## Obtaining Source Code

Expand All @@ -96,30 +126,36 @@ git clone https://github.com/OpenShot/libopenshot.git
git clone https://github.com/OpenShot/libopenshot-audio.git
```

## Folder Structure (libopenshot)
### Folder Structure (libopenshot)

The source code is divided up into the following folders.

* ### build/
* This folder needs to be manually created, and is used by cmake to store the temporary build files, such as makefiles, as well as the final binaries (library and test executables).
#### `build/`
This folder needs to be manually created, and is used by cmake to store the temporary build files, such as makefiles, as well as the final binaries (library and test executables).

* ### cmake/
* This folder contains custom modules not included by default in cmake, used to find dependency libraries and headers and determine if these libraries are installed.
#### `cmake/`
This folder contains custom modules not included by default in cmake.
CMake find modules are used to discover dependency libraries on the system, and to incorporate their headers and object files.
CMake code modules are used to implement build features such as test coverage scanning.

* ### doc/
* This folder contains documentation and related files, such as logos and images required by the doxygen auto-generated documentation.
#### `doc/`
This folder contains documentation and related files.
This includes logos and images required by the doxygen-generated API documentation.

* ### include/
* This folder contains all headers (*.h) used by libopenshot.
#### `include/`
This folder contains all headers (*.h) used by libopenshot.

* ### src/
* This folder contains all source code (*.cpp) used by libopenshot.
#### `src/`
This folder contains all source code (*.cpp) used by libopenshot.

* ### tests/
* This folder contains all unit test code. Each class has it’s own test file (*.cpp), and uses UnitTest++ macros to keep the test code simple and manageable.
#### `tests/`
This folder contains all unit test code.
Each test file (`<class>_Tests.cpp`) contains the tests for the named class.
We use UnitTest++ macros to keep the test code simple and manageable.

* ### thirdparty/
* This folder contains code not written by the OpenShot team. For example, jsoncpp, an open-source JSON parser.
#### `thirdparty/`
This folder contains code not written by the OpenShot team.
For example, `jsoncpp`, an open-source JSON parser.

## Linux Build Instructions (libopenshot-audio)
To compile libopenshot-audio, we need to go through a few additional steps to manually build and install it. Launch a terminal and enter:
Expand Down Expand Up @@ -148,6 +184,10 @@ make install

For more detailed instructions, please see:

* doc/INSTALL-LINUX.md
* doc/INSTALL-MAC.md
* doc/INSTALL-WINDOWS.md
* [doc/INSTALL-LINUX.md][INSTALL-LINUX]
* [doc/INSTALL-MAC.md][INSTALL-MAC]
* [doc/INSTALL-WINDOWS.md][INSTALL-WINDOWS]

[INSTALL-LINUX]: https://github.com/OpenShot/libopenshot/blob/develop/doc/INSTALL-LINUX.md
[INSTALL-MAC]: https://github.com/OpenShot/libopenshot/blob/develop/doc/INSTALL-MAC.md
[INSTALL-WINDOWS]: https://github.com/OpenShot/libopenshot/blob/develop/doc/INSTALL-WINDOWS.md

0 comments on commit 140e082

Please sign in to comment.