<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>The '--analyze' option is a convenience option to run the analyzer with a default set of checks.  It's main client (currently) is Xcode, but it can be used by whomever.</div><div><br></div><div>More specific checks can be enabled using the low-level '-cc1' options, e.g.:</div><div><br></div><div>$ clang -cc1 -help | grep analyze</div><div><div>  -analyze-function <value></div><div>  -analyzer-check-dead-stores</div><div>  -analyzer-check-idempotent-operations</div><div>  -analyzer-check-llvm-conventions</div><div>  -analyzer-check-objc-mem</div><div>  -analyzer-check-objc-methodsigs</div><div>  -analyzer-check-objc-missing-dealloc</div><div>  -analyzer-check-objc-unused-ivars</div><div>  -analyzer-check-security-syntactic</div><div>  -analyzer-constraints <value></div><div>  -analyzer-display-progress</div></div><div>...</div><div><br></div><div>It's instructive to look at what low-level options '--analyze' would run by adding -### to the end of the command line, e.g.:</div><div><br></div><div>$ clang --analyze foo.c -###</div><div><div>Apple clang version 2.0 (trunk 119338) (based on LLVM 2.9svn)</div><div>Target: x86_64-apple-darwin10</div><div>Thread model: posix</div><div> "/Developer/usr/bin/clang" "-cc1" "-triple" "x86_64-apple-darwin10.0.0" "-analyze" "-disable-free" "-disable-llvm-verifier" "-main-file-name" "foo.c" "-analyzer-store=region" "-analyzer-opt-analyze-nested-blocks" "-analyzer-check-dead-stores" "-analyzer-check-objc-mem" "-analyzer-eagerly-assume" "-analyzer-check-objc-methodsigs" "-analyzer-check-objc-unused-ivars" "-analyzer-check-idempotent-operations" "-analyzer-output" "plist" "-w" "-pic-level" "1" "-mdisable-fp-elim" "-masm-verbose" "-munwind-tables" "-target-cpu" "core2" "-target-linker-version" "97.14" "-resource-dir" "/Developer/usr/bin/../lib/clang/2.0" "-ferror-limit" "19" "-fmessage-length" "362" "-stack-protector" "1" "-fblocks" "-fdiagnostics-show-option" "-fcolor-diagnostics" "-o" "foo.plist" "-x" "c" "foo.c"</div></div><div><br></div><div>Note that the low-level analyzer options are all subject to change.  We have not stabilized an option set for the analyzer yet.</div><div><br></div><div><div>On Nov 21, 2010, at 4:21 PM, J Green wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><br><br>
<div class="gmail_quote">---------- Forwarded message ----------<br>From: <b class="gmail_sendername">J Green</b> <span dir="ltr"><<a href="mailto:greenabc99@gmail.com">greenabc99@gmail.com</a>></span><br>Date: 2010/11/22<br>
Subject: Re: [cfe-dev] Does clang analyzer can only report one warning?<br>To: Ted Kremenek <<a href="mailto:kremenek@apple.com">kremenek@apple.com</a>><br><br><br>
<div>p.s. </div>
<div>Whether there exists some options to set after command: "clang --analyze " (i.e. clang --analyze -option_a -option_b? or use scan-build command?)to let analyzer  show different sources warning messages at the same time?</div>

<div> </div>
<div><br><br> </div>
<div class="gmail_quote">2010/11/21 J Green <span dir="ltr"><<a href="mailto:greenabc99@gmail.com" target="_blank">greenabc99@gmail.com</a>></span> 
<div>
<div></div>
<div class="h5"><br>
<blockquote style="BORDER-LEFT: #ccc 1px solid; MARGIN: 0px 0px 0px 0.8ex; PADDING-LEFT: 1ex" class="gmail_quote">Hi, Ted<br>    First of all, thank for your quick reply.<br>    But I still puzzled for such case: if there exists several same kind of bugs, such as uninitialized variables, for example, a and b is two uninitialized variables, they do not have any relationship (they are in different paths), would they be reported by clang at the same time(give two uninitialized warning messages at the same time)?<br>
<br>Thanks again.<br><br> <br><br>
<div class="gmail_quote">2010/11/19 Ted Kremenek <span dir="ltr"><<a href="mailto:kremenek@apple.com" target="_blank">kremenek@apple.com</a>></span> 
<div>
<div></div>
<div><br>
<blockquote style="BORDER-LEFT: rgb(204,204,204) 1px solid; MARGIN: 0pt 0pt 0pt 0.8ex; PADDING-LEFT: 1ex" class="gmail_quote">For some bugs, such as uses of uninitialized variables or a null dereference, the analyzer stops analyzing a given path because the semantics would potentially be meaningless after the point of the bug.  If the second bug is dominated by one of these other fail stop bugs, it won't be reported until the other bug is resolved.  It's a tradeoff; the idea is that people will fix issues, run the analyzer again and uncover new ones, etc.<br>
<br>Sent from my iPad<br>
<div>
<div></div>
<div><br>On Nov 18, 2010, at 9:18 PM, J Green <<a href="mailto:greenabc99@gmail.com" target="_blank">greenabc99@gmail.com</a>> wrote:<br><br>> Hi, all<br>><br>>      I just want to use clang static analyzer, the command is : "clang --analyze xxx.c" to check xxx.c's errors. but I can only see one warning message,<br>
> for example, one variable is undefined, but there exists another null pointer dereference error after that, why the analyzer can not report null pointer deference warning? Do I miss dothing sth.(e.g. one or more options needed)? or clang analyzer can only report one warning message in one function?<br>
>      In other words, How clang analyzer deal with different source errors?  To one kind of errors, just report the first one? or To all kind of errors, just report the first one?<br>><br>>                          Thanks.<br>
>                          J Green<br></div></div>> _______________________________________________<br>> cfe-dev mailing list<br>> <a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a><br>
> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br></blockquote></div></div></div><br></blockquote></div></div></div><br></div><br>
_______________________________________________<br>cfe-dev mailing list<br><a href="mailto:cfe-dev@cs.uiuc.edu">cfe-dev@cs.uiuc.edu</a><br>http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev<br></blockquote></div><br></body></html>