forked from semgrep/semgrep
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsemgrep.jsonnet
108 lines (102 loc) · 4.26 KB
/
semgrep.jsonnet
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
# legacy rules written in YAML
local yml = import "semgrep.yml";
local pfff = import "semgrep-core/src/pfff/semgrep.yml";
# registry rules!
local ocaml = import "p/ocaml";
# this is useful to factorize exclude
local test_code_globs = ["Unit_*.ml", "Test_*.ml"];
local less_important_code_globs = ["spacegrep/*", "experiments/*", "scripts/*"];
local semgrep_rules = [
#TODO: this rule could be moved in pfff/semgrep.yml at some point
{ id: "pfff-no-open-in",
match: { or: ["open_in_bin ...", "open_in ..."]},
# Same but using The old syntax:
# "pattern-either": [
# { pattern: "open_in_bin ..." },
# { pattern: "open_in ..." },
# ],
languages: ["ocaml"],
severity: "ERROR",
message: |||
It is easy to forget to close `open_in` with `close_in`.
Use `Common.with_open_infile()` instead.
|||,
},
#TODO: this is an experimental rule. It has lots of findings, so maybe it is too
# noisy, but it's nice to dogfood how to handle noisy rules.
# 564 findings before the exclude
{ id: "semgrep-no-catch-all-match-underscore",
match: "| _ -> $X",
languages: ["ocaml"],
severity: "WARNING",
message: |||
Using a catch all pattern is dangerous in the long term for patterns over algebraic
data types (for matching over ints and strings it's fine). If someone adds a new
constructor, the compiler will not help us and telling us to maybe update this code.
Try to replace with the list of the remaining cases not handled instead (you can
rely on ocamlc to give you the disjunctive pattern covering all the cases and copy
paste it in the code). If you think adding a new constructor should have no
impact on this code, then replace the pattern with '| __else__ ->' instead.
|||,
paths: {
#TODO: we should make a tool or a flag to help construct those exclude lists
# or include something like 'bento archive' in semgrep
# or automatically add the (* nosemgrep *) annotation everywhere.
exclude: [
#TODO: those files contain less than 100 findings in total, so
# they should not be too hard to fix
# a few findings per file
"semgrep-core/src/analyzing/Dataflow_svalue.ml",
"semgrep-core/src/core/ast/AST_generic_helpers.ml",
"semgrep-core/src/engine/Match_search_mode.ml",
"semgrep-core/src/fixing/Autofix_metavar_replacement.ml",
"semgrep-core/src/matching/Matching_generic.ml",
"semgrep-core/src/matching/SubAST_generic.ml",
"semgrep-core/src/optimizing/Analyze_pattern.ml",
"semgrep-core/src/parsing/Parse_equivalences.ml",
"semgrep-core/src/parsing/Parse_target.ml",
"semgrep-core/src/runner/Run_semgrep.ml",
"semgrep-core/src/tainting/Dataflow_tainting.ml",
"semgrep-core/src/targeting/Guess_lang.ml",
"semgrep-core/src/utils/Regexp_engine.ml",
#TODO: we should fix those too. They account for 464 findings in total
"Generic_vs_generic.ml",
"Visitor_AST.ml",
"Naming_AST.ml",
"Pretty_print_AST.ml",
"Constant_propagation.ml",
"Eval_generic.ml",
"AST_to_IL.ml",
"Parse_rule.ml",
"parsing/tree_sitter/*",
"parsing/pfff/*",
"parsing/other/*",
"parsing/ast/*",
"metachecking/*",
] + test_code_globs + less_important_code_globs,
}
}
];
local todo_skipped_for_now = [
#TODO? what is the fix for that?
"ocaml.lang.portability.crlf-support.broken-input-line",
];
local override_messages = {
// pfff/semgrep specific adjustments
"ocaml.lang.best-practice.exception.bad-reraise": |||
You should not re-raise exceptions using 'raise' because it loses track of where the
exception was raised originally. See pfff/commons/Exception.mli for more information.
Use `Exception.catch exn` and later `Exception.raise exn` or
`Exception.catch_and_reraise exn` if there is no code between the moment you
catch the exn and re-raise it.
|||,
};
local all = yml.rules + semgrep_rules + pfff.rules + ocaml.rules;
{ rules:
[ if std.objectHas(override_messages, r.id)
then r + {message: override_messages[r.id]}
else r
for r in all
if !std.member(todo_skipped_for_now, r.id)
]
}