summaryrefslogtreecommitdiffstats
path: root/perl_checker.src/parser_helper.ml
diff options
context:
space:
mode:
authorPascal Rigaux <pixel@mandriva.com>2003-05-27 09:01:04 +0000
committerPascal Rigaux <pixel@mandriva.com>2003-05-27 09:01:04 +0000
commit487b90f5397f85d30031f4125f74f5f86b297fc9 (patch)
tree030a48152d9a59abffe0d8af693549e29c0b6b76 /perl_checker.src/parser_helper.ml
parent089e13bfbffff1f8318d7543abb5e9318c2f7200 (diff)
downloadperl-MDK-Common-487b90f5397f85d30031f4125f74f5f86b297fc9.tar
perl-MDK-Common-487b90f5397f85d30031f4125f74f5f86b297fc9.tar.gz
perl-MDK-Common-487b90f5397f85d30031f4125f74f5f86b297fc9.tar.bz2
perl-MDK-Common-487b90f5397f85d30031f4125f74f5f86b297fc9.tar.xz
perl-MDK-Common-487b90f5397f85d30031f4125f74f5f86b297fc9.zip
- disallow return(...), prefering return ...
- P_call_no_paren has a lower priority than P_comma
Diffstat (limited to 'perl_checker.src/parser_helper.ml')
-rw-r--r--perl_checker.src/parser_helper.ml38
1 files changed, 25 insertions, 13 deletions
diff --git a/perl_checker.src/parser_helper.ml b/perl_checker.src/parser_helper.ml
index b2726e4..bdf3d49 100644
--- a/perl_checker.src/parser_helper.ml
+++ b/perl_checker.src/parser_helper.ml
@@ -193,10 +193,10 @@ let rec prio_less = function
| _, P_and -> true
| P_and, _ -> false
- | _, P_comma -> true
- | P_comma, _ -> false
| _, P_call_no_paren -> true
| P_call_no_paren, _ -> false
+ | _, P_comma -> true
+ | P_comma, _ -> false
| _, P_assign -> true
| P_assign, _ -> false
| _, P_ternary -> true
@@ -228,21 +228,22 @@ let rec prio_less = function
| P_paren _, _ -> true
| P_tok, _ -> true
-let prio_lo pri_out in_ =
- if prio_less(in_.any.priority, pri_out) then
- (match in_.any.priority with
+let prio_lo_check pri_out pri_in pos expr =
+ if prio_less(pri_in, pri_out) then
+ (match pri_in with
| P_paren (P_paren_wanted _) -> ()
| P_paren pri_in' ->
if pri_in' <> pri_out &&
- prio_less(pri_in', pri_out) && not_complex (un_parenthesize in_.any.expr) then
- warn in_.pos "unneeded parentheses"
+ prio_less(pri_in', pri_out) && not_complex (un_parenthesize expr) then
+ warn pos "unneeded parentheses"
| _ -> ())
else
- (match in_.any.expr with
+ (match expr with
| Call_op ("print", [Deref (I_star, Ident (None, "STDOUT", _)); Deref(I_scalar, ident)], _) ->
- warn in_.pos (sprintf "use parentheses: replace \"print $%s ...\" with \"print($%s ...)\"" (string_of_Ident ident) (string_of_Ident ident))
- | _ -> warn in_.pos "missing parentheses (needed for clarity)") ;
- in_.any.expr
+ warn pos (sprintf "use parentheses: replace \"print $%s ...\" with \"print($%s ...)\"" (string_of_Ident ident) (string_of_Ident ident))
+ | _ -> warn pos "missing parentheses (needed for clarity)")
+
+let prio_lo pri_out in_ = prio_lo_check pri_out in_.any.priority in_.pos in_.any.expr ; in_.any.expr
let prio_lo_after pri_out in_ =
if in_.any.priority = P_call_no_paren then in_.any.expr else prio_lo pri_out in_
@@ -737,7 +738,7 @@ msgstr \"\"
) pot_strings ;
close_out fd
-let call_func is_a_func (e, para) =
+let call_raw is_a_func (e, para) =
match e with
| Deref(I_func, Ident(None, f, _)) ->
let para' = match f with
@@ -802,7 +803,18 @@ let call_func is_a_func (e, para) =
in Call(e, some_or para' para)
| _ -> Call(e, para)
-let call(e, para) = call_func false (e, para)
+let call(e, para) = call_raw false (e, para)
+
+let call_func esp_func esp_para = call_raw true (esp_func.any, esp_para.any.expr)
+
+let check_return esp_func esp_para =
+ match esp_func.any with
+ | Ident(None, "return", _) ->
+ prio_lo_check P_call_no_paren esp_para.any.priority esp_para.pos (List esp_para.any.expr)
+ | _ -> ()
+
+let call_no_paren esp_func esp_para = check_return esp_func esp_para; new_pesp M_unknown P_call_no_paren (call(Deref(I_func, esp_func.any), esp_para.any.expr)) esp_func esp_para
+let call_with_paren esp_func esp_para = check_return esp_func esp_para; new_pesp M_unknown P_tok (call(Deref(I_func, esp_func.any), esp_para.any.expr)) esp_func esp_para
let call_and_context(e, para) priority esp_start esp_end =
let context =