- static RequireVersion _ver(1, 3);
- glActiveTexture(GL_TEXTURE0+n);
+ if(MSP_legacy_features)
+ count = get_i(GL_MAX_TEXTURE_UNITS);
+ else
+ count = 0;
+ }
+ return count;
+}
+
+TexUnit &TexUnit::get_unit(unsigned n)
+{
+ if(n>0)
+ static Require _req(ARB_multitexture);
+ if(n>=get_n_units())
+ throw out_of_range("TexUnit::get_unit");
+
+ if(units.size()<=n)
+ {
+ unsigned i = units.size();
+ unsigned n_legacy = get_n_legacy_units();
+ units.resize(n+1, TexUnit());
+ for(; i<units.size(); ++i)
+ {
+ units[i].index = i;
+ units[i].legacy = (i<n_legacy);
+ }