Skip to content

Tools, documentation, and reference implementation of a Max Package built using the Min-API.

License

Notifications You must be signed in to change notification settings

whistleaudio/min-devkit

This branch is 50 commits behind Cycling74/min-devkit:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Robert Ramirez
Oct 29, 2020
d18840d · Oct 29, 2020
Oct 29, 2020
Jul 15, 2020
Dec 20, 2018
Jul 15, 2020
Jun 12, 2020
Dec 19, 2017
May 14, 2020
Oct 27, 2020
Oct 29, 2020
Jun 12, 2018
Apr 15, 2020
Apr 13, 2018
Mar 30, 2018
Apr 15, 2020
May 8, 2020
Feb 27, 2017
Dec 20, 2018
Sep 23, 2016
Feb 27, 2017
Mar 30, 2018
Jun 11, 2020
Oct 21, 2020
May 14, 2020
Dec 20, 2018

Repository files navigation

Min-DevKit

CI

Tools, documentation, and reference implementation of a Max Package built using the Min-API.

Structure

There are two layers of material included in the Min-DevKit package.

  • min-devkit is an example package following current best-practices for package creation.
  • min-api is a folder within the devkit containing all of the support files you will need to compile an external object written in modern C++. This folder you will include in your own package's source folder.
  • min-lib contains building blocks, helper classes, and unit generators that may be useful in authoring C++ code for audio, video, and data processing.

Prerequisites

To build the externals in this package you will need some form of compiler support on your system.

  • On the Mac this means Xcode 10 or 11 (you can get from the App Store for free).
  • On Windows this means Visual Studio 2017 or 2019 (you can download a free version from Microsoft). The installer for Visual Studio 2017 offers an option to install Git, which you should choose to do.

You will also need to install a recent version of CMake (version 3.10 or higher).

Building

  1. Clone the Min-DevKit from Github (or download from inside of Max using the Package Manager). If you clone it from Github, you should clone it into Max's Packages folder. If you clone it elsewhere you will need to make an alias to it in your Packages folder. The Packages folder can be found inside of your Max 8 folder which is inside of your user's Documents folder. Make sure you clone recursively so that all sub-modules are properly initiated : git clone https://github.com/Cycling74/min-devkit.git --recursive
  2. In the Terminal or Console app of your choice, change directories (cd) into the Min-Devkit folder you cloned/installed in step 0.
  3. mkdir build to create a folder with your various build files
  4. cd build to put yourself into that folder
  5. Now you can generate the projects for your choosen build environment:

Mac

Run cmake -G Xcode ..

Next run cmake --build . or open the Xcode project from this "build" folder and use the GUI.

Note: you can add the -j4 option where "4" is the number of cores to use. This can help to speed up your builds, though sometimes the error output is interleaved in such a way as to make troubleshooting more difficult.

Windows

You can run cmake --help to get a list of the options available. Assuming some version of Visual Studio 2019, the commands to generate the projects will look like this:

cmake -G "Visual Studio 16 2019" ..

Or using Visual Studio 2017 it will look like this:

cmake -G "Visual Studio 15 2017 Win64" ..

Having generated the projects, you can now build by opening the .sln file in the build folder with the Visual Studio app (just double-click the .sln file) or you can build on the command line like this:

cmake --build . --config Release

Unit Testing

On the command line you can run all unit tests using Cmake:

  • on debug builds: ctest -C Debug .
  • on release builds: ctest -C Release .

Or you can run an individual test, which is simply a command line program:

  • cd ..
  • cd tests
  • mac example: ./test_dcblocker_tilde -s
  • win example: test_dcblocker_tilde.exe -s

Or you can run them with your IDE's debugger by selecting the "RUN_TESTS" target.

Continuous Integration

Continuous Integration (CI) is a process by which each code check-in is verified by an automated build and automated tests to allow developers to detect problems early and distribute software easily.

The Min-DevKit project models CI using Github Actions.

Fetching your builds

  • Windows: On Appveyor it is simple. You go to the latest build, choose the "Platform" and then look under the "Artifacts" tab.
  • Mac: Travis CI does not host your build files for you like Appveyor. Instead, you need to configure a place for Travis to upload your builds. This is most easily done by signing up for a free Amazon Web Services account.

Additional Documentation

Contributors / Acknowledgements

Support

For support, please use the developer forums at: http://cycling74.com/forums/

About

Tools, documentation, and reference implementation of a Max Package built using the Min-API.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • CMake 86.8%
  • Max 5.6%
  • Vim Script 2.7%
  • C 2.3%
  • C++ 1.7%
  • Shell 0.5%
  • Other 0.4%