-
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
base: main
Are you sure you want to change the base?
Changes from all commits
3d48b23
f241e4b
09ebd6e
1465058
1f43e51
5462dcd
0ce6ab5
9cba91c
e55f94c
f6f5f97
6fcf56e
3fd760c
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,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 | ||
|
||
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. The python script puts the generated models in
If you intend to use this location for generated models, maybe consider to extend the 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. Oh, right. I've fixed this in a06d7fc |
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.
It is my intention to change the python script such that
--with-summaries
uses the mixed query instead (and correspondingly for the neutral), but for testing purposes it is nice to keep both the content based and heuristic based queries around.