Skip to content

Commit 6d5968e

Browse files
authored
Merge pull request #288 from kimdv/kimdv/add-convenience-inits-pt-2
Add convenience initializers for simple expr values
2 parents 1888022 + 58fa415 commit 6d5968e

11 files changed

+837
-250
lines changed

Sources/SwiftSyntaxBuilder/Buildables.swift.gyb

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
from gyb_syntax_support import *
33
from gyb_syntax_support.kinds import lowercase_first_word
44
from gyb_syntax_support.kinds import SYNTAX_BASE_KINDS
5-
from gyb_syntax_support.kinds import syntax_buildable_child_type
5+
from gyb_syntax_support.kinds import syntax_buildable_child_type, syntax_buildable_default_init_value
66
# -*- mode: Swift -*-
77
# Ignore the following admonition it applies to the resulting .swift file only
88
}%
@@ -103,8 +103,9 @@ public struct ${node.syntax_kind}: ${node.base_kind}Buildable {
103103
public init(
104104
% init_parameters = []
105105
% for child in node.children:
106+
% child_token = SYNTAX_TOKEN_MAP.get(child.syntax_kind)
106107
% param_type = syntax_buildable_child_type(child.type_name, child.syntax_kind, child.is_token(), child.is_optional)
107-
% default_value = " = nil" if child.is_optional else ""
108+
% default_value = syntax_buildable_default_init_value(child, child_token)
108109
% init_parameters.append("%s: %s%s" % (child.swift_name, param_type, default_value))
109110
% end
110111
${',\n '.join(init_parameters)}

Sources/SwiftSyntaxBuilder/BuildablesConvenienceInitializers.swift.gyb

Lines changed: 14 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,11 @@
11
%{
22
from gyb_syntax_support import *
3-
from gyb_syntax_support.kinds import SYNTAX_BASE_KINDS, lowercase_first_word, syntax_buildable_child_type
3+
from gyb_syntax_support.kinds import SYNTAX_BASE_KINDS, lowercase_first_word, syntax_buildable_child_type, syntax_buildable_default_init_value
44
NODE_MAP = create_node_map()
55
# -*- mode: Swift -*-
66
# Ignore the following admonition it applies to the resulting .swift file only
77
}%
8-
//// Automatically Generated From DeclBuildables.swift.gyb.
8+
//// Automatically Generated From BuildablesConvenienceInitializers.swift.gyb.
99
//// Do Not Edit Directly!
1010
//===----------------------------------------------------------------------===//
1111
//
@@ -23,36 +23,35 @@ import SwiftSyntax
2323

2424
% for node in SYNTAX_NODES:
2525
% if node.is_buildable():
26-
% has_syntax_collection_child = False
26+
% should_create_convenience_initializer = False
2727
% for child in node.children:
2828
% child_node = NODE_MAP.get(child.syntax_kind)
29-
% if child_node and child_node.is_syntax_collection():
30-
% has_syntax_collection_child = True
29+
% child_token = SYNTAX_TOKEN_MAP.get(child.syntax_kind)
30+
% if (child_node and child_node.is_syntax_collection()) or (child_token and not child_token.text):
31+
% # If the child token doesn’t have a text, we can create a convenience initializer that takes a string.
32+
% # If the child token doesn’t have a text, it takes a String as parameter, we can create a convenient initializer.
33+
% should_create_convenience_initializer = True
3134
% end
3235
% end
33-
% if has_syntax_collection_child:
36+
% if should_create_convenience_initializer:
3437
extension ${node.syntax_kind} {
3538
public init(
3639
% init_parameters = []
3740
% for child in node.children:
3841
% child_node = NODE_MAP.get(child.syntax_kind)
39-
% token = SYNTAX_TOKEN_MAP.get(child.syntax_kind)
42+
% child_token = SYNTAX_TOKEN_MAP.get(child.syntax_kind)
4043
% if child_node and child_node.is_syntax_collection():
4144
% # Allow initializing syntax collections with result builders
4245
% default_value = "? = { nil }" if child.is_optional else " = { .empty }"
4346
% init_parameters.append("@%sBuilder %sBuilder: () -> %s%s" % (child.syntax_kind, child.swift_name, child.syntax_kind, default_value))
44-
% elif child.syntax_kind is "IdentifierToken" or (token and not token.text):
47+
% elif child_token and not child_token.text:
4548
% # Allow initializing identifier or a token without a text with String value
4649
% param_type = "String?" if child.is_optional else "String"
4750
% init_parameters.append("%s: %s" % (child.swift_name, param_type))
4851
% else:
4952
% # When type is not handled above, use default value
5053
% param_type = syntax_buildable_child_type(child.type_name, child.syntax_kind, child.is_token(), child.is_optional)
51-
% default_value = ""
52-
% if token and token.text and not child.is_optional:
53-
% default_value = " = Tokens.`%s`" % lowercase_first_word(token.name)
54-
% elif child.is_optional:
55-
% default_value = " = nil"
54+
% default_value = syntax_buildable_default_init_value(child, child_token)
5655
% init_parameters.append("%s: %s%s" % (child.swift_name, param_type, default_value))
5756
% end
5857
% end
@@ -75,7 +74,7 @@ extension ${node.syntax_kind} {
7574
% if child.is_optional:
7675
% init_parameters.append("%s: %s.map(Tokens.%s)" % (child.swift_name, child.swift_name, lowercase_first_word(token.name)))
7776
% else:
78-
% init_parameters.append("%s: Tokens.%s(%s)" % (child.swift_name, token.name, child.swift_name))
77+
% init_parameters.append("%s: Tokens.%s(%s)" % (child.swift_name, lowercase_first_word(token.name), child.swift_name))
7978
% end
8079
% else:
8180
% init_parameters.append("%s: %s" % (child.swift_name, child.swift_name))
@@ -88,4 +87,4 @@ extension ${node.syntax_kind} {
8887

8988
% end
9089
% end
91-
% end
90+
% end

0 commit comments

Comments
 (0)