Ignore:
Timestamp:
Sep 27, 2016, 1:32:13 PM (9 years ago)
Author:
[email protected]
Message:

Add some needed CatchScopes in code that should not throw.
https://bugs.webkit.org/show_bug.cgi?id=162584

Reviewed by Keith Miller.

Re-landing minus the jsc.cpp and ExceptionHelpers.cpp changes. I'll address
those in a subsequent patch if the need manifests again in my testing.

  • API/JSObjectRef.cpp:

(JSObjectSetProperty):

  • This function already handles exceptions in its own way. We're honoring this contract and catching exceptions and passing it to the handler.
  • interpreter/Interpreter.cpp:

(JSC::notifyDebuggerOfUnwinding):

  • The debugger should not be throwing any exceptions.
  • profiler/ProfilerDatabase.cpp:

(JSC::Profiler::Database::save):

  • If an exception was thrown while saving the database, there's nothing we can really do about it anyway. Just fail nicely and return false. This is in line with existing error checking code in Database::save() that returns false if it's not able to open the file to save to.
  • runtime/JSModuleLoader.cpp:

(JSC::JSModuleLoader::finishCreation):

  • The existing code already RELEASE_ASSERT that no exception was thrown. Hence, it's appropriate to use a CatchScope here.
  • runtime/SamplingProfiler.cpp:

(JSC::SamplingProfiler::StackFrame::nameFromCallee):

  • The sampling profiler is doing a VMInquiry get here. It should never throw an exception. Hence, we'll just use a CatchScope and assert accordingly.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/Source/JavaScriptCore/profiler/ProfilerDatabase.cpp

    r206408 r206459  
    135135bool Database::save(const char* filename) const
    136136{
     137    auto scope = DECLARE_CATCH_SCOPE(m_vm);
    137138    auto out = FilePrintStream::open(filename, "w");
    138139    if (!out)
    139140        return false;
    140141   
    141     out->print(toJSON());
     142    String data = toJSON();
     143    if (UNLIKELY(scope.exception())) {
     144        scope.clearException();
     145        return false;
     146    }
     147    out->print(data);
    142148    return true;
    143149}
Note: See TracChangeset for help on using the changeset viewer.