about summary refs log tree commit diff homepage
path: root/lib/Basic/BOut.cpp
diff options
context:
space:
mode:
authorCristian Cadar <cristic@cs.stanford.edu>2009-05-23 02:42:09 +0000
committerCristian Cadar <cristic@cs.stanford.edu>2009-05-23 02:42:09 +0000
commit266cc79f26aa8df4718f2309808f77a5426f266c (patch)
tree640584c9eec64bb834a5452ff908145e4c5c8362 /lib/Basic/BOut.cpp
parentac6570f762e6520a4458d53963beb5bd4578a2f0 (diff)
downloadklee-266cc79f26aa8df4718f2309808f77a5426f266c.tar.gz
Changed bout to ktest. Kept "BOUT\n" as the header of test files, for backward compatibility. Also changed KLEE_RUNTEST to KTEST_FILE. Updated tutorial-1.
git-svn-id: https://llvm.org/svn/llvm-project/klee/trunk@72312 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Basic/BOut.cpp')
-rw-r--r--lib/Basic/BOut.cpp236
1 files changed, 0 insertions, 236 deletions
diff --git a/lib/Basic/BOut.cpp b/lib/Basic/BOut.cpp
deleted file mode 100644
index 42d17e27..00000000
--- a/lib/Basic/BOut.cpp
+++ /dev/null
@@ -1,236 +0,0 @@
-//===-- BOut.c ------------------------------------------------------------===//
-//
-//                     The KLEE Symbolic Virtual Machine
-//
-// This file is distributed under the University of Illinois Open Source
-// License. See LICENSE.TXT for details.
-//
-//===----------------------------------------------------------------------===//
-
-#include "klee/Internal/ADT/BOut.h"
-
-#include <stdlib.h>
-#include <string.h>
-#include <stdio.h>
-
-#define BOUT_MAGIC "BOUT\n"
-#define BOUT_MAGIC_SIZE 5
-#define BOUT_VERSION 2
-
-/***/
-
-static int read_uint32(FILE *f, unsigned *value_out) {
-  unsigned char data[4];
-  if (fread(data, 4, 1, f)!=1)
-    return 0;
-  *value_out = (((((data[0]<<8) + data[1])<<8) + data[2])<<8) + data[3];
-  return 1;
-}
-
-static int write_uint32(FILE *f, unsigned value) {
-  unsigned char data[4];
-  data[0] = value>>24;
-  data[1] = value>>16;
-  data[2] = value>> 8;
-  data[3] = value>> 0;
-  return fwrite(data, 1, 4, f)==4;
-}
-
-static int read_string(FILE *f, char **value_out) {
-  unsigned len;
-  if (!read_uint32(f, &len))
-    return 0;
-  *value_out = (char*) malloc(len+1);
-  if (!*value_out)
-    return 0;
-  if (fread(*value_out, len, 1, f)!=1)
-    return 0;
-  (*value_out)[len] = 0;
-  return 1;
-}
-
-static int write_string(FILE *f, const char *value) {
-  unsigned len = strlen(value);
-  if (!write_uint32(f, len))
-    return 0;
-  if (fwrite(value, len, 1, f)!=1)
-    return 0;
-  return 1;
-}
-
-/***/
-
-
-unsigned bOut_getCurrentVersion() {
-  return BOUT_VERSION;
-}
-
-
-static int bOut_checkHeader(FILE *f) {
-  char header[BOUT_MAGIC_SIZE];
-  if (fread(header, BOUT_MAGIC_SIZE, 1, f)!=1)
-    return 0;
-  if (memcmp(header, BOUT_MAGIC, BOUT_MAGIC_SIZE))
-    return 0;
-  return 1;
-}
-
-int bOut_isBOutFile(const char *path) {
-  FILE *f = fopen(path, "rb");
-  int res;
-
-  if (!f)
-    return 0;
-  res = bOut_checkHeader(f);
-  fclose(f);
-  
-  return res;
-}
-
-BOut *bOut_fromFile(const char *path) {
-  FILE *f = fopen(path, "rb");
-  BOut *res = 0;
-  unsigned i, version;
-
-  if (!f) 
-    goto error;
-  if (!bOut_checkHeader(f)) 
-    goto error;
-
-  res = (BOut*) calloc(1, sizeof(*res));
-  if (!res) 
-    goto error;
-
-  if (!read_uint32(f, &version)) 
-    goto error;
-  
-  if (version > bOut_getCurrentVersion())
-    goto error;
-
-  res->version = version;
-
-  if (!read_uint32(f, &res->numArgs)) 
-    goto error;
-  res->args = (char**) calloc(res->numArgs, sizeof(*res->args));
-  if (!res->args) 
-    goto error;
-  
-  for (i=0; i<res->numArgs; i++)
-    if (!read_string(f, &res->args[i]))
-      goto error;
-
-  if (version >= 2) {
-    if (!read_uint32(f, &res->symArgvs)) 
-      goto error;
-    if (!read_uint32(f, &res->symArgvLen)) 
-      goto error;
-  }
-
-  if (!read_uint32(f, &res->numObjects))
-    goto error;
-  res->objects = (BOutObject*) calloc(res->numObjects, sizeof(*res->objects));
-  if (!res->objects)
-    goto error;
-  for (i=0; i<res->numObjects; i++) {
-    BOutObject *o = &res->objects[i];
-    if (!read_string(f, &o->name))
-      goto error;
-    if (!read_uint32(f, &o->numBytes))
-      goto error;
-    o->bytes = (unsigned char*) malloc(o->numBytes);
-    if (fread(o->bytes, o->numBytes, 1, f)!=1)
-      goto error;
-  }
-
-  fclose(f);
-
-  return res;
- error:
-  if (res) {
-    if (res->args) {
-      for (i=0; i<res->numArgs; i++)
-        if (res->args[i])
-          free(res->args[i]);
-      free(res->args);
-    }
-    if (res->objects) {
-      for (i=0; i<res->numObjects; i++) {
-        BOutObject *bo = &res->objects[i];
-        if (bo->name)
-          free(bo->name);
-        if (bo->bytes)
-          free(bo->bytes);
-      }
-      free(res->objects);
-    }
-    free(res);
-  }
-
-  if (f) fclose(f);
-
-  return 0;
-}
-
-int bOut_toFile(BOut *bo, const char *path) {
-  FILE *f = fopen(path, "wb");
-  unsigned i;
-
-  if (!f) 
-    goto error;
-  if (fwrite(BOUT_MAGIC, strlen(BOUT_MAGIC), 1, f)!=1)
-    goto error;
-  if (!write_uint32(f, BOUT_VERSION))
-    goto error;
-      
-  if (!write_uint32(f, bo->numArgs))
-    goto error;
-  for (i=0; i<bo->numArgs; i++) {
-    if (!write_string(f, bo->args[i]))
-      goto error;
-  }
-
-  if (!write_uint32(f, bo->symArgvs))
-    goto error;
-  if (!write_uint32(f, bo->symArgvLen))
-    goto error;
-  
-  if (!write_uint32(f, bo->numObjects))
-    goto error;
-  for (i=0; i<bo->numObjects; i++) {
-    BOutObject *o = &bo->objects[i];
-    if (!write_string(f, o->name))
-      goto error;
-    if (!write_uint32(f, o->numBytes))
-      goto error;
-    if (fwrite(o->bytes, o->numBytes, 1, f)!=1)
-      goto error;
-  }
-
-  fclose(f);
-
-  return 1;
- error:
-  if (f) fclose(f);
-  
-  return 0;
-}
-
-unsigned bOut_numBytes(BOut *bo) {
-  unsigned i, res = 0;
-  for (i=0; i<bo->numObjects; i++)
-    res += bo->objects[i].numBytes;
-  return res;
-}
-
-void bOut_free(BOut *bo) {
-  unsigned i;
-  for (i=0; i<bo->numArgs; i++)
-    free(bo->args[i]);
-  free(bo->args);
-  for (i=0; i<bo->numObjects; i++) {
-    free(bo->objects[i].name);
-    free(bo->objects[i].bytes);
-  }
-  free(bo->objects);
-  free(bo);
-}