-
Notifications
You must be signed in to change notification settings - Fork 1.7k
C++: Instantiate model generation library #19295
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weβll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
3d48b23
f241e4b
09ebd6e
1465058
1f43e51
5462dcd
0ce6ab5
9cba91c
e55f94c
f6f5f97
6fcf56e
3fd760c
07d8f8d
9e9a580
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
extensions: | ||
- addsTo: | ||
pack: codeql/cpp-all | ||
extensible: summaryModel | ||
data: [] |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture content based summary models. | ||
* @description Finds applicable content based summary models to be used by other queries. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/contentbased-summary-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSummaryTargetApi api, string flow | ||
where flow = ContentSensitive::captureFlow(api, _) | ||
select flow order by flow |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture mixed neutral models. | ||
* @description Finds neutral models to be used by other queries. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/mixed-neutral-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSummaryTargetApi api, string noflow | ||
where noflow = captureMixedNeutral(api) | ||
select noflow order by noflow |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture mixed summary models. | ||
* @description Finds applicable summary models to be used by other queries. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/mixed-summary-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSummaryTargetApi api, string flow | ||
where flow = captureMixedFlow(api, _) | ||
select flow order by flow |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture neutral models. | ||
* @description Finds neutral models to be used by other queries. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/neutral-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSummaryTargetApi api, string noflow | ||
where noflow = captureNoFlow(api) | ||
select noflow order by noflow |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture sink models. | ||
* @description Finds public methods that act as sinks as they flow into a known sink. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/sink-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSinkTargetApi api, string sink | ||
where sink = captureSink(api) | ||
select sink order by sink |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture source models. | ||
* @description Finds APIs that act as sources as they expose already known sources. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/source-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSourceTargetApi api, string source | ||
where source = captureSource(api) | ||
select source order by source |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
/** | ||
* @name Capture summary models. | ||
* @description Finds applicable summary models to be used by other queries. | ||
* @kind diagnostic | ||
* @id cpp/utils/modelgenerator/summary-models | ||
* @tags modelgenerator | ||
*/ | ||
|
||
import internal.CaptureModels | ||
|
||
from DataFlowSummaryTargetApi api, string flow | ||
where flow = captureFlow(api) | ||
select flow order by flow |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
#!/usr/bin/python3 | ||
jketema marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
import sys | ||
import os.path | ||
import subprocess | ||
|
||
# Add Model as Data script directory to sys.path. | ||
gitroot = subprocess.check_output(["git", "rev-parse", "--show-toplevel"]).decode("utf-8").strip() | ||
madpath = os.path.join(gitroot, "misc/scripts/models-as-data/") | ||
sys.path.append(madpath) | ||
|
||
import generate_flow_model as model | ||
|
||
language = "cpp" | ||
model.Generator.make(language).run() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It is my intention to change the python script such that There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Started a PR with this work prior to easter: #19311
MathiasVP marked this conversation as resolved.
Show resolved
Hide resolved
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This generates warnings (when running queries/tests) that there are no files matching the
*.model.yml
.Consider adding an
empty.model.yml
(in the generated folder):There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Uh, well spotted! Fixed in 07d8f8d