+#ifdef HAVE_GETTEXT
+#include "gettext.h"
+#define _(str) dgettext(PACKAGE, (str))
+#define N_(str) dgettext(PACKAGE, (str))
+#else
+#define _(str) str
+#define N_(str) str
+#endif
+
+#define TMP_TEMPLATE_ON_STACK(var) \
+ const char *ttos_tmpdir = guestfs_tmpdir (); \
+ char var[strlen (ttos_tmpdir) + 32]; \
+ sprintf (var, "%s/libguestfsXXXXXX", ttos_tmpdir) \
+
+#define UNIX_PATH_MAX 108
+
+#ifndef MAX
+#define MAX(a,b) ((a)>(b)?(a):(b))
+#endif
+
+#ifdef __APPLE__
+#define xdr_uint32_t xdr_u_int32_t
+#endif
+
+/* Network configuration of the appliance. Note these addresses are
+ * only meaningful within the context of the running appliance. QEMU
+ * translates network connections to these magic addresses into
+ * userspace calls on the host (eg. connect(2)). qemu-doc has a nice
+ * diagram which is also useful to refer to.
+ *
+ * NETWORK: The network.
+ *
+ * ROUTER: The address of the "host", ie. this library.
+ *
+ * [Note: If you change NETWORK and ROUTER then you also have to
+ * change the network configuration in appliance/init].
+ *
+ * GUESTFWD_ADDR, GUESTFWD_PORT: The guestfwd feature of qemu
+ * magically connects this pseudo-address to the guestfwd channel. In
+ * typical Linux configurations of libguestfs, guestfwd is not
+ * actually used any more.
+ */
+#define NETWORK "169.254.0.0/16"
+#define ROUTER "169.254.2.2"
+
+/* GuestFS handle and connection. */
+enum state { CONFIG, LAUNCHING, READY, BUSY, NO_HANDLE };
+
+struct guestfs_h
+{
+ struct guestfs_h *next; /* Linked list of open handles. */
+
+ /* State: see the state machine diagram in the man page guestfs(3). */
+ enum state state;
+
+ int fd[2]; /* Stdin/stdout of qemu. */
+ int sock; /* Daemon communications socket. */
+ pid_t pid; /* Qemu PID. */
+ pid_t recoverypid; /* Recovery process PID. */
+
+ struct timeval launch_t; /* The time that we called guestfs_launch. */
+
+ char *tmpdir; /* Temporary directory containing socket. */
+
+ char *qemu_help, *qemu_version; /* Output of qemu -help, qemu -version. */
+
+ char **cmdline; /* Qemu command line. */
+ int cmdline_size;
+
+ int verbose;
+ int trace;
+ int autosync;
+ int direct;
+ int recovery_proc;
+ int enable_network;
+
+ char *path; /* Path to kernel, initrd. */
+ char *qemu; /* Qemu binary. */
+ char *append; /* Append to kernel command line. */
+
+ int memsize; /* Size of RAM (megabytes). */
+
+ int selinux; /* selinux enabled? */
+
+ char *last_error;
+ int last_errnum; /* errno, or 0 if there was no errno */
+
+ /* Callbacks. */
+ guestfs_abort_cb abort_cb;
+ guestfs_error_handler_cb error_cb;
+ void * error_cb_data;
+ guestfs_log_message_cb log_message_cb;
+ void * log_message_cb_data;
+ guestfs_subprocess_quit_cb subprocess_quit_cb;
+ void * subprocess_quit_cb_data;
+ guestfs_launch_done_cb launch_done_cb;
+ void * launch_done_cb_data;
+ guestfs_close_cb close_cb;
+ void * close_cb_data;
+ guestfs_progress_cb progress_cb;
+ void * progress_cb_data;
+
+ int msg_next_serial;
+
+ /* Information gathered by inspect_os. Must be freed by calling
+ * guestfs___free_inspect_info.
+ */
+ struct inspect_fs *fses;
+ size_t nr_fses;
+
+ /* Private data area. */
+ struct hash_table *pda;
+};
+
+/* Per-filesystem data stored for inspect_os. */
+enum inspect_fs_content {
+ FS_CONTENT_UNKNOWN = 0,
+ FS_CONTENT_LINUX_ROOT,
+ FS_CONTENT_WINDOWS_ROOT,
+ FS_CONTENT_LINUX_BOOT,
+ FS_CONTENT_LINUX_USR,
+ FS_CONTENT_LINUX_USR_LOCAL,
+ FS_CONTENT_LINUX_VAR,
+ FS_CONTENT_FREEBSD_ROOT,
+};
+
+enum inspect_os_type {
+ OS_TYPE_UNKNOWN = 0,
+ OS_TYPE_LINUX,
+ OS_TYPE_WINDOWS,
+ OS_TYPE_FREEBSD,
+};
+
+enum inspect_os_distro {
+ OS_DISTRO_UNKNOWN = 0,
+ OS_DISTRO_DEBIAN,
+ OS_DISTRO_FEDORA,
+ OS_DISTRO_REDHAT_BASED,
+ OS_DISTRO_RHEL,
+ OS_DISTRO_WINDOWS,
+ OS_DISTRO_PARDUS,
+ OS_DISTRO_ARCHLINUX,
+ OS_DISTRO_GENTOO,
+ OS_DISTRO_UBUNTU,
+ OS_DISTRO_MEEGO,
+ OS_DISTRO_LINUX_MINT,
+ OS_DISTRO_MANDRIVA,
+};
+
+enum inspect_os_package_format {
+ OS_PACKAGE_FORMAT_UNKNOWN = 0,
+ OS_PACKAGE_FORMAT_RPM,
+ OS_PACKAGE_FORMAT_DEB,
+ OS_PACKAGE_FORMAT_PACMAN,
+ OS_PACKAGE_FORMAT_EBUILD,
+ OS_PACKAGE_FORMAT_PISI
+};
+
+enum inspect_os_package_management {
+ OS_PACKAGE_MANAGEMENT_UNKNOWN = 0,
+ OS_PACKAGE_MANAGEMENT_YUM,
+ OS_PACKAGE_MANAGEMENT_UP2DATE,
+ OS_PACKAGE_MANAGEMENT_APT,
+ OS_PACKAGE_MANAGEMENT_PACMAN,
+ OS_PACKAGE_MANAGEMENT_PORTAGE,
+ OS_PACKAGE_MANAGEMENT_PISI,
+ OS_PACKAGE_MANAGEMENT_URPMI,
+};
+
+struct inspect_fs {
+ int is_root;
+ char *device;
+ int is_mountable;
+ int is_swap;
+ enum inspect_fs_content content;
+ enum inspect_os_type type;
+ enum inspect_os_distro distro;
+ enum inspect_os_package_format package_format;
+ enum inspect_os_package_management package_management;
+ char *product_name;
+ int major_version;
+ int minor_version;
+ char *arch;
+ char *hostname;
+ char *windows_systemroot;
+ struct inspect_fstab_entry *fstab;
+ size_t nr_fstab;
+};
+
+struct inspect_fstab_entry {
+ char *device;
+ char *mountpoint;
+};
+