1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
|
// Copyright 2015 The Emscripten Authors. All rights reserved.
// Emscripten is available under two separate licenses, the MIT license and the
// University of Illinois/NCSA Open Source License. Both these licenses can be
// found in the LICENSE file.
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <assert.h>
#include <stdint.h>
#include <emscripten.h>
#define TOTAL_SIZE (4*1024*1024)
int main() {
unsigned char temp;
printf("open file\n");
FILE *f = fopen("huge.dat", "r");
assert(f);
unsigned i;
for (i = 0; i < TOTAL_SIZE; i++) {
int ret = fseek(f, i, SEEK_SET);
assert(ret == 0);
int num = fread(&temp, 1, 1, f);
assert(num == 1);
unsigned char expected = (i*i)&255;
if (temp != expected) {
printf("%d: see %d != %d was expected :(\n", i, temp, expected);
abort();
}
if ((i & (1024*1024-1)) == 0) printf("%d of %d ..\n", i, TOTAL_SIZE);
}
printf("%d all ok.\n", i);
REPORT_RESULT(1);
}
|