summaryrefslogtreecommitdiffstats
path: root/shlibs/mount
diff options
context:
space:
mode:
authorKarel Zak2009-11-26 17:27:13 +0100
committerKarel Zak2010-06-03 15:20:10 +0200
commitf4ab4ae8eb49b99e61f9f8ba59de7195342a8a02 (patch)
tree604a55fbac5917dbaadcae5ad1cc5e1ec22e1682 /shlibs/mount
parentlibmount: add basic dirs (diff)
downloadkernel-qcow2-util-linux-f4ab4ae8eb49b99e61f9f8ba59de7195342a8a02.tar.gz
kernel-qcow2-util-linux-f4ab4ae8eb49b99e61f9f8ba59de7195342a8a02.tar.xz
kernel-qcow2-util-linux-f4ab4ae8eb49b99e61f9f8ba59de7195342a8a02.zip
libmount: add version.c
Signed-off-by: Karel Zak <kzak@redhat.com>
Diffstat (limited to 'shlibs/mount')
-rw-r--r--shlibs/mount/src/Makefile.am3
-rw-r--r--shlibs/mount/src/mount.h.in4
-rw-r--r--shlibs/mount/src/mount.sym3
-rw-r--r--shlibs/mount/src/mountP.h21
-rw-r--r--shlibs/mount/src/version.c52
5 files changed, 81 insertions, 2 deletions
diff --git a/shlibs/mount/src/Makefile.am b/shlibs/mount/src/Makefile.am
index 5d6c32df1..7b3aaaf09 100644
--- a/shlibs/mount/src/Makefile.am
+++ b/shlibs/mount/src/Makefile.am
@@ -11,7 +11,8 @@ nodist_mountinc_HEADERS = mount.h
usrlib_exec_LTLIBRARIES = libmount.la
libmount_la_SOURCES = $(mountinc_HEADERS)
-nodist_libmount_la_SOURCES = mount.h
+nodist_libmount_la_SOURCES = mount.h \
+ version.c
libmount_la_LIBADD = $(ul_libblkid_la)
diff --git a/shlibs/mount/src/mount.h.in b/shlibs/mount/src/mount.h.in
index e9b0425c1..9767a0a98 100644
--- a/shlibs/mount/src/mount.h.in
+++ b/shlibs/mount/src/mount.h.in
@@ -27,6 +27,10 @@ extern "C" {
#define LIBMOUNT_VERSION "@LIBMOUNT_VERSION@"
+/* version.c */
+extern int mnt_parse_version_string(const char *ver_string);
+extern int mnt_get_library_version(const char **ver_string);
+
#ifdef __cplusplus
}
#endif
diff --git a/shlibs/mount/src/mount.sym b/shlibs/mount/src/mount.sym
index 5922560b1..cf6907a98 100644
--- a/shlibs/mount/src/mount.sym
+++ b/shlibs/mount/src/mount.sym
@@ -5,7 +5,8 @@
*/
MOUNT_2.18 {
global:
- dummy;
+ mnt_get_library_version;
+ mnt_parse_version_string;
local:
*;
};
diff --git a/shlibs/mount/src/mountP.h b/shlibs/mount/src/mountP.h
new file mode 100644
index 000000000..2a486f02a
--- /dev/null
+++ b/shlibs/mount/src/mountP.h
@@ -0,0 +1,21 @@
+/*
+ * mountP.h - private library header file
+ *
+ * Copyright (C) 2008-2009 Karel Zak <kzak@redhat.com>
+ *
+ * This file may be redistributed under the terms of the
+ * GNU Lesser General Public License.
+ */
+
+#ifndef _LIBMOUNT_PRIVATE_H
+#define _LIBMOUNT_PRIVATE_H
+
+/* features */
+#define CONFIG_LIBMOUNT_ASSERT
+
+#ifdef CONFIG_LIBMOUNT_ASSERT
+#include <assert.h>
+#endif
+
+#include "mount.h"
+#endif
diff --git a/shlibs/mount/src/version.c b/shlibs/mount/src/version.c
new file mode 100644
index 000000000..8fd38a3c5
--- /dev/null
+++ b/shlibs/mount/src/version.c
@@ -0,0 +1,52 @@
+/*
+ * version.c - Return the version of the blkid library
+ *
+ * Copyright (C) 2008 Karel Zak <kzak@redhat.com>
+ * [Based on libblkid/version.c by Theodore Ts'o]
+ *
+ * See COPYING.libmount for the License of this software.
+ */
+
+#include <unistd.h>
+#include <string.h>
+#include <stdio.h>
+#include <ctype.h>
+
+#include "mountP.h"
+
+static const char *lib_version = LIBMOUNT_VERSION;
+
+/**
+ * mnt_parse_version_string:
+ * @ver_string: version string (e.g "2.18.0")
+ *
+ * Returns: release version code.
+ */
+int mnt_parse_version_string(const char *ver_string)
+{
+ const char *cp;
+ int version = 0;
+
+ for (cp = ver_string; *cp; cp++) {
+ if (*cp == '.')
+ continue;
+ if (!isdigit(*cp))
+ break;
+ version = (version * 10) + (*cp - '0');
+ }
+ return version;
+}
+
+/**
+ * mnt_get_library_version:
+ * @ver_string: return pointer to the static library version string
+ *
+ * Returns: release version number.
+ */
+int mnt_get_library_version(const char **ver_string)
+{
+ if (ver_string)
+ *ver_string = lib_version;
+
+ return mnt_parse_version_string(lib_version);
+}