From 733dea55dafd81b50e8d2c0128fbb96ab4614733 Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Sat, 25 May 2019 10:47:54 +0300 Subject: [PATCH 1/7] - fixed loading of 32-bit TGA textures with alpha channel https://forum.zdoom.org/viewtopic.php?t=64741#p1104564 --- src/gamedata/textures/formats/tgatexture.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gamedata/textures/formats/tgatexture.cpp b/src/gamedata/textures/formats/tgatexture.cpp index 9936a828e..927bf9b50 100644 --- a/src/gamedata/textures/formats/tgatexture.cpp +++ b/src/gamedata/textures/formats/tgatexture.cpp @@ -497,7 +497,7 @@ int FTGATexture::CopyPixels(FBitmap *bmp, int conversion) } else { - bmp->CopyPixelDataRGB(0, 0, ptr, Width, Height, step_x, Pitch, 9, CF_BGRA); + bmp->CopyPixelDataRGB(0, 0, ptr, Width, Height, step_x, Pitch, 0, CF_BGRA); transval = -1; } break; From 57a0a4c06635783ff6f48874b131e95fe9ab35c8 Mon Sep 17 00:00:00 2001 From: David Carlier Date: Sat, 25 May 2019 10:31:23 +0100 Subject: [PATCH 2/7] Fixing crash when loaded module, using proper function liberate them. --- src/gamedata/textures/animations.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gamedata/textures/animations.cpp b/src/gamedata/textures/animations.cpp index 644718bc4..0132fc336 100644 --- a/src/gamedata/textures/animations.cpp +++ b/src/gamedata/textures/animations.cpp @@ -73,7 +73,7 @@ FAnimDef *FTextureManager::AddAnim (FAnimDef *anim) if (mAnimations[i]->BasePic == anim->BasePic) { // Found one! - free (mAnimations[i]); + M_Free (mAnimations[i]); mAnimations[i] = anim; return anim; } From 688f130af633c4241424ec2e4b50f7b322d49f9e Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Sat, 25 May 2019 13:16:39 +0300 Subject: [PATCH 3/7] - fixed character position assignment for multi-lump fonts https://forum.zdoom.org/viewtopic.php?t=64741#p1104427 --- src/gamedata/fonts/font.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gamedata/fonts/font.cpp b/src/gamedata/fonts/font.cpp index da8fd25ee..09423933f 100644 --- a/src/gamedata/fonts/font.cpp +++ b/src/gamedata/fonts/font.cpp @@ -194,7 +194,7 @@ FFont::FFont (const char *name, const char *nametemplate, const char *filetempla { for (i = 0; i < lcount; i++) { - int position = '!' + i; + int position = lfirst + i; mysnprintf(buffer, countof(buffer), nametemplate, i + start); lump = TexMan.CheckForTexture(buffer, ETextureType::MiscPatch); @@ -253,7 +253,7 @@ FFont::FFont (const char *name, const char *nametemplate, const char *filetempla { if (texs[i]) { - int position = '!' + i; + int position = lfirst + i; Type = Multilump; if (position < minchar) minchar = position; if (position > maxchar) maxchar = position; From 64ce71eae26aad678baf12936a9aae25a844e3e0 Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Sat, 25 May 2019 17:14:52 +0300 Subject: [PATCH 4/7] - fixed wrong native call for Actor.Vec2Offset() https://forum.zdoom.org/viewtopic.php?t=64810 --- src/scripting/vmthunks_actors.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripting/vmthunks_actors.cpp b/src/scripting/vmthunks_actors.cpp index d37600444..1a68b340c 100644 --- a/src/scripting/vmthunks_actors.cpp +++ b/src/scripting/vmthunks_actors.cpp @@ -512,7 +512,7 @@ DEFINE_ACTION_FUNCTION_NATIVE(AActor, Vec2OffsetZ, Vec2OffsetZ) static void Vec2Offset(AActor *self, double x, double y, bool absolute, DVector2 *result) { - *result = self->Vec2OffsetZ(x, y, absolute); + *result = self->Vec2Offset(x, y, absolute); } DEFINE_ACTION_FUNCTION_NATIVE(AActor, Vec2Offset, Vec2Offset) From d9da513f74baa276d90016298bfc541a9f1c55cb Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Sat, 25 May 2019 17:50:18 +0300 Subject: [PATCH 5/7] - fixed 'Pause by ' message in multiplayer https://forum.zdoom.org/viewtopic.php?t=64765 --- src/d_main.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/d_main.cpp b/src/d_main.cpp index 0b0c99688..f9db5fe0e 100644 --- a/src/d_main.cpp +++ b/src/d_main.cpp @@ -853,7 +853,6 @@ void D_Display () { FTexture *tex; int x; - FString pstring = GStrings("TXT_BY"); tex = TexMan.GetTextureByName(gameinfo.PauseSign, true); x = (SCREENWIDTH - tex->GetDisplayWidth() * CleanXfac)/2 + @@ -862,7 +861,8 @@ void D_Display () if (paused && multiplayer) { FFont *font = generic_ui? NewSmallFont : SmallFont; - pstring << ' ' << players[paused - 1].userinfo.GetName(); + FString pstring = GStrings("TXT_BY"); + pstring.Substitute("%s", players[paused - 1].userinfo.GetName()); screen->DrawText(font, CR_RED, (screen->GetWidth() - font->StringWidth(pstring)*CleanXfac) / 2, (tex->GetDisplayHeight() * CleanYfac) + 4, pstring, DTA_CleanNoMove, true, TAG_DONE); From a54bc616780f6c2f862bd551726699842862f072 Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Sun, 26 May 2019 15:46:30 +0300 Subject: [PATCH 6/7] - fixed conversation links with pages referenced by name https://forum.zdoom.org/viewtopic.php?t=64177 --- src/maploader/usdf.cpp | 129 +++++++++++++++++++++-------------------- 1 file changed, 66 insertions(+), 63 deletions(-) diff --git a/src/maploader/usdf.cpp b/src/maploader/usdf.cpp index b2df9503c..6d398ce33 100644 --- a/src/maploader/usdf.cpp +++ b/src/maploader/usdf.cpp @@ -482,11 +482,74 @@ class USDFParser : public UDMFParserBase return false; } Level->SetConversation(dlgid, type, startpos); - for(;startpos < Level->StrifeDialogues.Size(); startpos++) + + auto& dialogues = Level->StrifeDialogues; + const auto numnodes = dialogues.Size(); + + for (auto i = startpos; i < numnodes; i++) { - Level->StrifeDialogues[startpos]->SpeakerType = type; - Level->StrifeDialogues[startpos]->MenuClassName = clsid; + dialogues[i]->SpeakerType = type; + dialogues[i]->MenuClassName = clsid; } + + if (namespace_bits == Gz) // string page name linker + { + TMap nameToIndex; + + for (auto i = startpos; i < numnodes; i++) + { + FString key = dialogues[i]->ThisNodeName; + if (key.IsNotEmpty()) + { + key.ToLower(); + if (nameToIndex.CheckKey(key)) + Printf("Warning! Duplicate page name '%s'!\n", dialogues[i]->ThisNodeName.GetChars()); + else + { + nameToIndex[key] = i - startpos; + DPrintf(DMSG_NOTIFY, "GZSDF linker: Assigning pagename '%s' to node %i\n", key.GetChars(), i); + } + } + } + + if (nameToIndex.CountUsed()) + { + for (auto i = startpos; i < numnodes; i++) + { + FString itemLinkKey = dialogues[i]->ItemCheckNodeName; + if (itemLinkKey.IsNotEmpty()) + { + itemLinkKey.ToLower(); + if (nameToIndex.CheckKey(itemLinkKey)) + { + dialogues[i]->ItemCheckNode = nameToIndex[itemLinkKey] + 1; + DPrintf(DMSG_NOTIFY, "GZSDF linker: Item Link '%s' in node %i was index %i\n", itemLinkKey.GetChars(), i, nameToIndex[itemLinkKey]); + } + else + Printf("Warning! Reference to non-existent item-linked dialogue page name '%s' in page %i!\n", dialogues[i]->ItemCheckNodeName.GetChars(), i); + } + + FStrifeDialogueReply *NodeCheck = dialogues[i]->Children; + while (NodeCheck) + { + if (NodeCheck->NextNodeName.IsNotEmpty()) + { + FString key = NodeCheck->NextNodeName; + key.ToLower(); + if (nameToIndex.CheckKey(key)) + { + NodeCheck->NextNode = nameToIndex[key] + 1; + DPrintf(DMSG_NOTIFY, "GZSDF linker: Nextpage Link '%s' in node %i was index %i\n", key.GetChars(), i, nameToIndex[key]); + } + else + Printf("Warning! Reference to non-existent reply-linked dialogue page name '%s' in page %i!\n", NodeCheck->NextNodeName.GetChars(), i); + } + NodeCheck = NodeCheck->Next; + } + } + } + } + return true; } @@ -551,66 +614,6 @@ public: } } - if (namespace_bits == Gz) // string page name linker - { - int numnodes = Level->StrifeDialogues.Size(); - int usedstrings = false; - - TMap nameToIndex; - for (int i = 0; i < numnodes; i++) - { - FString key = Level->StrifeDialogues[i]->ThisNodeName; - if (key.IsNotEmpty()) - { - key.ToLower(); - if (nameToIndex.CheckKey(key)) - Printf("Warning! Duplicate page name '%s'!\n", Level->StrifeDialogues[i]->ThisNodeName.GetChars()); - else - { - nameToIndex[key] = i; - DPrintf(DMSG_NOTIFY, "GZSDF linker: Assigning pagename '%s' to node %i\n", key.GetChars(), i); - } - usedstrings = true; - } - } - if (usedstrings) - { - for (int i = 0; i < numnodes; i++) - { - FString itemLinkKey = Level->StrifeDialogues[i]->ItemCheckNodeName; - if (itemLinkKey.IsNotEmpty()) - { - itemLinkKey.ToLower(); - if (nameToIndex.CheckKey(itemLinkKey)) - { - Level->StrifeDialogues[i]->ItemCheckNode = nameToIndex[itemLinkKey] + 1; - DPrintf(DMSG_NOTIFY, "GZSDF linker: Item Link '%s' in node %i was index %i\n", itemLinkKey.GetChars(), i, nameToIndex[itemLinkKey]); - } - else - Printf("Warning! Reference to non-existent item-linked dialogue page name '%s' in page %i!\n", Level->StrifeDialogues[i]->ItemCheckNodeName.GetChars(), i); - } - - FStrifeDialogueReply *NodeCheck = Level->StrifeDialogues[i]->Children; - while (NodeCheck) - { - if (NodeCheck->NextNodeName.IsNotEmpty()) - { - FString key = NodeCheck->NextNodeName; - key.ToLower(); - if (nameToIndex.CheckKey(key)) - { - NodeCheck->NextNode = nameToIndex[key] + 1; - DPrintf(DMSG_NOTIFY, "GZSDF linker: Nextpage Link '%s' in node %i was index %i\n", key.GetChars(), i, nameToIndex[key]); - } - else - Printf("Warning! Reference to non-existent reply-linked dialogue page name '%s' in page %i!\n", NodeCheck->NextNodeName.GetChars(), i); - } - NodeCheck = NodeCheck->Next; - } - } - } - - } return true; } }; From 8127af108273fdf7962793e4c648ce1e2f07248c Mon Sep 17 00:00:00 2001 From: Nemrtvi <26684396+Nemrtvi@users.noreply.github.com> Date: Mon, 27 May 2019 08:53:58 +0200 Subject: [PATCH 7/7] =?UTF-8?q?Improved=20SMALLFONT=20letter=20=D0=A7=20fo?= =?UTF-8?q?r=20Doom?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit In its past appearance, the letter was based on the number 4, which looks inconsistent among all letters. This new one is a modified Y. --- .../filter/doom.id/fonts/defsmallfont/0427.lmp | Bin 111 -> 125 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/wadsrc_extra/static/filter/doom.id/fonts/defsmallfont/0427.lmp b/wadsrc_extra/static/filter/doom.id/fonts/defsmallfont/0427.lmp index 4ef0669f68adf9b57325515c627af9441ea09da0..e4181d6ce3add071a4b0b06d2755a95fa1ce0520 100644 GIT binary patch literal 125 zcmd;JU}pdU4InlEVoM-)24Y_zjs)UVAT9)A24;N__|L$iufK5%h`|bEY~BiG0ofoH bJ4g+X1!ZsAymk9_7<(HKz}0}1=>G=*XW|}< literal 111 zcmXxa!3}^g3+f1&eel>GOegA((WNJM(nxGFwu`q=I