I'm messing with a simple concept of creating 2D walls with C++/OpenGL. Each wall is described by 4 vertices and either extends horizontally or vertically, and also has a color. Walls interlink if they collide. Perimeters formed by walls are filled by simple rectangles.
My idea would be to store many walls' vertex data in a single VBO. Or multiple for each attribute then place in a VAO? Interleave in one VBO and access via VAO? Regardless, many walls in one object. If whatever I'm storing in runs out of space, make another VBO (or whatever I'm using) to store another group of walls. I also wanted to have walls that meet, such as at a right angle, share vertices to save space.
However, the walls are mutable, so vertices can be added, moved, or removed at any time. This would require keeping track of the free blocks in the VBO and then allocating wall data to them as needed. It would also mean that if I have multiple VBOs, 2 walls that share vertices must be in the same VBO, possibly introducing all sorts of headaches. But at the same time, I don't want to make a VBO for every single wall, which is nothing but a very simple 4 vertex thing at most.
Example of some alterations occurring to the original image:
How is this situation typically handled? Does it require rolling my own memory allocation scheme to work with the VBOs, or is there a suitably fast solution that doesn't require so much work?