wxMaxima
|
To build wxMaxima from sources you need to have a C++ compiler (C++14), wxWidgets >= 3.0 (including development headers) and CMake >= 3.16 installed.
wxMaxima is built using the CMake build system.
The following steps will build and install wxMaxima using CMake. Download and extract wxMaxima and change in the wxMaxima tree. Then:
Now you can test your wxMaxima build (without installing it) by calling: ./wxmaxima-local
If everything is okay install it with:
If you want to install into a special prefix (not /usr/local
), add -DCMAKE_INSTALL_PREFIX=/your/installation/prefix
to the first cmake invocation. E.g.
Of course you can use the CMake GUI (cmake-gui
) or curses based CMake (ccmake
) for the configure step and change some CMake variables.
If you want to create binary packages (tar.gz, tar.bz2, DEB & RPM, on macOS also .dmg), the following command will create them:
To update the locale files (po and pot) in the source code:
You can use (or test) a fresh compiled wxMaxima (without installation) by calling ./wxmaxima-local
from the build-directory.
wxMaxima comes with several tests, which can be run using
from the build directory. If you want to run a single test, you can use the option -R <name-of-the-test>
when calling ctest
. The tests (and their names) can be seen in the file test/CMakeLists.txt
of the source code.
On Linux/Unix the tests usually require a X Server; if you start the tests without an X server (e.g. automatic tests using cron, when doing tests using a continuous integration system, etc.) you can use xvfb-run
to create a virtual X Server environment, e.g. just run: xvfb-run ctest
This requires wxWidgets to be installed, e.G. using MacPorts. If you are in the extracted wxMaxima directory, call e.g.
On Ubuntu < 24.04 install an older wxWidgets version (libwxbase3.0-dev libwxgtk3.0-gtk3-dev libwxgtk-webview3.0-gtk3-dev
instead of the version 3.2).
beforehand or (if apt-get is configured to load the source package repositories and not only the binary packages) by the simpler
You must use the apt-get install command when the version you are building has dependencies which are not listed as dependencies in your distro's repository version of wxmaxima.
On macOS X you most probably need the command-line compiler one can tell Xcode to install. Additionally wxWidgets needs to be installed, which can be done using Homebrew, Fink or MacPorts and should be named wxWidgets or wxMac there. XCode versions older than version 13.0 have problems compiling wxMaxima.
Additional information about building on macOS:
You can use the MinGW-w64 (https://www.mingw-w64.org/) compilers.
You can also build using MS Visual Studio 2019 or newer. Since MSVS provides adequate versions of both cmake and ninja, there's no need to install those. The build has to start from within the x64 Native Tools Command Prompt, and you have to first build wxWidgets before you build wxmaxima. You can get some inspiration about how to do both of these steps by examining the PowerShell scripts that do the building within .appveyor.yml
file.
These compilers come with two forms of thread support - win32 and posix. The win32 thread version does not support std::thread, which wxMaxima uses for multithreading, so be sure to install or reconfigure the posix version.
On Ubuntu Linux the crosscompiler x86_64-w64-mingw32-g++
can be reconfigured using:
(For 32 bit the same works for the 32 bit crosscompiler i686-w64-mingw32-g++
.)
Some information how to build for Android 9 can be found in the wxMaxima discussion forum: https://github.com/wxMaxima-developers/wxmaxima/discussions/1594
An HTML version of wxMaxima's source code documentation can be found at https://wxmaxima-developers.github.io/wxmaxima/Doxygen-documentation/
A local version of the documentation of wxMaxima's source can be generated using doxygen and the doxygen
target:
CMake has currently (Feb 2022) problems finding a wxWidgets that was compiled using CMake. If that is the reason maybe wxWidgets was compiled without wxWebView. In that case
might allow cmake to find wxWidgets at the cost of loosing the integrated dockable help browser.
wxMaxima, if linked statically, is pretty standalone and therefore fit for creating a portable app:
If a wxMaxima install should come without manual or translation files that might not be the end of the world, neither:
If you have problems when compiling wxMaxima, maybe a look in the configurations for various CI-Systems (.appveyor.yml
and files in .github/workflows/
) may be helpful to see, how wxMaxima is compiled on these systems.