1 ////////////////////////////////////////////////////////////////////////////
3 ////////////////////////////////////////////////////////////////////////////
7 static pmt_@TAG@vector *
10 return dynamic_cast<pmt_@TAG@vector*>(x.get());
14 pmt_@TAG@vector::pmt_@TAG@vector(size_t k, @TYPE@ fill)
17 for (size_t i = 0; i < k; i++)
21 pmt_@TAG@vector::pmt_@TAG@vector(size_t k, const @TYPE@ *data)
24 for (size_t i = 0; i < k; i++)
29 pmt_@TAG@vector::ref(size_t k) const
32 throw pmt_out_of_range("pmt_@TAG@vector_ref", pmt_from_long(k));
37 pmt_@TAG@vector::set(size_t k, @TYPE@ x)
40 throw pmt_out_of_range("pmt_@TAG@vector_set", pmt_from_long(k));
45 pmt_@TAG@vector::elements(size_t &len)
52 pmt_@TAG@vector::writable_elements(size_t &len)
59 pmt_@TAG@vector::uniform_elements(size_t &len)
61 len = length() * sizeof(@TYPE@);
66 pmt_@TAG@vector::uniform_writable_elements(size_t &len)
68 len = length() * sizeof(@TYPE@);
73 pmt_is_@TAG@vector(pmt_t obj)
75 return obj->is_@TAG@vector();
79 pmt_make_@TAG@vector(size_t k, @TYPE@ fill)
81 return pmt_t(new pmt_@TAG@vector(k, fill));
85 pmt_init_@TAG@vector(size_t k, const @TYPE@ *data)
87 return pmt_t(new pmt_@TAG@vector(k, data));
91 pmt_@TAG@vector_ref(pmt_t vector, size_t k)
93 if (!vector->is_@TAG@vector())
94 throw pmt_wrong_type("pmt_@TAG@vector_ref", vector);
95 return _@TAG@vector(vector)->ref(k);
99 pmt_@TAG@vector_set(pmt_t vector, size_t k, @TYPE@ obj)
101 if (!vector->is_@TAG@vector())
102 throw pmt_wrong_type("pmt_@TAG@vector_set", vector);
103 _@TAG@vector(vector)->set(k, obj);
107 pmt_@TAG@vector_elements(pmt_t vector, size_t &len)
109 if (!vector->is_@TAG@vector())
110 throw pmt_wrong_type("pmt_@TAG@vector_elements", vector);
111 return _@TAG@vector(vector)->elements(len);
115 pmt_@TAG@vector_writable_elements(pmt_t vector, size_t &len)
117 if (!vector->is_@TAG@vector())
118 throw pmt_wrong_type("pmt_@TAG@vector_writable_elements", vector);
119 return _@TAG@vector(vector)->writable_elements(len);
122 } /* namespace gruel */