Commit 5f61d440 authored by Max Kellermann's avatar Max Kellermann

lib/yajl/Handle: un-inline the throwing code

Reduces header dependencies.
parent 6bc73a9e
/*
* Copyright 2018-2020 Max Kellermann <max.kellermann@gmail.com>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* FOUNDATION OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "Handle.hxx"
#include "util/RuntimeError.hxx"
#include "util/ScopeExit.hxx"
namespace Yajl {
void
Handle::ThrowError()
{
unsigned char *str = yajl_get_error(handle, false,
nullptr, 0);
AtScopeExit(this, str) {
yajl_free_error(handle, str);
};
throw FormatRuntimeError("Failed to parse JSON: %s", str);
}
} // namespace Yajl
/* /*
* Copyright (C) 2018 Max Kellermann <max.kellermann@gmail.com> * Copyright 2018-2020 Max Kellermann <max.kellermann@gmail.com>
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions * modification, are permitted provided that the following conditions
...@@ -30,12 +30,8 @@ ...@@ -30,12 +30,8 @@
#ifndef YAJL_HANDLE_HXX #ifndef YAJL_HANDLE_HXX
#define YAJL_HANDLE_HXX #define YAJL_HANDLE_HXX
#include "util/RuntimeError.hxx"
#include "util/ScopeExit.hxx"
#include <yajl/yajl_parse.h> #include <yajl/yajl_parse.h>
#include <stdexcept>
#include <algorithm> #include <algorithm>
namespace Yajl { namespace Yajl {
...@@ -77,15 +73,12 @@ public: ...@@ -77,15 +73,12 @@ public:
private: private:
void HandleStatus(yajl_status status) { void HandleStatus(yajl_status status) {
if (status == yajl_status_error) { if (status == yajl_status_error)
unsigned char *str = yajl_get_error(handle, false, ThrowError();
nullptr, 0);
AtScopeExit(this, str) {
yajl_free_error(handle, str);
};
throw FormatRuntimeError("Failed to parse JSON: %s", str);
}
} }
[[noreturn]]
void ThrowError();
}; };
} // namespace Yajl } // namespace Yajl
......
...@@ -5,6 +5,7 @@ endif ...@@ -5,6 +5,7 @@ endif
yajl = static_library( yajl = static_library(
'yajl', 'yajl',
'Handle.cxx',
'ResponseParser.cxx', 'ResponseParser.cxx',
'ParseInputStream.cxx', 'ParseInputStream.cxx',
include_directories: inc, include_directories: inc,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment