2017-03-25 09:21:39 +00:00
|
|
|
/**
|
|
|
|
* The MIT License (MIT)
|
|
|
|
*
|
2017-03-25 13:29:29 +00:00
|
|
|
* Copyright (c) 2013-2017 OSSRS(winlin)
|
2017-03-25 09:21:39 +00:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
|
|
* this software and associated documentation files (the "Software"), to deal in
|
|
|
|
* the Software without restriction, including without limitation the rights to
|
|
|
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
|
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
|
|
|
* subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
|
|
* copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
|
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
|
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
2013-11-23 03:36:07 +00:00
|
|
|
|
2014-03-01 02:30:16 +00:00
|
|
|
#include <srs_kernel_error.hpp>
|
2014-01-11 11:55:55 +00:00
|
|
|
|
2017-06-09 03:50:35 +00:00
|
|
|
#include <srs_kernel_log.hpp>
|
|
|
|
|
|
|
|
#include <errno.h>
|
|
|
|
#include <sstream>
|
2017-06-11 01:03:29 +00:00
|
|
|
#include <stdarg.h>
|
2017-06-09 03:50:35 +00:00
|
|
|
using namespace std;
|
|
|
|
|
2014-01-11 11:55:55 +00:00
|
|
|
bool srs_is_system_control_error(int error_code)
|
|
|
|
{
|
2014-03-18 03:32:58 +00:00
|
|
|
return error_code == ERROR_CONTROL_RTMP_CLOSE
|
2016-01-08 10:17:37 +00:00
|
|
|
|| error_code == ERROR_CONTROL_REPUBLISH
|
|
|
|
|| error_code == ERROR_CONTROL_REDIRECT;
|
2014-01-11 11:55:55 +00:00
|
|
|
}
|
|
|
|
|
2014-03-18 03:28:22 +00:00
|
|
|
bool srs_is_client_gracefully_close(int error_code)
|
|
|
|
{
|
2014-03-18 03:32:58 +00:00
|
|
|
return error_code == ERROR_SOCKET_READ
|
|
|
|
|| error_code == ERROR_SOCKET_READ_FULLY
|
2017-06-11 10:44:20 +00:00
|
|
|
|| error_code == ERROR_SOCKET_WRITE;
|
2014-03-18 03:28:22 +00:00
|
|
|
}
|
2014-08-02 14:18:39 +00:00
|
|
|
|
2017-06-09 03:50:35 +00:00
|
|
|
SrsError::SrsError()
|
|
|
|
{
|
|
|
|
code = ERROR_SUCCESS;
|
|
|
|
wrapped = NULL;
|
|
|
|
cid = rerrno = line = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
SrsError::~SrsError()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string SrsError::description() {
|
|
|
|
if (desc.empty()) {
|
|
|
|
stringstream ss;
|
|
|
|
ss << "code=" << code;
|
|
|
|
|
|
|
|
SrsError* next = this;
|
|
|
|
while (next) {
|
|
|
|
ss << " : " << next->msg;
|
|
|
|
next = next->wrapped;
|
|
|
|
}
|
|
|
|
ss << endl;
|
|
|
|
|
|
|
|
next = this;
|
|
|
|
while (next) {
|
|
|
|
ss << "thread #" << next->cid << ": "
|
|
|
|
<< next->func << "() [" << next->file << ":" << next->line << "]"
|
|
|
|
<< "[errno=" << next->rerrno << "]"
|
|
|
|
<< endl;
|
|
|
|
next = next->wrapped;
|
|
|
|
}
|
|
|
|
|
|
|
|
desc = ss.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
return desc;
|
|
|
|
}
|
|
|
|
|
|
|
|
SrsError* SrsError::create(const char* func, const char* file, int line, int code, const char* fmt, ...) {
|
|
|
|
int rerrno = (int)errno;
|
|
|
|
|
|
|
|
va_list ap;
|
|
|
|
va_start(ap, fmt);
|
|
|
|
static char buffer[4096];
|
|
|
|
vsnprintf(buffer, sizeof(buffer), fmt, ap);
|
|
|
|
va_end(ap);
|
|
|
|
|
|
|
|
SrsError* err = new SrsError();
|
|
|
|
|
|
|
|
err->func = func;
|
|
|
|
err->file = file;
|
|
|
|
err->line = line;
|
|
|
|
err->code = code;
|
|
|
|
err->rerrno = rerrno;
|
|
|
|
err->msg = buffer;
|
|
|
|
err->wrapped = NULL;
|
|
|
|
if (_srs_context) {
|
|
|
|
err->cid = _srs_context->get_id();
|
|
|
|
}
|
|
|
|
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
SrsError* SrsError::wrap(const char* func, const char* file, int line, SrsError* v, const char* fmt, ...) {
|
|
|
|
int rerrno = (int)errno;
|
|
|
|
|
|
|
|
va_list ap;
|
|
|
|
va_start(ap, fmt);
|
|
|
|
static char buffer[4096];
|
|
|
|
vsnprintf(buffer, sizeof(buffer), fmt, ap);
|
|
|
|
va_end(ap);
|
|
|
|
|
|
|
|
SrsError* err = new SrsError();
|
|
|
|
|
|
|
|
err->func = func;
|
|
|
|
err->file = file;
|
|
|
|
err->line = line;
|
|
|
|
err->code = v->code;
|
|
|
|
err->rerrno = rerrno;
|
|
|
|
err->msg = buffer;
|
|
|
|
err->wrapped = v;
|
|
|
|
if (_srs_context) {
|
|
|
|
err->cid = _srs_context->get_id();
|
|
|
|
}
|
|
|
|
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
SrsError* SrsError::success() {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-06-11 10:44:20 +00:00
|
|
|
SrsError* SrsError::copy(SrsError* from)
|
|
|
|
{
|
|
|
|
if (from == srs_success) {
|
|
|
|
return srs_success;
|
|
|
|
}
|
|
|
|
|
|
|
|
SrsError* err = new SrsError();
|
|
|
|
|
|
|
|
err->code = from->code;
|
|
|
|
err->wrapped = srs_error_copy(from->wrapped);
|
|
|
|
err->msg = from->msg;
|
|
|
|
err->func = from->func;
|
|
|
|
err->file = from->file;
|
|
|
|
err->line = from->line;
|
|
|
|
err->cid = from->cid;
|
|
|
|
err->rerrno = from->rerrno;
|
|
|
|
err->desc = from->desc;
|
|
|
|
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
2017-06-09 03:50:35 +00:00
|
|
|
string SrsError::description(SrsError* err)
|
|
|
|
{
|
|
|
|
return err? err->description() : "Success";
|
|
|
|
}
|
|
|
|
|
|
|
|
int SrsError::error_code(SrsError* err)
|
|
|
|
{
|
|
|
|
return err? err->code : ERROR_SUCCESS;
|
|
|
|
}
|
|
|
|
|