Yet more tracking
This commit is contained in:
parent
f1f10639a5
commit
83d0813b0f
|
@ -70,7 +70,7 @@ private:
|
||||||
DisplayLine m_pending_status_line;
|
DisplayLine m_pending_status_line;
|
||||||
DisplayLine m_mode_line;
|
DisplayLine m_mode_line;
|
||||||
|
|
||||||
std::vector<Key> m_pending_keys;
|
Vector<Key> m_pending_keys;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,7 +50,7 @@ public:
|
||||||
ByteCount pos_in_token) const;
|
ByteCount pos_in_token) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::vector<ArgumentCompleter> m_completers;
|
Vector<ArgumentCompleter, MemoryDomain::Commands> m_completers;
|
||||||
};
|
};
|
||||||
|
|
||||||
using CommandInfo = std::pair<String, String>;
|
using CommandInfo = std::pair<String, String>;
|
||||||
|
@ -88,7 +88,7 @@ private:
|
||||||
CommandFlags flags;
|
CommandFlags flags;
|
||||||
CommandCompleter completer;
|
CommandCompleter completer;
|
||||||
};
|
};
|
||||||
using CommandMap = UnorderedMap<String, CommandDescriptor>;
|
using CommandMap = UnorderedMap<String, CommandDescriptor, MemoryDomain::Commands>;
|
||||||
CommandMap m_commands;
|
CommandMap m_commands;
|
||||||
|
|
||||||
CommandMap::const_iterator find_command(const Context& context,
|
CommandMap::const_iterator find_command(const Context& context,
|
||||||
|
|
|
@ -833,9 +833,13 @@ const CommandDesc debug_cmd = {
|
||||||
auto options = UsedMemory<MemoryDomain::Options>::byte_count;
|
auto options = UsedMemory<MemoryDomain::Options>::byte_count;
|
||||||
auto highlight = UsedMemory<MemoryDomain::Highlight>::byte_count;
|
auto highlight = UsedMemory<MemoryDomain::Highlight>::byte_count;
|
||||||
auto word_db = UsedMemory<MemoryDomain::WordDB>::byte_count;
|
auto word_db = UsedMemory<MemoryDomain::WordDB>::byte_count;
|
||||||
|
auto mapping = UsedMemory<MemoryDomain::Mapping>::byte_count;
|
||||||
|
auto commands = UsedMemory<MemoryDomain::Commands>::byte_count;
|
||||||
|
auto hooks = UsedMemory<MemoryDomain::Hooks>::byte_count;
|
||||||
auto undefined = UsedMemory<MemoryDomain::Undefined>::byte_count;
|
auto undefined = UsedMemory<MemoryDomain::Undefined>::byte_count;
|
||||||
|
|
||||||
auto total = string + interned_string + buffer_content + buffer_meta + options + highlight + word_db + undefined;
|
auto total = string + interned_string + buffer_content + buffer_meta +
|
||||||
|
options + highlight + word_db + mapping + commands + hooks + undefined;
|
||||||
|
|
||||||
write_debug("Memory usage:");
|
write_debug("Memory usage:");
|
||||||
write_debug("String: " + to_string(string));
|
write_debug("String: " + to_string(string));
|
||||||
|
@ -845,6 +849,9 @@ const CommandDesc debug_cmd = {
|
||||||
write_debug("Options: " + to_string(options));
|
write_debug("Options: " + to_string(options));
|
||||||
write_debug("Highlight: " + to_string(highlight));
|
write_debug("Highlight: " + to_string(highlight));
|
||||||
write_debug("WordDB: " + to_string(word_db));
|
write_debug("WordDB: " + to_string(word_db));
|
||||||
|
write_debug("Mapping: " + to_string(mapping));
|
||||||
|
write_debug("Commands: " + to_string(commands));
|
||||||
|
write_debug("Hooks: " + to_string(hooks));
|
||||||
write_debug("Undefined: " + to_string(undefined));
|
write_debug("Undefined: " + to_string(undefined));
|
||||||
write_debug("Total: " + to_string(total));
|
write_debug("Total: " + to_string(total));
|
||||||
write_debug("Malloced: " + to_string(mallinfo().uordblks));
|
write_debug("Malloced: " + to_string(mallinfo().uordblks));
|
||||||
|
|
|
@ -29,7 +29,7 @@ private:
|
||||||
friend class Scope;
|
friend class Scope;
|
||||||
|
|
||||||
HookManager* m_parent;
|
HookManager* m_parent;
|
||||||
UnorderedMap<String, IdMap<HookFunc>> m_hook;
|
UnorderedMap<String, IdMap<HookFunc, MemoryDomain::Hooks>, MemoryDomain::Hooks> m_hook;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,8 +4,7 @@
|
||||||
#include "keys.hh"
|
#include "keys.hh"
|
||||||
#include "hash.hh"
|
#include "hash.hh"
|
||||||
#include "unordered_map.hh"
|
#include "unordered_map.hh"
|
||||||
|
#include "vector.hh"
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
namespace Kakoune
|
namespace Kakoune
|
||||||
{
|
{
|
||||||
|
@ -29,7 +28,7 @@ class KeymapManager
|
||||||
public:
|
public:
|
||||||
KeymapManager(KeymapManager& parent) : m_parent(&parent) {}
|
KeymapManager(KeymapManager& parent) : m_parent(&parent) {}
|
||||||
|
|
||||||
using KeyList = std::vector<Key>;
|
using KeyList = Vector<Key, MemoryDomain::Mapping>;
|
||||||
void map_key(Key key, KeymapMode mode, KeyList mapping);
|
void map_key(Key key, KeymapMode mode, KeyList mapping);
|
||||||
void unmap_key(Key key, KeymapMode mode);
|
void unmap_key(Key key, KeymapMode mode);
|
||||||
|
|
||||||
|
@ -44,7 +43,7 @@ private:
|
||||||
KeymapManager* m_parent;
|
KeymapManager* m_parent;
|
||||||
|
|
||||||
using KeyAndMode = std::pair<Key, KeymapMode>;
|
using KeyAndMode = std::pair<Key, KeymapMode>;
|
||||||
using Keymap = UnorderedMap<KeyAndMode, KeyList>;
|
using Keymap = UnorderedMap<KeyAndMode, KeyList, MemoryDomain::Mapping>;
|
||||||
Keymap m_mapping;
|
Keymap m_mapping;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -4,8 +4,7 @@
|
||||||
#include "unicode.hh"
|
#include "unicode.hh"
|
||||||
#include "flags.hh"
|
#include "flags.hh"
|
||||||
#include "hash.hh"
|
#include "hash.hh"
|
||||||
|
#include "vector.hh"
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
namespace Kakoune
|
namespace Kakoune
|
||||||
{
|
{
|
||||||
|
@ -67,7 +66,7 @@ struct Key
|
||||||
|
|
||||||
template<> struct WithBitOps<Key::Modifiers> : std::true_type {};
|
template<> struct WithBitOps<Key::Modifiers> : std::true_type {};
|
||||||
|
|
||||||
using KeyList = std::vector<Key>;
|
using KeyList = Vector<Key, MemoryDomain::Mapping>;
|
||||||
|
|
||||||
class String;
|
class String;
|
||||||
class StringView;
|
class StringView;
|
||||||
|
|
|
@ -17,6 +17,9 @@ enum class MemoryDomain
|
||||||
BufferMeta,
|
BufferMeta,
|
||||||
Options,
|
Options,
|
||||||
Highlight,
|
Highlight,
|
||||||
|
Mapping,
|
||||||
|
Commands,
|
||||||
|
Hooks,
|
||||||
WordDB
|
WordDB
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ struct SwitchDesc
|
||||||
String description;
|
String description;
|
||||||
};
|
};
|
||||||
|
|
||||||
using SwitchMap = IdMap<SwitchDesc>;
|
using SwitchMap = IdMap<SwitchDesc, MemoryDomain::Commands>;
|
||||||
|
|
||||||
String generate_switches_doc(const SwitchMap& opts);
|
String generate_switches_doc(const SwitchMap& opts);
|
||||||
|
|
||||||
|
@ -145,8 +145,8 @@ struct ParametersParser
|
||||||
iterator end() const;
|
iterator end() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ParameterList m_params;
|
ParameterList m_params;
|
||||||
std::vector<size_t> m_positional_indices;
|
Vector<size_t, MemoryDomain::Commands> m_positional_indices;
|
||||||
const ParameterDesc& m_desc;
|
const ParameterDesc& m_desc;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -138,7 +138,7 @@ void test_string()
|
||||||
|
|
||||||
void test_keys()
|
void test_keys()
|
||||||
{
|
{
|
||||||
std::vector<Key> keys{
|
KeyList keys{
|
||||||
{ ' ' },
|
{ ' ' },
|
||||||
{ 'c' },
|
{ 'c' },
|
||||||
{ Key::Modifiers::Alt, 'j' },
|
{ Key::Modifiers::Alt, 'j' },
|
||||||
|
|
Loading…
Reference in New Issue
Block a user