GnuCash Double-Entry Accounting Program.
Go to file
Geert Janssens 5d95bb042d zh_CN translation of gnucash glossary file, patch by Tao Wang
git-svn-id: svn+ssh://svn.gnucash.org/repo/gnucash/trunk@19085 57a11ea4-9604-0410-9ed3-97b8803252fd
2010-04-29 15:56:31 +00:00
accounts Updated zh_CN translation of accounts, patch by Tao Wang 2010-04-29 15:44:26 +00:00
art Bug #523922: Use correct scalable icon and add/fix 22x22/24x24 icons. 2008-04-25 23:19:33 +00:00
checks Bump minimum required versions of gtk+, goffice and gtkhtml 2010-02-21 18:30:32 +00:00
contrib Moved svnlog2ul from contrib to util 2010-02-08 17:59:15 +00:00
doc Bug #616696 - Development version warning string should not include hardcode version. 2010-04-28 13:23:27 +00:00
intl-scm * intl-scm/xgettext.scm: remove the absolute path from filenames 2006-02-18 14:39:21 +00:00
lib Remove local srfi's and require guile 1.6.7 or better. 2010-04-05 16:48:09 +00:00
macros Fix 598491: Remove use of guile's deprecated GH interface 2009-10-17 17:47:56 +00:00
packaging Bug #617072 - Update create_cross_mingw.sh, patch by Yasuaki Taniguchi 2010-04-28 13:54:45 +00:00
po zh_CN translation of gnucash glossary file, patch by Tao Wang 2010-04-29 15:56:31 +00:00
src Change default report stylesheet from "Default" to "Default CSS" 2010-04-28 17:48:49 +00:00
util Insert missing "format:" - otherwise it didn't build for me. 2010-04-10 12:22:56 +00:00
.gitignore More header include compatibility: Watch out for HAVE_UNISTD_H. 2010-02-27 18:38:52 +00:00
AUTHORS Redo of the dot-gnucash fix (so that GNC_DOT_DIR actually works) fixing bug 610707, adding Doxygen comments for all functions in gnc-filepath-utils, and adding testing for xaccResolveURI and more tests for xaccResolveFilePath. 2010-02-28 22:53:02 +00:00
autogen.sh Fix a couple of echo commands and set warnings=no-portability when running automake. 2009-12-17 07:15:16 +00:00
ChangeLog.1 Split top-level ChangeLog by year. Everything before 2005-11-16 20:18:48 +00:00
ChangeLog.2001 Split top-level ChangeLog by year. Everything before 2005-11-16 20:18:48 +00:00
ChangeLog.2002 Split top-level ChangeLog by year. Everything before 2005-11-16 20:18:48 +00:00
ChangeLog.2003 Fix old Changelogs from HEAD/gnome2 parallelity; entries are now in correct year 2006-01-28 19:04:04 +00:00
ChangeLog.2004 Fix old Changelogs from HEAD/gnome2 parallelity; entries are now in correct year 2006-01-28 19:04:04 +00:00
ChangeLog.2005 ChangeLog entries from svn for past 12 days. 2006-01-13 02:05:51 +00:00
ChangeLog.2006 Add generated ChangeLog of the year 2006 (r15286:r12229) to tarball. 2007-02-01 14:25:42 +00:00
ChangeLog.2006-manual Move old manual 2006 Changelog to separate filename 2007-04-30 09:32:35 +00:00
ChangeLog.2007 Add ChangeLog.2007 2008-01-02 20:05:36 +00:00
ChangeLog.2008 Add ChangeLog.2008. 2009-01-02 10:46:27 +00:00
ChangeLog.2009 Add ChangeLog.2009 for the last year. 2010-01-15 20:49:10 +00:00
CMakeLists.txt Cutecash: Add install and packaging rules. 2010-04-12 19:21:14 +00:00
configure.ac Bug #554936 - 'configure.in' files should be renamed 'configure.ac' 2010-04-28 13:43:45 +00:00
DOCUMENTERS Fix misspelled name 2006-06-16 10:48:51 +00:00
GNOME2_STATUS Migrate content to bugzilla. 2006-01-19 01:29:52 +00:00
HACKING Move valgrind suppression rules to debug subdirectory 2010-02-08 17:30:21 +00:00
LICENSE Update LICENSE to explain the state of the world. Add OpenSSL exemption to my sources. 2007-07-06 21:13:48 +00:00
make-gnucash-potfiles.in Add src/gnome/gnucash.desktop.in.in to the translation input files. 2010-04-22 20:45:22 +00:00
Makefile.am Add a "make indent" target, but watch out with using its result. 2010-02-28 13:40:38 +00:00
Makefile.TAGS only conditionally remove the file. 2006-05-28 14:34:50 +00:00
NEWS 1) Update svn:ignore for accounts/cs to ignore Makefile and Makefile.in 2009-05-14 00:33:28 +00:00
README README referred to a non-existent file 2010-02-20 00:00:58 +00:00
README.dependencies Update README.dependencies with Jean-David Beyer's updates for RHEL5(/FC7). 2007-06-26 22:58:50 +00:00
README.svn Minor updates to README.svn; remove README.patches from gnucash.spec.in. 2008-03-08 20:04:46 +00:00
TODO Collapse the gnome2 branch back into HEAD. 2005-11-02 03:32:36 +00:00

