2020-06-13 23:28:08 +00:00
|
|
|
#
|
|
|
|
# This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
#
|
|
|
|
# Copyright (C) 2017 CERN
|
|
|
|
# @author Alejandro García Montoro <alejandro.garciamontoro@gmail.com>
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, you may find one here:
|
|
|
|
# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
# or you may search the http://www.gnu.org website for the version 2 license,
|
|
|
|
# or you may write to the Free Software Foundation, Inc.,
|
|
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
|
|
|
|
find_package(Boost COMPONENTS unit_test_framework REQUIRED)
|
|
|
|
find_package( wxWidgets 3.0.0 COMPONENTS gl aui adv html core net base xml stc REQUIRED )
|
|
|
|
|
|
|
|
|
|
|
|
add_definitions(-DBOOST_TEST_DYN_LINK -DPCBNEW -DDRC_PROTO)
|
|
|
|
|
|
|
|
if( BUILD_GITHUB_PLUGIN )
|
|
|
|
set( GITHUB_PLUGIN_LIBRARIES github_plugin )
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
add_executable( drc_proto
|
2020-06-30 08:44:12 +00:00
|
|
|
drc_rules_proto_keywords.cpp
|
2020-06-13 23:28:08 +00:00
|
|
|
drc_proto_test.cpp
|
|
|
|
drc_rule.cpp
|
|
|
|
drc_rule_parser.cpp
|
|
|
|
drc_test_provider.cpp
|
2020-06-19 21:34:19 +00:00
|
|
|
drc_test_provider_clearance_base.cpp
|
|
|
|
drc_test_provider_copper_clearance.cpp
|
|
|
|
drc_test_provider_hole_clearance.cpp
|
2020-08-03 22:12:11 +00:00
|
|
|
drc_test_provider_edge_clearance.cpp
|
2020-07-27 13:33:06 +00:00
|
|
|
drc_test_provider_hole_size.cpp
|
2020-08-25 17:42:52 +00:00
|
|
|
drc_test_provider_disallow.cpp
|
|
|
|
drc_test_provider_track_width.cpp
|
|
|
|
drc_test_provider_annulus.cpp
|
|
|
|
drc_test_provider_connectivity.cpp
|
|
|
|
drc_test_provider_courtyard_clearance.cpp
|
|
|
|
drc_test_provider_via_diameter.cpp
|
|
|
|
drc_test_provider_lvs.cpp
|
|
|
|
drc_test_provider_misc.cpp
|
2020-06-13 23:28:08 +00:00
|
|
|
drc_engine.cpp
|
2020-07-27 13:33:06 +00:00
|
|
|
drc_item.cpp
|
2020-06-13 23:28:08 +00:00
|
|
|
../qa_utils/mocks.cpp
|
|
|
|
../pcbnew_utils/board_file_utils.cpp
|
|
|
|
../qa_utils/stdstream_line_reader.cpp
|
|
|
|
../../common/base_units.cpp
|
|
|
|
../../3d-viewer/3d_viewer/3d_viewer_settings.cpp
|
|
|
|
)
|
|
|
|
|
2020-08-23 19:01:08 +00:00
|
|
|
add_dependencies( drc_proto pnsrouter pcbcommon ${PCBNEW_IO_LIBRARIES} ${GITHUB_PLUGIN_LIBRARIES} )
|
2020-06-30 08:44:12 +00:00
|
|
|
|
2020-06-13 23:28:08 +00:00
|
|
|
include_directories( BEFORE ${INC_BEFORE} )
|
|
|
|
include_directories(
|
|
|
|
${CMAKE_SOURCE_DIR}
|
|
|
|
${CMAKE_SOURCE_DIR}/include
|
|
|
|
${CMAKE_SOURCE_DIR}/3d-viewer
|
|
|
|
${CMAKE_SOURCE_DIR}/common
|
|
|
|
${CMAKE_SOURCE_DIR}/pcbnew
|
|
|
|
${CMAKE_SOURCE_DIR}/pcbnew/router
|
|
|
|
${CMAKE_SOURCE_DIR}/pcbnew/tools
|
|
|
|
${CMAKE_SOURCE_DIR}/pcbnew/dialogs
|
|
|
|
${CMAKE_SOURCE_DIR}/polygon
|
|
|
|
${CMAKE_SOURCE_DIR}/common/geometry
|
2020-08-11 23:50:56 +00:00
|
|
|
${CMAKE_SOURCE_DIR}/libs/kimath/include/math
|
2020-06-13 23:28:08 +00:00
|
|
|
${CMAKE_SOURCE_DIR}/qa/common
|
|
|
|
${CMAKE_SOURCE_DIR}/qa
|
|
|
|
${CMAKE_SOURCE_DIR}/qa/qa_utils
|
|
|
|
${CMAKE_SOURCE_DIR}/qa/qa_utils/include
|
|
|
|
${CMAKE_SOURCE_DIR}/qa/pcbnew_utils/include
|
|
|
|
${Boost_INCLUDE_DIR}
|
|
|
|
${INC_AFTER}
|
|
|
|
)
|
|
|
|
|
|
|
|
target_link_libraries( drc_proto
|
|
|
|
pnsrouter
|
|
|
|
common
|
|
|
|
pcbcommon
|
|
|
|
bitmaps
|
|
|
|
pnsrouter
|
|
|
|
common
|
|
|
|
pcbcommon
|
|
|
|
bitmaps
|
|
|
|
pnsrouter
|
|
|
|
common
|
|
|
|
pcbcommon
|
|
|
|
bitmaps
|
|
|
|
pnsrouter
|
|
|
|
common
|
|
|
|
pcbcommon
|
|
|
|
bitmaps
|
|
|
|
gal
|
|
|
|
common
|
|
|
|
pcbcommon
|
2020-08-23 19:01:08 +00:00
|
|
|
${PCBNEW_IO_LIBRARIES}
|
2020-06-13 23:28:08 +00:00
|
|
|
${GITHUB_PLUGIN_LIBRARIES}
|
|
|
|
common
|
|
|
|
pcbcommon
|
|
|
|
${Boost_FILESYSTEM_LIBRARY}
|
|
|
|
${Boost_SYSTEM_LIBRARY}
|
|
|
|
${Boost_UNIT_TEST_FRAMEWORK_LIBRARY}
|
|
|
|
${wxWidgets_LIBRARIES}
|
|
|
|
)
|
|
|
|
|
|
|
|
# auto-generate drc_rules_lexer.h and drc_rules_keywords.cpp
|
|
|
|
make_lexer(
|
|
|
|
drc_proto
|
|
|
|
drc_rules_proto.keywords
|
|
|
|
drc_rules_proto_lexer.h
|
|
|
|
drc_rules_proto_keywords.cpp
|
|
|
|
DRCRULEPROTO_T
|
2020-08-23 19:01:08 +00:00
|
|
|
)
|