498 lines
15 KiB
CMake
498 lines
15 KiB
CMake
# .cpp files are compiled with extra ${WSHADOW_FLAGS}
|
|
if( COMPILER_SUPPORTS_WSHADOW )
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${WSHADOW_FLAGS}")
|
|
endif()
|
|
|
|
add_definitions( -DEESCHEMA )
|
|
|
|
if( KICAD_SPICE )
|
|
set( INC_AFTER ${INC_AFTER} ${NGSPICE_INCLUDE_DIR} )
|
|
|
|
# Find out the exact libngspice file name
|
|
get_filename_component( NGSPICE_DLL_REALPATH "${NGSPICE_DLL}" REALPATH )
|
|
get_filename_component( NGSPICE_DLL_FILE "${NGSPICE_DLL_REALPATH}" NAME )
|
|
|
|
set_property( SOURCE sim/ngspice.cpp
|
|
APPEND PROPERTY COMPILE_DEFINITIONS
|
|
NGSPICE_DLL_FILE="${NGSPICE_DLL_FILE}"
|
|
)
|
|
endif()
|
|
|
|
include_directories( BEFORE ${INC_BEFORE} )
|
|
include_directories(
|
|
./dialogs
|
|
./netlist_exporters
|
|
./widgets
|
|
./libedit
|
|
./libview
|
|
./tools
|
|
../common
|
|
../common/dialogs
|
|
${INC_AFTER}
|
|
)
|
|
|
|
|
|
set( EESCHEMA_DLGS
|
|
dialogs/dialog_annotate.cpp
|
|
dialogs/dialog_annotate_base.cpp
|
|
dialogs/dialog_bom.cpp
|
|
dialogs/dialog_bom_base.cpp
|
|
dialogs/dialog_bom_cfg_keywords.cpp
|
|
dialogs/dialog_bus_manager.cpp
|
|
dialogs/dialog_fields_editor_global.cpp
|
|
dialogs/dialog_fields_editor_global_base.cpp
|
|
dialogs/dialog_choose_component.cpp
|
|
dialogs/dialog_edit_component_in_lib.cpp
|
|
dialogs/dialog_edit_component_in_lib_base.cpp
|
|
dialogs/dialog_edit_component_in_schematic.cpp
|
|
dialogs/dialog_edit_component_in_schematic_base.cpp
|
|
dialogs/dialog_edit_components_libid.cpp
|
|
dialogs/dialog_edit_components_libid_base.cpp
|
|
dialogs/dialog_edit_label.cpp
|
|
dialogs/dialog_edit_label_base.cpp
|
|
dialogs/dialog_edit_line_style.cpp
|
|
dialogs/dialog_edit_line_style_base.cpp
|
|
dialogs/dialog_edit_one_field.cpp
|
|
dialogs/dialog_erc.cpp
|
|
dialogs/dialog_erc_base.cpp
|
|
dialogs/dialog_global_sym_lib_table_config.cpp
|
|
dialogs/dialog_lib_edit_draw_item.cpp
|
|
dialogs/dialog_lib_edit_draw_item_base.cpp
|
|
dialogs/dialog_lib_edit_pin.cpp
|
|
dialogs/dialog_lib_edit_pin_base.cpp
|
|
dialogs/dialog_lib_edit_pin_table.cpp
|
|
dialogs/dialog_lib_edit_pin_table_base.cpp
|
|
dialogs/dialog_lib_edit_text.cpp
|
|
dialogs/dialog_lib_edit_text_base.cpp
|
|
dialogs/dialog_lib_new_component.cpp
|
|
dialogs/dialog_lib_new_component_base.cpp
|
|
dialogs/dialog_migrate_buses.cpp
|
|
dialogs/dialog_migrate_buses_base.cpp
|
|
dialogs/dialog_netlist.cpp
|
|
dialogs/dialog_netlist_base.cpp
|
|
dialogs/dialog_plot_schematic.cpp
|
|
dialogs/dialog_plot_schematic_base.cpp
|
|
dialogs/dialog_print_using_printer.cpp
|
|
dialogs/dialog_print_using_printer_base.cpp
|
|
dialogs/dialog_rescue_each.cpp
|
|
dialogs/dialog_rescue_each_base.cpp
|
|
dialogs/dialog_sch_edit_sheet_pin.cpp
|
|
dialogs/dialog_sch_edit_sheet_pin_base.cpp
|
|
dialogs/dialog_sch_sheet_props.cpp
|
|
dialogs/dialog_sch_sheet_props_base.cpp
|
|
dialogs/dialog_schematic_find.cpp
|
|
dialogs/dialog_schematic_find_base.cpp
|
|
dialogs/dialog_set_grid.cpp
|
|
dialogs/dialog_set_grid_base.cpp
|
|
dialogs/dialog_symbol_remap.cpp
|
|
dialogs/dialog_symbol_remap_base.cpp
|
|
dialogs/dialog_update_fields.cpp
|
|
dialogs/dialog_update_fields_base.cpp
|
|
dialogs/panel_eeschema_template_fieldnames.cpp
|
|
dialogs/panel_eeschema_template_fieldnames_base.cpp
|
|
dialogs/panel_eeschema_display_options.cpp
|
|
dialogs/panel_eeschema_display_options_base.cpp
|
|
dialogs/panel_eeschema_settings.cpp
|
|
dialogs/panel_eeschema_settings_base.cpp
|
|
dialogs/panel_libedit_display_options.cpp
|
|
dialogs/panel_libedit_settings.cpp
|
|
dialogs/panel_libedit_settings_base.cpp
|
|
dialogs/panel_sym_lib_table.cpp
|
|
dialogs/panel_sym_lib_table_base.cpp
|
|
)
|
|
|
|
set( EESCHEMA_WIDGETS
|
|
widgets/pin_shape_combobox.cpp
|
|
widgets/pin_type_combobox.cpp
|
|
widgets/symbol_preview_widget.cpp
|
|
widgets/symbol_tree_pane.cpp
|
|
widgets/widget_eeschema_color_config.cpp
|
|
)
|
|
|
|
|
|
set ( EESCHEMA_LIBEDIT_SRCS
|
|
libedit/block_libedit.cpp
|
|
libedit/controller.cpp
|
|
libedit/libedit.cpp
|
|
libedit/libedit_onleftclick.cpp
|
|
libedit/libedit_onrightclick.cpp
|
|
libedit/libedit_plot_component.cpp
|
|
libedit/libedit_undo_redo.cpp
|
|
libedit/lib_edit_frame.cpp
|
|
libedit/libfield.cpp
|
|
libedit/menubar_libedit.cpp
|
|
libedit/pinedit.cpp
|
|
libedit/symbdraw.cpp
|
|
libedit/symbedit.cpp
|
|
libedit/toolbars_libedit.cpp
|
|
libedit/lib_export.cpp
|
|
libedit/lib_manager.cpp
|
|
|
|
)
|
|
set( EESCHEMA_SRCS
|
|
${EESCHEMA_DLGS}
|
|
${EESCHEMA_WIDGETS}
|
|
${EESCHEMA_LIBEDIT_SRCS}
|
|
bom_plugins.cpp
|
|
sch_view.cpp
|
|
sch_painter.cpp
|
|
annotate.cpp
|
|
autoplace_fields.cpp
|
|
backanno.cpp
|
|
block.cpp
|
|
bus_alias.cpp
|
|
bus-wire-junction.cpp
|
|
class_libentry.cpp
|
|
class_library.cpp
|
|
cmp_library_keywords.cpp
|
|
cmp_library_lexer.cpp
|
|
component_references_lister.cpp
|
|
controle.cpp
|
|
connection_graph.cpp
|
|
cross-probing.cpp
|
|
drc_erc_item.cpp
|
|
edit_bitmap.cpp
|
|
edit_component_in_schematic.cpp
|
|
edit_label.cpp
|
|
eeschema.cpp
|
|
eeschema_config.cpp
|
|
erc.cpp
|
|
fields_grid_table.cpp
|
|
files-io.cpp
|
|
find.cpp
|
|
generate_alias_info.cpp
|
|
getpart.cpp
|
|
hierarch.cpp
|
|
hotkeys.cpp
|
|
lib_arc.cpp
|
|
lib_bezier.cpp
|
|
lib_circle.cpp
|
|
lib_draw_item.cpp
|
|
lib_field.cpp
|
|
lib_pin.cpp
|
|
lib_polyline.cpp
|
|
lib_rectangle.cpp
|
|
lib_text.cpp
|
|
libarch.cpp
|
|
menubar.cpp
|
|
netlist_generator.cpp
|
|
netlist_object_list.cpp
|
|
netlist_object.cpp
|
|
pin_number.cpp
|
|
pin_shape.cpp
|
|
pin_type.cpp
|
|
plot_schematic_DXF.cpp
|
|
plot_schematic_HPGL.cpp
|
|
plot_schematic_PDF.cpp
|
|
plot_schematic_PS.cpp
|
|
plot_schematic_SVG.cpp
|
|
sch_draw_panel.cpp
|
|
project_rescue.cpp
|
|
sch_base_frame.cpp
|
|
sch_bitmap.cpp
|
|
sch_bus_entry.cpp
|
|
sch_collectors.cpp
|
|
sch_component.cpp
|
|
sch_connection.cpp
|
|
sch_eagle_plugin.cpp
|
|
sch_field.cpp
|
|
sch_io_mgr.cpp
|
|
sch_item_struct.cpp
|
|
sch_junction.cpp
|
|
sch_legacy_plugin.cpp
|
|
sch_line.cpp
|
|
sch_marker.cpp
|
|
sch_no_connect.cpp
|
|
sch_pin.cpp
|
|
sch_plugin.cpp
|
|
sch_preview_panel.cpp
|
|
sch_screen.cpp
|
|
sch_sheet.cpp
|
|
sch_sheet_path.cpp
|
|
sch_sheet_pin.cpp
|
|
sch_text.cpp
|
|
sch_validators.cpp
|
|
schematic_undo_redo.cpp
|
|
sch_edit_frame.cpp
|
|
selpart.cpp
|
|
sheet.cpp
|
|
symbol_lib_table.cpp
|
|
symbol_tree_model_adapter.cpp
|
|
symbol_tree_synchronizing_adapter.cpp
|
|
template_fieldnames.cpp
|
|
template_fieldnames_keywords.cpp
|
|
toolbars_sch_editor.cpp
|
|
toolbars_viewlib.cpp
|
|
transform.cpp
|
|
viewlib_frame.cpp
|
|
viewlibs.cpp
|
|
|
|
netlist_exporters/netlist_exporter.cpp
|
|
netlist_exporters/netlist_exporter_cadstar.cpp
|
|
netlist_exporters/netlist_exporter_generic.cpp
|
|
netlist_exporters/netlist_exporter_kicad.cpp
|
|
netlist_exporters/netlist_exporter_orcadpcb2.cpp
|
|
netlist_exporters/netlist_exporter_pspice.cpp
|
|
|
|
tools/sch_actions.cpp
|
|
tools/sch_drawing_tool.cpp
|
|
tools/sch_edit_tool.cpp
|
|
tools/sch_editor_control.cpp
|
|
tools/sch_inspection_tool.cpp
|
|
tools/sch_wire_bus_tool.cpp
|
|
tools/sch_move_tool.cpp
|
|
tools/sch_picker_tool.cpp
|
|
tools/sch_selection_tool.cpp
|
|
tools/selection.cpp
|
|
)
|
|
|
|
|
|
set( EESCHEMA_COMMON_SRCS
|
|
../common/dialogs/dialog_page_settings.cpp
|
|
../common/base_screen.cpp
|
|
../common/base_units.cpp
|
|
../common/eda_text.cpp
|
|
../common/page_info.cpp
|
|
)
|
|
|
|
|
|
if( KICAD_SPICE )
|
|
set( EESCHEMA_SRCS
|
|
${EESCHEMA_SRCS}
|
|
sim/netlist_exporter_pspice_sim.cpp
|
|
sim/ngspice.cpp
|
|
sim/sim_plot_frame.cpp
|
|
sim/sim_plot_frame_base.cpp
|
|
sim/sim_plot_panel.cpp
|
|
sim/simulate.cpp
|
|
sim/spice_simulator.cpp
|
|
sim/spice_value.cpp
|
|
simulation_cursors.cpp
|
|
dialogs/dialog_signal_list.cpp
|
|
dialogs/dialog_signal_list_base.cpp
|
|
dialogs/dialog_sim_settings.cpp
|
|
dialogs/dialog_sim_settings_base.cpp
|
|
dialogs/dialog_spice_model.cpp
|
|
dialogs/dialog_spice_model_base.cpp
|
|
widgets/tuner_slider.cpp
|
|
widgets/tuner_slider_base.cpp
|
|
)
|
|
endif()
|
|
|
|
|
|
if( MINGW )
|
|
# EESCHEMA_RESOURCES variable is set by the macro.
|
|
mingw_resource_compiler( eeschema )
|
|
else()
|
|
set( EESCHEMA_RESOURCES eeschema.rc )
|
|
endif()
|
|
|
|
# Create a C++ compilable string initializer containing html text into a *.h file:
|
|
add_custom_command(
|
|
OUTPUT ${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help_html.h
|
|
COMMAND ${CMAKE_COMMAND}
|
|
-DinputFile=${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help.html
|
|
-DoutputFile=${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help_html.h
|
|
-P ${CMAKE_MODULE_PATH}/Html2C.cmake
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help.html
|
|
COMMENT "creating ${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help_html.h
|
|
from ${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help.html"
|
|
)
|
|
|
|
set_source_files_properties( dialogs/dialog_bom.cpp
|
|
PROPERTIES
|
|
OBJECT_DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_help_html.h
|
|
)
|
|
|
|
if( APPLE )
|
|
# setup bundle
|
|
set( EESCHEMA_RESOURCES eeschema.icns eeschema_doc.icns )
|
|
set_source_files_properties( "${CMAKE_CURRENT_SOURCE_DIR}/eeschema.icns" PROPERTIES
|
|
MACOSX_PACKAGE_LOCATION Resources
|
|
)
|
|
set_source_files_properties( "${CMAKE_CURRENT_SOURCE_DIR}/eeschema_doc.icns" PROPERTIES
|
|
MACOSX_PACKAGE_LOCATION Resources
|
|
)
|
|
set( MACOSX_BUNDLE_ICON_FILE eeschema.icns )
|
|
set( MACOSX_BUNDLE_GUI_IDENTIFIER org.kicad-pcb.kicad )
|
|
set( MACOSX_BUNDLE_NAME eeschema )
|
|
endif()
|
|
|
|
|
|
add_executable( eeschema WIN32 MACOSX_BUNDLE
|
|
../common/single_top.cpp
|
|
../common/pgm_base.cpp
|
|
${EESCHEMA_RESOURCES}
|
|
)
|
|
set_source_files_properties( ../common/single_top.cpp PROPERTIES
|
|
COMPILE_DEFINITIONS "TOP_FRAME=FRAME_SCH;PGM_DATA_FILE_EXT=\"sch\";BUILD_KIWAY_DLL"
|
|
)
|
|
target_link_libraries( eeschema
|
|
#singletop # replaces common, giving us restrictive control and link warnings.
|
|
# There's way too much crap coming in from common yet.
|
|
gal
|
|
legacy_gal
|
|
common
|
|
${wxWidgets_LIBRARIES}
|
|
)
|
|
|
|
# the DSO (KIFACE) housing the main eeschema code:
|
|
add_library( eeschema_kiface SHARED
|
|
${EESCHEMA_SRCS}
|
|
${EESCHEMA_COMMON_SRCS}
|
|
)
|
|
target_link_libraries( eeschema_kiface
|
|
gal
|
|
legacy_gal
|
|
common
|
|
${wxWidgets_LIBRARIES}
|
|
${GDI_PLUS_LIBRARIES}
|
|
)
|
|
target_include_directories( eeschema_kiface PUBLIC
|
|
${CMAKE_CURRENT_SOURCE_DIR}
|
|
)
|
|
|
|
if( KICAD_SPICE )
|
|
target_link_libraries( eeschema_kiface
|
|
${NGSPICE_LIBRARY}
|
|
)
|
|
endif()
|
|
|
|
set_target_properties( eeschema_kiface PROPERTIES
|
|
# Decorate OUTPUT_NAME with PREFIX and SUFFIX, creating something like
|
|
# _eeschema.so, _eeschema.dll, or _eeschema.kiface
|
|
OUTPUT_NAME eeschema
|
|
PREFIX ${KIFACE_PREFIX}
|
|
SUFFIX ${KIFACE_SUFFIX}
|
|
)
|
|
|
|
# The KIFACE is in eeschema.cpp, export it:
|
|
set_source_files_properties( eeschema.cpp PROPERTIES
|
|
COMPILE_DEFINITIONS "BUILD_KIWAY_DLL;COMPILING_DLL"
|
|
)
|
|
|
|
# if building eeschema, then also build eeschema_kiface if out of date.
|
|
add_dependencies( eeschema eeschema_kiface )
|
|
|
|
if( MAKE_LINK_MAPS )
|
|
# generate link map with cross reference
|
|
set_target_properties( eeschema_kiface PROPERTIES
|
|
LINK_FLAGS "-Wl,-cref,-Map=${KIFACE_PREFIX}eeschema${KIFACE_SUFFIX}.map"
|
|
)
|
|
set_target_properties( eeschema PROPERTIES
|
|
LINK_FLAGS "-Wl,-cref,-Map=eeschema.map"
|
|
)
|
|
endif()
|
|
|
|
# these 2 binaries are a matched set, keep them together:
|
|
if( APPLE )
|
|
set_target_properties( eeschema PROPERTIES
|
|
MACOSX_BUNDLE_INFO_PLIST ${CMAKE_CURRENT_SOURCE_DIR}/Info.plist
|
|
)
|
|
|
|
# puts binaries into the *.app bundle while linking
|
|
set_target_properties( eeschema_kiface PROPERTIES
|
|
LIBRARY_OUTPUT_DIRECTORY ${OSX_BUNDLE_BUILD_KIFACE_DIR}
|
|
)
|
|
# put individual bundle outside of main bundle as a first step
|
|
# will be pulled into the main bundle when creating main bundle
|
|
install( TARGETS eeschema
|
|
DESTINATION ${KICAD_BIN}
|
|
COMPONENT binary
|
|
)
|
|
|
|
install( CODE "
|
|
# override default embedded path settings
|
|
${OSX_BUNDLE_OVERRIDE_PATHS}
|
|
|
|
# do all the work
|
|
include( BundleUtilities )
|
|
fixup_bundle( ${KICAD_BIN}/eeschema.app/Contents/MacOS/eeschema
|
|
\"\"
|
|
\"\"
|
|
)
|
|
" COMPONENT Runtime
|
|
)
|
|
|
|
if( KICAD_SPICE )
|
|
# bundle libngspice, codemodels and scripts
|
|
get_filename_component( REAL_LIBNGSPICE ${NGSPICE_LIBRARY} REALPATH )
|
|
get_filename_component( LIBNGSPICE_PATH ${REAL_LIBNGSPICE} DIRECTORY )
|
|
install( FILES "${REAL_LIBNGSPICE}"
|
|
DESTINATION "${OSX_BUNDLE_INSTALL_PLUGIN_DIR}/sim" )
|
|
install( DIRECTORY "${LIBNGSPICE_PATH}/ngspice"
|
|
DESTINATION "${OSX_BUNDLE_INSTALL_PLUGIN_DIR}/sim" )
|
|
install( DIRECTORY "${LIBNGSPICE_PATH}/../share/ngspice/scripts"
|
|
DESTINATION "${OSX_BUNDLE_INSTALL_PLUGIN_DIR}/sim/ngspice" )
|
|
endif()
|
|
else()
|
|
install( TARGETS eeschema
|
|
DESTINATION ${KICAD_BIN}
|
|
COMPONENT binary
|
|
)
|
|
install( TARGETS eeschema_kiface
|
|
# actual filename subject to change at milestone C)
|
|
# modular-kicad blueprint.
|
|
DESTINATION ${KICAD_BIN}
|
|
COMPONENT binary
|
|
)
|
|
endif()
|
|
|
|
# auto-generate cmp_library_lexer.h and cmp_library_keywords.cpp for the component
|
|
# library format.
|
|
make_lexer(
|
|
${CMAKE_CURRENT_SOURCE_DIR}/cmp_library.keywords
|
|
${CMAKE_CURRENT_SOURCE_DIR}/cmp_library_lexer.h
|
|
${CMAKE_CURRENT_SOURCE_DIR}/cmp_library_keywords.cpp
|
|
TLIB_T
|
|
)
|
|
|
|
add_custom_target(
|
|
cmp_library_lexer_source_files ALL
|
|
DEPENDS
|
|
${CMAKE_CURRENT_SOURCE_DIR}/cmp_library_lexer.h
|
|
${CMAKE_CURRENT_SOURCE_DIR}/cmp_library_keywords.cpp
|
|
)
|
|
|
|
add_dependencies( eeschema_kiface cmp_library_lexer_source_files )
|
|
|
|
make_lexer(
|
|
${CMAKE_CURRENT_SOURCE_DIR}/template_fieldnames.keywords
|
|
${CMAKE_CURRENT_SOURCE_DIR}/template_fieldnames_lexer.h
|
|
${CMAKE_CURRENT_SOURCE_DIR}/template_fieldnames_keywords.cpp
|
|
TFIELD_T
|
|
|
|
# Pass header file with dependency on *_lexer.h as extra_arg
|
|
template_fieldnames.h
|
|
)
|
|
|
|
add_custom_target(
|
|
field_template_lexer_source_files ALL
|
|
DEPENDS
|
|
${CMAKE_CURRENT_SOURCE_DIR}/template_fieldnames_lexer.h
|
|
${CMAKE_CURRENT_SOURCE_DIR}/template_fieldnames_keywords.cpp
|
|
)
|
|
|
|
add_dependencies( eeschema_kiface field_template_lexer_source_files )
|
|
|
|
make_lexer(
|
|
${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_cfg.keywords
|
|
${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_cfg_lexer.h
|
|
${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_cfg_keywords.cpp
|
|
T_BOMCFG_T
|
|
|
|
# Pass header file with dependency on *_lexer.h as extra_arg
|
|
dialogs/dialog_bom_cfg.h
|
|
)
|
|
|
|
add_custom_target(
|
|
dialog_bom_cfg_lexer_source_files ALL
|
|
DEPENDS
|
|
${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_cfg_lexer.h
|
|
${CMAKE_CURRENT_SOURCE_DIR}/dialogs/dialog_bom_cfg_keywords.cpp
|
|
)
|
|
|
|
add_dependencies( eeschema_kiface dialog_bom_cfg_lexer_source_files )
|
|
|
|
add_subdirectory( plugins )
|