############################################################
          GnuCash 2.1.x README file.

NOTE: THIS IS A DEVELOPMENT RELEASE!!! THIS VERSION HAS NOT 
BEEN TESTED PROPERLY AND MAY DO ABSOLUTELY ANYTHING!   

USE AT YOUR OWN RISK (AND KEEP *LOTS* OF BACKUPS) 

If you want something a bit more tested, please use the 
2.0 stable series. 
------------------------------------------------------------

##################
Table of Contents:
------------------

  - Overview
  - Upgrading from 2.0.x
  - Dependencies
  - Invocation/running
  - Internationalization
  - Building & Installing
  - Supported Platforms
  - Additional Download Sites
  - Getting the Source via SVN
  - Developing GnuCash

########
Overview
--------

GnuCash is a personal finance manager. A check-book like register GUI
allows you to enter and track bank accounts, stocks, income and even
currency trades. A full set of reports allow you to see the state of
your finances. The interface is designed to be simple and easy to use,
but is backed with double-entry accounting principles to ensure
balanced books.

Features include:

  - An easy-to-use interface.  If you can use the
    register in the back of your checkbook, you 
    can use GnuCash.  Type directly into the register,
    tab between fields, and use quick-fill to
    automatically complete the transaction.
    The interface is customizable from within the 
    application itself (no editing config files :) )
  - Scheduled Transactions: GnuCash now has the ability to 
    automatically create and enter transactions, remind when
    a transaction is due, give a choice of entering a transaction
    or postponing it and remove an automated transaction after a
    certain period.
  - Mortgage & Loan Repayment Druid: Used to setup a variable
    payment loan scheduled transaction.
  - Small Business Accounting Features: GnuCash now can be used
    for Customer and Vendor tracking, Invoicing and Bill Payment,
    and using different Tax and Billing	Terms in a small business.
  - OFX Import: GnuCash is the first free software application 
    to support the Open Financial Exchange protocol that many 
    banks and financial services are moving to use. The 
    development of OFX and HBCI support has also resulted in
    an improved transaction matching system that more accurately
    picks duplicate transactions.
  - HBCI Support: GnuCash is the first free software application
    to support the German Home Banking Computer Interface protocol
    which includes statement download, initiate bank transfers 
    and direct debits.
  - Quicken File Import: Import Quicken QIF style files.
    QIF files are automatically merged to eliminate 
    duplicate transactions.
  - Reconcile window  with running reconciled 
    and cleared balances makes reconciliation easy.
  - Stock/Mutual Fund Portfolios:  Track stocks
    individually (one per account) or in portfolio
    of accounts (a group of accounts that can be 
    displayed together).  
  - Get Stock & Mutual Fund quotes from various web sites, 
    update portfolio automatically (more funds being added 
    regularly).
  - Reports: Display Balance Sheet, Profit&Loss, Portfolio 
    Valuation, Transaction Reports, or account balance tracking,
    or export them as HTML.  You can write your own custom
    report if you know a little Scheme.  Reports can now be performed
    over an accounting period!
  - Multiple Currencies & Currency Trading: Multiple 
    currencies are supported and can be bought and
    sold (traded).  Currency movements between accounts
    are fully balanced when double-entry is enabled.
  - New Multi-Currency Transaction Handling: GnuCash no longer
    requires separate currency exchange accounts to handle 
    multiple currency transfers.
  - Chart of Accounts: A master account can have a hierarchy
    of detail accounts underneath it.  This allows similar
    account types (e.g. Cash, Bank, Stock) to be grouped 
    into one master account (e.g. Assets).
  - Split Transactions: A single transaction can be split
    into several pieces to record taxes, fees, and
    other compound entries.
  - Double Entry: When enabled, every transaction must 
    debit one account and credit another by an equal amount.
    This ensures that the "books balance": that the 
    difference between income and outflow exactly equals
    the sum of all assets, be they bank, cash, stock or other.
  - Income/Expense Account Types (Categories):  
    These serve not only to categorize your cash flow, 
    but when used properly with the double-entry feature,
    these can provide an accurate Profit&Loss statement.
  - General Ledger: Multiple accounts can be displayed 
    in one register window at the same time.  This can
    ease the trouble of tracking down typing/entry errors.
    It also provides a convenient way of viewing a
    portfolio of many stocks, by showing all transactions
    in that portfolio.
  - Written in C with embedded scheme support via Guile.
  - File access is locked in a network-safe fashion, preventing
    accidental damage if several users attempt to access the 
    same file, even if the file is NFS-mounted.
  - Provides a byte-stream format, which allows accounts and
    account groups to be transmitted to other processes
    via pipes or sockets.
  - International date handling, many different translations.
  - New User Manual and Help: A brand new user help has been 
    written which focuses on how to do tasks in conjunction 
    with a Tutorial and Concepts guide that gives the user 
    background information on using GnuCash.
  - Redesigned Menu's: The GnuCash menu's have been redesigned
    to conform more with the new GNOME Human Interface Guidelines.

