hivex.git
13 years agohivexml: Report attributes in values instead of text.
Alex Nelson [Fri, 2 Sep 2011 01:17:43 +0000 (18:17 -0700)]
hivexml: Report attributes in values instead of text.

Reporting value data in attributes has two advantages:
* The output of hivexml breaks Python expat processing if binary data
makes it out.  This was observed in Software hives.
* Not having child text makes room for child elements.

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
13 years agohivex: Add metadata length functions for nodes and values
Alex Nelson [Fri, 2 Sep 2011 01:17:36 +0000 (18:17 -0700)]
hivex: Add metadata length functions for nodes and values

This patch adds hivex_node_struct_length and hivex_value_struct_length
to the hivex ABI, to report the amount of hive space used for each
stored structure.

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
A fix added by RWMJ.

13 years agohivex: Split value_key function into value_key and value_key_len
Alex Nelson [Fri, 2 Sep 2011 01:17:27 +0000 (18:17 -0700)]
hivex: Split value_key function into value_key and value_key_len

This function breaks the value name calculation out so the name does
not need to be fetched and immediately thrown away when one only needs
the name.

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
RWMJ fixed hivex_value_key handling of errno.

13 years agogenerator: Add new return type to ABI: RSize
Alex Nelson [Fri, 2 Sep 2011 01:17:23 +0000 (18:17 -0700)]
generator: Add new return type to ABI: RSize

This patch adds RSize, similar to RNode and RValue.

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
OCaml bindings fixed by RWMJ.

13 years agoInclude libintl.h to silence warning about bindtextdomain, textdomain.
Richard W.M. Jones [Tue, 6 Sep 2011 12:59:41 +0000 (13:59 +0100)]
Include libintl.h to silence warning about bindtextdomain, textdomain.

13 years agolib/byte_conversions.h: Use bswap* functions instead of __bswap* functions.
Gillen Daniel [Tue, 6 Sep 2011 12:52:42 +0000 (13:52 +0100)]
lib/byte_conversions.h: Use bswap* functions instead of __bswap* functions.

13 years agoMac OS X: Run glibtoolize in absence of libtoolize
Alex Nelson [Tue, 6 Sep 2011 01:52:58 +0000 (18:52 -0700)]
Mac OS X: Run glibtoolize in absence of libtoolize

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
13 years agoMac OS X: setlocale function requires locale.h
Alex Nelson [Tue, 6 Sep 2011 01:52:55 +0000 (18:52 -0700)]
Mac OS X: setlocale function requires locale.h

In the style of libguestfs commit:
9e397cc16be51f4f3940c7a5b90d0bc43f3f13a8

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
13 years agoMac OS X: Detect bindtextdomain
Alex Nelson [Tue, 6 Sep 2011 01:52:50 +0000 (18:52 -0700)]
Mac OS X: Detect bindtextdomain

In the style of libguestfs commit:
7581672c7893fd392ca10b47f044af327011f502

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
13 years agoocaml: Fix binding for Hivex.value_type
Alex Nelson [Wed, 31 Aug 2011 00:47:01 +0000 (17:47 -0700)]
ocaml: Fix binding for Hivex.value_type

13 years agoVersion 1.3.1. 1.3.1
Richard W.M. Jones [Fri, 26 Aug 2011 10:22:47 +0000 (11:22 +0100)]
Version 1.3.1.

13 years agohivex: Newer Python versions want parentheses around arguments of "print"
Hilko Bengen [Mon, 22 Aug 2011 18:45:24 +0000 (20:45 +0200)]
hivex: Newer Python versions want parentheses around arguments of "print"

13 years agohivex: Fix building on platforms without O_CLOEXEC such as FreeBSD
Hilko Bengen [Mon, 22 Aug 2011 17:52:02 +0000 (19:52 +0200)]
hivex: Fix building on platforms without O_CLOEXEC such as FreeBSD

13 years agohivex: Don't build static library, .so.* symlinks for Python bindings
Hilko Bengen [Mon, 22 Aug 2011 17:46:20 +0000 (19:46 +0200)]
hivex: Don't build static library, .so.* symlinks for Python bindings

