File: new.cpp

package info (click to toggle)
emscripten 3.1.69%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 121,872 kB
  • sloc: ansic: 636,110; cpp: 425,974; javascript: 78,401; python: 58,404; sh: 49,154; pascal: 5,237; makefile: 3,365; asm: 2,415; lisp: 1,869
file content (43 lines) | stat: -rw-r--r-- 1,257 bytes parent folder | download | duplicates (4)
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
39
40
41
42
43
// Copyright 2012 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.

// Emscripten tests

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>

struct Structy { char data[100]; int x; };

int main() {
  int NUM = 100;
  char* allocations[NUM];
  for (int i = 0; i < NUM/2; i++) {
    allocations[i] = (char*){{{ NEW }}};
    assert(allocations[i]);
    if (i > 10 && i%4 == 1 && allocations[i-10]) {
      {{{ DELETE }}}(allocations[i-10]);
      allocations[i-10] = NULL;
    }
  }
  for (int i = NUM/2; i < NUM; i++) {
    allocations[i] = (char*){{{ NEW }}};
    assert(allocations[i]);
    if (i > 10 && i%4 != 1 && allocations[i-10]) {
      {{{ DELETE }}}(allocations[i-10]);
      allocations[i-10] = NULL;
    }
  }
  char* first = allocations[0];
  for (int i = 0; i < NUM; i++) {
    if (allocations[i]) {
      {{{ DELETE }}}(allocations[i]);
    }
  }
  char *last = (char*){{{ NEW }}}; /* should be identical, as we free'd it all */
  char *newer = (char*){{{ NEW }}}; /* should be different */
  printf("*%d,%d*\n", first == last, first == newer);
}