ScopeTimer + small fixes

This commit is contained in:
Ara 2023-12-08 09:53:51 +06:00
parent eea920d98f
commit 42e632d220
5 changed files with 29 additions and 7 deletions

1
.gitignore vendored
View File

@ -4,6 +4,7 @@ Debug/src/**/*.o
Debug/voxel_engine
/build
/screenshots
/world
/worlds/**/*

View File

@ -93,7 +93,8 @@ namespace gui {
void back();
void clearHistory();
void reset();
//comment or erase pragma if you hate notes..
#pragma message("gui::PagesControl::current() returns Page by-value! (can initiate unexpected behaviour)")
Page current();
};
}

View File

@ -1,5 +1,7 @@
#include "timeutil.h"
#include <iostream>
using std::chrono::high_resolution_clock;
using std::chrono::duration_cast;
using std::chrono::microseconds;
@ -11,6 +13,12 @@ int64_t timeutil::Timer::stop() {
return duration_cast<microseconds>(high_resolution_clock::now()-start).count();
}
timeutil::ScopeLogTimer::ScopeLogTimer(long long id) : scopeid_(id) {}
timeutil::ScopeLogTimer::~ScopeLogTimer() {
std::cout << "Scope "<< scopeid_ <<" finished in "<< ScopeLogTimer::stop() << " micros."<<std::endl;
}
float timeutil::time_value(float hour, float minute, float second) {
return (hour + (minute + second / 60.0f) / 60.0f) / 24.0f;
}

View File

@ -12,6 +12,19 @@ namespace timeutil {
int64_t stop();
};
/* Timer that stops and prints time when destructor called
* @example:
* { // some scope (custom, function, if/else, cycle etc.)
* timeutil::ScopeLogTimer scopeclock();
* ...
* } */
class ScopeLogTimer : public Timer{
long long scopeid_;
public:
ScopeLogTimer(long long id);
~ScopeLogTimer();
};
float time_value(float hour, float minute, float second);
void from_value(float value, int& hour, int& minute, int& second);
}

View File

@ -45,7 +45,7 @@ Chunks::~Chunks(){
}
voxel* Chunks::get(int x, int y, int z){
x -= ox * CHUNK_W;
x -= ox * CHUNK_W;
z -= oz * CHUNK_D;
int cx = x / CHUNK_W;
int cy = y / CHUNK_H;
@ -174,7 +174,7 @@ void Chunks::set(int x, int y, int z, int id, uint8_t states){
if (lz == CHUNK_D-1 && (chunk = getChunk(cx+ox, cz+oz+1)))
chunk->setModified(true);
}
#include "../util/timeutil.h"
voxel* Chunks::rayCast(vec3 start,
vec3 dir,
float maxDist,
@ -218,6 +218,7 @@ voxel* Chunks::rayCast(vec3 start,
voxel* voxel = get(ix, iy, iz);
const Block* def = nullptr;
if (voxel == nullptr || (def = contentIds->getBlockDef(voxel->id))->selectable){
timeutil::ScopeLogTimer lg((long long)def);
end.x = px + t * dx;
end.y = py + t * dy;
end.z = pz + t * dz;
@ -336,7 +337,7 @@ void Chunks::translate(int dx, int dz){
}
for (int z = 0; z < d; z++){
for (int x = 0; x < w; x++){
shared_ptr<Chunk> chunk = chunks[z * d + x];
shared_ptr<Chunk> chunk = chunks[z * w + x];
int nx = x - dx;
int nz = z - dz;
if (chunk == nullptr)
@ -351,9 +352,7 @@ void Chunks::translate(int dx, int dz){
chunksSecond[nz * w + nx] = chunk;
}
}
shared_ptr<Chunk>* ctemp = chunks;
chunks = chunksSecond;
chunksSecond = ctemp;
std::swap(chunks, chunksSecond);
ox += dx;
oz += dz;