[LLVMbugs] [Bug 9382] New: Incorrect "'noreturn' should not return" when there's code after a nested call to a noreturn member function

bugzilla-daemon at llvm.org bugzilla-daemon at llvm.org
Wed Mar 2 15:31:22 PST 2011


http://llvm.org/bugs/show_bug.cgi?id=9382

           Summary: Incorrect "'noreturn' should not return" when there's
                    code after a nested call to a noreturn member function
           Product: clang
           Version: trunk
          Platform: PC
        OS/Version: All
            Status: NEW
          Severity: normal
          Priority: P
         Component: C++
        AssignedTo: unassignedclangbugs at nondot.org
        ReportedBy: jyasskin at google.com
                CC: llvmbugs at cs.uiuc.edu, dgregor at apple.com


$ cat test.cc
struct Errors {
  void fatal() __attribute__((noreturn));
};

void gold_fatal(const char* format) __attribute__((noreturn));

void gold_fatal(const char* format) {
  Errors().fatal();
  (void)3;
}

$ clang++  -Wall -Werror -c test.cc
test.cc:14:1: error: function declared 'noreturn' should not return
      [-Werror,-Winvalid-noreturn]
}
^
1 error generated.

--------------
Removing the (void)3; or taking 'fatal' out of Errors causes the warning to go
away.

Arguably, clang should generate an "unreachable code" warning instead, but the
original code after the noreturn call was a va_end() call, which seems nice to
keep symmetric.

-- 
Configure bugmail: http://llvm.org/bugs/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
You are on the CC list for the bug.



More information about the llvm-bugs mailing list