diff options
| author | Pascal Rigaux <pixel@mandriva.com> | 2004-10-13 09:13:30 +0000 | 
|---|---|---|
| committer | Pascal Rigaux <pixel@mandriva.com> | 2004-10-13 09:13:30 +0000 | 
| commit | e169ac19faaa269be5ab8dab712cdc72135a40df (patch) | |
| tree | 5126c1b89e3fa681188ec4a357843175527cd4c8 | |
| parent | f5165b979f95a02cc4ed23ab8544b201c790241c (diff) | |
| download | perl_checker-e169ac19faaa269be5ab8dab712cdc72135a40df.tar perl_checker-e169ac19faaa269be5ab8dab712cdc72135a40df.tar.gz perl_checker-e169ac19faaa269be5ab8dab712cdc72135a40df.tar.bz2 perl_checker-e169ac19faaa269be5ab8dab712cdc72135a40df.tar.xz perl_checker-e169ac19faaa269be5ab8dab712cdc72135a40df.zip | |
check 'xxx' if $xxx (=> value is dropped)
| -rw-r--r-- | perl_checker.src/parser_helper.ml | 55 | ||||
| -rw-r--r-- | perl_checker.src/test/return_value.t | 4 | 
2 files changed, 33 insertions, 26 deletions
| diff --git a/perl_checker.src/parser_helper.ml b/perl_checker.src/parser_helper.ml index 5a147eb..d797daf 100644 --- a/perl_checker.src/parser_helper.ml +++ b/perl_checker.src/parser_helper.ml @@ -1008,32 +1008,6 @@ let call_one_scalar_para { any = e ; pos = pos } para esp_start esp_end =    new_pesp M_unknown P_mul (call(Deref(I_func, Ident(None, e, raw_pos2pos pos)), para)) esp_start esp_end -let call_op_if_infix left right esp_start esp_end = -  (match left, right with -  | List [Call_op("=", [Deref(context, _); _], _)], _ when non_scalar_context context -> () -  | List [Call_op("=", [v; _], _)], -    List [Call_op("not", [v'], _)] when is_same_fromparser v v' -> -      warn_rule "\"$foo = ... if !$foo\" can be written \"$foo ||= ...\"" -  | _ -> ()); -  let pos = raw_pos_range esp_start esp_end in -  new_any M_none (Call_op("if infix", [ left ; right], raw_pos2pos pos)) esp_start.spaces pos - -let call_op_unless_infix left right esp_start esp_end = -  (match left, right with -  | List [Call_op("=", [Deref(context, _); _], _)], _ when non_scalar_context context -> () -  | List [Call_op("=", [v; _], _)], List [v'] when is_same_fromparser v v' -> -      warn_rule "\"$foo = ... unless $foo\" can be written \"$foo ||= ...\"" -  | _ -> ()); -  (match right with -  | List [Call_op(op, _, _)] -> -      (match op with -      | "&&" | "||" | "not" | "ne" | "?:" -> warn_rule "don't use \"unless\" when the condition is complex, use \"if\" instead" -      | _ -> ()); -  | _ -> ()); -  let pos = raw_pos_range esp_start esp_end in -  new_any M_none (Call_op("unless infix", [ left ; right], raw_pos2pos pos)) esp_start.spaces pos - -  let (current_lexbuf : Lexing.lexbuf option ref) = ref None  let rec list2tokens l = @@ -1283,6 +1257,35 @@ let mtuple_context_concat c1 c2 =    | M_tuple l, _ -> M_tuple (l @ [c2])    | _ -> M_tuple [c1 ; c2] +let call_op_if_infix left right esp_start esp_end = +  (match left, right with +  | List [Call_op("=", [Deref(context, _); _], _)], _ when non_scalar_context context -> () +  | List [Call_op("=", [v; _], _)], +    List [Call_op("not", [v'], _)] when is_same_fromparser v v' -> +      warn_rule "\"$foo = ... if !$foo\" can be written \"$foo ||= ...\"" +  | _ -> ()); + +  mcontext_check_none "value is dropped" [left] esp_start; +  let pos = raw_pos_range esp_start esp_end in +  new_any M_none (Call_op("if infix", [ left ; right], raw_pos2pos pos)) esp_start.spaces pos + +let call_op_unless_infix left right esp_start esp_end = +  (match left, right with +  | List [Call_op("=", [Deref(context, _); _], _)], _ when non_scalar_context context -> () +  | List [Call_op("=", [v; _], _)], List [v'] when is_same_fromparser v v' -> +      warn_rule "\"$foo = ... unless $foo\" can be written \"$foo ||= ...\"" +  | _ -> ()); +  (match right with +  | List [Call_op(op, _, _)] -> +      (match op with +      | "&&" | "||" | "not" | "ne" | "?:" -> warn_rule "don't use \"unless\" when the condition is complex, use \"if\" instead" +      | _ -> ()); +  | _ -> ()); + +  mcontext_check_none "value is dropped" [left] esp_start; +  let pos = raw_pos_range esp_start esp_end in +  new_any M_none (Call_op("unless infix", [ left ; right], raw_pos2pos pos)) esp_start.spaces pos +  let symops pri para_context return_context op_str left op right =    sp_same op right;    let skip_context_check = diff --git a/perl_checker.src/test/return_value.t b/perl_checker.src/test/return_value.t index cae8652..a781033 100644 --- a/perl_checker.src/test/return_value.t +++ b/perl_checker.src/test/return_value.t @@ -10,6 +10,10 @@ $xxx && yyy();                           value is dropped  /(.*)/;                                  value is dropped +'xxx'; + +'xxx' if $xxx; +  map { xxx($_) } @l;                      if you don't use the return value, use "foreach" instead of "map"  $xxx = chomp;                            () context not accepted here | 