13 years agohivexml: Add root attribute to the root node
Alex Nelson [Tue, 16 Aug 2011 04:50:28 +0000 (21:50 -0700)]
hivexml: Add root attribute to the root node

New feature:  If the root node of the XML root is the hive root node,
denote with attribute/value root="1".

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
13 years agoruby: Test against locally built library.
Richard W.M. Jones [Mon, 15 Aug 2011 10:08:16 +0000 (11:08 +0100)]
ruby: Test against locally built library.

13 years agoPrevent warning about unused variable in test.
Richard W.M. Jones [Mon, 15 Aug 2011 09:56:41 +0000 (10:56 +0100)]
Prevent warning about unused variable in test.

13 years agoFix incorrect printf format specifier in error string.
Richard W.M. Jones [Mon, 15 Aug 2011 09:52:00 +0000 (10:52 +0100)]
Fix incorrect printf format specifier in error string.

13 years agohivex(3): Fix link to CSS.
Richard W.M. Jones [Mon, 15 Aug 2011 09:43:47 +0000 (10:43 +0100)]
hivex(3): Fix link to CSS.

13 years agoVersion 1.3.0. 1.3.0
Richard W.M. Jones [Mon, 15 Aug 2011 09:40:01 +0000 (10:40 +0100)]
Version 1.3.0.

13 years agoAdd Ruby bindings.
Richard W.M. Jones [Mon, 15 Aug 2011 07:37:09 +0000 (08:37 +0100)]
Add Ruby bindings.

13 years agoheader: Fix including just <hivex.h>.
Richard W.M. Jones [Mon, 15 Aug 2011 07:36:04 +0000 (08:36 +0100)]
header: Fix including just <hivex.h>.

Also this adds a regression test so we don't break it in future.

13 years agoReport last-modified time of hive root and nodes
Alex Nelson [Sat, 13 Aug 2011 06:03:37 +0000 (23:03 -0700)]
Report last-modified time of hive root and nodes

The infrastructure for modified-time reporting has been essentially
unused.  These changes report the registry time by treating the
time fields as Windows filetime fields stored in little-Endian
(which means they can be treated as a single 64-bit little-Endian
integer).

This patch adds to the hivex ABI:

 * int64_t hivex_last_modified (hive_h *)
 * int64_t hivex_node_timestamp (hive_h *, hive_node_h)

These two functions return the hive's last-modified time and
a particular node's last-modified time, respectively.  Credit
to Richard Jones for the ABI suggestion, and for the tip on
Microsoft's filetime time span.

hivexml employs these two functions to produce mtime elements
for a hive and all of its nodes, producing ISO-8601 formatted
time.

Signed-off-by: Alex Nelson <ajnelson@cs.ucsc.edu>
A lot of code cleanup by RWMJ.

13 years agoVersion 1.2.8. 1.2.8
Richard W.M. Jones [Fri, 12 Aug 2011 09:07:14 +0000 (10:07 +0100)]
Version 1.2.8.

Pushed and pulled translations from Transifex.

13 years agoMore changes needed separate builddir
Hilko Bengen [Thu, 11 Aug 2011 23:33:39 +0000 (01:33 +0200)]
More changes needed separate builddir

This patch hopefully fixes building and installing the OCaml bindings
both in-tree and out-of-tree.

-Hilko

13 years agoMore changes needed separate builddir
Hilko Bengen [Thu, 11 Aug 2011 23:30:52 +0000 (01:30 +0200)]
More changes needed separate builddir

Here's the fix for perl. Both in-tree and out-of-tree build and install
worked.

-Hilko

13 years agohivex: A few tweaks to enable building in a separate directory
Hilko Bengen [Thu, 11 Aug 2011 15:24:05 +0000 (17:24 +0200)]
hivex: A few tweaks to enable building in a separate directory

A couple of fixes by RWMJ so it still works in the same directory case.

13 years agoCorrect 32-bit to 64-bit call
Alex Nelson [Thu, 11 Aug 2011 03:56:33 +0000 (20:56 -0700)]
Correct 32-bit to 64-bit call

