[Kst] branches/kst/1.2/kst/kst/datasources/planck
George Staikos
staikos at kde.org
Wed Apr 5 17:05:56 CEST 2006
SVN commit 526765 by staikos:
fix off-by-one in planck skip
M +10 -9 planck.cpp
--- branches/kst/1.2/kst/kst/datasources/planck/planck.cpp #526764:526765
@@ -160,17 +160,18 @@
return 0;
}
- if (skip > n || skip > count || skip > end) { // what are they thinking?
- return 0;
- }
-
if (n < 0) { // reading less than 0 -> read only one sample!
n = 1;
}
- if (s + (n-1)*skip > count) { // trying to read past the end
+ if (s + (n-1)*skip >= count) { // trying to read past the end
kdDebug() << "TRYING TO READ PAST END. n=" << n << endl;
- n = (count - s) / skip + 1;
+ // n = ceil((count-s)/skip)
+ if ((count - s) % skip == 0) {
+ n = (count - s) / skip;
+ } else {
+ n = (count - s) / skip + 1;
+ }
kdDebug() << "N IS NOW=" << n << endl;
}
@@ -181,9 +182,9 @@
// PIOLib doesn't have a mechanism to read with skip. This needs to be added
// later. For now, we read into a temp buffer, then extract what we need.
- double *tmp = new double[(n + 1) * skip];
- int rc = _planckObject->readObject(field, tmp, start + s, start + s + (n + 1)*skip - 1);
- //kdDebug() << "readObject rc=" << rc << " from=" << start+s << " to=" << start + s + (n+1)*skip -1 << endl;
+ double *tmp = new double[(n - 1) * skip + 1];
+ int rc = _planckObject->readObject(field, tmp, start + s, start + s + (n - 1) * skip);
+ //kdDebug() << "readObject rc=" << rc << " from=" << start+s << " to=" << start + s + (n - 1) * skip << endl;
int i = 0;
while (i < n && i*skip < rc) {
v[i] = tmp[i * skip];
More information about the Kst
mailing list