Rudy Ges 87ada5e2af OCaml 5 compatibility (#11272) 1 년 전
..
META 9b679e4c58 Move files to libs/ 6 년 전
Makefile 9b679e4c58 Move files to libs/ 6 년 전
README 9b679e4c58 Move files to libs/ 6 년 전
alloc.h 6f15597dda [dune] update to dune 3.0 (#10925) 2 년 전
bitarray.h 6f15597dda [dune] update to dune 3.0 (#10925) 2 년 전
c_objsize.c 87ada5e2af OCaml 5 compatibility (#11272) 1 년 전
dune 6f15597dda [dune] update to dune 3.0 (#10925) 2 년 전
objsize.ml 9b679e4c58 Move files to libs/ 6 년 전
objsize.mli 9b679e4c58 Move files to libs/ 6 년 전
tests.ml 9b679e4c58 Move files to libs/ 6 년 전
util.h 9b679e4c58 Move files to libs/ 6 년 전

README

What is this?

This is a small OCaml library for computing size of OCaml values.
It computes count of words used for values, count of values' headers,
maximal depth of values. There are functions to get size of values
in bytes too.


How to use it?

See objsize.mli for documentation.


How to compile/install it?

Run "make " in this directory. Useful make targets are:
- lib : build objsize library
- tests : build tests with fresh-compiled library
- install : install package "objsize" using findlib
- uninstall : uninstall package "objsize"
- clean : clean working directory
- tests-installed : clean working directory and build test programs
assuming you have installed package "objsize" using findlib.


How it works?

C-function walks through values and uses header's field "color"
to mark visited values, then restores original values' "color".
Colors are stored using rle-like compression to decrease memory
usage.


Bugs?

1. Some constant values (like lists of integers) are
constructed at compile time and placed outside of both heaps,
and size of these values will be returned as 0.

2. Internal function is not fully tail-recursive,
so generally it uses stack proportionally to the depth
of the value.

There is an optimization to handle long lists and some
other datastructures: when objsize walks through the
structured block, the goto is used instead of recursive
call to walk into the last value that should be visited.

This optimization is not general, and the best solution
would be to use heap memory instead of stack memory to store
"walk path", but I don't need it now (please contribute
if you want).

3. It requires gnu make. It's possible to write Makefile for
nmake, but I have no MSVC to test. The best solution is
to use ocamlbuild. Either I will write ocamlbuild script
later, or you will contribute it. But it's possible
to build without any makefiles: see original Makefile for
details.

4. OCaml 3.11 has new implementation of heap. Versions of
objsize >= 0.12 work only with OCaml 3.11 heap, versions
of objsize <= 0.11 work only with OCaml <= 3.10.2 heap.
Runtime failure will be raised if you link objsize >= 0.12
with OCaml < 3.11.

5. "Bugs" section is too long.


License?

Dual: BSD/GPL.


Changes?

0.1 - 2007-12-13 - Initial public release.
0.11 - 2007-12-14 - "configure" made right. Now it works on 64-bits too.
0.12 - 2009-04-08 - Works with OCaml 3.11, installs with findlib.
0.13 - 2009-09-01 - Tiny change about so/dll suffix for unix/windows.
0.14 - 2010-01-26 - Fixing so/dll again.
Some stack usage optimization,
see the modified Bug #2 description.
0.15 - 2010-04-15 - Fixing bug appeared in 0.14. (thanks to Steven Ramsay)
0.16 - 2010-08-11 - Fixing bug appeared in 0.14. (thanks to SerP)

Author?

Dmitry Grebeniuk