13 years agoperl: Fix CCFLAGS on Perl 5.14.
Richard W.M. Jones [Fri, 22 Jul 2011 09:39:37 +0000 (10:39 +0100)]
perl: Fix CCFLAGS on Perl 5.14.

A change to ExtUtils::CBuilder in Perl 5.14 causes CCFLAGS to
completely replace, rather than appending, the C flags.

The unfortunate consequence of this is that vital flags such as
-D_FILE_OFFSET_BITS=64 are missing.  For 32 bit code, this means you
get binary-incompatible code that completely fails to load.

For further analysis see:

http://www.nntp.perl.org/group/perl.perl5.porters/2011/04/msg171535.html

This commit changes CCFLAGS so that it appends to the existing
$Config{ccflags} instead of replacing it.  On earlier versions of Perl
this means we get two copies of the flags, which is unfortunate but
should be safe.

Also, ignore MYMETA.yml file produced by Perl 5.14.

13 years agoClose the file descriptor along the writable path.
Michael Huang [Mon, 11 Jul 2011 14:06:49 +0000 (15:06 +0100)]
Close the file descriptor along the writable path.

Since the file has been completely read into memory, there is no
reason to keep the file descriptor open.

13 years agoSort m4/.gitignore file.
Richard W.M. Jones [Wed, 29 Jun 2011 09:10:12 +0000 (10:10 +0100)]
Sort m4/.gitignore file.

13 years agomaint: add cfg.mk to prepare for syntax-check tests
Jim Meyering [Tue, 28 Jun 2011 23:21:05 +0000 (01:21 +0200)]
maint: add cfg.mk to prepare for syntax-check tests

* cfg.mk: New file, to tell maint.mk which syntax-checks to skip
for now, where .gnulib/ is, to exempt images/minimal from
one of the tests and to exempt sh/hivexsh\.pod from another.
Also exempt lib/gettext.h from sc_useless_cpp_parens.

13 years agomaint: remove rule that generated po/POTFILES.in
Jim Meyering [Tue, 28 Jun 2011 18:09:57 +0000 (20:09 +0200)]
maint: remove rule that generated po/POTFILES.in

* Makefile.am (all-local): Remove rule.  It would put many
files in po/POTFILES.in that contain no translatable diagnostic.

13 years agobuild: update gnulib submodule to latest
Jim Meyering [Tue, 28 Jun 2011 18:09:56 +0000 (20:09 +0200)]
build: update gnulib submodule to latest

13 years agomaint: remove spaces before TAB
Jim Meyering [Tue, 28 Jun 2011 18:09:55 +0000 (20:09 +0200)]
maint: remove spaces before TAB

* perl/typemap: Remove spaces-before-TAB.

13 years agomaint: avoid using test's -a and -o operators; they are not portable
Jim Meyering [Tue, 28 Jun 2011 18:09:54 +0000 (20:09 +0200)]
maint: avoid using test's -a and -o operators; they are not portable

* configure.ac: use "test C1 && test C2", not "test C1 -a C2";
* autogen.sh: Likewise.
* sh/hivexget: Use "test C1 || test C2", not "test C1 -o C2"

13 years agomaint: use "test x = x", not "test x == x"
Jim Meyering [Tue, 28 Jun 2011 18:09:52 +0000 (20:09 +0200)]
maint: use "test x = x", not "test x == x"

* autogen.sh: Using "test x = x" is more portable.

13 years agomaint: remove trailing blanks
Jim Meyering [Tue, 28 Jun 2011 18:09:51 +0000 (20:09 +0200)]
maint: remove trailing blanks

13 years agomaint: remove now-unnecessary #ifdef HAVE_BYTESWAP_H guard
Jim Meyering [Tue, 28 Jun 2011 18:09:50 +0000 (20:09 +0200)]
maint: remove now-unnecessary #ifdef HAVE_BYTESWAP_H guard

* lib/byte_conversions.h: Remove #ifdef HAVE_BYTESWAP_H guard.
With gnulib, we're guaranteed to have that header file.
* bootstrap (modules): Use the byteswap module.

