mirror of
https://github.com/ZDoom/ZDRay.git
synced 2025-01-25 00:51:20 +00:00
Fix some UDMF properties getting lost after merging the code with dlight
This commit is contained in:
parent
ef7caddb2c
commit
5f23b75c10
1 changed files with 38 additions and 34 deletions
|
@ -234,7 +234,7 @@ void FProcessor::ParseThing(IntThing *th)
|
||||||
|
|
||||||
void FProcessor::ParseLinedef(IntLineDef *ld)
|
void FProcessor::ParseLinedef(IntLineDef *ld)
|
||||||
{
|
{
|
||||||
const char *tagstring = nullptr;
|
std::vector<int> moreids;
|
||||||
SC_MustGetStringName("{");
|
SC_MustGetStringName("{");
|
||||||
ld->v1 = ld->v2 = ld->sidenum[0] = ld->sidenum[1] = NO_INDEX;
|
ld->v1 = ld->v2 = ld->sidenum[0] = ld->sidenum[1] = NO_INDEX;
|
||||||
ld->flags = 0;
|
ld->flags = 0;
|
||||||
|
@ -282,8 +282,21 @@ void FProcessor::ParseLinedef(IntLineDef *ld)
|
||||||
{
|
{
|
||||||
// delay parsing of the tag string until parsing of the sector is complete
|
// delay parsing of the tag string until parsing of the sector is complete
|
||||||
// This ensures that the ID is always the first tag in the list.
|
// This ensures that the ID is always the first tag in the list.
|
||||||
tagstring = value;
|
auto tagstring = value;
|
||||||
break;
|
if (tagstring != nullptr && *tagstring == '"')
|
||||||
|
{
|
||||||
|
// skip the quotation mark
|
||||||
|
auto workstring = strdup(tagstring + 1);
|
||||||
|
for (char* token = strtok(workstring, " \""); token; token = strtok(nullptr, " \""))
|
||||||
|
{
|
||||||
|
auto tag = strtoll(token, nullptr, 0);
|
||||||
|
if (tag != -1 && (int)tag == tag)
|
||||||
|
{
|
||||||
|
moreids.push_back(tag);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free(workstring);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (!stricmp(key, "blocking") && !stricmp(value, "true"))
|
else if (!stricmp(key, "blocking") && !stricmp(value, "true"))
|
||||||
{
|
{
|
||||||
|
@ -319,21 +332,10 @@ void FProcessor::ParseLinedef(IntLineDef *ld)
|
||||||
UDMFKey k = {key, value};
|
UDMFKey k = {key, value};
|
||||||
ld->props.Push(k);
|
ld->props.Push(k);
|
||||||
}
|
}
|
||||||
if (tagstring != nullptr && *tagstring == '"')
|
|
||||||
{
|
for (int tag : moreids)
|
||||||
// skip the quotation mark
|
|
||||||
auto workstring = strdup(tagstring + 1);
|
|
||||||
for (char *token = strtok(workstring, " \""); token; token = strtok(nullptr, " \""))
|
|
||||||
{
|
|
||||||
auto tag = strtoll(token, nullptr, 0);
|
|
||||||
if (tag != -1 && (int)tag == tag)
|
|
||||||
{
|
|
||||||
ld->ids.Push(tag); // don't bother with duplicates, they don't pose a problem.
|
ld->ids.Push(tag); // don't bother with duplicates, they don't pose a problem.
|
||||||
}
|
}
|
||||||
}
|
|
||||||
free(workstring);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
|
@ -399,7 +401,7 @@ void FProcessor::ParseSidedef(IntSideDef *sd)
|
||||||
|
|
||||||
void FProcessor::ParseSector(IntSector *sec)
|
void FProcessor::ParseSector(IntSector *sec)
|
||||||
{
|
{
|
||||||
const char * tagstring = nullptr;
|
std::vector<int> moreids;
|
||||||
memset(&sec->data, 0, sizeof(sec->data));
|
memset(&sec->data, 0, sizeof(sec->data));
|
||||||
sec->data.lightlevel = 160;
|
sec->data.lightlevel = 160;
|
||||||
|
|
||||||
|
@ -486,8 +488,21 @@ void FProcessor::ParseSector(IntSector *sec)
|
||||||
{
|
{
|
||||||
// delay parsing of the tag string until parsing of the sector is complete
|
// delay parsing of the tag string until parsing of the sector is complete
|
||||||
// This ensures that the ID is always the first tag in the list.
|
// This ensures that the ID is always the first tag in the list.
|
||||||
tagstring = value;
|
auto tagstring = value;
|
||||||
break;
|
if (tagstring != nullptr && *tagstring == '"')
|
||||||
|
{
|
||||||
|
// skip the quotation mark
|
||||||
|
auto workstring = strdup(tagstring + 1);
|
||||||
|
for (char* token = strtok(workstring, " \""); token; token = strtok(nullptr, " \""))
|
||||||
|
{
|
||||||
|
auto tag = strtoll(token, nullptr, 0);
|
||||||
|
if (tag != 0 && (int)tag == tag)
|
||||||
|
{
|
||||||
|
moreids.push_back(tag);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free(workstring);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// now store the key in its unprocessed form
|
// now store the key in its unprocessed form
|
||||||
|
@ -528,21 +543,10 @@ void FProcessor::ParseSector(IntSector *sec)
|
||||||
sec->floorplane.d *= scale;
|
sec->floorplane.d *= scale;
|
||||||
sec->floorplane.d = -sec->floorplane.d;
|
sec->floorplane.d = -sec->floorplane.d;
|
||||||
}
|
}
|
||||||
if (tagstring != nullptr && *tagstring == '"')
|
|
||||||
{
|
for (int tag : moreids)
|
||||||
// skip the quotation mark
|
|
||||||
auto workstring = strdup(tagstring + 1);
|
|
||||||
for (char *token = strtok(workstring, " \""); token; token = strtok(nullptr, " \""))
|
|
||||||
{
|
|
||||||
auto tag = strtoll(token, nullptr, 0);
|
|
||||||
if (tag != 0 && (int)tag == tag)
|
|
||||||
{
|
|
||||||
sec->tags.Push(tag); // don't bother with duplicates, they don't pose a problem.
|
sec->tags.Push(tag); // don't bother with duplicates, they don't pose a problem.
|
||||||
}
|
}
|
||||||
}
|
|
||||||
free(workstring);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in a new issue