0
0
mirror of https://github.com/yse/easy_profiler.git synced 2025-01-14 00:27:55 +08:00

Create tree structure

This commit is contained in:
Sergey Yagovtsev 2016-06-17 16:31:09 +03:00
parent 5f96b6403c
commit 7713f91500
3 changed files with 66 additions and 14 deletions

View File

@ -286,6 +286,7 @@ namespace profiler
SerilizedBlock(profiler::Block* block);
SerilizedBlock(uint16_t _size, const char* _data);
SerilizedBlock(SerilizedBlock&& that);
SerilizedBlock(const SerilizedBlock& other);
~SerilizedBlock();
const char* const data() const { return m_data; }

View File

@ -2,12 +2,35 @@
#include <fstream>
#include <list>
#include <iostream>
#include <map>
#include <stack>
#include <vector>
template<class T>
struct tree
struct BlocksTree
{
typedef tree<T> tree_t;
tree_t* parent;
profiler::SerilizedBlock* node;
std::vector<BlocksTree> children;
BlocksTree* parent;
BlocksTree(){
node = nullptr;
parent = nullptr;
}
BlocksTree(BlocksTree&& that){
node = that.node;
parent = that.parent;
children = std::move(that.children);
that.node = nullptr;
that.parent = nullptr;
}
~BlocksTree(){
if (node){
delete node;
}
node = nullptr;
}
};
int main()
@ -18,7 +41,15 @@ int main()
return -1;
}
std::list<profiler::SerilizedBlock> blocksList;
//std::list<profiler::SerilizedBlock> blocksList;
typedef std::map<profiler::timestamp_t, profiler::SerilizedBlock> blocks_map_t;
typedef std::map<size_t, blocks_map_t> thread_map_t;
typedef std::map<size_t, BlocksTree> thread_blocks_tree_t;
thread_map_t blocksList;
BlocksTree root;
thread_blocks_tree_t threaded_trees;
while (!inFile.eof()){
uint16_t sz = 0;
inFile.read((char*)&sz, sizeof(sz));
@ -29,14 +60,27 @@ int main()
}
char* data = new char[sz];
inFile.read((char*)&data[0], sz);
blocksList.emplace_back(sz, data);
}
for (auto& i : blocksList){
static auto thread_id = i.block()->getThreadId();
//if (i.block()->thread_id == thread_id)
std::cout << i.block()->duration() << "\n";
//std::cout << i.getBlockName() << ":" << (i.block()->end - i.block()->begin)/1000 << " usec." << std::endl;
profiler::BaseBlockData* baseData = (profiler::BaseBlockData*)data;
blocksList[baseData->getThreadId()].emplace(
baseData->getBegin(),
profiler::SerilizedBlock(sz, data));
BlocksTree tree;
tree.node = new profiler::SerilizedBlock(sz, data);
root.children.push_back(std::move(tree));
BlocksTree currentRoot = threaded_trees[baseData->getThreadId()];
if (currentRoot.node == nullptr){
threaded_trees[baseData->getThreadId()] = tree;
}
delete[] data;
//blocksList.emplace_back(sz, data);
}
return 0;

View File

@ -53,6 +53,13 @@ SerilizedBlock::~SerilizedBlock()
}
}
SerilizedBlock::SerilizedBlock(const SerilizedBlock& other)
{
m_size = other.m_size;
m_data = new char[m_size];
memcpy(&m_data[0], other.m_data, m_size);
}
SerilizedBlock::SerilizedBlock(SerilizedBlock&& that)
{
m_size = that.m_size;
@ -100,7 +107,7 @@ void ProfileManager::beginBlock(Block* _block)
{
if (!m_isEnabled)
return;
if (_block->getType() != BLOCK_TYPE_EVENT){
if (BLOCK_TYPE_BLOCK == _block->getType()){
guard_lock_t lock(m_spin);
m_openedBracketsMap[_block->getThreadId()].push(_block);
}