File: split_memory_large_file.cpp

package info (click to toggle)
emscripten 2.0.12~dfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 108,440 kB
  • sloc: ansic: 510,324; cpp: 384,763; javascript: 84,341; python: 51,362; sh: 50,019; pascal: 4,159; makefile: 3,409; asm: 2,150; lisp: 1,869; ruby: 488; cs: 142
file content (38 lines) | stat: -rw-r--r-- 983 bytes parent folder | download
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);
}