13 years agomaint: remove definition of O_CLOEXEC, ...
Jim Meyering [Tue, 28 Jun 2011 18:09:49 +0000 (20:09 +0200)]
maint: remove definition of O_CLOEXEC, ...

now that we're using gnulib's fcntl module, which ensures
that we use a conforming <fcntl.h>.
* lib/hivex.c (O_CLOEXEC): Remove definition.
* bootstrap (modules): Add fcntl for its guaranteed definition
of O_CLOEXEC.

13 years agomaint: normalize to exactly one newline at EOF
Jim Meyering [Tue, 28 Jun 2011 18:09:48 +0000 (20:09 +0200)]
maint: normalize to exactly one newline at EOF

* .tx/config: Remove trailing empty line.
* images/Makefile.am: Likewise.
* sh/example1: Add newline at EOF.
* sh/example2: Likewise.
* sh/example3: Likewise.
* sh/example4: Likewise.
* sh/example5: Likewise.

13 years agomaint: update po/POTFILES.in
Jim Meyering [Tue, 28 Jun 2011 18:09:47 +0000 (20:09 +0200)]
maint: update po/POTFILES.in

* po/POTFILES.in: Reduce list of files with translatable messages
to match reality.

13 years agomaint: remove definitions of PRId64 and PRIu64, ...
Jim Meyering [Tue, 28 Jun 2011 18:09:46 +0000 (20:09 +0200)]
maint: remove definitions of PRId64 and PRIu64, ...

now that we're using gnulib's inttypes module, which ensures
that we use a conforming <inttypes.h>.
* bootstrap (modules): Add inttypes.
* generator/generator.ml (generate_perl_xs) [PRId64, PRIu64]:
Don't define these symbols.  Instead, ...
Include <inttypes.h>.

13 years agomaint: remove unnecessary test-before-free
Jim Meyering [Tue, 28 Jun 2011 18:09:45 +0000 (20:09 +0200)]
maint: remove unnecessary test-before-free

* lib/hivex.c (hivex_node_set_value): Remove unnecessary
test-before-free.

13 years agoocaml: Really fix 'make install' rule.
Richard W.M. Jones [Tue, 17 May 2011 16:37:31 +0000 (17:37 +0100)]
ocaml: Really fix 'make install' rule.

This fixes commit b8ad15031cacf910634b4f4f4632232949c4acd2
and commit f408b757b1d75429fae5fa7630a4fc5451844de7.

13 years agoocaml: Set package name when installing native bindings.
Richard W.M. Jones [Tue, 17 May 2011 16:19:27 +0000 (17:19 +0100)]
ocaml: Set package name when installing native bindings.

This fixes commit b8ad15031cacf910634b4f4f4632232949c4acd2.

13 years agoVersion 1.2.7. 1.2.7
Richard W.M. Jones [Tue, 17 May 2011 15:51:48 +0000 (16:51 +0100)]
Version 1.2.7.

13 years agoUpdate gnulib to latest version.
Richard W.M. Jones [Tue, 17 May 2011 15:51:37 +0000 (16:51 +0100)]
Update gnulib to latest version.

13 years agohivexregedit: Add --unsafe-printable-strings option.
Richard W.M. Jones [Tue, 17 May 2011 10:16:10 +0000 (11:16 +0100)]
hivexregedit: Add --unsafe-printable-strings option.

13 years agohivex_root: Return errno == HIVEX_NO_KEY when root key is missing.
Richard W.M. Jones [Fri, 13 May 2011 17:19:22 +0000 (18:19 +0100)]
hivex_root: Return errno == HIVEX_NO_KEY when root key is missing.

Previously we returned errno == ENOKEY.  However this was an
unfortunate choice of error code since it is not defined in POSIX.  As
a result it is missing on several platforms.

HIVEX_NO_KEY is defined as ENOKEY on platforms where this symbol
exists (thus maintaining backwards ABI compatibility), and defined as
another POSIX error code otherwise.

13 years agohivex: Fix install target for systems without native OCaml compiler
Hilko Bengen [Fri, 13 May 2011 06:37:56 +0000 (08:37 +0200)]
hivex: Fix install target for systems without native OCaml compiler

