From f6a79048dc51e2b7b9c1a3dc86c762d9c23c5c26 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Helge=20He=C3=9F?= Date: Sun, 10 Nov 2024 16:48:05 +0100 Subject: [PATCH] Add a &inout style var-refs A little confusing, because our regular var expression is called variableReference already ... --- .../LighterCodeGenAST/Nodes/Expression.swift | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/Plugins/Libraries/LighterCodeGenAST/Nodes/Expression.swift b/Plugins/Libraries/LighterCodeGenAST/Nodes/Expression.swift index 8c234ee..bf8e7cc 100644 --- a/Plugins/Libraries/LighterCodeGenAST/Nodes/Expression.swift +++ b/Plugins/Libraries/LighterCodeGenAST/Nodes/Expression.swift @@ -194,7 +194,16 @@ public extension Expression { static func variable(_ name: String) -> Self { .variableReference(instance: nil, name: name) } - + + /// A variable (inout) reference, e.g. `&self.sql`. + static func variableRef(_ instance: String, _ name: String) -> Self { + .raw("&\(instance).\(name)") // TODO: add expr + } + /// A variable (inout) reference, e.g. `&self.sql`. + static func variableRef(_ name: String) -> Self { + .raw("&\(name)") // TODO: add expr + } + /// A KeyPath expression. static func keyPath(_ baseType: TypeReference? = nil, _ property: String) -> Self