From 3f854e16acc880b9c9ccab2244dc585705dfac1e Mon Sep 17 00:00:00 2001
From: Joel Challis <git@zvecr.com>
Date: Sun, 9 May 2021 21:39:48 +0100
Subject: Catch 'LAYOUTS = all' in lint (#12848)

Co-authored-by: Zach White <skullydazed@drpepper.org>
---
 lib/python/qmk/info.py | 13 +++++++++++++
 1 file changed, 13 insertions(+)

(limited to 'lib/python')

diff --git a/lib/python/qmk/info.py b/lib/python/qmk/info.py
index e2350b7f72..47c8bff7a8 100644
--- a/lib/python/qmk/info.py
+++ b/lib/python/qmk/info.py
@@ -19,6 +19,12 @@ true_values = ['1', 'on', 'yes']
 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):
     """Generate the info.json data for a specific keyboard.
     """
@@ -71,6 +77,13 @@ def info_json(keyboard):
     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.')
 
+    # 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
     for layout in info_data.get('community_layouts', []):
         layout_name = 'LAYOUT_' + layout
-- 
cgit v1.2.3