,----
| ocamlfind install \
|           -ldconf ignore -destdir /build/buildd-hivex_1.2.6-1-ia64-iqcb38/hivex-1.2.6/debian/tmp/usr/lib/ocaml \
|           hivex \
|           META *.so *.a *.cma *.cmx *.cmxa *.cmi *.mli
| Installed /build/buildd-hivex_1.2.6-1-ia64-iqcb38/hivex-1.2.6/debian/tmp/usr/lib/ocaml/hivex/hivex.mli
| Installed /build/buildd-hivex_1.2.6-1-ia64-iqcb38/hivex-1.2.6/debian/tmp/usr/lib/ocaml/hivex/hivex.cmi
| ocamlfind: *.cmxa: No such file or directory
| make[4]: *** [install-data-hook] Error 2
`----

13 years agohivex: Remove python bytecode on "make clean"
Hilko Bengen [Fri, 13 May 2011 06:37:55 +0000 (08:37 +0200)]
hivex: Remove python bytecode on "make clean"

13 years agoocaml: Use libtool to get correct library to build OCaml tests.
Richard W.M. Jones [Thu, 12 May 2011 11:25:21 +0000 (12:25 +0100)]
ocaml: Use libtool to get correct library to build OCaml tests.

See this thread:
https://www.redhat.com/archives/libguestfs/2011-May/thread.html#00015

Thanks to Hilko Bengen and Török Edwin for coming up with this fix.

13 years agoVersion 1.2.6. 1.2.6
Richard W.M. Jones [Thu, 12 May 2011 10:12:03 +0000 (11:12 +0100)]
Version 1.2.6.

13 years agobuild: Workaround broken libtool.
Richard W.M. Jones [Thu, 12 May 2011 11:03:15 +0000 (12:03 +0100)]
build: Workaround broken libtool.

Same as this error:
https://www.redhat.com/archives/libguestfs/2011-April/msg00042.html
https://www.redhat.com/archives/libguestfs/2011-May/msg00041.html

We don't know why latest libtool is so obviously broken, but this
works around the problem.

13 years agobootstrap: Force gnulib-tool --libtool option.
Richard W.M. Jones [Thu, 12 May 2011 11:03:06 +0000 (12:03 +0100)]
bootstrap: Force gnulib-tool --libtool option.

This forces the recent gnulib to generate a libgnu.la file.  Otherwise
it appears to default to --no-libtool which doesn't generate one.

13 years agoconfigure: AC_PROG_LIBTOOL -> AM_PROG_LIBTOOL.
Richard W.M. Jones [Thu, 12 May 2011 11:02:11 +0000 (12:02 +0100)]
configure: AC_PROG_LIBTOOL -> AM_PROG_LIBTOOL.

Unclear if this makes any difference.

13 years agoUpdate gnulib.
Richard W.M. Jones [Thu, 12 May 2011 10:30:42 +0000 (11:30 +0100)]
Update gnulib.

13 years agohivex: Fix for endianess bug.
Hilko Bengen [Wed, 11 May 2011 22:04:20 +0000 (00:04 +0200)]
hivex: Fix for endianess bug.

* Richard W.M. Jones:
> > Both size_t and int are 32 bit values.  An endianess issue, maybe?
> I guess it might be.  We're supposed to be doing le32toh / be32toh
> everywhere as appropriate, but we might be missing one.  The code is
> mainly tested on little endian arches.

Found it.

Now "make check" completes successfully on Sparc and PowerPC.

13 years agohivex: check for presence of OCaml native compiler
Hilko Bengen [Wed, 11 May 2011 22:04:19 +0000 (00:04 +0200)]
hivex: check for presence of OCaml native compiler

Only compile bytecode otherwise, avoiding ocamlfind's helpful error
message "ocamlfind: Not supported in your configuration: ocamlopt"

(Successfully tested on Debian/unstable on alpha)

13 years agohivex: Use OCaml bytecode compiler for caml_raise_with_args check
Hilko Bengen [Wed, 11 May 2011 22:04:18 +0000 (00:04 +0200)]
hivex: Use OCaml bytecode compiler for caml_raise_with_args check

On installations where no native OCaml compiler is available, the
test program can't be compiled and so we get this message:

,----
| checking for function caml_raise_with_args... not found
`----

