A fast, robust nesting tool for laser cutters and other CNC tools
Deepnest is a desktop application originally based on SVGNest
- New nesting engine with speed critical code written in C
- Merges common lines for laser cuts
- Support for DXF files (via conversion)
- New path approximation feature for highly complex parts
This is a fork of Dogthemachine's fork of Jack000's
Deepnest, with changes made to the make it able to be built
again (only Windows has tested, but work was done in the binding.gyp
file to improve
multi-platform building, and the dependency on a local path to boost has been removed).
No attempts have been made to upgrade to the latest package versions, and as such this software depends on old packages. You must pay close attention to the prerequisites to get a successful build.
The primary goal has been to get Deepnest buildable again, to prevent it to become abandonware as the original author does not seem to be activley involved. The goal of creating the fork under this organization is to create again a centralized repo where development of this program can continue. It would be wonderful if more contributors join this organization so we can bring this project back to life, update it with latest dependencies and start adding features / fixing issues. There are a few small improvments (see Code changes in this fork).
- You must have Visual Studio with C++ extensions installed.
- Clone this fork with:
git clone --recurse-submodules --remote-submodules https://github.com/cmidgley/Deepnest
- Use Node.js version 8 (10 generates lots of warnings, and 12+ fails due to node-gyp). Recommend using the Node version manager. nvm-windows to download Node and change versions.
- Ensure you are on Python 2.7 (Python 3 does not work). Recommend using Python version manager
pyenv-win to download and change versions. Make sure to
close all command shells (including VSCode) after doing this, to get the latest environment
variables. Check with
python --version
.- NOTE: If you are running Windows 10 1905 or newer, you might need to disable the built-in Python launcher via Start > "Manage App Execution Aliases" and turning off the "App Installer" aliases for Python"
node-gyp
(the Node to C++ binding environment) requires Visual Studio with C++ extensions. See this page for a simple to install package that may work (not tested, as my system already has it already installed).
Your first build should do the following:
npm install
npm run w:build
If you change the electron-related files (web files, javascript), a build with
npm run w:build
is all that is needed. If you change the the Minkowski files (the .cc
or .h
files),
where the NFP (Non-Fit Polygon) logic and background threading is handled, you must rebuild using
node-gyp
to recompile the files using:
npm run w:fullbuild
Unless you want to create a distribution build (a separate set of executable files that can be run without dependency on the build environment), you can run Deepnest with:
npm run w:start
Two clean options:
- For regular clean of build artifacts, use
npm run w:clean
and thennpm run w:build
. - To remove everything, including
node_modules
usenpm run w:fullclean
, then build again.
To build a distribution set of files, run:
npm run w:dist
The resulting files will be located in .\deepnest-win32-x64
. All files need to be distributed,
meaning a ZIP file or writing a simple installer would be needed to avoid handling a larger number
of files.
If the environment variable "deepnest_debug" has a value of "1", Deepnest will open the browser dev tools (debugger/inspector).
Aside from improving the ability to build (mostly in binding.gyp
, package.json
, and
README.md
), the following changes have also been made:
- Cloned the
plus.svg
file intoadd_sheet.svg
(it was missing) for the add-sheet icon. - Added environment variable
deepnest_debug
to open the browser dev tools (see Browser dev tools). - Checked for thrown errors on a couple paths that would cause expections when closing the
application while the nest was still running. A better solution would be to cleanly shutdown the
workers when the app is closed, but this works for now (but could hide important exceptions).
The two places are marked with a
// todo:
comment inmain.js
. - Removed a bunch of unused source files. There are likely more to be discovered. There also appears to be code that is unused within the source files.
- Eliminated the dependency on a manually downloaded instance of boost (completion of work from
prior fork, using the
polygon
sub-repo). - Removed all build artifacts. This means there is no pre-built binaries in this fork and a build is required in order to use this. Eventually a cleaner release solution, perhaps with ZIP or an installer, should be added along with making releases offical in GitHub.
- Bumped the version number to 1.0.6cm (the 'cm' to indicate this has come from the
cmidgley
fork). - Eliminated the dependency on the
c:\nest
directory pre-existing, instead using the os-specific temp directory (os.tmpdir()
) and creating it if it does not exist. - Clarified the license is MIT. Removed an old reference to GPL and added the
license
property topackage.json
. Moved theLICENSE.txt
file to the root and renamed toLICENSE
.