diff options
author | Richard Jones <rjones@trick.home.annexia.org> | 2009-07-10 17:52:09 +0100 |
---|---|---|
committer | Richard Jones <rjones@trick.home.annexia.org> | 2009-07-10 17:52:09 +0100 |
commit | 745f1d9ee8480b3a38f778fcc4506ce86da473a6 (patch) | |
tree | bbc56de7c7fc5dd24cedd64c5fdbb65fc8e39b28 /src/generator.ml | |
parent | 2105fabddfdcecca68e20285808b4d8bbe133227 (diff) | |
download | libguestfs-745f1d9ee8480b3a38f778fcc4506ce86da473a6.tar.gz libguestfs-745f1d9ee8480b3a38f778fcc4506ce86da473a6.tar.xz libguestfs-745f1d9ee8480b3a38f778fcc4506ce86da473a6.zip |
Add 'version' call to get true library version number.
This patch also changes the way that the version is specified
in configure.ac. It is now made out of four parts (major, minor,
release and extra) and constructed for AC_INIT.
Diffstat (limited to 'src/generator.ml')
-rwxr-xr-x | src/generator.ml | 41 |
1 files changed, 40 insertions, 1 deletions
diff --git a/src/generator.ml b/src/generator.ml index 7c0e5662..0904afc0 100755 --- a/src/generator.ml +++ b/src/generator.ml @@ -636,6 +636,36 @@ qemu subprocess, then this will return an error. This is an internal call used for debugging and testing."); + ("version", (RStruct ("version", "version"), []), -1, [], + [InitBasicFS, Always, TestOutputStruct ( + [["version"]], [CompareWithInt ("major", 1)])], + "get the library version number", + "\ +Return the libguestfs version number that the program is linked +against. + +Note that because of dynamic linking this is not necessarily +the version of libguestfs that you compiled against. You can +compile the program, and then at runtime dynamically link +against a completely different C<libguestfs.so> library. + +This call was added in version C<1.0.58>. In previous +versions of libguestfs there was no way to get the version +number. From C code you can use ELF weak linking tricks to find out if +this symbol exists (if it doesn't, then it's an earlier version). + +The call returns a structure with four elements. The first +three (C<major>, C<minor> and C<release>) are numbers and +correspond to the usual version triplet. The fourth element +(C<extra>) is a string and is normally empty, but may be +used for distro-specific information. + +To construct the original version string: +C<$major.$minor.$release$extra> + +I<Note:> Don't use this call to test for availability +of features. Distro backports makes this unreliable."); + ] (* daemon_functions are any functions which cause some action @@ -2928,6 +2958,14 @@ let structs = [ "ftyp", FChar; "name", FString; ]; + + (* Version numbers. *) + "version", [ + "major", FInt64; + "minor", FInt64; + "release", FInt64; + "extra", FString; + ]; ] (* end of structs *) (* Ugh, Java has to be different .. @@ -2940,7 +2978,8 @@ let java_structs = [ "lvm_lv", "LV"; "stat", "Stat"; "statvfs", "StatVFS"; - "dirent", "Dirent" + "dirent", "Dirent"; + "version", "Version"; ] (* Used for testing language bindings. *) |