This breaks building of the OCaml bindings.

,----
| gcc -std=gnu99 -I.. -I/usr/lib/ocaml -I../ocaml -I../lib   -g -O2 -fPIC -Wall -c hivex_c.c
| hivex_c.c:52: error: static declaration of 'caml_raise_with_args' follows non-static declaration
| /usr/lib/ocaml/caml/fail.h:30: note: previous declaration of 'caml_raise_with_args' was here
| make[2]: *** [hivex_c.o] Error 1
`----

(Successfully tested on Debian/unstable on alpha)

13 years agoconfigure: Use Python platform-dependent site-packages.
Richard W.M. Jones [Thu, 12 May 2011 09:49:13 +0000 (10:49 +0100)]
configure: Use Python platform-dependent site-packages.

This updates commit b808c875a34e62fcdf360534f923d6030590ff44.

13 years agoUse Python's distutils to determine include and site-packages directories.
Hilko Bengen [Tue, 3 May 2011 22:29:39 +0000 (00:29 +0200)]
Use Python's distutils to determine include and site-packages directories.

The code has been taken from specifically ac_python_devel.m4 published
at <http://ac-archive.sf.net/>, it has turned out to be less
error-prone on my Debian system.

13 years agoDon't rely on OCaml native compiler for tests
Hilko Bengen [Mon, 9 May 2011 07:08:17 +0000 (09:08 +0200)]
Don't rely on OCaml native compiler for tests

This should make it possible to build useful OCaml bindings on
architectures other than i386 and amd64 (Debian bug #589809).

13 years agoInclude generator in the tarball.
Richard W.M. Jones [Thu, 28 Apr 2011 08:48:23 +0000 (09:48 +0100)]
Include generator in the tarball.

13 years agohivex/python fix for i386 integer size issue
Hilko Bengen [Wed, 27 Apr 2011 22:20:08 +0000 (00:20 +0200)]
hivex/python fix for i386 integer size issue

Hi,

While working on Debian packages of hivex 1.2.5, I came across a test
failure for the Python bindings with Python 2.7 on the i386
architecture. (The tests ran fine on amd64.)

,----
| $ make -C python check
| make[1]: Entering directory `/home/bengen/src/deb/hivex/hivex.git/python'
| 010-import.py
| 020-open.py
| 021-close.py
| 200-write.py
| python: hivex-py.c:52: get_handle: Assertion `obj' failed.
`----

I narrowed this down to hivex-py.c:py_hivex_node_add_child():

The call

,----
| PyArg_ParseTuple (args, (char *) "OLs:hivex_node_add_child",
|                         &py_h, &parent, &name)
`----

results in `py_h' set to NULL, though Python's documentation claims that
this cannot happen. I think this happens because `parent' is declared a
`long int', but "L" in the format string corresponds to a `long long'.
On amd64, they have the same size, but on i386 they don't, so the
PyObject pointer is written to the wrong address.

Please consider applying the patch below which just changes the format
string. After regenerating hivex-py.c, I have successfully tested the
1.2.5 code base on both architectures.

Cheers,
-Hilko

13 years agomaint: Split long lines.
Jim Meyering [Wed, 13 Apr 2011 15:03:50 +0000 (16:03 +0100)]
maint: Split long lines.

* lib/hivex.c: Split lines longer than 80 columns.

13 years agoVersion 1.2.5. 1.2.5
Richard W.M. Jones [Wed, 13 Apr 2011 14:06:43 +0000 (15:06 +0100)]
Version 1.2.5.

Updated PO files.

13 years agoRemove no longer used internal function utf16_string_len_in_bytes.
Richard W.M. Jones [Wed, 13 Apr 2011 13:04:16 +0000 (14:04 +0100)]
Remove no longer used internal function utf16_string_len_in_bytes.

13 years agohivex_value_multiple_strings: Don't read uninitialized data.
Richard W.M. Jones [Wed, 13 Apr 2011 13:01:03 +0000 (14:01 +0100)]
hivex_value_multiple_strings: Don't read uninitialized data.

