Catch 'LAYOUTS = all' in lint (#12848)
Co-authored-by: Zach White <skullydazed@drpepper.org>
This commit is contained in:
parent
4fa32f0f04
commit
3f854e16ac
1 changed files with 13 additions and 0 deletions
|
@ -19,6 +19,12 @@ true_values = ['1', 'on', 'yes']
|
||||||
false_values = ['0', 'off', 'no']
|
false_values = ['0', 'off', 'no']
|
||||||
|
|
||||||
|
|
||||||
|
def _valid_community_layout(layout):
|
||||||
|
"""Validate that a declared community list exists
|
||||||
|
"""
|
||||||
|
return (Path('layouts/default') / layout).exists()
|
||||||
|
|
||||||
|
|
||||||
def info_json(keyboard):
|
def info_json(keyboard):
|
||||||
"""Generate the info.json data for a specific keyboard.
|
"""Generate the info.json data for a specific keyboard.
|
||||||
"""
|
"""
|
||||||
|
@ -71,6 +77,13 @@ def info_json(keyboard):
|
||||||
if not info_data.get('layouts'):
|
if not info_data.get('layouts'):
|
||||||
_log_error(info_data, 'No LAYOUTs defined! Need at least one layout defined in the keyboard.h or info.json.')
|
_log_error(info_data, 'No LAYOUTs defined! Need at least one layout defined in the keyboard.h or info.json.')
|
||||||
|
|
||||||
|
# Filter out any non-existing community layouts
|
||||||
|
for layout in info_data.get('community_layouts', []):
|
||||||
|
if not _valid_community_layout(layout):
|
||||||
|
# Ignore layout from future checks
|
||||||
|
info_data['community_layouts'].remove(layout)
|
||||||
|
_log_error(info_data, 'Claims to support a community layout that does not exist: %s' % (layout))
|
||||||
|
|
||||||
# Make sure we supply layout macros for the community layouts we claim to support
|
# Make sure we supply layout macros for the community layouts we claim to support
|
||||||
for layout in info_data.get('community_layouts', []):
|
for layout in info_data.get('community_layouts', []):
|
||||||
layout_name = 'LAYOUT_' + layout
|
layout_name = 'LAYOUT_' + layout
|
||||||
|
|
Loading…
Reference in a new issue