/**************************************************************************/ /* */ /* OCaml */ /* */ /* Xavier Leroy, projet Cristal, INRIA Rocquencourt */ /* */ /* Copyright 1996 Institut National de Recherche en Informatique et */ /* en Automatique. */ /* */ /* All rights reserved. This file is distributed under the terms of */ /* the GNU Lesser General Public License version 2.1, with the */ /* special exception on linking described in the file LICENSE. */ /* */ /**************************************************************************/ #define CAML_INTERNALS #include #include #include #include #include #include #include "caml/unixsupport.h" #ifndef _WIN32 #include #endif #ifdef HAS_TRUNCATE CAMLprim value caml_unix_truncate(value path, value vlen) { CAMLparam2(path, vlen); char * p; int ret; file_offset len = Long_val(vlen); caml_unix_check_path(path, "truncate"); p = caml_stat_strdup(String_val(path)); caml_enter_blocking_section(); ret = truncate(p, len); caml_leave_blocking_section(); caml_stat_free(p); if (ret == -1) caml_uerror("truncate", path); CAMLreturn(Val_unit); } CAMLprim value caml_unix_truncate_64(value path, value vlen) { CAMLparam2(path, vlen); char * p; int ret; file_offset len = File_offset_val(vlen); caml_unix_check_path(path, "truncate"); p = caml_stat_strdup(String_val(path)); caml_enter_blocking_section(); ret = truncate(p, len); caml_leave_blocking_section(); caml_stat_free(p); if (ret == -1) caml_uerror("truncate", path); CAMLreturn(Val_unit); } #else CAMLprim value caml_unix_truncate(value path, value len) { caml_invalid_argument("truncate not implemented"); } CAMLprim value caml_unix_truncate_64(value path, value len) { caml_invalid_argument("truncate not implemented"); } #endif