/root/doris/be/src/common/status.cpp
| Line | Count | Source | 
| 1 |  | // Copyright (c) 2011 The LevelDB Authors. All rights reserved. | 
| 2 |  | // Use of this source code is governed by a BSD-style license that can be | 
| 3 |  | // found in the LICENSE file. See the AUTHORS file for names of contributors. | 
| 4 |  |  | 
| 5 |  | #include "common/status.h" | 
| 6 |  |  | 
| 7 |  | #include <gen_cpp/Status_types.h> | 
| 8 |  | #include <gen_cpp/types.pb.h> // for PStatus | 
| 9 |  | #include <rapidjson/encodings.h> | 
| 10 |  | #include <rapidjson/prettywriter.h> | 
| 11 |  | #include <rapidjson/stringbuffer.h> | 
| 12 |  |  | 
| 13 |  | #include <algorithm> | 
| 14 |  | #include <new> | 
| 15 |  | #include <vector> | 
| 16 |  |  | 
| 17 |  | #include "service/backend_options.h" | 
| 18 |  |  | 
| 19 |  | namespace doris { | 
| 20 |  | namespace ErrorCode { | 
| 21 |  |  | 
| 22 |  | ErrorCodeState error_states[MAX_ERROR_CODE_DEFINE_NUM]; | 
| 23 |  | ErrorCodeInitializer error_code_init(10); | 
| 24 |  | } // namespace ErrorCode | 
| 25 |  |  | 
| 26 | 599k | void Status::to_thrift(TStatus* s) const { | 
| 27 | 599k |     s->error_msgs.clear(); | 
| 28 | 599k |     if (ok()) { | 
| 29 | 589k |         s->status_code = TStatusCode::OK; | 
| 30 | 589k |         return; | 
| 31 | 589k |     } | 
| 32 |  |     // Currently, there are many error codes, not defined in thrift and need pass to FE. | 
| 33 |  |     // DCHECK(_code > 0) | 
| 34 |  |     //        << "The error code has to > 0 because TStatusCode need it > 0, it's actual value is " | 
| 35 |  |     //        << _code; | 
| 36 | 9.99k |     s->status_code = (int16_t)_code > 0 ? (TStatusCode::type)_code : TStatusCode::INTERNAL_ERROR; | 
| 37 |  |  | 
| 38 | 9.99k |     if (_code == ErrorCode::VERSION_ALREADY_MERGED) { | 
| 39 | 0 |         s->status_code = TStatusCode::OLAP_ERR_VERSION_ALREADY_MERGED; | 
| 40 | 9.99k |     } else if (_code == ErrorCode::TABLE_NOT_FOUND) { | 
| 41 | 0 |         s->status_code = TStatusCode::TABLET_MISSING; | 
| 42 | 0 |     } | 
| 43 |  |  | 
| 44 | 9.99k |     s->error_msgs.push_back(fmt::format("({})[{}]{}", BackendOptions::get_localhost(), | 
| 45 | 9.99k |                                         code_as_string(), _err_msg ? _err_msg->_msg : "")); | 
| 46 | 9.99k |     s->__isset.error_msgs = true; | 
| 47 | 9.99k | } | 
| 48 |  |  | 
| 49 | 574k | TStatus Status::to_thrift() const { | 
| 50 | 574k |     TStatus s; | 
| 51 | 574k |     to_thrift(&s); | 
| 52 | 574k |     return s; | 
| 53 | 574k | } | 
| 54 |  |  | 
| 55 | 2.93M | void Status::to_protobuf(PStatus* s) const { | 
| 56 | 2.93M |     s->clear_error_msgs(); | 
| 57 | 2.93M |     s->set_status_code((int)_code); | 
| 58 | 2.93M |     if (!ok()) { | 
| 59 | 29.3k |         s->add_error_msgs(fmt::format("({})[{}]{}", BackendOptions::get_localhost(), | 
| 60 | 18.4E |                                       code_as_string(), _err_msg ? _err_msg->_msg : "")); | 
| 61 | 29.3k |     } | 
| 62 | 2.93M | } | 
| 63 |  |  | 
| 64 | 140 | Status& Status::prepend(std::string_view msg) { | 
| 65 | 140 |     if (!ok()) { | 
| 66 | 131 |         if (_err_msg == nullptr) { | 
| 67 | 0 |             _err_msg = std::make_unique<ErrMsg>(); | 
| 68 | 0 |         } | 
| 69 | 131 |         _err_msg->_msg = std::string(msg) + _err_msg->_msg; | 
| 70 | 131 |     } | 
| 71 | 140 |     return *this; | 
| 72 | 140 | } | 
| 73 |  |  | 
| 74 | 2.94k | Status& Status::append(std::string_view msg) { | 
| 75 | 2.94k |     if (!ok()) { | 
| 76 | 2.94k |         if (_err_msg == nullptr) { | 
| 77 | 0 |             _err_msg = std::make_unique<ErrMsg>(); | 
| 78 | 0 |         } | 
| 79 | 2.94k |         _err_msg->_msg.append(msg); | 
| 80 | 2.94k |     } | 
| 81 | 2.94k |     return *this; | 
| 82 | 2.94k | } | 
| 83 |  |  | 
| 84 | 353 | std::string Status::to_json() const { | 
| 85 | 353 |     rapidjson::StringBuffer s; | 
| 86 | 353 |     rapidjson::PrettyWriter<rapidjson::StringBuffer> writer(s); | 
| 87 | 353 |     writer.StartObject(); | 
| 88 |  |     // status | 
| 89 | 353 |     writer.Key("status"); | 
| 90 | 353 |     writer.String(code_as_string().c_str()); | 
| 91 |  |     // msg | 
| 92 | 353 |     writer.Key("msg"); | 
| 93 | 353 |     ok() ? writer.String("OK") : writer.String(_err_msg ? _err_msg->_msg.c_str() : ""); | 
| 94 | 353 |     writer.EndObject(); | 
| 95 | 353 |     return s.GetString(); | 
| 96 | 353 | } | 
| 97 |  |  | 
| 98 |  | } // namespace doris |