Home Page:
http://gnucash.org/

Precompiled binaries:
http://www.gnucash.org/pub/gnucash/

Development versions:
http://www.gnucash.org/en/hacking.phtml

###############################
Upgrading from earlier versions
-------------------------------

There are many changes from the 2.0 series - have a look at the
NEWS file if you want more details. In particular:

- GnuCash now uses SWIG 1.3.28 instead of g-wrap for the
inter-language bindings. g-wrap has been dropped completely in
gnucash 2.2.0. See the "dependencies" section of this file for
more detail.

- The data files are not able to be accessed by 1.6 once the new
features are used and saved, i.e. they are not backwards-compatible! 
So backup your data!

- The help documentation of gnucash has been moved to the separate
package gnucash-docs. If you see error messages like "URL not found"
when clicking on the "Help" menu item, you need to install the
separate package gnucash-docs.

We hope you enjoy all the new features!


############
Dependencies
------------

The following packages are required to be installed to run GnuCash:

[see README.dependencies]

To be able to use certain features of GnuCash, such as reports and
network stock price downloads, you must have the following packages
below installed (in addition to those listed above).

  perl: Almost any version of perl5 should work.  I run perl-5.004 

In addition, some perl modules need to be installed. You can run
the script 'update-finance-quote' as root to obtain the latest
versions of required packages.

To use the new import features (OFX and HBCI) you need to obtain
the following;
  libofx: This library provide support for OFX file imports. 
    GnuCash-2.0.0 and newer needs at least the version libofx-0.7.0
    or newer. Sources can be found at
    http://sourceforge.net/projects/libofx/
  aqbanking: This library provide support for HBCI online actions.
    GnuCash has mostly been tested against the 1.3.0 version, though
    any newer version should also work. Sources can be found at
    http://sourceforge.net/projects/aqbanking . Requires
    gwenhywfar, http://sourceforge.net/projects/gwenhywfar . More
    info in doc/README.HBCI.

