use std::error;
use std::fmt;
use VulkanObject;
use buffer::BufferAccess;
use device::DeviceOwned;
use pipeline::vertex::VertexSource;
pub fn check_vertex_buffers<P, V>(pipeline: &P, vertex_buffers: V)
-> Result<CheckVertexBuffer, CheckVertexBufferError>
where P: DeviceOwned + VertexSource<V>
{
let (vertex_buffers, vertex_count, instance_count) = pipeline.decode(vertex_buffers);
for (num, buf) in vertex_buffers.iter().enumerate() {
assert_eq!(buf.inner().buffer.device().internal_object(),
pipeline.device().internal_object());
if !buf.inner().buffer.usage_vertex_buffer() {
return Err(CheckVertexBufferError::BufferMissingUsage { num_buffer: num });
}
}
Ok(CheckVertexBuffer {
vertex_buffers,
vertex_count: vertex_count as u32,
instance_count: instance_count as u32,
})
}
pub struct CheckVertexBuffer {
pub vertex_buffers: Vec<Box<BufferAccess + Send + Sync>>,
pub vertex_count: u32,
pub instance_count: u32,
}
#[derive(Debug, Copy, Clone)]
pub enum CheckVertexBufferError {
BufferMissingUsage {
num_buffer: usize,
},
}
impl error::Error for CheckVertexBufferError {
#[inline]
fn description(&self) -> &str {
match *self {
CheckVertexBufferError::BufferMissingUsage { .. } => {
"the vertex buffer usage is missing on a vertex buffer"
},
}
}
}
impl fmt::Display for CheckVertexBufferError {
#[inline]
fn fmt(&self, fmt: &mut fmt::Formatter) -> Result<(), fmt::Error> {
write!(fmt, "{}", error::Error::description(self))
}
}