diff options
Diffstat (limited to 'src/CMakeLists.txt')
-rw-r--r-- | src/CMakeLists.txt | 457 |
1 files changed, 457 insertions, 0 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt new file mode 100644 index 0000000..7ca556f --- /dev/null +++ b/src/CMakeLists.txt @@ -0,0 +1,457 @@ +# SPDX-License-Identifier: GPL-2.0-or-later +# ----------------------------------------------------------------------------- +# Define the main source +# ----------------------------------------------------------------------------- + +set(inkscape_SRC + alignment-snapper.cpp + attribute-rel-css.cpp + attribute-rel-svg.cpp + attribute-rel-util.cpp + attribute-sort-util.cpp + attributes.cpp + auto-save.cpp + axis-manip.cpp + hsluv.cpp + color.cpp + composite-undo-stack-observer.cpp + conditions.cpp + conn-avoid-ref.cpp + console-output-undo-observer.cpp + context-fns.cpp + desktop-events.cpp + desktop-style.cpp + desktop.cpp + device-manager.cpp + distribution-snapper.cpp + document-subset.cpp + document-undo.cpp + document.cpp + ege-color-prof-tracker.cpp + event-log.cpp + extract-uri.cpp + file.cpp + file-update.cpp + filter-chemistry.cpp + filter-enums.cpp + gc-anchored.cpp + gc-finalized.cpp + gradient-chemistry.cpp + gradient-drag.cpp + guide-snapper.cpp + grid-snapper.cpp + id-clash.cpp + inkscape.cpp + inkscape-version-info.cpp + layer-manager.cpp + line-geometry.cpp + line-snapper.cpp + media.cpp + message-context.cpp + message-stack.cpp + mod360.cpp + object-hierarchy.cpp + object-snapper.cpp + oklab.cpp + page-manager.cpp + path-chemistry.cpp + path-prefix.cpp + perspective-line.cpp + preferences.cpp + print.cpp + profile-manager.cpp + proj_pt.cpp + pure-transform.cpp + rdf.cpp + rubberband.cpp + selcue.cpp + selection-chemistry.cpp + selection-describer.cpp + selection.cpp + seltrans-handles.cpp + seltrans.cpp + snap-preferences.cpp + snap.cpp + snapped-curve.cpp + snapped-line.cpp + snapped-point.cpp + snapper.cpp + style-internal.cpp + style.cpp + text-chemistry.cpp + text-editing.cpp + transf_mat_3x4.cpp + unicoderange.cpp + vanishing-point.cpp + version.cpp + + # ------- + # Headers + alignment-snapper.h + attribute-rel-css.h + attribute-rel-svg.h + attribute-rel-util.h + attribute-sort-util.h + attributes.h + auto-save.h + axis-manip.h + bad-uri-exception.h + cms-color-types.h + cms-system.h + color-profile-cms-fns.h + color-rgba.h + hsluv.h + color.h + colorspace.h + composite-undo-stack-observer.h + conditions.h + conn-avoid-ref.h + console-output-undo-observer.h + context-fns.h + desktop-events.h + desktop-style.h + desktop.h + device-manager.h + distribution-snapper.h + document-subset.h + document-undo.h + document.h + ege-color-prof-tracker.h + enums.h + event-log.h + event.h + extract-uri.h + file.h + fill-or-stroke.h + filter-chemistry.h + filter-enums.h + gc-anchored.h + gc-finalized.h + gradient-chemistry.h + gradient-drag.h + guide-snapper.h + grid-snapper.h + id-clash.h + inkscape-version.h + inkscape-version-info.h + inkscape.h + layer-manager.h + line-geometry.h + line-snapper.h + media.h + message-context.h + message-stack.h + message.h + mod360.h + number-opt-number.h + object-hierarchy.h + object-snapper.h + oklab.h + page-manager.h + path-chemistry.h + path-prefix.h + pattern-manager.cpp + pattern-manager.h + pattern-manipulation.cpp + pattern-manipulation.h + perspective-line.h + preferences-skeleton.h + preferences.h + print.h + profile-manager.h + proj_pt.h + pure-transform.h + rdf.h + rubberband.h + selcue.h + selection-chemistry.h + selection-describer.h + selection.h + seltrans-handles.h + seltrans.h + snap-candidate.h + snap-enums.h + snap-preferences.h + snap.h + snapped-curve.h + snapped-line.h + snapped-point.h + snapper.h + streq.h + strneq.h + style-enums.h + style-internal.h + style.h + syseq.h + text-chemistry.h + text-editing.h + text-tag-attributes.h + transf_mat_3x4.h + undo-stack-observer.h + unicoderange.h + vanishing-point.h + version.h + + # TEMP Need to detangle inkscape-view from ui/interface.cpp + inkscape-window.h + inkscape-window.cpp + + inkscape-application.h + inkscape-application.cpp + actions/actions-effect-data.h + actions/actions-effect-data.cpp + actions/actions-extra-data.h + actions/actions-extra-data.cpp + actions/actions-hint-data.h + actions/actions-hint-data.cpp + + actions/actions-base.h + actions/actions-base.cpp + actions/actions-canvas-mode.h + actions/actions-canvas-mode.cpp + actions/actions-canvas-snapping.h + actions/actions-canvas-snapping.cpp + actions/actions-canvas-transform.h + actions/actions-canvas-transform.cpp + actions/actions-dialogs.cpp + actions/actions-dialogs.h + actions/actions-edit-document.h + actions/actions-edit-document.cpp + actions/actions-edit-window.h + actions/actions-edit-window.cpp + actions/actions-edit.h + actions/actions-edit.cpp + actions/actions-effect.h + actions/actions-effect.cpp + actions/actions-element-a.h + actions/actions-element-a.cpp + actions/actions-element-image.h + actions/actions-element-image.cpp + actions/actions-file-window.h + actions/actions-file-window.cpp + actions/actions-file.h + actions/actions-file.cpp + actions/actions-helper.h + actions/actions-helper.cpp + actions/actions-help-url.h + actions/actions-help-url.cpp + actions/actions-hide-lock.h + actions/actions-hide-lock.cpp + actions/actions-layer.h + actions/actions-layer.cpp + actions/actions-node-align.h + actions/actions-node-align.cpp + actions/actions-object.h + actions/actions-object.cpp + actions/actions-object-align.h + actions/actions-object-align.cpp + actions/actions-output.h + actions/actions-output.cpp + actions/actions-paths.h + actions/actions-paths.cpp + actions/actions-selection-object.h + actions/actions-selection-object.cpp + actions/actions-selection-window.h + actions/actions-selection-window.cpp + actions/actions-selection.h + actions/actions-selection.cpp + actions/actions-text.h + actions/actions-text.cpp + actions/actions-tools.h + actions/actions-tools.cpp + actions/actions-tutorial.h + actions/actions-tutorial.cpp + actions/actions-transform.h + actions/actions-transform.cpp + actions/actions-undo-document.h + actions/actions-undo-document.cpp + actions/actions-view-mode.h + actions/actions-view-mode.cpp + actions/actions-view-window.h + actions/actions-view-window.cpp + actions/actions-window.h + actions/actions-window.cpp + actions/actions-pages.h + actions/actions-pages.cpp + + inkview-application.h + inkview-application.cpp + inkview-window.h + inkview-window.cpp + + manipulation/copy-resource.h + manipulation/copy-resource.cpp +) + +# ----------------------------------------------------------------------------- +# Generate version file +# ----------------------------------------------------------------------------- + +# configure with values known at configure time +configure_file(inkscape-version.cpp.in ${CMAKE_BINARY_DIR}/src/inkscape-version.cpp.in @ONLY) + +# configure further at build time (always built as run_always.txt is never actually created) +add_custom_command( + OUTPUT inkscape-version.cpp run_always.txt + COMMAND ${CMAKE_COMMAND} + -DINKSCAPE_SOURCE_DIR=${CMAKE_SOURCE_DIR} + -DINKSCAPE_BINARY_DIR=${CMAKE_BINARY_DIR} + -P ${CMAKE_SOURCE_DIR}/CMakeScripts/inkscape-version.cmake + COMMENT "Generating inkscape-version.cpp") + +list(APPEND inkscape_SRC + ${CMAKE_BINARY_DIR}/src/inkscape-version.cpp +) + + +# ----------------------------------------------------------------------------- +# Load in subdirectories +# ----------------------------------------------------------------------------- + +# All folders for internal inkscape +# these call add_inkscape_source +add_subdirectory(actions) +add_subdirectory(async) +add_subdirectory(color) +add_subdirectory(debug) +add_subdirectory(display) +add_subdirectory(extension) +add_subdirectory(helper) +add_subdirectory(include) +add_subdirectory(io) +add_subdirectory(live_effects) +add_subdirectory(object) +add_subdirectory(path) +add_subdirectory(svg) +add_subdirectory(trace) +add_subdirectory(ui) +add_subdirectory(util) +add_subdirectory(widgets) +add_subdirectory(xml) + +# Directories containing lists files that describe building internal libraries +add_subdirectory(3rdparty) +add_subdirectory(inkgc) +add_subdirectory(livarot) +add_subdirectory(libnrtype) +include_directories("3rdparty/adaptagrams") + +get_property(inkscape_global_SRC GLOBAL PROPERTY inkscape_global_SRC) + +set(inkscape_SRC + ${inkscape_global_SRC} + ${inkscape_SRC} +) + +# ----------------------------------------------------------------------------- +# Setup the executable +# ----------------------------------------------------------------------------- +set(main_SRC + inkscape-main.cpp +) +set(view_SRC + inkview-main.cpp +) + +if(WIN32) + # Configure and add the platform specific resource files (enabling the app icon). + string(TIMESTAMP COPYRIGHT_YEAR %Y) + + set(FILE_NAME inkscape) + set(PROGRAM_NAME Inkscape) + set(PROGRAM_DESCRIPTION "Inkscape vector graphics editor") + configure_file(inkscape.rc ${CMAKE_BINARY_DIR}/src/inkscape.rc) + configure_file(inkscape-manifest.xml ${CMAKE_BINARY_DIR}/src/inkscape-manifest.xml) + list(APPEND main_SRC ${CMAKE_BINARY_DIR}/src/inkscape.rc) + + set(FILE_NAME inkview) + set(PROGRAM_NAME Inkview) + set(PROGRAM_DESCRIPTION "Inkview vector graphics viewer") + configure_file(inkscape.rc ${CMAKE_BINARY_DIR}/src/inkview.rc) + configure_file(inkscape-manifest.xml ${CMAKE_BINARY_DIR}/src/inkview-manifest.xml) + list(APPEND view_SRC ${CMAKE_BINARY_DIR}/src/inkview.rc) +endif() + +# make executables for inkscape and inkview +add_executable(inkscape ${main_SRC}) +add_executable(inkview ${view_SRC}) +if(WIN32) + # Make the same executables again, but this time as console application (GUI applications can't print to the console) + add_executable(inkscape_com ${main_SRC}) + set_target_properties(inkscape_com + PROPERTIES + LINK_FLAGS "-mconsole" + OUTPUT_NAME "inkscapecom" + SUFFIX ".com") + add_executable(inkview_com ${view_SRC}) + set_target_properties(inkview_com + PROPERTIES + LINK_FLAGS "-mconsole" + OUTPUT_NAME "inkviewcom" + SUFFIX ".com") +endif() + + +set(INKSCAPE_TARGET_LIBS + # order from automake + #sp_LIB + #inkscape_LIB + #sp_LIB # annoying, we need both! + croco_LIB + avoid_LIB + cola_LIB + vpsc_LIB + livarot_LIB + uemf_LIB + depixelize_LIB + autotrace_LIB + util_LIB + gc_LIB +) + +# Build everything except main and inkview.c in a shared library. +add_library(inkscape_base ${inkscape_SRC} ${sp_SRC}) +set_target_properties(inkscape_base PROPERTIES SOVERSION "${INKSCAPE_VERSION_MAJOR}.${INKSCAPE_VERSION_MINOR}.${INKSCAPE_VERSION_PATCH}.0") + +# added so that locally installed inkscape can find lib2geom if it's not installed systemwide +if(NOT APPLE) + set_target_properties(inkscape_base PROPERTIES INSTALL_RPATH "$ORIGIN/..") +else() + set_target_properties(inkscape_base PROPERTIES INSTALL_RPATH "@loader_path/..") +endif() + +if(WITH_INTERNAL_CAIRO) +add_dependencies(inkscape_base cairo_ext) +endif() + +target_link_libraries(inkscape_base PUBLIC Boost::filesystem) + +# Link the inkscape_base library against all external dependencies +target_link_libraries(inkscape_base + PRIVATE + ${INKSCAPE_TARGET_LIBS} + 2Geom::2geom + PUBLIC + ${INKSCAPE_LIBS} + ) +target_include_directories(inkscape_base INTERFACE ${2Geom_INCLUDE_DIRS}) + +# Link inkscape and inkview against inkscape_base +target_link_libraries(inkscape inkscape_base) +target_link_libraries(inkview inkscape_base) +if(WIN32) + target_link_libraries(inkscape_com inkscape_base) + target_link_libraries(inkview_com inkscape_base) +endif() + + + +#Define the installation +install(TARGETS inkscape inkview RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) +if(WIN32) + install(TARGETS inkscape_com RENAME "inkscape.com") + install(TARGETS inkview_com RENAME "inkview.com") +endif() +if(BUILD_SHARED_LIBS) + install(TARGETS inkscape_base LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}/inkscape") +endif() |