#######
Running
-------

For GnuCash invocation details, see the manpage in doc/gnucash.1.
You can also run gnucash --help for the command line options.

You can start GnuCash at the command-line, with "gnucash" or "gnucash
<filename>", where <filename> is a GnuCash account file.  Sample
accounts can be found in "data" subdirectory.  *.xac files are GnuCash
accounts that can opened with the "Open File" menu entry.  *.qif files
are Quicken Import Format files that can be opened with the "Import
QIF" menu entry.

GnuCash responds to the following environment variables:

  GNC_BOOTSTRAP_SCM - the location of the initial bootstrapping scheme code.

  GUILE_LOAD_PATH - an override for the GnuCash load path, used when
  loading scheme files.  It should be a string in the same form as the
  PATH or LD_LIBRARY_PATH environment variable.

  GNC_MODULE_PATH - an override for the GnuCash load path, used when
  loading gnucash modules.  It should be a string representing a
  proper scheme list.  It should be a string in the same form as the
  PATH or LD_LIBRARY_PATH environment variable.

  GNC_DEBUG - enable debugging output.  This allows you to turn on
  debugging earlier in the startup process than you can with --debug.


####################
Internationalization
--------------------
Message catalogues exist for many different languages. These are
enabled with environment variables. For example, 

Francais, en bash:
    export LANG=fr_FR

Francais, en tcsh:
    setenv LANG fr_FR

German version:
    export LANG=de_DE


#####################
Building & Installing
---------------------

(For additional build system details, see doc/README.build-system.)

GnuCash uses GNU Automake to handle the build process, so for most of
the details, see the generic instructions in INSTALL.  (If you are
building directory from SVN, read the README.svn for more instructions.)
Below we detail the GnuCash specific bits.

Prior to building GnuCash, you will have to obtain and install the
following packages:


  libtool: Available at ftp://ftp.gnu.org/gnu.
    RPM's and debs are widely available with most distributions.

  gnome development system: headers, libraries, etc.

  libxml: available from ftp.gnome.org

  SWIG: 1.3.28 or later is needed. See http://www.swig.org or
    http://sourceforge.net/project/showfiles.php?group_id=1645
    (Note: g-wrap has been dropped completely in gnucash 2.2.0 and
    is no longer needed.)

  texinfo: If you are building from SVN, you need the GNU texinfo
           package, version 4.0 or later.

What you'll need to get and install in order to make sure you have all
of these pieces properly installed for your particular operating
system flavor will vary, but here's at least a partial list of what
you'll need for the systems we know about:

  Debian/GNU/Linux: see README.dependencies and 
    current:
      libgnome-dev
      libgtkhtml-dev
      guile1.4
      libguile9-dev
      libguile9-slib


  SuSE:
    see README.dependencies

GnuCash understands a few non-standard ./configure options.  You
should run ./configure --help for the most up to date summary of the
supported options.

If you only want a particular language installed, you can set the
LINGUAS environment variable before you run configure. For example,
to only install the French translations, run

  $ export LINGUAS=fr
  $ ./configure

If you want to make sure that all languages get installed, run

  $ unset LINGUAS
  $ ./configure

Note that while you need the Gnome libraries installed, you don't
need to have a Gnome desktop.  

Runtime and install destinations are separate.  The --prefix you
specify to configure determines where the resulting binary will look
for things at runtime.  Normally this determines where a "make
install" will put all the files.  However, automake also supports the
variable.  DESTDIR is used during the `make install' step to relocate
install objects into a staging area.  Each object and path is prefixed
with the value of `DESTDIR' before being copied into the install area.
Here is an example of typical DESTDIR usage:

     make DESTDIR=/tmp/staging install

   This places install objects in a directory tree built under
`/tmp/staging'.  If `/gnu/bin/foo' and `/gnu/share/aclocal/foo.m4' are
to be installed, the above command would install
`/tmp/staging/gnu/bin/foo' and `/tmp/staging/gnu/share/aclocal/foo.m4'.

DESTDIR can be helpful when trying to build install images and
packages.