If hivex_value_multiple_strings was given a value which had an odd
length or if the data in the value was unterminated,
hivex_value_multiple_strings could read uninitialized data.

Potentially (although very unlikely) this could cause a
non-exploitable segfault in the calling program.

13 years agoHandle odd-length "UTF16" strings.
Richard W.M. Jones [Wed, 13 Apr 2011 13:03:21 +0000 (14:03 +0100)]
Handle odd-length "UTF16" strings.

If the length of the buffer is not even, then this would read a byte
of uninitialized data.  Fix the length check to avoid this.

13 years agoReturn real length of buffer from hivex_value_value.
Richard W.M. Jones [Wed, 13 Apr 2011 12:55:49 +0000 (13:55 +0100)]
Return real length of buffer from hivex_value_value.

In real registries, often the length declared in the header does not
match the length of the block.  In this case hivex_value_value would
only allocate a value with a size which is the shorter of the two
length values, which is correct and safe.

However user code could do:

  buf = hivex_value_value (h, v, &t, &len);
  memcpy (somewhere, buf, len);

which would copy uninitialized data.

If hivex_value_value truncates a value like this, we also need to
return the shorter length to the user as well.

13 years agoReally fix the case where a UTF-16 string contains junk after the string.
Richard W.M. Jones [Wed, 13 Apr 2011 12:54:05 +0000 (13:54 +0100)]
Really fix the case where a UTF-16 string contains junk after the string.

The previous commit b71b88f588f8660935a7d462e97b84aa2d669249 attempted
to fix this, but got the test the wrong way round so the length would
never be shorter.

13 years agoFix use-after-free in hivex_close.
Richard W.M. Jones [Tue, 12 Apr 2011 16:59:47 +0000 (17:59 +0100)]
Fix use-after-free in hivex_close.

Found using valgrind.

13 years agoPull translations from Transifex.
Richard W.M. Jones [Sat, 2 Apr 2011 07:53:01 +0000 (08:53 +0100)]
Pull translations from Transifex.

13 years agodebian: Fix python test script for bash.
Richard W.M. Jones [Fri, 1 Apr 2011 21:46:07 +0000 (22:46 +0100)]
debian: Fix python test script for bash.

13 years agoImport hivex into transifex.
Richard W.M. Jones [Mon, 7 Mar 2011 10:53:52 +0000 (10:53 +0000)]
Import hivex into transifex.

http://www.transifex.net/projects/p/hivex/

13 years agoRefresh documentation.
Richard W.M. Jones [Thu, 23 Dec 2010 19:46:05 +0000 (19:46 +0000)]
Refresh documentation.

13 years agoocaml: Fix segfault in Hivex.value_value binding.
Richard W.M. Jones [Thu, 16 Dec 2010 13:41:59 +0000 (13:41 +0000)]
ocaml: Fix segfault in Hivex.value_value binding.

13 years agoVersion 1.2.4. 1.2.4
Richard W.M. Jones [Thu, 2 Dec 2010 15:29:38 +0000 (15:29 +0000)]
Version 1.2.4.

13 years agoPython bindings.
Richard W.M. Jones [Sun, 28 Nov 2010 11:14:11 +0000 (11:14 +0000)]
Python bindings.

14 years agoVersion 1.2.3. 1.2.3
Richard Jones [Fri, 27 Aug 2010 08:48:34 +0000 (09:48 +0100)]
Version 1.2.3.

14 years agobuild: Don't warn about 'long long'.
Richard Jones [Fri, 27 Aug 2010 07:51:37 +0000 (08:51 +0100)]
build: Don't warn about 'long long'.

We have to allow this, even though it's a GCC extension.

This is a port of libguestfs commit 0c0976496dafda4d172c5a7fc787d6a87d5bce8d.

