Merge pull request #65 from tinmanjuggernaut/mono-build-errors

Fix mono & gcc build issues
This commit is contained in:
Marc 2019-10-03 20:24:31 +02:00 committed by GitHub
commit bd857dcdfc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 36 additions and 37 deletions

View File

@ -5,7 +5,7 @@
#include <core/os/file_access.h>
namespace {
const int BLOCK_TRAILING_MAGIC = 0x900df00d;
const unsigned int BLOCK_TRAILING_MAGIC = 0x900df00d;
const int BLOCK_TRAILING_MAGIC_SIZE = 4;
} // namespace
@ -155,7 +155,7 @@ bool VoxelBlockSerializer::decompress_and_deserialize(const std::vector<uint8_t>
_data.resize(decompressed_size);
int actually_decompressed_size = LZ4_decompress_safe(
unsigned int actually_decompressed_size = LZ4_decompress_safe(
(const char *)p_data.data() + header_size,
(char *)_data.data(),
p_data.size() - header_size,
@ -175,7 +175,7 @@ bool VoxelBlockSerializer::decompress_and_deserialize(FileAccess *f, unsigned in
ERR_FAIL_COND_V(f == nullptr, false);
_compressed_data.resize(size_to_read);
int read_size = f->get_buffer(_compressed_data.data(), size_to_read);
unsigned int read_size = f->get_buffer(_compressed_data.data(), size_to_read);
ERR_FAIL_COND_V(read_size != size_to_read, false);
return decompress_and_deserialize(_compressed_data, out_voxel_buffer);

View File

@ -136,15 +136,15 @@ VoxelStreamRegionFiles::EmergeResult VoxelStreamRegionFiles::_emerge_block(Ref<V
return EMERGE_OK_FALLBACK;
}
int sector_index = block_info.get_sector_index();
//int sector_count = block_info.get_sector_count();
unsigned int sector_index = block_info.get_sector_index();
//unsigned int sector_count = block_info.get_sector_count();
int blocks_begin_offset = get_region_header_size();
FileAccess *f = cache->file_access;
f->seek(blocks_begin_offset + sector_index * _meta.sector_size);
int block_data_size = f->get_32();
unsigned int block_data_size = f->get_32();
CRASH_COND(f->eof_reached());
ERR_FAIL_COND_V_MSG(!_block_serializer.decompress_and_deserialize(f, block_data_size, **out_buffer), EMERGE_FAILED,
@ -217,7 +217,7 @@ void VoxelStreamRegionFiles::_immerge_block(Ref<VoxelBuffer> voxel_buffer, Vecto
block_info.set_sector_index((block_offset - blocks_begin_offset) / _meta.sector_size);
block_info.set_sector_count(get_sector_count_from_bytes(written_size));
for (int i = 0; i < block_info.get_sector_count(); ++i) {
for (unsigned int i = 0; i < block_info.get_sector_count(); ++i) {
cache->sectors.push_back(block_rpos);
}
@ -288,7 +288,7 @@ void VoxelStreamRegionFiles::_immerge_block(Ref<VoxelBuffer> voxel_buffer, Vecto
}
}
void VoxelStreamRegionFiles::remove_sectors_from_block(CachedRegion *p_region, Vector3i block_rpos, int p_sector_count) {
void VoxelStreamRegionFiles::remove_sectors_from_block(CachedRegion *p_region, Vector3i block_rpos, unsigned int p_sector_count) {
VOXEL_PROFILE_SCOPE(profile_scope);
// Removes sectors from a block, starting from the last ones.
@ -342,7 +342,7 @@ void VoxelStreamRegionFiles::remove_sectors_from_block(CachedRegion *p_region, V
p_region->sectors.begin() + (block_info.get_sector_index() + block_info.get_sector_count() - p_sector_count),
p_region->sectors.begin() + (block_info.get_sector_index() + block_info.get_sector_count()));
int old_sector_index = block_info.get_sector_index();
unsigned int old_sector_index = block_info.get_sector_index();
// Reduce sectors of current block in header.
if (block_info.get_sector_count() > p_sector_count) {
@ -355,7 +355,7 @@ void VoxelStreamRegionFiles::remove_sectors_from_block(CachedRegion *p_region, V
// Shift sector index of following blocks
if (old_sector_index < p_region->sectors.size()) {
RegionHeader &header = p_region->header;
for (int i = 0; i < header.blocks.size(); ++i) {
for (unsigned int i = 0; i < header.blocks.size(); ++i) {
BlockInfo &b = header.blocks[i];
if (b.data != 0 && b.get_sector_index() > old_sector_index) {
b.set_sector_index(b.get_sector_index() - p_sector_count);
@ -516,7 +516,7 @@ Vector3i VoxelStreamRegionFiles::get_region_position_from_blocks(const Vector3i
}
void VoxelStreamRegionFiles::close_all_regions() {
for (int i = 0; i < _region_cache.size(); ++i) {
for (unsigned int i = 0; i < _region_cache.size(); ++i) {
CachedRegion *cache = _region_cache[i];
close_region(cache);
memdelete(cache);
@ -539,7 +539,7 @@ String VoxelStreamRegionFiles::get_region_file_path(const Vector3i &region_pos,
VoxelStreamRegionFiles::CachedRegion *VoxelStreamRegionFiles::get_region_from_cache(const Vector3i pos, int lod) const {
// A linear search might be better than a Map data structure,
// because it's unlikely to have more than about 10 regions cached at a time
for (int i = 0; i < _region_cache.size(); ++i) {
for (unsigned int i = 0; i < _region_cache.size(); ++i) {
CachedRegion *r = _region_cache[i];
if (r->position == pos && r->lod == lod) {
return r;
@ -642,7 +642,7 @@ VoxelStreamRegionFiles::CachedRegion *VoxelStreamRegionFiles::open_region(const
// Filter only present blocks and keep the index around because it represents the 3D position of the block
RegionHeader &header = cache->header;
std::vector<BlockInfoAndIndex> blocks_sorted_by_offset;
for (int i = 0; i < header.blocks.size(); ++i) {
for (unsigned int i = 0; i < header.blocks.size(); ++i) {
const BlockInfo b = header.blocks[i];
if (b.data != 0) {
BlockInfoAndIndex p;
@ -657,10 +657,10 @@ VoxelStreamRegionFiles::CachedRegion *VoxelStreamRegionFiles::open_region(const
return a.b.get_sector_index() < b.b.get_sector_index();
});
for (int i = 0; i < blocks_sorted_by_offset.size(); ++i) {
for (unsigned int i = 0; i < blocks_sorted_by_offset.size(); ++i) {
const BlockInfoAndIndex b = blocks_sorted_by_offset[i];
Vector3i bpos = get_block_position_from_index(b.i);
for (int j = 0; j < b.b.get_sector_count(); ++j) {
for (unsigned int j = 0; j < b.b.get_sector_count(); ++j) {
cache->sectors.push_back(bpos);
}
}
@ -711,7 +711,7 @@ void VoxelStreamRegionFiles::close_oldest_region() {
uint64_t oldest_time = 0;
uint64_t now = OS::get_singleton()->get_ticks_usec();
for (int i = 0; i < _region_cache.size(); ++i) {
for (unsigned int i = 0; i < _region_cache.size(); ++i) {
CachedRegion *r = _region_cache[i];
uint64_t time = now - r->last_opened;
if (time >= oldest_time) {
@ -861,7 +861,7 @@ void VoxelStreamRegionFiles::_convert_files(Meta new_meta) {
// Read all blocks from the old stream and write them into the new one
for (int i = 0; i < old_region_list.size(); ++i) {
for (unsigned int i = 0; i < old_region_list.size(); ++i) {
PositionAndLod region_info = old_region_list[i];
const CachedRegion *region = old_stream->open_region(region_info.position, region_info.lod, false);
@ -872,7 +872,7 @@ void VoxelStreamRegionFiles::_convert_files(Meta new_meta) {
print_line(String("Converting region lod{0}/{1}").format(varray(region_info.lod, region_info.position.to_vec3())));
const RegionHeader &header = region->header;
for (int j = 0; j < header.blocks.size(); ++j) {
for (unsigned int j = 0; j < header.blocks.size(); ++j) {
const BlockInfo bi = header.blocks[j];
if (bi.data == 0) {
continue;

View File

@ -72,7 +72,7 @@ private:
int get_sector_count_from_bytes(int size_in_bytes) const;
int get_region_header_size() const;
CachedRegion *get_region_from_cache(const Vector3i pos, int lod) const;
void remove_sectors_from_block(CachedRegion *p_region, Vector3i block_rpos, int p_sector_count);
void remove_sectors_from_block(CachedRegion *p_region, Vector3i block_rpos, unsigned int p_sector_count);
int get_sectors_count(const RegionHeader &header) const;
void close_oldest_region();
void save_header(CachedRegion *p_region);
@ -160,7 +160,7 @@ private:
bool _meta_loaded = false;
bool _meta_saved = false;
std::vector<CachedRegion *> _region_cache;
int _max_open_regions = MIN(8, FOPEN_MAX);
unsigned int _max_open_regions = MIN(8, FOPEN_MAX);
};
#endif // VOXEL_STREAM_REGION_H

View File

@ -345,12 +345,12 @@ private:
if (index) {
// The block is already in the update queue, replace it
++replaced_blocks;
CRASH_COND(*index < 0 || *index >= job.shared_input.blocks.size());
CRASH_COND(*index < 0 || *index >= (int)job.shared_input.blocks.size());
job.shared_input.blocks[*index] = block;
} else {
// Append new block request
int j = job.shared_input.blocks.size();
unsigned int j = job.shared_input.blocks.size();
job.shared_input.blocks.push_back(block);
job.shared_input_block_indexes[block.lod][block.position] = j;
}
@ -393,8 +393,8 @@ private:
});
}
int input_begin = queue_index;
int batch_count = data.batch_count;
unsigned int input_begin = queue_index;
unsigned int batch_count = data.batch_count;
if (input_begin + batch_count > data.input.blocks.size()) {
batch_count = data.input.blocks.size() - input_begin;
@ -404,10 +404,10 @@ private:
uint64_t time_before = OS::get_singleton()->get_ticks_usec();
int output_begin = data.output.blocks.size();
unsigned int output_begin = data.output.blocks.size();
data.output.blocks.resize(data.output.blocks.size() + batch_count);
for (int i = 0; i < batch_count; ++i) {
for (unsigned int i = 0; i < batch_count; ++i) {
CRASH_COND(input_begin + i < 0 || input_begin + i >= data.input.blocks.size());
InputBlock &ib = data.input.blocks[input_begin + i];
OutputBlock &ob = data.output.blocks.write[output_begin + i];

View File

@ -16,7 +16,6 @@ static Ref<ConcavePolygonShape> create_concave_polygon_shape(Array surface_array
ERR_FAIL_COND_V(indices.size() % 3 != 0, Ref<ConcavePolygonShape>());
int face_points_count = indices.size();
int face_count = face_points_count / 3;
PoolVector<Vector3> face_points;
face_points.resize(face_points_count);

View File

@ -2,7 +2,7 @@
#include "../streams/voxel_stream.h"
#include "../util/utility.h"
VoxelDataLoader::VoxelDataLoader(int thread_count, Ref<VoxelStream> stream, int block_size_pow2) {
VoxelDataLoader::VoxelDataLoader(unsigned int thread_count, Ref<VoxelStream> stream, unsigned int block_size_pow2) {
print_line("Constructing VoxelDataLoader");
CRASH_COND(stream.is_null());
@ -26,7 +26,7 @@ VoxelDataLoader::VoxelDataLoader(int thread_count, Ref<VoxelStream> stream, int
// Note: more than one thread can make sense for generators,
// but won't be as useful for file and network streams
for (int i = 1; i < thread_count; ++i) {
for (unsigned int i = 1; i < thread_count; ++i) {
stream = stream->duplicate();
processors[i] = [this, stream](ArraySlice<InputBlock> inputs, ArraySlice<OutputBlock> outputs, Mgr::ProcessorStats &stats) {
this->process_blocks_thread_func(inputs, outputs, stream, stats);

View File

@ -29,7 +29,7 @@ public:
typedef Mgr::Output Output;
typedef Mgr::Stats Stats;
VoxelDataLoader(int thread_count, Ref<VoxelStream> stream, int block_size_pow2);
VoxelDataLoader(unsigned int thread_count, Ref<VoxelStream> stream, unsigned int block_size_pow2);
~VoxelDataLoader();
void push(const Input &input) { _mgr->push(input); }

View File

@ -621,7 +621,7 @@ void VoxelLodTerrain::send_block_data_requests() {
lod.blocks_to_load.clear();
}
for (int i = 0; i < _blocks_to_save.size(); ++i) {
for (unsigned int i = 0; i < _blocks_to_save.size(); ++i) {
print_line(String("Requesting save of block {0} lod {1}")
.format(varray(_blocks_to_save[i].position.to_vec3(), _blocks_to_save[i].lod)));
input.blocks.push_back(_blocks_to_save[i]);
@ -1186,7 +1186,7 @@ void VoxelLodTerrain::flush_pending_lod_edits() {
// Make sure LOD0 gets updates even if _lod_count is 1
Lod &lod0 = _lods[0];
for (int i = 0; i < lod0.blocks_pending_lodding.size(); ++i) {
for (unsigned int i = 0; i < lod0.blocks_pending_lodding.size(); ++i) {
Vector3i bpos = lod0.blocks_pending_lodding[i];
VoxelBlock *block = lod0.map->get_block(bpos);
block->set_needs_lodding(false);
@ -1202,7 +1202,7 @@ void VoxelLodTerrain::flush_pending_lod_edits() {
Lod &src_lod = _lods[dst_lod_index - 1];
Lod &dst_lod = _lods[dst_lod_index];
for (int i = 0; i < src_lod.blocks_pending_lodding.size(); ++i) {
for (unsigned int i = 0; i < src_lod.blocks_pending_lodding.size(); ++i) {
Vector3i src_bpos = src_lod.blocks_pending_lodding[i];
Vector3i dst_bpos = src_bpos >> 1;
@ -1312,7 +1312,7 @@ Dictionary VoxelLodTerrain::get_statistics() const {
d["time_request_blocks_to_update"] = _stats.time_request_blocks_to_update;
d["time_process_update_responses"] = _stats.time_process_update_responses;
d["remaining_main_thread_blocks"] = _blocks_pending_main_thread_update.size();
d["remaining_main_thread_blocks"] = (int)_blocks_pending_main_thread_update.size();
d["dropped_block_loads"] = _stats.dropped_block_loads;
d["dropped_block_meshs"] = _stats.dropped_block_meshs;
d["updated_blocks"] = _stats.updated_blocks;

View File

@ -95,7 +95,7 @@ void VoxelMeshUpdater::process_blocks_thread_func(
CRASH_COND(inputs.size() != outputs.size());
for (int i = 0; i < inputs.size(); ++i) {
for (unsigned int i = 0; i < inputs.size(); ++i) {
const InputBlock &ib = inputs[i];
const InputBlockData &block = ib.data;

View File

@ -349,7 +349,7 @@ Dictionary VoxelTerrain::get_statistics() const {
d["time_request_blocks_to_update"] = _stats.time_request_blocks_to_update;
d["time_process_update_responses"] = _stats.time_process_update_responses;
d["remaining_main_thread_blocks"] = _blocks_pending_main_thread_update.size();
d["remaining_main_thread_blocks"] = (int)_blocks_pending_main_thread_update.size();
d["dropped_block_loads"] = _stats.dropped_block_loads;
d["dropped_block_meshs"] = _stats.dropped_block_meshs;
d["updated_blocks"] = _stats.updated_blocks;
@ -714,7 +714,7 @@ void VoxelTerrain::send_block_data_requests() {
input.blocks.push_back(input_block);
}
for (int i = 0; i < _blocks_to_save.size(); ++i) {
for (unsigned int i = 0; i < _blocks_to_save.size(); ++i) {
print_line(String("Requesting save of block {0}").format(varray(_blocks_to_save[i].position.to_vec3())));
input.blocks.push_back(_blocks_to_save[i]);
}