mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2024-11-24 20:36:24 -05:00
51 lines
1.2 KiB
C++
51 lines
1.2 KiB
C++
// Copyright 2014 Citra Emulator Project
|
|
// Licensed under GPLv2
|
|
// Refer to the license.txt file included.
|
|
|
|
#include "clipper.h"
|
|
#include "pica.h"
|
|
#include "primitive_assembly.h"
|
|
#include "vertex_shader.h"
|
|
|
|
namespace Pica {
|
|
|
|
namespace PrimitiveAssembly {
|
|
|
|
static OutputVertex buffer[2];
|
|
static int buffer_index = 0; // TODO: reset this on emulation restart
|
|
|
|
void SubmitVertex(OutputVertex& vtx)
|
|
{
|
|
switch (registers.triangle_topology) {
|
|
case Regs::TriangleTopology::List:
|
|
case Regs::TriangleTopology::ListIndexed:
|
|
if (buffer_index < 2) {
|
|
buffer[buffer_index++] = vtx;
|
|
} else {
|
|
buffer_index = 0;
|
|
|
|
Clipper::ProcessTriangle(buffer[0], buffer[1], vtx);
|
|
}
|
|
break;
|
|
|
|
case Regs::TriangleTopology::Fan:
|
|
if (buffer_index == 2) {
|
|
buffer_index = 0;
|
|
|
|
Clipper::ProcessTriangle(buffer[0], buffer[1], vtx);
|
|
|
|
buffer[1] = vtx;
|
|
} else {
|
|
buffer[buffer_index++] = vtx;
|
|
}
|
|
break;
|
|
|
|
default:
|
|
ERROR_LOG(GPU, "Unknown triangle mode %x:", (int)registers.triangle_topology.Value());
|
|
break;
|
|
}
|
|
}
|
|
|
|
} // namespace
|
|
|
|
} // namespace
|