mirror of
https://github.com/panda3d/panda3d.git
synced 2025-09-30 00:32:57 -04:00
a few checks against bad data
This commit is contained in:
parent
b5eeced04a
commit
1c9395b311
@ -109,6 +109,7 @@ get_point(int x, int y) const {
|
||||
////////////////////////////////////////////////////////////////////
|
||||
INLINE void PfmFile::
|
||||
set_point(int x, int y, const LVecBase3 &point) {
|
||||
nassertv(!point.is_nan());
|
||||
nassertv(x >= 0 && x < _x_size);
|
||||
nassertv(y >= 0 && y < _y_size);
|
||||
_table[y * _x_size + x] = point;
|
||||
|
@ -208,7 +208,9 @@ read(istream &in) {
|
||||
LittleEndian value(&data, sizeof(data));
|
||||
PN_float32 result;
|
||||
value.store_value(&result, sizeof(result));
|
||||
point[ci] = result;
|
||||
if (!cnan(result)) {
|
||||
point[ci] = result;
|
||||
}
|
||||
}
|
||||
_table.push_back(point);
|
||||
}
|
||||
@ -221,7 +223,9 @@ read(istream &in) {
|
||||
BigEndian value(&data, sizeof(data));
|
||||
PN_float32 result;
|
||||
value.store_value(&result, sizeof(result));
|
||||
point[ci] = result;
|
||||
if (!cnan(result)) {
|
||||
point[ci] = result;
|
||||
}
|
||||
}
|
||||
_table.push_back(point);
|
||||
}
|
||||
@ -841,7 +845,7 @@ make_vis_mesh_geom(GeomNode *gnode, bool inverted) const {
|
||||
for (int xi = x_begin; xi < x_end; ++xi) {
|
||||
const LPoint3 &point = get_point(xi, yi);
|
||||
LPoint2 uv(PN_stdfloat(xi) / PN_stdfloat(_x_size - 1),
|
||||
PN_stdfloat(yi) / PN_stdfloat(_y_size - 1));
|
||||
PN_stdfloat(yi) / PN_stdfloat(_y_size - 1));
|
||||
|
||||
if (_vis_inverse) {
|
||||
vertex.add_data2(uv);
|
||||
@ -879,6 +883,7 @@ make_vis_mesh_geom(GeomNode *gnode, bool inverted) const {
|
||||
n[2] += v0[0] * v1[1] - v0[1] * v1[0];
|
||||
}
|
||||
n.normalize();
|
||||
nassertv(!n.is_nan());
|
||||
if (inverted) {
|
||||
n = -n;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user