A new user interface for you! Read more...

File libguestfs.spec of Package libguestfs

# Enable to build w/o network.
%global buildnonet 0

Summary:     Access and modify virtual machine disk images
Name:        libguestfs
Version:     1.2.9
Release:     1%{?dist}
License:     LGPLv2+
Group:       Development/Libraries
URL:         http://et.redhat.com/~rjones/libguestfs/
Source0:     http://et.redhat.com/~rjones/libguestfs/files/%{name}-%{version}.tar.gz
BuildRoot:   %{_tmppath}/%{name}-%{version}-%{release}-root

# Currently fails on non-x86 because of this error:
# "qemu: linux kernel too old to load a ram disk"
#ExclusiveArch: %{ix86} x86_64

# Basic build requirements:
BuildRequires: perl
BuildRequires: mkisofs
#BuildRequires: febootstrap >= 1.5
#BuildRequires: augeas-devel >= 0.5.0
BuildRequires: readline-devel
BuildRequires: qemu
#BuildRequires: createrepo

# This is only needed for RHEL 5 because readline-devel doesn't
# properly depend on it, but doesn't do any harm on other platforms:
BuildRequires: ncurses-devel

# Build requirements for the appliance:
# (see 'make-initramfs.sh.in' in the source)
BuildRequires: kernel-xen, bash, coreutils, lvm2, util-linux
BuildRequires: ntfs-3g febootstrap, fakechroot, fakeroot
BuildRequires: net-tools, file
BuildRequires: module-init-tools, procps, strace, iputils

# These are only required if you want to build the bindings for
# different languages:
BuildRequires: ocaml
#BuildRequires: ocaml-findlib-devel
#BuildRequires: perl-devel
BuildRequires: perl-Test-Simple
BuildRequires: perl-Test-Pod
BuildRequires: perl-Test-Pod-Coverage
#BuildRequires: perl-ExtUtils-MakeMaker
BuildRequires: python-devel
#BuildRequires: ruby-devel
#BuildRequires: rubygem-rake
#BuildRequires: java >= 1.5.0
#BuildRequires: jpackage-utils
#BuildRequires: java-devel

# For virt-inspector:
#BuildRequires: perl-Sys-Virt

# Runtime requires:
Requires:    qemu


%description
Libguestfs is a library for accessing and modifying guest disk images.
Amongst the things this is good for: making batch configuration
changes to guests, getting disk used/free statistics (see also:
virt-df), migrating between virtualization systems (see also:
virt-p2v), performing partial backups, performing partial guest
clones, cloning guests and changing registry/UUID/hostname info, and
much else besides.

Libguestfs uses Linux kernel and qemu code, and can access any type of
guest filesystem that Linux and qemu can, including but not limited
to: ext2/3/4, btrfs, FAT and NTFS, LVM, many different disk partition
schemes, qcow, qcow2, vmdk.

Libguestfs provides ways to enumerate guest storage (eg. partitions,
LVs, what filesystem is in each LV, etc.).  It can also run commands
in the context of the guest.  Also you can access filesystems over FTP.

Libguestfs is a library that can be linked with C and C++ management
programs.

See also the 'guestfish' package for shell scripting and command line
access.

For Perl bindings, see 'perl-libguestfs'.

For OCaml bindings, see 'ocaml-libguestfs-devel'.

For Python bindings, see 'python-libguestfs'.

For Ruby bindings, see 'ruby-libguestfs'.

For Java bindings, see 'libguestfs-java-devel'.


%package devel
Summary:     Development tools and libraries for %{name}
Group:       Development/Libraries
Requires:    %{name} = %{version}-%{release}
Requires:    pkgconfig


%description devel
%{name}-devel contains development tools and libraries
for %{name}.


%package -n guestfish
Summary:     Shell for accessing and modifying virtual machine disk images
Group:       Development/Tools
License:     GPLv2+
Requires:    %{name} = %{version}-%{release}
Requires:    perl


%description -n guestfish
Guestfish is the Filesystem Interactive SHell, for accessing and
modifying virtual machine disk images from the command line and shell
scripts.


%package -n virt-inspector
Summary:     Display OS version, kernel, drivers, etc in a virtual machine
Group:       Development/Tools
License:     GPLv2+
Requires:    %{name} = %{version}-%{release}
Requires:    guestfish
Requires:    perl-Sys-Virt


%description -n virt-inspector
Virt-inspector examines a virtual machine and tries to determine the
version of the OS, the kernel version, what drivers are installed,
whether the virtual machine is fully virtualized (FV) or
para-virtualized (PV), what applications are installed and more.


#%package -n ocaml-%{name}
#Summary:     OCaml bindings for %{name}
#Group:       Development/Libraries
#Requires:    %{name} = %{version}-%{release}