NOTE: If you have installed different parts of Gnome in different
places (for instance, if you've installed gtkhtml in /usr/local) you
will need to set the environment variables GNOME_PATH and
GNOME_LIBCONFIG_PATH.  See the manpage for gnome-config for more
details.


###################
Supported Platforms
-------------------

GnuCash 2.0.x is known to work with the following operating systems:

GNU/Linux             -- x86, Sparc, PPC
Solaris		      -- Sparc
FreeBSD               -- x86
OpenBSD               -- x86
MacOS X		      -- PPC

Previous versions have been known to work on the following platforms, but
their current status is unknown:

SGI IRIX              -- MIPS 
IBM AIX 4.1.5         -- RS/6000   http://www-frec.bull.com/
Unixware 7            -- Intel
SCO OpenServer 5.0.4  -- Intel

See http://www.gnucash.org/pub/gnucash (high-bandwidth)
or  http://linas.org/linux/gnucash (slow-www ) 
for precompiled (but *very old*) binaries for these platforms

GnuCash can probably be made to work with most POSIX-ish platforms, 
provided the libraries and toolchain are available.

#########################
Additional Download Sites
-------------------------

You can also download GnuCash from:

  - http://download.sourceforge.net/gnucash

You can download GnuCash Solaris packages from:

  - http://www.unixrealm.com/downloads/

You can get GnuCash Mandrake packages on Mandriva Cooker sites.


Precompiled binaries & pre-requisite packages can be found at the
following sites. The GnuCash versions here are all *extremely*
old, and were indeed from GnuCash's ancestor "x-accountant".

IBM AIX 4.1.5 
      -- SMIT-installable images 
      -- warning, this is from the 1.0 series of xacc
      http://www.bull.de/pub/
      see also http://www-frec.bull.com/
      
SCO OpenServer 5.0.4 
      http://www.sco.com/skunkware/osr5/x11/apps/xacc/VOLS.tar
      -- this is from the 1.0 series of xacc

Unixware 7
      -- use pkgadd to install
      http://www.sco.com/skunkware/uw7/x11/apps/xacc/xacc.pkg.gz

SGI Irix
      -- in SGI install format
      -- warning, this is a very down-level version
      http://linas.org/linux/xacc/xacc-1.0b7-sgi-irix.inst.tar


##############################
Getting Source with Subversion
------------------------------
A read-only version of the svn tree is available on the net at:

  http://svn.gnucash.org/repo/gnucash/

To get what used to be CVS HEAD (and now includes what used to be 
gnucash-gnome2-dev), you will need to get the svn TRUNK:

  svn checkout http://svn.gnucash.org/repo/gnucash/trunk gnucash

The argument "gnucash" above can be whatever you want your local 
directory to be called, and is optional. If you leave it out,
you'll have a directory called "trunk" created containing all the
source code.

If you want the latest 2.0.x code, you'd need to pull from the 
2.0 branch, as follows:

  svn checkout http://svn.gnucash.org/repo/gnucash/branches/2.0 gnucash-2.0


##################
Developing GnuCash
------------------
Before you start developing GnuCash, you should do the following:

1. Read http://wiki.gnucash.org/wiki/Development

2. Several of the directories under src contain files called design.txt
   which explain many aspects of GnuCash's design. Read those.

3. Go to the GnuCash website and skim the archives of the GnuCash
   development mailing list.

4. Join the GnuCash development mailing list. See the GnuCash website
   for details on how to do this.


Submitting a Patch:

  Once you have done some work that you would like to submit, you need
  to send a patch.  There are two ways to submit a patch.  First, if
  you're using SVN and only made changes to existing SVN files you
  can generate the patch using:

      svn diff > /tmp/mypatch

  and send /tmp/mypatch to gnucash-devel@gnucash.org with `[PATCH]'
  prefixed to the Subject: of the email.  Note that this
  ONLY WORKS if you have NOT added any new files to the source tree.

  If your patch adds new files, use the `-N' flag to diff between a
  clean directory and your development directory.  E.g.

  $ diff -urN {gnucash-pristine} {gnucash-mydevel} > /tmp/mypatch

Thank you.