mirror of
https://github.com/KingDuckZ/kamokan.git
synced 2025-02-09 09:23:56 +00:00
IncRedis is now held by Response, if requested by the base class. Response objects know their names, and they use it to load the html (soon to be mustache) data from disk. Main only prepares a factory, the factory then instantiates the actual Response. The code now correctly serves index.cgi when the request is /. Remove kakoune's safe_ptr from inside src and put an updated one in lib/kakoune.
109 lines
2.6 KiB
C++
109 lines
2.6 KiB
C++
#ifndef safe_ptr_hh_INCLUDED
|
|
#define safe_ptr_hh_INCLUDED
|
|
|
|
// #define SAFE_PTR_TRACK_CALLSTACKS
|
|
|
|
//King_DuckZ:
|
|
#include <cassert>
|
|
#define kak_assert(a) assert(a)
|
|
|
|
//#include "assert.hh"
|
|
#include "ref_ptr.hh"
|
|
|
|
#include <type_traits>
|
|
#include <utility>
|
|
|
|
#ifdef SAFE_PTR_TRACK_CALLSTACKS
|
|
#include "backtrace.hh"
|
|
#include "vector.hh"
|
|
#include <algorithm>
|
|
#endif
|
|
|
|
namespace Kakoune
|
|
{
|
|
|
|
// *** SafePtr: objects that assert nobody references them when they die ***
|
|
|
|
class SafeCountable
|
|
{
|
|
public:
|
|
#ifdef KAK_DEBUG
|
|
SafeCountable() : m_count(0) {}
|
|
SafeCountable (SafeCountable&&) : m_count(0) {}
|
|
~SafeCountable()
|
|
{
|
|
kak_assert(m_count == 0);
|
|
#ifdef SAFE_PTR_TRACK_CALLSTACKS
|
|
kak_assert(m_callstacks.empty());
|
|
#endif
|
|
}
|
|
|
|
private:
|
|
friend struct SafeCountablePolicy;
|
|
#ifdef SAFE_PTR_TRACK_CALLSTACKS
|
|
struct Callstack
|
|
{
|
|
Callstack(void* p) : ptr(p) {}
|
|
void* ptr;
|
|
Backtrace bt;
|
|
};
|
|
|
|
mutable Vector<Callstack> m_callstacks;
|
|
#endif
|
|
mutable int m_count;
|
|
#endif
|
|
};
|
|
|
|
struct SafeCountablePolicy
|
|
{
|
|
#ifdef KAK_DEBUG
|
|
static void inc_ref(const SafeCountable* sc, void* ptr) noexcept
|
|
{
|
|
++sc->m_count;
|
|
#ifdef SAFE_PTR_TRACK_CALLSTACKS
|
|
sc->m_callstacks.emplace_back(ptr);
|
|
#else
|
|
static_cast<void>(ptr);
|
|
#endif
|
|
}
|
|
|
|
static void dec_ref(const SafeCountable* sc, void* ptr) noexcept
|
|
{
|
|
--sc->m_count;
|
|
kak_assert(sc->m_count >= 0);
|
|
#ifdef SAFE_PTR_TRACK_CALLSTACKS
|
|
auto it = std::find_if(sc->m_callstacks.begin(), sc->m_callstacks.end(),
|
|
[=](const SafeCountable::Callstack& cs) { return cs.ptr == ptr; });
|
|
kak_assert(it != sc->m_callstacks.end());
|
|
sc->m_callstacks.erase(it);
|
|
#else
|
|
static_cast<void>(ptr);
|
|
#endif
|
|
}
|
|
|
|
static void ptr_moved(const SafeCountable* sc, void* from, void* to) noexcept
|
|
{
|
|
#ifdef SAFE_PTR_TRACK_CALLSTACKS
|
|
auto it = std::find_if(sc->m_callstacks.begin(), sc->m_callstacks.end(),
|
|
[=](const SafeCountable::Callstack& cs) { return cs.ptr == from; });
|
|
kak_assert(it != sc->m_callstacks.end());
|
|
it->ptr = to;
|
|
#else
|
|
static_cast<void>(sc);
|
|
static_cast<void>(from);
|
|
static_cast<void>(to);
|
|
#endif
|
|
}
|
|
#else
|
|
static void inc_ref(const SafeCountable*, void*) noexcept {}
|
|
static void dec_ref(const SafeCountable*, void*) noexcept {}
|
|
static void ptr_moved(const SafeCountable*, void*, void*) noexcept {}
|
|
#endif
|
|
};
|
|
|
|
template<typename T>
|
|
using SafePtr = RefPtr<T, SafeCountablePolicy>;
|
|
|
|
}
|
|
|
|
#endif // safe_ptr_hh_INCLUDED
|