47 lines
1.6 KiB
Python
47 lines
1.6 KiB
Python
from sys import exit
|
|
from subprocess import call
|
|
from kiplot.macros import macros, pre_class # noqa: F401
|
|
from kiplot.error import KiPlotConfigurationError
|
|
from kiplot.gs import GS
|
|
from kiplot.kiplot import check_script
|
|
from kiplot.misc import CMD_PCBNEW_RUN_DRC, URL_PCBNEW_RUN_DRC, DRC_ERROR
|
|
from kiplot.pre_base import BasePreFlight
|
|
from kiplot.log import get_logger
|
|
|
|
logger = get_logger(__name__)
|
|
|
|
|
|
@pre_class
|
|
class Run_DRC(BasePreFlight):
|
|
""" [boolean=false] Runs the DRC (Distance Rules Check). To ensure we have a valid PCB """
|
|
def __init__(self, name, value):
|
|
super().__init__(name, value)
|
|
if not isinstance(value, bool):
|
|
raise KiPlotConfigurationError('must be boolean')
|
|
self._enabled = value
|
|
self._pcb_related = True
|
|
|
|
def run(self):
|
|
check_script(CMD_PCBNEW_RUN_DRC, URL_PCBNEW_RUN_DRC, '1.4.0')
|
|
cmd = [CMD_PCBNEW_RUN_DRC, 'run_drc']
|
|
if GS.filter_file:
|
|
cmd.extend(['-f', GS.filter_file])
|
|
if BasePreFlight.get_option('ignore_unconnected'):
|
|
cmd.append('-i')
|
|
cmd.extend([GS.pcb_file, GS.out_dir])
|
|
# If we are in verbose mode enable debug in the child
|
|
if GS.debug_enabled:
|
|
cmd.insert(1, '-vv')
|
|
cmd.insert(1, '-r')
|
|
logger.info('- Running the DRC')
|
|
logger.debug('Executing: '+str(cmd))
|
|
ret = call(cmd)
|
|
if ret:
|
|
if ret > 127:
|
|
ret = -(256-ret)
|
|
if ret < 0:
|
|
logger.error('DRC errors: %d', -ret)
|
|
else:
|
|
logger.error('DRC returned %d', ret)
|
|
exit(DRC_ERROR)
|