14 years agoAdd Dutch translations (RHBZ#624455).
Geert Warrink [Fri, 27 Aug 2010 07:49:33 +0000 (08:49 +0100)]
Add Dutch translations (RHBZ#624455).

14 years agoAdd debug output to hivex_close.
Matthew Booth [Fri, 13 Aug 2010 16:44:28 +0000 (17:44 +0100)]
Add debug output to hivex_close.

14 years agoDon't try to process junk after a string value as UTF-16.
Richard Jones [Mon, 12 Jul 2010 14:06:35 +0000 (15:06 +0100)]
Don't try to process junk after a string value as UTF-16.

Thanks to Hilko Bengen for characterizing the issue and
providing an initial version of this patch.

14 years agoCall iconv_close along error path out of function.
Hilko Bengen [Mon, 12 Jul 2010 13:50:31 +0000 (14:50 +0100)]
Call iconv_close along error path out of function.

14 years agoperl: Fix generated XS code for value_dword binding.
Richard Jones [Sun, 11 Jul 2010 22:32:14 +0000 (23:32 +0100)]
perl: Fix generated XS code for value_dword binding.

Thanks to Hilko Bengen for spotting the problem.

14 years agoAdd hivex_set_value API call, and ocaml and perl bindings, and tests.
Conrad Meyer [Thu, 8 Jul 2010 10:12:42 +0000 (11:12 +0100)]
Add hivex_set_value API call, and ocaml and perl bindings, and tests.

14 years agohivex_value_type: Returns -1 on error. Fix documentation.
Richard Jones [Sun, 13 Jun 2010 18:38:09 +0000 (19:38 +0100)]
hivex_value_type: Returns -1 on error.  Fix documentation.

14 years agoInclude a test for regimport of values containing backslash chars.
Richard Jones [Thu, 13 May 2010 10:23:50 +0000 (11:23 +0100)]
Include a test for regimport of values containing backslash chars.

14 years agoregedit: Fix documentation for CurrentControlSet (thanks Yuval Kashtan).
Richard Jones [Fri, 30 Apr 2010 08:47:16 +0000 (09:47 +0100)]
regedit: Fix documentation for CurrentControlSet (thanks Yuval Kashtan).

14 years agoVersion 1.2.2. 1.2.2
Richard Jones [Wed, 28 Apr 2010 14:13:41 +0000 (15:13 +0100)]
Version 1.2.2.

14 years agoregedit: Add implicit nul-termination when importing strings.
Richard Jones [Wed, 28 Apr 2010 13:28:27 +0000 (14:28 +0100)]
regedit: Add implicit nul-termination when importing strings.

When you import a string value like:
  "Foo"="Bar"
using Windows regedit program, implicit nul-termination is added
to the value (not the key), so what is stored in the value would
be something like:
  hex(1):42,00,61,00,72,00,00,00
where two of the trailing zero bytes come from the implicit
terminator.  This corrects the reg_import function so it works
the same way.

14 years agoRemove checks for Test::Pod and Test::Pod::Coverage.
Richard Jones [Tue, 20 Apr 2010 17:45:19 +0000 (18:45 +0100)]
Remove checks for Test::Pod and Test::Pod::Coverage.

Although these modules are optionally used by the Perl tests,
they aren't necessary and won't break the build if they are not
there.  These modules aren't available in RHEL 5.  Therefore
remove these checks.

14 years agoAdd a linker script to limit visibility to exported symbols.
Richard Jones [Sat, 3 Apr 2010 15:06:58 +0000 (16:06 +0100)]
Add a linker script to limit visibility to exported symbols.

14 years agoRemove explicit dependency on ncurses.
TJ [Sat, 3 Apr 2010 09:50:48 +0000 (10:50 +0100)]
Remove explicit dependency on ncurses.

14 years agoSpelling: reencode -> re-encode.
TJ [Sat, 3 Apr 2010 08:23:43 +0000 (09:23 +0100)]
Spelling: reencode -> re-encode.

14 years agoAdd CLEANFILES rules.
TJ [Fri, 2 Apr 2010 15:51:40 +0000 (16:51 +0100)]
Add CLEANFILES rules.

14 years agoNew Russian translation (RHBZ#578347).
Yulia [Thu, 1 Apr 2010 07:30:38 +0000 (08:30 +0100)]
New Russian translation (RHBZ#578347).