Skip to content

Commit

Permalink
Use remainder instead of modulo, fix #70
Browse files Browse the repository at this point in the history
  • Loading branch information
lexaknyazev committed Feb 24, 2018
1 parent 97d3e6d commit 9fd834a
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 11 deletions.
8 changes: 6 additions & 2 deletions lib/src/base/accessor.dart
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ class Accessor extends GltfChildOfRootProperty {
int _componentLength = -1;
bool _isUnit = false;
bool _isXyzSign = false;
bool _isCubicSpline = false;
AccessorUsage _usage;

Accessor._(
Expand Down Expand Up @@ -115,6 +116,7 @@ class Accessor extends GltfChildOfRootProperty {

bool get isUnit => _isUnit;
bool get isXyzSign => _isXyzSign;
bool get isCubicSpline => _isCubicSpline;

AccessorUsage get usage => _usage;

Expand Down Expand Up @@ -339,6 +341,8 @@ class Accessor extends GltfChildOfRootProperty {

void setXyzSign() => _isXyzSign = true;

void setCubicSpline() => _isCubicSpline = true;

Iterable<num> getElements({bool normalize: false}) sync* {
// Ensure required fields to not check for them each time
if (componentType == -1 || count == -1 || type == null) {
Expand Down Expand Up @@ -533,7 +537,7 @@ class Accessor extends GltfChildOfRootProperty {
return false;
}

if (byteOffset % componentLength != 0) {
if (byteOffset.remainder(componentLength) != 0) {
if (context != null) {
context.addIssue(SemanticError.accessorOffsetAlignment,
name: BYTE_OFFSET, args: [byteOffset, componentLength]);
Expand All @@ -548,7 +552,7 @@ class Accessor extends GltfChildOfRootProperty {
}

final totalOffset = bufferView.byteOffset + byteOffset;
if (totalOffset % componentLength != 0) {
if (totalOffset.remainder(componentLength) != 0) {
if (context != null) {
context.addIssue(LinkError.accessorTotalOffsetAlignment,
name: BYTE_OFFSET, args: [totalOffset, componentLength]);
Expand Down
1 change: 1 addition & 0 deletions lib/src/base/animation.dart
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,7 @@ class Animation extends GltfChildOfRootProperty {

if (channel._sampler.interpolation == CUBICSPLINE) {
outputCount *= 3;
channel._sampler._output.setCubicSpline();
}

if (channel.target.path == WEIGHTS) {
Expand Down
2 changes: 1 addition & 1 deletion lib/src/base/buffer_view.dart
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ class BufferView extends GltfChildOfRootProperty {
name: BYTE_STRIDE, args: [byteStride, byteLength]);
}

if (byteStride % 4 != 0) {
if (byteStride.remainder(4) != 0) {
context.addIssue(SchemaError.valueMultipleOf,
name: BYTE_STRIDE, args: [byteStride, 4]);
}
Expand Down
14 changes: 8 additions & 6 deletions lib/src/base/mesh.dart
Original file line number Diff line number Diff line change
Expand Up @@ -321,8 +321,9 @@ class MeshPrimitive extends GltfProperty {
args: [format, validFormats]);
}

if ((accessor.byteOffset != -1 && accessor.byteOffset % 4 != 0) ||
(accessor.elementLength % 4 != 0 &&
if ((accessor.byteOffset != -1 &&
accessor.byteOffset.remainder(4) != 0) ||
(accessor.elementLength.remainder(4) != 0 &&
accessor.bufferView != null &&
accessor.bufferView.byteStride == -1)) {
context.addIssue(LinkError.meshPrimitiveAccessorUnaligned,
Expand Down Expand Up @@ -396,9 +397,9 @@ class MeshPrimitive extends GltfProperty {
*/

if ((context.validate && _count != -1) &&
((mode == 1 && _count % 2 != 0) ||
((mode == 1 && _count.remainder(2) != 0) ||
((mode == 2 || mode == 3) && _count < 2) ||
(mode == 4 && _count % 3 != 0) ||
(mode == 4 && _count.remainder(3) != 0) ||
((mode == 5 || mode == 6) && _count < 3))) {
context.addIssue(LinkError.meshPrimitiveIncompatibleMode,
args: [_count, gl.MODES_NAMES[mode]]);
Expand Down Expand Up @@ -467,8 +468,9 @@ class MeshPrimitive extends GltfProperty {
args: [format, validFormats]);
}

if ((accessor.byteOffset != -1 && accessor.byteOffset % 4 != 0) ||
(accessor.elementLength % 4 != 0 &&
if ((accessor.byteOffset != -1 &&
accessor.byteOffset.remainder(4) != 0) ||
(accessor.elementLength.remainder(4) != 0 &&
accessor.bufferView != null &&
accessor.bufferView.byteStride == -1)) {
context.addIssue(LinkError.meshPrimitiveAccessorUnaligned,
Expand Down
17 changes: 15 additions & 2 deletions lib/src/data_access/validate_accessors.dart
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,10 @@ void validateAccessorsData(Gltf gltf, Context context) {
return;
}

if (accessor.isCubicSpline && accessor.count.remainder(3) != 0) {
return;
}

// Skip empty accessors
if (accessor.bufferView == null && accessor.sparse == null) {
return;
Expand Down Expand Up @@ -109,6 +113,9 @@ void validateAccessorsData(Gltf gltf, Context context) {
var index = 0;
var componentIndex = 0;

// 0: in; 1: value; 2: out
var cubicSplineState = 0;

final iterator = gltf.accessors[i].getElements().iterator;

var hasNext = iterator.moveNext();
Expand Down Expand Up @@ -184,7 +191,8 @@ void validateAccessorsData(Gltf gltf, Context context) {
} else if (accessor.usage == AccessorUsage.IBM) {
matrix.storage[componentIndex] = value;
} else if (accessor.isUnit &&
!(accessor.isXyzSign && componentIndex == 3)) {
!(accessor.isXyzSign && componentIndex == 3) &&
!(accessor.isCubicSpline && cubicSplineState != 1)) {
sum += value * value;
}
}
Expand All @@ -194,7 +202,8 @@ void validateAccessorsData(Gltf gltf, Context context) {
if (!isTrsDecomposable(matrix)) {
context.addIssue(DataError.indecomposableMatrix, args: [index]);
}
} else if (accessor.isUnit) {
} else if (accessor.isUnit &&
!(accessor.isCubicSpline && cubicSplineState != 1)) {
if ((sum - 1.0).abs() > 0.0005) {
context.addIssue(DataError.accessorNonUnit,
args: [index, sqrt(sum)]);
Expand All @@ -207,6 +216,10 @@ void validateAccessorsData(Gltf gltf, Context context) {
}
}

if (accessor.isCubicSpline && ++cubicSplineState == 3) {
cubicSplineState = 0;
}

componentIndex = 0;
}

Expand Down

0 comments on commit 9fd834a

Please sign in to comment.