Find a file
Ramiro Estrugo f5f7af7389 New function to insert a string without having to access the string list
* libnautilus-extensions/nautilus-string-picker.c:
	(nautilus_string_picker_initialize),
	(nautilus_string_picker_destroy),
	(nautilus_string_picker_set_string_list),
	(nautilus_string_picker_get_string_list),
	(nautilus_string_picker_get_selected_string),
	(nautilus_string_picker_set_selected_string),
	(nautilus_string_picker_insert_string):
	* libnautilus-extensions/nautilus-string-picker.h:
	New function to insert a string without having to access the
	string list first.  Also renamed some poorly named functions.

	* libnautilus-extensions/nautilus-preferences-item.c:
	(preferences_item_create_font_family),
	(preferences_item_create_theme), (text_item_changed_callback):
	Update for string picker api changes.

	* test/test-nautilus-widgets.c: (test_string_picker),
	(string_picker_changed_callback):
	Update for string picker api changes.
2000-08-18 06:52:56 +00:00
components Remove extra parameters now that the initial files callback is gone. It 2000-08-17 21:57:13 +00:00
cut-n-paste-code Only bugfixes so I suspect I'm allowed to check these in. 2000-08-04 21:27:35 +00:00
data implemented task 2078, we need a better drag and drop based way to delete 2000-08-17 23:22:48 +00:00
docs Some tweaks to Maciej's proposed states for ViewFrame. 2000-08-11 23:16:49 +00:00
helper-utilities Added a declaration to work around a bug or version issue that some 2000-08-04 17:40:05 +00:00
icons made nautilus_image handle images with an alpha channel better, and 2000-08-17 22:22:30 +00:00
idl Changes caused by the festival of renaming in OAF. 2000-08-12 02:39:11 +00:00
libnautilus More of the implementation of all the trash functions. About 1/3 done now. 2000-08-16 02:37:44 +00:00
libnautilus-extensions New function to insert a string without having to access the string list 2000-08-18 06:52:56 +00:00
libnautilus-private New function to insert a string without having to access the string list 2000-08-18 06:52:56 +00:00
librsvg Fixed a libart bug that triggers when rendering into an rgb buffer without 2000-08-15 08:02:48 +00:00
nautilus-installer Changed some of the default values. 2000-08-15 06:23:51 +00:00
nautilus-widgets Move the nautilus-widgets classes to libnautilus-extensions. 2000-06-10 00:38:05 +00:00
po Updated russian translation. 2000-08-17 18:37:27 +00:00
src Finished task 1991 (Need "Create Link" menu item) and did 2000-08-18 00:21:52 +00:00
test New function to insert a string without having to access the string list 2000-08-18 06:52:56 +00:00
tools Turn my dumbass brain on this time before committing. Add the moved leak 2000-07-15 02:12:01 +00:00
.cvsignore Some generated file names changed, so these must change too. 2000-07-14 22:56:20 +00:00
acconfig.h Now Time in the About box (when it was build not current) 2000-08-05 01:34:57 +00:00
AUTHORS Added myself. This file is *seriously* out of date. 2000-08-16 02:11:39 +00:00
autogen.sh Finish the hack to not make people get gnome.m4 from gnome-libs any more. 2000-02-23 19:06:47 +00:00
ChangeLog New function to insert a string without having to access the string list 2000-08-18 06:52:56 +00:00
ChangeLog-20000414 Added appropriate copyright notices. 2000-04-14 06:40:27 +00:00
ChangeLog-20000625 Ignore some additional generated files. 2000-06-26 18:01:44 +00:00
check-config-h.pl Added "." parameter to "find" so it works with non-GNU versions of find. 2000-05-09 00:57:17 +00:00
check-FIXME.pl Added HACKING to the files to skip. 2000-08-02 19:26:39 +00:00
check-headers-in-Makefile.pl Wrote a script to check that the Makefile.am file matches what's actually 2000-07-05 23:49:25 +00:00
check-signals.pl Wrote a script to check for people who forget to call 2000-08-03 18:40:39 +00:00
configure.in Fixed GtkHTML configure section so it will work with 3-part version 2000-08-14 20:59:38 +00:00
COPYING.LIB Just adding copyright/license notices, and a copy of the LGPL. 1999-12-07 19:59:42 +00:00
CVSVERSION New file, used to detect whether we are configuring a cvs version or a 2000-08-08 01:36:50 +00:00
HACKING Another pass on README/HACKING. Still room for improvement. 2000-08-11 18:39:15 +00:00
MAINTAINERS Changed to the new Nautilus list instead of the old secret list. 2000-04-27 22:54:19 +00:00
Makefile.am tweak files for upcommin release. see Changelog. 2000-08-11 18:18:39 +00:00
nautilus-clean.sh CLI programs that prompt for root password now use getpass(() 2000-08-03 18:15:17 +00:00
nautilus.desktop Added German (de) to ALL_LINGUAS Added German translations 2000-06-14 16:30:36 +00:00
nautilus.png Made NautilusFile async. like NautilusDirectory already was. 2000-06-20 22:09:36 +00:00
nautilus.spec.in removed config dumbness 2000-08-10 06:44:04 +00:00
NEWS Basic framework is there. Now for URL resolution and loading. 1999-12-06 00:49:57 +00:00
README Don't use tabs any more. Spell check. Add libglade. 2000-08-17 00:43:18 +00:00
RENAMING Add an entry. 2000-07-24 07:52:00 +00:00
RPMs-README Fixed bug 1891 (calling set_title before report_load_underway has 2000-08-11 21:33:11 +00:00
TODO Added an empty file to fix the build (required since Elliot added it to 2000-07-13 23:10:07 +00:00

This file contains build instructions for Nautilus, the GNOME shell
and file manager.

====================
0: Table of contents
====================

0: Table of contents
1: Hacking
2: Introduction
3: Distribution-specific notes
4: Compiling
5: Running

==========
1: Hacking
==========

If you would like to hack on Nautilus, or have patches, please send
mail to the Nautilus maintainer: Darin Adler <darin@eazel.com>.
Patches should also be sent to the Nautilus mailing list:
<nautilus-list@lists.eazel.com>

The HACKING file contains other things you should know when hacking on
Nautilus and when contributing code. Please, make sure you check the
coding style document in docs/style-guide.html and other documents
found in the "docs" directory.

===============
2: Introduction
===============

To build Nautilus without interfering with an existing Gnome install,
you will need to build several components either from CVS or from 
tarballs into a separate prefix. Detailed instructions on how
to accomplish this are available in section 4.

==============================
3: Distribution-specific notes
==============================

The following describes the libraries that Nautilus hackers use for
development and what we have tested with. At the moment, we make no
guarantees one way or another about whether Nautilus will work with
other versions.

You will also need the library package that is associated with each
development package, these versions are for Red Hat 6.2 and Debian
"potato":

library         Red Hat                   Debian                          approx. version
--------------  ------------------------  ------------------------------  ------------------
audiofile       audiofile-devel-0.1.9-3   libaudiofile-dev (0.1.9-0.1)    0.1.9
libc            glibc-devel-2.1.3-15      libc6-dev (2.1.3-10)            2.1.3
libc++          egcs-c++-1.1.2-30         libstdc++2.10-dev (2.95.2-12)   2.9.0, 2.10
libjpeg         libjpeg-devel-6b-10       libjpeg62-dev (6b-1.2)          6b 1.0-1.2
libpng          libpng-devel-1.0.5-3      libpng2-dev (1.0.5-1)           1.0.5
libtiff         libtiff-devel-3.5.4-5     libtiff3g-dev (3.5.4-5)         3.5.4
libungif        libungif-devel-4.1.0-4    libungif3g-dev (3.0-3)          3.0 or 4.1.0
w3c-libwww      w3c-libwww-devel-5.2.8-4  libw3c-libwww-dev (5.2.8-1)     5.2.8
Xlib            XFree86-devel-3.3.6-20    xlib6g-dev (3.3.6-7)            3.3.6
zlib            zlib-devel-1.1.3-6        zlib1g-dev (1.1.3-5)            1.1.3

Other modules for Red Hat users: either 6.1 or 6.2

        - For most modules, the versions in Red Hat 6.1 or 6.2 will do (listed above).
        - ORBit requires popt-1.5, which can be fetched from:

        ftp://ftp.valinux.com/pub/mirrors/redhat/rawhide/i386/RedHat/RPMS/popt-1.5-0.45.i386.rpm
        ftp://ftp.valinux.com/pub/mirrors/redhat/redhat/redhat-6.2/i386/RedHat/RPMS/popt-1.5-0.48.i386.rpm

Other modules for Debian users: using potato, or possibly woody

        - You'll need libwww, which can be found at:

        ftp://ftp.internatif.org/pub/debian/UNOFFICIAL/libw3c-libwww5_5.2.8-1_i386.deb
        ftp://ftp.internatif.org/pub/debian/UNOFFICIAL/libw3c-libwww-dev_5.2.8-1_i386.deb

If you need to get a copy of popt from source: 

        CVSROOT=:pserver:anonymous@cvs.rpm.org:/cvs/devel
        The default password is a carriage return.  You should do a cvs co popt

============
4: Compiling
============

First, make sure you have installed the packages detailed below. If
you are running GNOME from binaries (Helix Code or your native
distribution binaries), please make sure you have installed the
corresponding development packages.  (i.e.: the *-devel packages which
provide the necessary C header files.

Then, make sure you have no old version of the packages nautilus
depends on on your system. You can check the version of the relevant
packages by trying to execute "package-config --version" (ie:
gnome-config --version will report gnome-libs version, gconf-config
--version will report gconf's version).

        Compiling from tarballs.
        ------------------------
If you are compiling from tarballs, (ie: using released versions of
nautilus and the relevant packages), you want to follow the
instructions below.

The following lists the packages and the versions they should report.

    module             version            configure options      dist.
    ------             ------             -----------------      -----
    popt:              <1.5, but not from GNOME CVS, see below>  RH6.2
    glib:              1.2.8                                     HC1.2
    gtk+:              1.2.8                                     HC1.2
    imlib:             1.9.8.1                                   HC1.2
    gnome-xml:         1.8.1                                     HC1.2
    ORBit:             0.5.3                                     HC1.2
    gnome-libs:        1.2.4              --enable-prefer-db1    HC1.2
    gnome-http:        1.0.6
    oaf:               0.5.0
    gconf:             0.8
    gdk-pixbuf:        0.8.0              --enable-canvas-pixbuf
    gnome-print:       0.20.0
    control-center     1.2.0
    gnome-vfs:         HEAD
    bonobo:            0.17
    libglade:          0.14
    gtkhtml:           0.6
    eog:               0.3                --with-bonobo
    medusa:            0.2
    nautilus:          0.1

RH6.2 == Version from Red Hat 6.2 OK
HC1.2 == Version from Helix Code Gnome 1.2 OK

If you are running Helix Code's GNOME, you should not need recompile
the packages marked "HC1.2" provided you have installed the
corresponding development packages.

We assume you want to install these packages in another prefix than
/usr since you want to keep a working system. For the following, we
assume you are installing in /usr/local. ie: ${prefix}=/usr/local

Redefine your PATH env variable: 
        export PATH=$PATH:${prefix}/bin
Redefine your LD_LIBRARY_PATH env variable: 
        export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:${prefix}/lib
Redefine your GNOME_PATH env variable: 
        export GNOME_PATH=$GNOME_PATH:${prefix}

In the order defined above and with the specific options detailed
above, you should run the configure scripts with: "./configure
--prefix=${prefix} --special-options" Then, run make; get root and run
make install.

You should get a running nautilus soon after. :)

        Compiling from cvs.
        -------------------
Compiling from cvs usually requires more work and some packages may
not compile. Do so at your own risk!!

The following lists the packages and the versions that are required.

    module             branch             configure options      dist.
    ------             ------             -----------------      -----
    popt:              <1.5, but not from GNOME CVS, see below>  RH6.2
    glib:              glib-1-2                                  HC1.2
    gtk+:              gtk-1-2                                   HC1.2
    imlib:             HEAD                                      HC1.2
    gnome-xml:         LIB_XML_1_X                               HC1.2
    ORBit:             orbit-stable-0-5                          HC1.2
    gnome-libs:        gnome-libs-1-0     --enable-prefer-db1    HC1.2
    gnome-http:        HEAD
    oaf:               HEAD
    gconf:             HEAD
    gdk-pixbuf:        HEAD               --enable-canvas-pixbuf
    gnome-print:       GNOME_PRINT_0_20
    control-center     control-center-1-0
    gnome-vfs:         HEAD
    bonobo:            HEAD
    gtkhtml:           HEAD
    libglade:          HEAD
    eog:               HEAD               --with-bonobo
    xpdf:              HEAD
    medusa:            HEAD
    nautilus:          HEAD

RH6.2 == Version from Red Hat 6.2 OK
HC1.2 == Version from Helix Code Gnome 1.2 OK

One difference between tarball and cvs compilation is that when you
get stuff from cvs, you don't get a configure script. This script has
to be generated.  This script is usually generated with the help of
another script available from cvs named "autogen.sh". For those
interested, "autogen.sh" will run in turn aclocal, automake, autoconf
and configure. You thus need versions of the GNU tools for the
following packages:

        package         version       command
        -------         -------       -------
        automake        1.4           automake --version
        autoconf        2.13          autoconf --version

Earlier versions might work but no one has tested them.

Once you have these tools, you need to follow the compilation
instructions detailed above for tarballs but instead of running
"./configure --stuff", you will run "./autogen.sh --stuff" Using this
also requires you to create the ${prefix}/share/aclocal directory
before compiling any package and setup the following env variable:

        export ACLOCAL_FLAGS="$ACLOCAL_FLAGS -I ${prefix}/share/aclocal"

Besides these differences, building from CVS should be otherwise
like building from released packages as described above.

===============================
5: Issues when running Nautilus
===============================

There's a script named nautilus-clean.sh, at the top level of the
Nautilus sources. If OAF or GConf changes, you may need to run this
script to get Nautilus to work properly. One way to invoke it is
like this:

        ./nautilus-clean.sh -x