Merge branch 'dev' into generated-pcm-stream

This commit is contained in:
MihailRis 2025-10-14 23:18:33 +03:00
commit cc8e763f97
14 changed files with 51 additions and 44 deletions

View File

@ -101,7 +101,7 @@ block.set_rotation(x: int, y: int, z: int, rotation: int)
## Extended blocks
Extended blocks are blocks with size greather than 1x1x1
Extended blocks are blocks with size greater than 1x1x1
```lua
-- Checks whether the block is extended.

View File

@ -104,7 +104,7 @@ pack.get_info(packids: table) -> {id={...}, id2={...}, ...}
```
```lua
pack.assemble(packis: table) -> table
pack.assemble(packids: table) -> table
```
Checks the configuration for correctness and adds dependencies, returning the complete configuration.

View File

@ -92,7 +92,7 @@ pack.get_info(packids: table) -> {id={...}, id2={...}, ...}
```
```lua
pack.assemble(packis: table) -> table
pack.assemble(packids: table) -> table
```
Проверяет корректность конфигурации и добавляет зависимости, возвращая полную.

View File

@ -33,4 +33,5 @@
onup="on_history_up()"
ondown="on_history_down()">
</textbox>
<textbox size="200" margin="20" multiline="true" text-wrap="true" autoresize="false"/>
</container>

View File

@ -194,42 +194,49 @@ function Version.__equal(ver1, ver2)
return ver1[1] == ver2[1] and ver1[2] == ver2[2] and ver1[3] == ver2[3];
end
function Version.__more(ver1, ver2)
function Version.__greater(ver1, ver2)
if ver1[1] ~= ver2[1] then return ver1[1] > ver2[1] end;
if ver1[2] ~= ver2[2] then return ver1[2] > ver2[2] end;
return ver1[3] > ver2[3];
end
function Version.__less(ver1, ver2)
return Version.__more(ver2, ver1);
return Version.__greater(ver2, ver1);
end
function Version.__more_or_equal(ver1, ver2)
function Version.__greater_or_equal(ver1, ver2)
return not Version.__less(ver1, ver2);
end
function Version.__less_or_equal(ver1, ver2)
return not Version.__more(ver1, ver2);
return not Version.__greater(ver1, ver2);
end
Version.operators = {
["="] = Version.__equal,
[">"] = Version.__greater,
["<"] = Version.__less,
[">="] = Version.__greater_or_equal,
["<="] = Version.__less_or_equal
}
function Version.compare(op, ver1, ver2)
ver1 = string.split(ver1, ".");
ver2 = string.split(ver2, ".");
if op == "=" then return Version.__equal(ver1, ver2);
elseif op == ">" then return Version.__more(ver1, ver2);
elseif op == "<" then return Version.__less(ver1, ver2);
elseif op == ">=" then return Version.__more_or_equal(ver1, ver2);
elseif op == "<=" then return Version.__less_or_equal(ver1, ver2);
else return false; end
local comparison_func = Version.operators[op];
if comparison_func then
return comparison_func(ver1, ver2);
else
return false;
end
end
function Version.parse(version)
function Version.parse(version)
local op = string.sub(version, 1, 2);
if op == ">=" or op == "=>" then
return ">=", string.sub(version, #op + 1);
elseif op == "<=" or op == "=<" then
return "<=", string.sub(version, #op + 1);
if op == ">=" or op == "<=" then
return op, string.sub(version, #op + 1);
end
op = string.sub(version, 1, 1);
@ -340,12 +347,6 @@ function refresh()
packs_info[id] = {packinfo.id, packinfo.title}
end
for i,id in ipairs(packs_installed) do
if table.has(required, id) then
document["pack_"..id].enabled = false
end
end
if #packs_excluded == 0 then packs_excluded = table.copy(packs_available) end
if #packs_included == 0 then packs_included = table.copy(packs_installed) end
@ -365,6 +366,12 @@ function refresh()
place_pack(packs_add, packinfo, callback, string.format('reposition_func("%s")', packinfo.id))
end
for i,id in ipairs(packs_installed) do
if table.has(required, id) then
document["pack_"..id].enabled = false
end
end
check_deleted()
apply_movements(packs_cur, packs_add)
refresh_changes()

View File

@ -27,15 +27,15 @@ public:
};
enum class VersionOperator {
EQUAL, GREATHER, LESS,
GREATHER_OR_EQUAL, LESS_OR_EQUAL
EQUAL, GREATER, LESS,
GREATER_OR_EQUAL, LESS_OR_EQUAL
};
VC_ENUM_METADATA(VersionOperator)
{"=", VersionOperator::EQUAL},
{">", VersionOperator::GREATHER},
{">", VersionOperator::GREATER},
{"<", VersionOperator::LESS},
{">=", VersionOperator::GREATHER_OR_EQUAL},
{">=", VersionOperator::GREATER_OR_EQUAL},
{"<=", VersionOperator::LESS_OR_EQUAL},
VC_ENUM_END

View File

@ -37,13 +37,13 @@ public:
switch (op) {
case VersionOperator::EQUAL:
return *this == other;
case VersionOperator::GREATHER:
case VersionOperator::GREATER:
return *this > other;
case VersionOperator::LESS:
return *this < other;
case VersionOperator::LESS_OR_EQUAL:
return *this <= other;
case VersionOperator::GREATHER_OR_EQUAL:
case VersionOperator::GREATER_OR_EQUAL:
return *this >= other;
default:
return false;

View File

@ -108,17 +108,15 @@ static bool resolve_dependencies(
continue;
}
auto dep_pack = found -> second;
auto dep_pack = found->second;
if (Version::matchesPattern(dep.version) && Version::matchesPattern(dep_pack.version)
&& Version(dep_pack.version)
.processOperator(dep.op, Version(dep.version))
) {
// dependency pack version meets the required one
continue;
} else if (dep.version == "*" || dep.version == dep_pack.version){
// fallback: dependency pack version also meets required one
continue;
} else {
throw contentpack_error(
dep.id,

View File

@ -54,7 +54,7 @@ public:
/// @brief Build atlas from all added images
/// @param extrusion textures extrusion pixels
/// (greather is less mip-mapping artifacts)
/// (greater is less mip-mapping artifacts)
/// @param prepare generate atlas texture (calls .prepare())
/// @param maxResolution max atlas resolution
std::unique_ptr<Atlas> build(uint extrusion, bool prepare=true, uint maxResolution=0);

View File

@ -25,7 +25,7 @@
namespace fs = std::filesystem;
/// @brief Not greather than 64 for this BIG_PRIME value
/// @brief Not greater than 64 for this BIG_PRIME value
inline constexpr int UPDATE_AREA_DIAMETER = 32;
/// @brief Number of blocks in the volume
inline constexpr int UPDATE_BLOCKS =

View File

@ -253,9 +253,10 @@ void TextBox::draw(const DrawContext& pctx, const Assets& assets) {
float time = gui.getWindow().time();
if (editable && static_cast<int>((time - caretLastMove) * 2) % 2 == 0) {
uint line = rawTextCache.getLineByTextIndex(caret);
uint lcaret = caret - rawTextCache.getTextLineOffset(line);
uint line = label->getLineByTextIndex(caret);
uint lcaret = caret - label->getTextLineOffset(line);
int width = rawTextCache.metrics.calcWidth(input, 0, lcaret);
batch->rect(
lcoord.x + width,
lcoord.y + label->getLineYOffset(line),
@ -272,10 +273,10 @@ void TextBox::draw(const DrawContext& pctx, const Assets& assets) {
batch->setColor(glm::vec4(0.8f, 0.9f, 1.0f, 0.25f));
int start = rawTextCache.metrics.calcWidth(
labelText, selectionStart - label->getTextLineOffset(startLine)
labelText, 0, selectionStart - label->getTextLineOffset(startLine)
);
int end = rawTextCache.metrics.calcWidth(
labelText, selectionEnd - label->getTextLineOffset(endLine)
labelText, 0, selectionEnd - label->getTextLineOffset(endLine)
);
int lineY = label->getLineYOffset(startLine);
@ -1210,8 +1211,8 @@ void TextBox::setCaret(size_t position) {
scrolled(-glm::ceil(offset / static_cast<double>(scrollStep) + 0.5f));
}
int lcaret = caret - rawTextCache.getTextLineOffset(line);
int realoffset =
rawTextCache.metrics.calcWidth(labelText, 0, lcaret) - static_cast<int>(textOffset) + 2;
int realoffset = rawTextCache.metrics.calcWidth(labelText, 0, lcaret) -
static_cast<int>(textOffset) + 2;
if (realoffset - width > 0) {
setTextOffset(textOffset + realoffset - width);

View File

@ -44,7 +44,7 @@ namespace gui {
runnable onDownPressed;
/// @brief Is current input valid
bool valid = true;
/// @brief Text input pointer, value may be greather than text length
/// @brief Text input pointer, value may be greater than text length
size_t caret = 0;
/// @brief Actual local (line) position of the caret on vertical move
size_t maxLocalCaret = 0;

View File

@ -273,7 +273,7 @@ static int l_meta_meta_call(lua::State* L) {
auto width = tointeger(L, 2);
auto height = tointeger(L, 3);
if (width <= 0 || height <= 0) {
throw std::runtime_error("width and height must be greather than 0");
throw std::runtime_error("width and height must be greater than 0");
}
return newuserdata<LuaHeightmap>(
L, static_cast<uint>(width), static_cast<uint>(height)

View File

@ -276,7 +276,7 @@ public:
/// @brief does the block emit any lights
bool emissive = false;
// @brief block size is greather than 1x1x1
// @brief block size is greater than 1x1x1
bool extended = false;
/// @brief set of hitboxes sets with all coord-systems precalculated