mirror of
https://github.com/github/codeql.git
synced 2026-04-29 10:45:15 +02:00
Swift: split generated C++ code into .h and .cpp
This commit is contained in:
@@ -99,7 +99,7 @@ class Tag:
|
||||
@dataclass
|
||||
class TrapList:
|
||||
template: ClassVar = 'trap_traps'
|
||||
|
||||
extensions = ["h", "cpp"]
|
||||
traps: List[Trap]
|
||||
source: str
|
||||
|
||||
@@ -107,6 +107,7 @@ class TrapList:
|
||||
@dataclass
|
||||
class TagList:
|
||||
template: ClassVar = 'trap_tags'
|
||||
extensions = ["h"]
|
||||
|
||||
tags: List[Tag]
|
||||
source: str
|
||||
@@ -143,6 +144,7 @@ class Class:
|
||||
@dataclass
|
||||
class ClassList:
|
||||
template: ClassVar = "cpp_classes"
|
||||
extensions: ClassVar = ["h", "cpp"]
|
||||
|
||||
classes: List[Class]
|
||||
source: str
|
||||
|
||||
@@ -28,18 +28,23 @@ class Renderer:
|
||||
|
||||
`data` must have a `template` attribute denoting which template to use from the template directory.
|
||||
|
||||
If the file is unchanged, then no write is performed (and `done_something` remains unchanged)
|
||||
|
||||
If `guard_base` is provided, it must be a path at the root of `output` and a header guard will be injected in
|
||||
the template based off of the relative path of `output` in `guard_base`
|
||||
Optionally, `data` can also have an `extensions` attribute denoting list of file extensions: they will all be
|
||||
appended to the template name with an underscore and be generated in turn.
|
||||
"""
|
||||
mnemonic = type(data).__name__
|
||||
output.parent.mkdir(parents=True, exist_ok=True)
|
||||
data = self._r.render_name(data.template, data, generator=self._generator)
|
||||
with open(output, "w") as out:
|
||||
out.write(data)
|
||||
log.debug(f"generated {mnemonic} {output.name}")
|
||||
self.written.add(output)
|
||||
extensions = getattr(data, "extensions", [None])
|
||||
for ext in extensions:
|
||||
output_filename = output
|
||||
template = data.template
|
||||
if ext:
|
||||
output_filename = output_filename.with_suffix(f".{ext}")
|
||||
template += f"_{ext}"
|
||||
contents = self._r.render_name(template, data, generator=self._generator)
|
||||
with open(output_filename, "w") as out:
|
||||
out.write(contents)
|
||||
log.debug(f"{mnemonic}: generated {output.name}")
|
||||
self.written.add(output_filename)
|
||||
|
||||
def cleanup(self, existing):
|
||||
""" Remove files in `existing` for which no `render` has been called """
|
||||
|
||||
Reference in New Issue
Block a user