mirror of
				https://github.com/koalaman/shellcheck.git
				synced 2025-10-25 09:50:45 +08:00 
			
		
		
		
	Parse &&/|| as left-associative
This commit is contained in:
		| @@ -867,7 +867,7 @@ prop_checkShorthandIf5 = verifyNot checkShorthandIf "foo && rm || printf b" | |||||||
| prop_checkShorthandIf6 = verifyNot checkShorthandIf "if foo && bar || baz; then true; fi" | prop_checkShorthandIf6 = verifyNot checkShorthandIf "if foo && bar || baz; then true; fi" | ||||||
| prop_checkShorthandIf7 = verifyNot checkShorthandIf "while foo && bar || baz; do true; done" | prop_checkShorthandIf7 = verifyNot checkShorthandIf "while foo && bar || baz; do true; done" | ||||||
| prop_checkShorthandIf8 = verify checkShorthandIf "if true; then foo && bar || baz; fi" | prop_checkShorthandIf8 = verify checkShorthandIf "if true; then foo && bar || baz; fi" | ||||||
| checkShorthandIf params x@(T_AndIf id _ (T_OrIf _ _ (T_Pipeline _ _ t))) | checkShorthandIf params x@(T_OrIf _ (T_AndIf id _ _) (T_Pipeline _ _ t)) | ||||||
|         | not (isOk t || inCondition) = |         | not (isOk t || inCondition) = | ||||||
|     info id 2015 "Note that A && B || C is not if-then-else. C may run when A is true." |     info id 2015 "Note that A && B || C is not if-then-else. C may run when A is true." | ||||||
|   where |   where | ||||||
|   | |||||||
| @@ -2286,7 +2286,7 @@ readAndOr = do | |||||||
|         parseProblemAt apos ErrorC 1123 "ShellCheck directives are only valid in front of complete compound commands, like 'if', not e.g. individual 'elif' branches." |         parseProblemAt apos ErrorC 1123 "ShellCheck directives are only valid in front of complete compound commands, like 'if', not e.g. individual 'elif' branches." | ||||||
|  |  | ||||||
|     andOr <- withAnnotations annotations $ |     andOr <- withAnnotations annotations $ | ||||||
|         chainr1 readPipeline $ do |         chainl1 readPipeline $ do | ||||||
|             op <- g_AND_IF <|> g_OR_IF |             op <- g_AND_IF <|> g_OR_IF | ||||||
|             readLineBreak |             readLineBreak | ||||||
|             return $ case op of T_AND_IF id -> T_AndIf id |             return $ case op of T_AND_IF id -> T_AndIf id | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user