#%description -n ocaml-%{name}
#ocaml-%{name} contains OCaml bindings for %{name}.

#This is for toplevel and scripting access only.  To compile OCaml
#programs which use %{name} you will also need ocaml-%{name}-devel.


#%package -n ocaml-%{name}-devel
#Summary:     OCaml bindings for %{name}
#Group:       Development/Libraries
#Requires:    ocaml-%{name} = %{version}-%{release}


#%description -n ocaml-%{name}-devel
#ocaml-%{name}-devel contains development libraries
#required to use the OCaml bindings for %{name}.


%package -n perl-%{name}
Summary:     Perl bindings for %{name}
Group:       Development/Libraries
Requires:    %{name} = %{version}-%{release}
Requires:    perl(:MODULE_COMPAT_%(eval "`%{__perl} -V:version`"; echo $version))


%description -n perl-%{name}
perl-%{name} contains Perl bindings for %{name}.


%package -n python-%{name}
Summary:     Python bindings for %{name}
Group:       Development/Libraries
Requires:    %{name} = %{version}-%{release}

%{!?python_sitelib: %global python_sitelib %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")}
%{!?python_sitearch: %global python_sitearch %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib(1)")}

%description -n python-%{name}
python-%{name} contains Python bindings for %{name}.


#%package -n ruby-%{name}
#Summary:     Ruby bindings for %{name}
#Group:       Development/Libraries
#Requires:    %{name} = %{version}-%{release}
#Requires:    ruby(abi) = 1.8
#Provides:    ruby(guestfs) = %{version}

#%{!?ruby_sitelib: %define ruby_sitelib %(ruby -rrbconfig -e "puts Config::CONFIG['sitelibdir']")}
#%{!?ruby_sitearch: %define ruby_sitearch %(ruby -rrbconfig -e "puts Config::CONFIG['sitearchdir']")}

#%description -n ruby-%{name}
#ruby-%{name} contains Ruby bindings for %{name}.


#%package java
#Summary:     Java bindings for %{name}
#Group:       Development/Libraries
#Requires:    %{name} = %{version}-%{release}
#Requires:    java >= 1.5.0
#Requires:    jpackage-utils

#%description java
#%{name}-java contains Java bindings for %{name}.

#If you want to develop software in Java which uses %{name}, then
#you will also need %{name}-java-devel.


#%package java-devel
#Summary:     Java development package for %{name}
#Group:       Development/Libraries
#Requires:    %{name} = %{version}-%{release}
#Requires:    %{name}-java = %{version}-%{release}

#%description java-devel
#%{name}-java-devel contains the tools for developing Java software
#using %{name}.

#See also %{name}-javadoc.


#%package javadoc
#Summary:     Java documentation for %{name}
#Group:       Development/Libraries
#Requires:    %{name} = %{version}-%{release}
#Requires:    %{name}-java = %{version}-%{release}
#Requires:    jpackage-utils

#%description javadoc
#%{name}-javadoc contains the Java documentation for %{name}.


%prep
%setup -q

mkdir -p daemon/m4


%build
%if %{buildnonet}
mkdir repo
find /var/cache/yum/build -type f -name '*.rpm' -print0 | xargs -0 cp -t repo
createrepo repo
%define extra --with-mirror=file://$(pwd)/repo --with-repo=fedora-12
%else
%define extra %nil
%endif

./configure \
  --prefix=%{_prefix} --libdir=%{_libdir} \
  --mandir=%{_mandir} \
  --with-qemu="qemu-kvm qemu-system-%{_build_arch} qemu" \
  --enable-debug-command \
  %{extra}

# This ensures that /usr/sbin/chroot is on the path.  Not needed
# except for RHEL 5, it shouldn't do any harm on other platforms.
export PATH=/usr/sbin:$PATH

# 'INSTALLDIRS' ensures that perl libs are installed in the vendor dir
# not the site dir.
make INSTALLDIRS=vendor %{?_smp_mflags}


%check
# These tests take a seriously long time in Koji.  It was looking
# like hours, possibly because Koji is already running inside a
# VM, so it's a case of virt-on-virt.  Disabled for now, but we
# should enable them later and/or work out how to speed them up.
# make check


%install
rm -rf $RPM_BUILD_ROOT

make DESTDIR=$RPM_BUILD_ROOT install

rm $RPM_BUILD_ROOT%{_libdir}/libguestfs.a
rm $RPM_BUILD_ROOT%{_libdir}/libguestfs.la

# Clean up the examples/ directory which will get installed in %doc.
# Note we can't delete the original examples/Makefile because that
# will be needed by the check section later in the RPM build.
cp -a examples ex
pushd ex
make clean
rm Makefile*
rm -rf .deps .libs
popd

# Same for ocaml/examples.
#cp -a ocaml/examples ocaml/ex
#pushd ocaml/ex
#make clean
#rm Makefile*
#popd

find $RPM_BUILD_ROOT -name perllocal.pod -delete
find $RPM_BUILD_ROOT -name .packlist -delete
find $RPM_BUILD_ROOT -name '*.bs' -delete

rm $RPM_BUILD_ROOT%{python_sitearch}/libguestfsmod.a
rm $RPM_BUILD_ROOT%{python_sitearch}/libguestfsmod.la

if [ "$RPM_BUILD_ROOT%{python_sitearch}" != "$RPM_BUILD_ROOT%{python_sitelib}" ]; then
   mkdir -p $RPM_BUILD_ROOT%{python_sitelib}
   mv $RPM_BUILD_ROOT%{python_sitearch}/guestfs.py* \
     $RPM_BUILD_ROOT%{python_sitelib}/
fi

# Install ruby bindings by hand.
#mkdir -p $RPM_BUILD_ROOT%{ruby_sitelib}
#mkdir -p $RPM_BUILD_ROOT%{ruby_sitearch}
#install -p -m0644 ruby/lib/guestfs.rb $RPM_BUILD_ROOT%{ruby_sitelib}
#install -p -m0755 ruby/ext/guestfs/_guestfs.so $RPM_BUILD_ROOT%{ruby_sitearch}

# Remove static-linked Java bindings.
#rm $RPM_BUILD_ROOT%{_libdir}/libguestfs_jni.a
#rm $RPM_BUILD_ROOT%{_libdir}/libguestfs_jni.la

# Generator shouldn't be executable when we distribute it.
#chmod -x src/generator.ml


%clean
rm -rf $RPM_BUILD_ROOT


%post -p /sbin/ldconfig

%postun -p /sbin/ldconfig


%files
%defattr(-,root,root,-)
%doc COPYING
%{_libdir}/guestfs/
%{_libdir}/libguestfs.so.*


%files devel
%defattr(-,root,root,-)
%doc ChangeLog HACKING TODO README ex html/guestfs.3.html html/pod.css
%doc src/generator.ml
%{_libdir}/libguestfs.so
%{_mandir}/man3/guestfs.3*
%{_includedir}/guestfs.h
%{_includedir}/guestfs-actions.h
%{_includedir}/guestfs-structs.h
%{_libdir}/pkgconfig/libguestfs.pc


%files -n guestfish
%defattr(-,root,root,-)
%doc html/guestfish.1.html html/pod.css recipes/
%{_bindir}/guestfish
%{_mandir}/man1/guestfish.1*


%files -n virt-inspector
%defattr(-,root,root,-)
%{_bindir}/virt-inspector
%{_mandir}/man1/virt-inspector.1*


#%files -n ocaml-%{name}
#%defattr(-,root,root,-)
#%doc README
#%{_libdir}/ocaml/guestfs
#%exclude %{_libdir}/ocaml/guestfs/*.a
#%exclude %{_libdir}/ocaml/guestfs/*.cmxa
#%exclude %{_libdir}/ocaml/guestfs/*.cmx
#%exclude %{_libdir}/ocaml/guestfs/*.mli
#%{_libdir}/ocaml/stublibs/*.so
#%{_libdir}/ocaml/stublibs/*.so.owner


#%files -n ocaml-%{name}-devel
#%defattr(-,root,root,-)
#%doc ocaml/ex
#%{_libdir}/ocaml/guestfs/*.a
#%{_libdir}/ocaml/guestfs/*.cmxa
#%{_libdir}/ocaml/guestfs/*.cmx
#%{_libdir}/ocaml/guestfs/*.mli


%files -n perl-%{name}
%defattr(-,root,root,-)
%doc perl/examples
%{perl_vendorarch}/*
%{_mandir}/man3/Sys::Guestfs.3pm*


%files -n python-%{name}
%defattr(-,root,root,-)
%doc README
%{python_sitearch}/*
%{python_sitelib}/*.py
%{python_sitelib}/*.pyc
%{python_sitelib}/*.pyo


#%files -n ruby-%{name}
#%defattr(-,root,root,-)
#%doc README
#%{ruby_sitelib}/guestfs.rb
#%{ruby_sitearch}/_guestfs.so


#%files java
#%defattr(-,root,root,-)
#%doc README
#%{_libdir}/libguestfs_jni*.so.*
#%{_datadir}/java/*.jar


#%files java-devel
#%defattr(-,root,root,-)
#%doc README
#%{_libdir}/libguestfs_jni*.so


#%files javadoc
#%defattr(-,root,root,-)
#%doc README
#%{_datadir}/javadoc/%{name}-java-%{version}


%changelog
* Thu May  7 2009 Richard Jones <rjones@redhat.com> - 1.0.20-1
- New upstream version 1.0.20.