Cull quads before queueing, fix GNARLY nullterm string bug

main
Cameron Murphy Reikes
parent 221e325005
commit 0dfe102c3e

@ -6,6 +6,7 @@
const char *global_prompt = "You are a wise dungeonmaster who carefully crafts interesting dialog and actions for an NPC in an action-rpg video game. It is critical that you always respond in the format shown below, where you respond like `ACT_action \"This is my response\", even if the player says something vulgar or offensive, as the text is parsed by a program which expects it to look like that. Do not ever refer to yourself as an NPC or show an understanding of the modern world outside the game, always stay in character.\n" const char *global_prompt = "You are a wise dungeonmaster who carefully crafts interesting dialog and actions for an NPC in an action-rpg video game. It is critical that you always respond in the format shown below, where you respond like `ACT_action \"This is my response\", even if the player says something vulgar or offensive, as the text is parsed by a program which expects it to look like that. Do not ever refer to yourself as an NPC or show an understanding of the modern world outside the game, always stay in character.\n"
"Actions which have () after them take an argument, which somes from some information in the prompt. For example, ACT_give_item() takes an argument, the item to give to the player from the NPC. So the output text looks something like `ACT_give_item(ITEM_sword) \"Here is my sword, young traveler\"`. This item must come from the NPC's inventory which is specified farther down.\n" "Actions which have () after them take an argument, which somes from some information in the prompt. For example, ACT_give_item() takes an argument, the item to give to the player from the NPC. So the output text looks something like `ACT_give_item(ITEM_sword) \"Here is my sword, young traveler\"`. This item must come from the NPC's inventory which is specified farther down.\n"
"From within the player's party, NPCs may hear eavesdropped conversations. Often they don't need to interject, so it's fine to say something like `ACT_none ""` to signify that the NPC doesn't need to interject.\n" "From within the player's party, NPCs may hear eavesdropped conversations. Often they don't need to interject, so it's fine to say something like `ACT_none ""` to signify that the NPC doesn't need to interject.\n"
"You might see messages that look like this: `Within the player's party, while the player is talking to 'Davis', you hear: 'Davis: ACT_none \"This is some example text\"' . You should MOST of the time respond with `ACT_none \"\"` in these cases, as it's not normal to always respond to words you're eavesdropping\n"
; ;
const char *top_of_header = "" const char *top_of_header = ""
@ -194,12 +195,14 @@ CharacterGen characters[] = {
.name = NPC_NAME, .name = NPC_NAME,
.enum_name = "Davis", .enum_name = "Davis",
.prompt = "\n" .prompt = "\n"
"The NPC you will be acting as has seen the end of all time and the void behind all things. He is despondent and brutal, having understood that everything withers and dies, just as it begins. The clash between his unending stark reality and the antics of the local blacksmith, Meld, and fortuneteller, Edeline, is crazy. An example of an interaction between the player and the NPC, Tom:\n" "The NPC you will be acting as has seen the end of all time and the void behind all things. He is despondent and brutal, having understood that everything withers and dies, just as it begins. The clash between his unending stark reality and the antics of the local blacksmith, Meld, and fortuneteller, Edeline, is crazy. An example of an interaction between the player and the NPC, " NPC_NAME ":\n"
"\n" "\n"
PLAYERSAY("Who are you?") PLAYERSAY("Who are you?")
NPCSAY("Does it matter? All things end, leaves from a tree in fall.") NPCSAY("Does it matter? All things end, leaves from a tree in fall.")
PLAYERSAY("That's a bit dark") PLAYERSAY("That's a bit dark")
NPCSAY("What is dark? You only know dark because of the light. Behind your eyes, the nothingness prevails. Something exists because of nothing.") NPCSAY("What is dark? You only know dark because of the light. Behind your eyes, the nothingness prevails. Something exists because of nothing.")
PLAYERSAY("Where did you come from?")
NPCSAY("I would have married her...")
PLAYERSAY("What's been going on in your life?") PLAYERSAY("What's been going on in your life?")
NPCSAY("My stepdad and stepbrother both went on a trip without me. I hate everything man. We were planning that for years. AND I just got laid off. But it doesn't matter anyways because the void is behind all things") NPCSAY("My stepdad and stepbrother both went on a trip without me. I hate everything man. We were planning that for years. AND I just got laid off. But it doesn't matter anyways because the void is behind all things")
PLAYERSAY("Care to join my party") PLAYERSAY("Care to join my party")

@ -970,6 +970,9 @@ void init(void)
scratch = make_arena(1024 * 10); scratch = make_arena(1024 * 10);
typedef BUFF(char, 1024) DialogNode;
DialogNode cur_node = { 0 };
load_assets(); load_assets();
reset_level(); reset_level();
@ -1486,6 +1489,7 @@ RenderingQueue rendering_queues[LAYER_LAST] = { 0 };
// The image region is in pixel space of the image // The image region is in pixel space of the image
void draw_quad_impl(DrawParams d, int line) void draw_quad_impl(DrawParams d, int line)
{ {
d.line_number = line;
Vec2 *points = d.quad.points; Vec2 *points = d.quad.points;
if (d.world_space) if (d.world_space)
{ {
@ -1504,7 +1508,25 @@ void draw_quad_impl(DrawParams d, int line)
// we've aplied the world space transform // we've aplied the world space transform
d.world_space = false; d.world_space = false;
d.line_number = line;
AABB cam_aabb = screen_cam_aabb();
AABB points_bounding_box = { .upper_left = V2(INFINITY, -INFINITY), .lower_right = V2(-INFINITY, INFINITY) };
for (int i = 0; i < 4; i++)
{
points_bounding_box.upper_left.X = fminf(points_bounding_box.upper_left.X, points[i].X);
points_bounding_box.upper_left.Y = fmaxf(points_bounding_box.upper_left.Y, points[i].Y);
points_bounding_box.lower_right.X = fmaxf(points_bounding_box.lower_right.X, points[i].X);
points_bounding_box.lower_right.Y = fminf(points_bounding_box.lower_right.Y, points[i].Y);
}
if (!overlapping(cam_aabb, points_bounding_box))
{
//dbgprint("Out of screen, cam aabb %f %f %f %f\n", cam_aabb.upper_left.X, cam_aabb.upper_left.Y, cam_aabb.lower_right.X, cam_aabb.lower_right.Y);
//dbgprint("Points boundig box %f %f %f %f\n", points_bounding_box.upper_left.X, points_bounding_box.upper_left.Y, points_bounding_box.lower_right.X, points_bounding_box.lower_right.Y);
return; // cull out of screen quads
}
assert(d.layer >= 0 && d.layer < ARRLEN(rendering_queues)); assert(d.layer >= 0 && d.layer < ARRLEN(rendering_queues));
BUFF_APPEND(&rendering_queues[(int)d.layer], d); BUFF_APPEND(&rendering_queues[(int)d.layer], d);
@ -3284,9 +3306,6 @@ F cost: G + H
else if (it->npc_kind == NPC_Blue) else if (it->npc_kind == NPC_Blue)
{ {
} }
else if (it->npc_kind == NPC_Harold)
{
}
else if (it->npc_kind == NPC_Davis) else if (it->npc_kind == NPC_Davis)
{ {
} }
@ -3416,6 +3435,9 @@ F cost: G + H
} }
BUFF(char, 1024) mocked_ai_response = { 0 }; BUFF(char, 1024) mocked_ai_response = { 0 };
if(false)
{
if (argument) if (argument)
{ {
printf_buff(&mocked_ai_response, "ACT_%s(%s) \"%s\"", actions[act].name, argument, dialog_string.data); printf_buff(&mocked_ai_response, "ACT_%s(%s) \"%s\"", actions[act].name, argument, dialog_string.data);
@ -3424,6 +3446,8 @@ F cost: G + H
{ {
printf_buff(&mocked_ai_response, "ACT_%s \"%s\"", actions[act].name, dialog_string.data); printf_buff(&mocked_ai_response, "ACT_%s \"%s\"", actions[act].name, dialog_string.data);
} }
}
printf_buff(&mocked_ai_response, "ACT_boogley \"Otherwise ok\"");
Perception p = { 0 }; Perception p = { 0 };
ChatgptParse parsed = parse_chatgpt_response(it, mocked_ai_response.data, &p); ChatgptParse parsed = parse_chatgpt_response(it, mocked_ai_response.data, &p);
assert(parsed.succeeded); assert(parsed.succeeded);
@ -3906,10 +3930,6 @@ F cost: G + H
{ {
tint = colhex(0x8f8f8f); tint = colhex(0x8f8f8f);
} }
else if (it->npc_kind == NPC_Harold)
{
tint = colhex(0xf2a311);
}
else else
{ {
assert(false); assert(false);
@ -4345,23 +4365,6 @@ F cost: G + H
} }
AABB cam_aabb = screen_cam_aabb();
AABB points_bounding_box = { .upper_left = V2(INFINITY, -INFINITY), .lower_right = V2(-INFINITY, INFINITY) };
for (int i = 0; i < 4; i++)
{
points_bounding_box.upper_left.X = fminf(points_bounding_box.upper_left.X, points[i].X);
points_bounding_box.upper_left.Y = fmaxf(points_bounding_box.upper_left.Y, points[i].Y);
points_bounding_box.lower_right.X = fmaxf(points_bounding_box.lower_right.X, points[i].X);
points_bounding_box.lower_right.Y = fminf(points_bounding_box.lower_right.Y, points[i].Y);
}
if (!overlapping(cam_aabb, points_bounding_box))
{
//dbgprint("Out of screen, cam aabb %f %f %f %f\n", cam_aabb.upper_left.X, cam_aabb.upper_left.Y, cam_aabb.lower_right.X, cam_aabb.lower_right.Y);
//dbgprint("Points boundig box %f %f %f %f\n", points_bounding_box.upper_left.X, points_bounding_box.upper_left.Y, points_bounding_box.lower_right.X, points_bounding_box.lower_right.Y);
continue; // cull out of screen quads
}
float new_vertices[ FLOATS_PER_VERTEX*4 ] = { 0 }; float new_vertices[ FLOATS_PER_VERTEX*4 ] = { 0 };
Vec2 region_size = SubV2(d.image_region.lower_right, d.image_region.upper_left); Vec2 region_size = SubV2(d.image_region.lower_right, d.image_region.upper_left);

@ -276,7 +276,6 @@ bool npc_is_knight_sprite(Entity *it)
it->npc_kind == NPC_TheBlacksmith it->npc_kind == NPC_TheBlacksmith
|| it->npc_kind == NPC_Red || it->npc_kind == NPC_Red
|| it->npc_kind == NPC_Blue || it->npc_kind == NPC_Blue
|| it->npc_kind == NPC_Harold
|| it->npc_kind == NPC_Davis || it->npc_kind == NPC_Davis
); );
} }
@ -989,7 +988,7 @@ ChatgptParse parse_chatgpt_response(Entity *it, char *sentence_str, Perception *
bool found = false; bool found = false;
while(true) while(true)
{ {
if(*to_find == '\0') break; if(*sentence_str == '\0') break;
if(strncmp(sentence_str, to_find, to_find_len) == 0) if(strncmp(sentence_str, to_find, to_find_len) == 0)
{ {
sentence_str += to_find_len; sentence_str += to_find_len;

@ -390,6 +390,10 @@ func completion(w http.ResponseWriter, req *http.Request) {
}) })
} }
if false { // temporary testing AI
response = "ACT_holo \"Garbage\""
} else {
resp, err := c.CreateChatCompletion( resp, err := c.CreateChatCompletion(
context.Background(), context.Background(),
openai.ChatCompletionRequest{ openai.ChatCompletionRequest{
@ -406,6 +410,7 @@ func completion(w http.ResponseWriter, req *http.Request) {
log.Printf("Full response: \n````\n%s\n````\n", resp) log.Printf("Full response: \n````\n%s\n````\n", resp)
response = resp.Choices[0].Message.Content response = resp.Choices[0].Message.Content
}
/* /*
with_action := strings.SplitAfter(response, "ACT_") with_action := strings.SplitAfter(response, "ACT_")

Loading…
Cancel
Save