blob: 371a369b7be0792bd53f720d8b3f3dea029632a3 [file] [log] [blame]
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
#include "common/exception.h"
#include "common/config.h"
#include "util/stack_util.h"
namespace doris {
// private concrete constructor
Exception::Exception(int code, const std::string_view& msg, bool from_status) {
_code = code;
_err_msg = std::make_unique<ErrMsg>();
_err_msg->_msg = msg;
#ifndef BE_TEST
if (ErrorCode::error_states[abs(code)].stacktrace) {
_err_msg->_stack = get_stack_trace();
// if haven't construct Status, no error stack before. so we need print.
if (!from_status && config::enable_stacktrace) {
LOG(WARNING) << "meet exception, error code: " << code << ", message: " << msg << '\n'
<< _err_msg->_stack;
}
}
#else
if (ErrorCode::error_states[abs(code)].stacktrace) {
_err_msg->_stack = get_stack_trace(0, "DISABLED");
}
// BE UT TEST exceptions thrown during execution cannot be caught
// and the error `C++ exception with description "argument not found" thrown in the test body` will be printed,
// which is of not much help.
// Disabled by default because now there are a lot of UT case that throw exceptions
// and it may slow down the test execution.
// Open this code to print the stack trace if you need to debug the UT case.
// std::cout << "Exception: " << code << ", " << msg << ", " << get_stack_trace(0, "DISABLED")
// << std::endl;
#endif
if (config::exit_on_exception) {
LOG(FATAL) << "[ExitOnException] error code: " << code << ", message: " << msg;
}
}
} // namespace doris