openerp-community team mailing list archive
-
openerp-community team
-
Mailing list archive
-
Message #00957
lp:~openerp-community/openerp-tools/yolanda.robla-openerp-server into lp:openerp-tools
Yolanda Robla has proposed merging lp:~openerp-community/openerp-tools/yolanda.robla-openerp-server into lp:openerp-tools.
Requested reviews:
Antony Lesuisse (OpenERP) (al-openerp)
For more details, see:
https://code.launchpad.net/~openerp-community/openerp-tools/yolanda.robla-openerp-server/+merge/102736
Added changes in paths to follow the Ubuntu recommendations. In the package, code should not be placed into python/dist-packages, because only python files are copied there, but no XML, CSS, etc... This caused that the package needed to copy the files manually to different place using rsync.
The recommendation we give is to modify the package (openerp-core, and openerp-desktop), and modify the OpenERP code to search for modules inside: /usr/share/openerp
--
The attached diff has been truncated due to its size.
https://code.launchpad.net/~openerp-community/openerp-tools/yolanda.robla-openerp-server/+merge/102736
Your team OpenERP Community is subscribed to branch lp:~openerp-community/openerp-tools/yolanda.robla-openerp-server.
=== added file '.bzrignore'
--- .bzrignore 1970-01-01 00:00:00 +0000
+++ .bzrignore 2012-04-19 18:12:21 +0000
@@ -0,0 +1,23 @@
+*.pyc
+.*.swp
+.bzrignore
+openerp/addons/*
+openerp/filestore*
+.Python
+include
+lib
+bin/activate
+bin/activate_this.py
+bin/easy_install
+bin/easy_install-2.6
+bin/pip
+bin/python
+bin/python2.6
+*.pyc
+*.pyo
+build/
+bin/yolk
+bin/pil*.py
+.project
+.pydevproject
+.settings
=== added file 'LICENSE'
--- LICENSE 1970-01-01 00:00:00 +0000
+++ LICENSE 2012-04-19 18:12:21 +0000
@@ -0,0 +1,669 @@
+OpenERP v6.0 is published under the GNU AFFERO GENERAL PUBLIC LICENSE,
+Version 3 (AGPLv3), as included below. Some external libraries and
+contributions bundled with OpenERP may be published under other
+AGPLv3-compatible licenses. For these, please refer to the relevant
+source files and/or license files, in the source code tree.
+
+**************************************************************************
+
+ GNU AFFERO GENERAL PUBLIC LICENSE
+ Version 3, 19 November 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The GNU Affero General Public License is a free, copyleft license for
+software and other kinds of works, specifically designed to ensure
+cooperation with the community in the case of network server software.
+
+ The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works. By contrast,
+our General Public Licenses are intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains free
+software for all its users.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+them if you wish), that you receive source code or can get it if you
+want it, that you can change the software or use pieces of it in new
+free programs, and that you know you can do these things.
+
+ Developers that use our General Public Licenses protect your rights
+with two steps: (1) assert copyright on the software, and (2) offer
+you this License which gives you legal permission to copy, distribute
+and/or modify the software.
+
+ A secondary benefit of defending all users' freedom is that
+improvements made in alternate versions of the program, if they
+receive widespread use, become available for other developers to
+incorporate. Many developers of free software are heartened and
+encouraged by the resulting cooperation. However, in the case of
+software used on network servers, this result may fail to come about.
+The GNU General Public License permits making a modified version and
+letting the public access it on a server without ever releasing its
+source code to the public.
+
+ The GNU Affero General Public License is designed specifically to
+ensure that, in such cases, the modified source code becomes available
+to the community. It requires the operator of a network server to
+provide the source code of the modified version running there to the
+users of that server. Therefore, public use of a modified version, on
+a publicly accessible server, gives the public access to the source
+code of the modified version.
+
+ An older license, called the Affero General Public License and
+published by Affero, was designed to accomplish similar goals. This is
+a different license, not a version of the Affero GPL, but Affero has
+released a new version of the Affero GPL which permits relicensing under
+this license.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ TERMS AND CONDITIONS
+
+ 0. Definitions.
+
+ "This License" refers to version 3 of the GNU Affero General Public License.
+
+ "Copyright" also means copyright-like laws that apply to other kinds of
+works, such as semiconductor masks.
+
+ "The Program" refers to any copyrightable work licensed under this
+License. Each licensee is addressed as "you". "Licensees" and
+"recipients" may be individuals or organizations.
+
+ To "modify" a work means to copy from or adapt all or part of the work
+in a fashion requiring copyright permission, other than the making of an
+exact copy. The resulting work is called a "modified version" of the
+earlier work or a work "based on" the earlier work.
+
+ A "covered work" means either the unmodified Program or a work based
+on the Program.
+
+ To "propagate" a work means to do anything with it that, without
+permission, would make you directly or secondarily liable for
+infringement under applicable copyright law, except executing it on a
+computer or modifying a private copy. Propagation includes copying,
+distribution (with or without modification), making available to the
+public, and in some countries other activities as well.
+
+ To "convey" a work means any kind of propagation that enables other
+parties to make or receive copies. Mere interaction with a user through
+a computer network, with no transfer of a copy, is not conveying.
+
+ An interactive user interface displays "Appropriate Legal Notices"
+to the extent that it includes a convenient and prominently visible
+feature that (1) displays an appropriate copyright notice, and (2)
+tells the user that there is no warranty for the work (except to the
+extent that warranties are provided), that licensees may convey the
+work under this License, and how to view a copy of this License. If
+the interface presents a list of user commands or options, such as a
+menu, a prominent item in the list meets this criterion.
+
+ 1. Source Code.
+
+ The "source code" for a work means the preferred form of the work
+for making modifications to it. "Object code" means any non-source
+form of a work.
+
+ A "Standard Interface" means an interface that either is an official
+standard defined by a recognized standards body, or, in the case of
+interfaces specified for a particular programming language, one that
+is widely used among developers working in that language.
+
+ The "System Libraries" of an executable work include anything, other
+than the work as a whole, that (a) is included in the normal form of
+packaging a Major Component, but which is not part of that Major
+Component, and (b) serves only to enable use of the work with that
+Major Component, or to implement a Standard Interface for which an
+implementation is available to the public in source code form. A
+"Major Component", in this context, means a major essential component
+(kernel, window system, and so on) of the specific operating system
+(if any) on which the executable work runs, or a compiler used to
+produce the work, or an object code interpreter used to run it.
+
+ The "Corresponding Source" for a work in object code form means all
+the source code needed to generate, install, and (for an executable
+work) run the object code and to modify the work, including scripts to
+control those activities. However, it does not include the work's
+System Libraries, or general-purpose tools or generally available free
+programs which are used unmodified in performing those activities but
+which are not part of the work. For example, Corresponding Source
+includes interface definition files associated with source files for
+the work, and the source code for shared libraries and dynamically
+linked subprograms that the work is specifically designed to require,
+such as by intimate data communication or control flow between those
+subprograms and other parts of the work.
+
+ The Corresponding Source need not include anything that users
+can regenerate automatically from other parts of the Corresponding
+Source.
+
+ The Corresponding Source for a work in source code form is that
+same work.
+
+ 2. Basic Permissions.
+
+ All rights granted under this License are granted for the term of
+copyright on the Program, and are irrevocable provided the stated
+conditions are met. This License explicitly affirms your unlimited
+permission to run the unmodified Program. The output from running a
+covered work is covered by this License only if the output, given its
+content, constitutes a covered work. This License acknowledges your
+rights of fair use or other equivalent, as provided by copyright law.
+
+ You may make, run and propagate covered works that you do not
+convey, without conditions so long as your license otherwise remains
+in force. You may convey covered works to others for the sole purpose
+of having them make modifications exclusively for you, or provide you
+with facilities for running those works, provided that you comply with
+the terms of this License in conveying all material for which you do
+not control copyright. Those thus making or running the covered works
+for you must do so exclusively on your behalf, under your direction
+and control, on terms that prohibit them from making any copies of
+your copyrighted material outside their relationship with you.
+
+ Conveying under any other circumstances is permitted solely under
+the conditions stated below. Sublicensing is not allowed; section 10
+makes it unnecessary.
+
+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
+
+ No covered work shall be deemed part of an effective technological
+measure under any applicable law fulfilling obligations under article
+11 of the WIPO copyright treaty adopted on 20 December 1996, or
+similar laws prohibiting or restricting circumvention of such
+measures.
+
+ When you convey a covered work, you waive any legal power to forbid
+circumvention of technological measures to the extent such circumvention
+is effected by exercising rights under this License with respect to
+the covered work, and you disclaim any intention to limit operation or
+modification of the work as a means of enforcing, against the work's
+users, your or third parties' legal rights to forbid circumvention of
+technological measures.
+
+ 4. Conveying Verbatim Copies.
+
+ You may convey verbatim copies of the Program's source code as you
+receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice;
+keep intact all notices stating that this License and any
+non-permissive terms added in accord with section 7 apply to the code;
+keep intact all notices of the absence of any warranty; and give all
+recipients a copy of this License along with the Program.
+
+ You may charge any price or no price for each copy that you convey,
+and you may offer support or warranty protection for a fee.
+
+ 5. Conveying Modified Source Versions.
+
+ You may convey a work based on the Program, or the modifications to
+produce it from the Program, in the form of source code under the
+terms of section 4, provided that you also meet all of these conditions:
+
+ a) The work must carry prominent notices stating that you modified
+ it, and giving a relevant date.
+
+ b) The work must carry prominent notices stating that it is
+ released under this License and any conditions added under section
+ 7. This requirement modifies the requirement in section 4 to
+ "keep intact all notices".
+
+ c) You must license the entire work, as a whole, under this
+ License to anyone who comes into possession of a copy. This
+ License will therefore apply, along with any applicable section 7
+ additional terms, to the whole of the work, and all its parts,
+ regardless of how they are packaged. This License gives no
+ permission to license the work in any other way, but it does not
+ invalidate such permission if you have separately received it.
+
+ d) If the work has interactive user interfaces, each must display
+ Appropriate Legal Notices; however, if the Program has interactive
+ interfaces that do not display Appropriate Legal Notices, your
+ work need not make them do so.
+
+ A compilation of a covered work with other separate and independent
+works, which are not by their nature extensions of the covered work,
+and which are not combined with it such as to form a larger program,
+in or on a volume of a storage or distribution medium, is called an
+"aggregate" if the compilation and its resulting copyright are not
+used to limit the access or legal rights of the compilation's users
+beyond what the individual works permit. Inclusion of a covered work
+in an aggregate does not cause this License to apply to the other
+parts of the aggregate.
+
+ 6. Conveying Non-Source Forms.
+
+ You may convey a covered work in object code form under the terms
+of sections 4 and 5, provided that you also convey the
+machine-readable Corresponding Source under the terms of this License,
+in one of these ways:
+
+ a) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by the
+ Corresponding Source fixed on a durable physical medium
+ customarily used for software interchange.
+
+ b) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by a
+ written offer, valid for at least three years and valid for as
+ long as you offer spare parts or customer support for that product
+ model, to give anyone who possesses the object code either (1) a
+ copy of the Corresponding Source for all the software in the
+ product that is covered by this License, on a durable physical
+ medium customarily used for software interchange, for a price no
+ more than your reasonable cost of physically performing this
+ conveying of source, or (2) access to copy the
+ Corresponding Source from a network server at no charge.
+
+ c) Convey individual copies of the object code with a copy of the
+ written offer to provide the Corresponding Source. This
+ alternative is allowed only occasionally and noncommercially, and
+ only if you received the object code with such an offer, in accord
+ with subsection 6b.
+
+ d) Convey the object code by offering access from a designated
+ place (gratis or for a charge), and offer equivalent access to the
+ Corresponding Source in the same way through the same place at no
+ further charge. You need not require recipients to copy the
+ Corresponding Source along with the object code. If the place to
+ copy the object code is a network server, the Corresponding Source
+ may be on a different server (operated by you or a third party)
+ that supports equivalent copying facilities, provided you maintain
+ clear directions next to the object code saying where to find the
+ Corresponding Source. Regardless of what server hosts the
+ Corresponding Source, you remain obligated to ensure that it is
+ available for as long as needed to satisfy these requirements.
+
+ e) Convey the object code using peer-to-peer transmission, provided
+ you inform other peers where the object code and Corresponding
+ Source of the work are being offered to the general public at no
+ charge under subsection 6d.
+
+ A separable portion of the object code, whose source code is excluded
+from the Corresponding Source as a System Library, need not be
+included in conveying the object code work.
+
+ A "User Product" is either (1) a "consumer product", which means any
+tangible personal property which is normally used for personal, family,
+or household purposes, or (2) anything designed or sold for incorporation
+into a dwelling. In determining whether a product is a consumer product,
+doubtful cases shall be resolved in favor of coverage. For a particular
+product received by a particular user, "normally used" refers to a
+typical or common use of that class of product, regardless of the status
+of the particular user or of the way in which the particular user
+actually uses, or expects or is expected to use, the product. A product
+is a consumer product regardless of whether the product has substantial
+commercial, industrial or non-consumer uses, unless such uses represent
+the only significant mode of use of the product.
+
+ "Installation Information" for a User Product means any methods,
+procedures, authorization keys, or other information required to install
+and execute modified versions of a covered work in that User Product from
+a modified version of its Corresponding Source. The information must
+suffice to ensure that the continued functioning of the modified object
+code is in no case prevented or interfered with solely because
+modification has been made.
+
+ If you convey an object code work under this section in, or with, or
+specifically for use in, a User Product, and the conveying occurs as
+part of a transaction in which the right of possession and use of the
+User Product is transferred to the recipient in perpetuity or for a
+fixed term (regardless of how the transaction is characterized), the
+Corresponding Source conveyed under this section must be accompanied
+by the Installation Information. But this requirement does not apply
+if neither you nor any third party retains the ability to install
+modified object code on the User Product (for example, the work has
+been installed in ROM).
+
+ The requirement to provide Installation Information does not include a
+requirement to continue to provide support service, warranty, or updates
+for a work that has been modified or installed by the recipient, or for
+the User Product in which it has been modified or installed. Access to a
+network may be denied when the modification itself materially and
+adversely affects the operation of the network or violates the rules and
+protocols for communication across the network.
+
+ Corresponding Source conveyed, and Installation Information provided,
+in accord with this section must be in a format that is publicly
+documented (and with an implementation available to the public in
+source code form), and must require no special password or key for
+unpacking, reading or copying.
+
+ 7. Additional Terms.
+
+ "Additional permissions" are terms that supplement the terms of this
+License by making exceptions from one or more of its conditions.
+Additional permissions that are applicable to the entire Program shall
+be treated as though they were included in this License, to the extent
+that they are valid under applicable law. If additional permissions
+apply only to part of the Program, that part may be used separately
+under those permissions, but the entire Program remains governed by
+this License without regard to the additional permissions.
+
+ When you convey a copy of a covered work, you may at your option
+remove any additional permissions from that copy, or from any part of
+it. (Additional permissions may be written to require their own
+removal in certain cases when you modify the work.) You may place
+additional permissions on material, added by you to a covered work,
+for which you have or can give appropriate copyright permission.
+
+ Notwithstanding any other provision of this License, for material you
+add to a covered work, you may (if authorized by the copyright holders of
+that material) supplement the terms of this License with terms:
+
+ a) Disclaiming warranty or limiting liability differently from the
+ terms of sections 15 and 16 of this License; or
+
+ b) Requiring preservation of specified reasonable legal notices or
+ author attributions in that material or in the Appropriate Legal
+ Notices displayed by works containing it; or
+
+ c) Prohibiting misrepresentation of the origin of that material, or
+ requiring that modified versions of such material be marked in
+ reasonable ways as different from the original version; or
+
+ d) Limiting the use for publicity purposes of names of licensors or
+ authors of the material; or
+
+ e) Declining to grant rights under trademark law for use of some
+ trade names, trademarks, or service marks; or
+
+ f) Requiring indemnification of licensors and authors of that
+ material by anyone who conveys the material (or modified versions of
+ it) with contractual assumptions of liability to the recipient, for
+ any liability that these contractual assumptions directly impose on
+ those licensors and authors.
+
+ All other non-permissive additional terms are considered "further
+restrictions" within the meaning of section 10. If the Program as you
+received it, or any part of it, contains a notice stating that it is
+governed by this License along with a term that is a further
+restriction, you may remove that term. If a license document contains
+a further restriction but permits relicensing or conveying under this
+License, you may add to a covered work material governed by the terms
+of that license document, provided that the further restriction does
+not survive such relicensing or conveying.
+
+ If you add terms to a covered work in accord with this section, you
+must place, in the relevant source files, a statement of the
+additional terms that apply to those files, or a notice indicating
+where to find the applicable terms.
+
+ Additional terms, permissive or non-permissive, may be stated in the
+form of a separately written license, or stated as exceptions;
+the above requirements apply either way.
+
+ 8. Termination.
+
+ You may not propagate or modify a covered work except as expressly
+provided under this License. Any attempt otherwise to propagate or
+modify it is void, and will automatically terminate your rights under
+this License (including any patent licenses granted under the third
+paragraph of section 11).
+
+ However, if you cease all violation of this License, then your
+license from a particular copyright holder is reinstated (a)
+provisionally, unless and until the copyright holder explicitly and
+finally terminates your license, and (b) permanently, if the copyright
+holder fails to notify you of the violation by some reasonable means
+prior to 60 days after the cessation.
+
+ Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+
+ Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License. If your rights have been terminated and not permanently
+reinstated, you do not qualify to receive new licenses for the same
+material under section 10.
+
+ 9. Acceptance Not Required for Having Copies.
+
+ You are not required to accept this License in order to receive or
+run a copy of the Program. Ancillary propagation of a covered work
+occurring solely as a consequence of using peer-to-peer transmission
+to receive a copy likewise does not require acceptance. However,
+nothing other than this License grants you permission to propagate or
+modify any covered work. These actions infringe copyright if you do
+not accept this License. Therefore, by modifying or propagating a
+covered work, you indicate your acceptance of this License to do so.
+
+ 10. Automatic Licensing of Downstream Recipients.
+
+ Each time you convey a covered work, the recipient automatically
+receives a license from the original licensors, to run, modify and
+propagate that work, subject to this License. You are not responsible
+for enforcing compliance by third parties with this License.
+
+ An "entity transaction" is a transaction transferring control of an
+organization, or substantially all assets of one, or subdividing an
+organization, or merging organizations. If propagation of a covered
+work results from an entity transaction, each party to that
+transaction who receives a copy of the work also receives whatever
+licenses to the work the party's predecessor in interest had or could
+give under the previous paragraph, plus a right to possession of the
+Corresponding Source of the work from the predecessor in interest, if
+the predecessor has it or can get it with reasonable efforts.
+
+ You may not impose any further restrictions on the exercise of the
+rights granted or affirmed under this License. For example, you may
+not impose a license fee, royalty, or other charge for exercise of
+rights granted under this License, and you may not initiate litigation
+(including a cross-claim or counterclaim in a lawsuit) alleging that
+any patent claim is infringed by making, using, selling, offering for
+sale, or importing the Program or any portion of it.
+
+ 11. Patents.
+
+ A "contributor" is a copyright holder who authorizes use under this
+License of the Program or a work on which the Program is based. The
+work thus licensed is called the contributor's "contributor version".
+
+ A contributor's "essential patent claims" are all patent claims
+owned or controlled by the contributor, whether already acquired or
+hereafter acquired, that would be infringed by some manner, permitted
+by this License, of making, using, or selling its contributor version,
+but do not include claims that would be infringed only as a
+consequence of further modification of the contributor version. For
+purposes of this definition, "control" includes the right to grant
+patent sublicenses in a manner consistent with the requirements of
+this License.
+
+ Each contributor grants you a non-exclusive, worldwide, royalty-free
+patent license under the contributor's essential patent claims, to
+make, use, sell, offer for sale, import and otherwise run, modify and
+propagate the contents of its contributor version.
+
+ In the following three paragraphs, a "patent license" is any express
+agreement or commitment, however denominated, not to enforce a patent
+(such as an express permission to practice a patent or covenant not to
+sue for patent infringement). To "grant" such a patent license to a
+party means to make such an agreement or commitment not to enforce a
+patent against the party.
+
+ If you convey a covered work, knowingly relying on a patent license,
+and the Corresponding Source of the work is not available for anyone
+to copy, free of charge and under the terms of this License, through a
+publicly available network server or other readily accessible means,
+then you must either (1) cause the Corresponding Source to be so
+available, or (2) arrange to deprive yourself of the benefit of the
+patent license for this particular work, or (3) arrange, in a manner
+consistent with the requirements of this License, to extend the patent
+license to downstream recipients. "Knowingly relying" means you have
+actual knowledge that, but for the patent license, your conveying the
+covered work in a country, or your recipient's use of the covered work
+in a country, would infringe one or more identifiable patents in that
+country that you have reason to believe are valid.
+
+ If, pursuant to or in connection with a single transaction or
+arrangement, you convey, or propagate by procuring conveyance of, a
+covered work, and grant a patent license to some of the parties
+receiving the covered work authorizing them to use, propagate, modify
+or convey a specific copy of the covered work, then the patent license
+you grant is automatically extended to all recipients of the covered
+work and works based on it.
+
+ A patent license is "discriminatory" if it does not include within
+the scope of its coverage, prohibits the exercise of, or is
+conditioned on the non-exercise of one or more of the rights that are
+specifically granted under this License. You may not convey a covered
+work if you are a party to an arrangement with a third party that is
+in the business of distributing software, under which you make payment
+to the third party based on the extent of your activity of conveying
+the work, and under which the third party grants, to any of the
+parties who would receive the covered work from you, a discriminatory
+patent license (a) in connection with copies of the covered work
+conveyed by you (or copies made from those copies), or (b) primarily
+for and in connection with specific products or compilations that
+contain the covered work, unless you entered into that arrangement,
+or that patent license was granted, prior to 28 March 2007.
+
+ Nothing in this License shall be construed as excluding or limiting
+any implied license or other defenses to infringement that may
+otherwise be available to you under applicable patent law.
+
+ 12. No Surrender of Others' Freedom.
+
+ If conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot convey a
+covered work so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you may
+not convey it at all. For example, if you agree to terms that obligate you
+to collect a royalty for further conveying from those to whom you convey
+the Program, the only way you could satisfy both those terms and this
+License would be to refrain entirely from conveying the Program.
+
+ 13. Remote Network Interaction; Use with the GNU General Public License.
+
+ Notwithstanding any other provision of this License, if you modify the
+Program, your modified version must prominently offer all users
+interacting with it remotely through a computer network (if your version
+supports such interaction) an opportunity to receive the Corresponding
+Source of your version by providing access to the Corresponding Source
+from a network server at no charge, through some standard or customary
+means of facilitating copying of software. This Corresponding Source
+shall include the Corresponding Source for any work covered by version 3
+of the GNU General Public License that is incorporated pursuant to the
+following paragraph.
+
+ Notwithstanding any other provision of this License, you have
+permission to link or combine any covered work with a work licensed
+under version 3 of the GNU General Public License into a single
+combined work, and to convey the resulting work. The terms of this
+License will continue to apply to the part which is the covered work,
+but the work with which it is combined will remain governed by version
+3 of the GNU General Public License.
+
+ 14. Revised Versions of this License.
+
+ The Free Software Foundation may publish revised and/or new versions of
+the GNU Affero General Public License from time to time. Such new versions
+will be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+ Each version is given a distinguishing version number. If the
+Program specifies that a certain numbered version of the GNU Affero General
+Public License "or any later version" applies to it, you have the
+option of following the terms and conditions either of that numbered
+version or of any later version published by the Free Software
+Foundation. If the Program does not specify a version number of the
+GNU Affero General Public License, you may choose any version ever published
+by the Free Software Foundation.
+
+ If the Program specifies that a proxy can decide which future
+versions of the GNU Affero General Public License can be used, that proxy's
+public statement of acceptance of a version permanently authorizes you
+to choose that version for the Program.
+
+ Later license versions may give you additional or different
+permissions. However, no additional obligations are imposed on any
+author or copyright holder as a result of your choosing to follow a
+later version.
+
+ 15. Disclaimer of Warranty.
+
+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. Limitation of Liability.
+
+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGES.
+
+ 17. Interpretation of Sections 15 and 16.
+
+ If the disclaimer of warranty and limitation of liability provided
+above cannot be given local legal effect according to their terms,
+reviewing courts shall apply local law that most closely approximates
+an absolute waiver of all civil liability in connection with the
+Program, unless a warranty or assumption of liability accompanies a
+copy of the Program in return for a fee.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+state the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+Also add information on how to contact you by electronic and paper mail.
+
+ If your software can interact with users remotely through a computer
+network, you should also make sure that it provides a way for users to
+get its source. For example, if your program is a web application, its
+interface could display a "Source" link that leads users to an archive
+of the code. There are many ways you could offer source, and different
+solutions will be better for different programs; see section 13 for the
+specific requirements.
+
+ You should also get your employer (if you work as a programmer) or school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.
+For more information on this, and how to apply and follow the GNU AGPL, see
+<http://www.gnu.org/licenses/>.
=== added file 'MANIFEST.in'
--- MANIFEST.in 1970-01-01 00:00:00 +0000
+++ MANIFEST.in 2012-04-19 18:12:21 +0000
@@ -0,0 +1,13 @@
+graft debian
+graft doc
+graft install
+graft openerp
+graft tests
+graft win32
+include README
+include LICENSE
+include MANIFEST.in
+include gunicorn.conf.py
+include openerp-server
+include setup*
+global-exclude *pyc *~ # Exclude possible garbage from previous graft.
=== added file 'README'
--- README 1970-01-01 00:00:00 +0000
+++ README 2012-04-19 18:12:21 +0000
@@ -0,0 +1,69 @@
+About OpenERP
+-------------
+
+OpenERP is an OpenSource/Free software Enterprise Resource Planning and
+Customer Relationship Management software. More info at:
+
+ http://www.openerp.com
+
+Installation on Debian Ubuntu
+-----------------------------
+
+Download the deb file and type:
+
+ $ sudo dpkg -i <openerp-deb-filename>
+ $ sudo apt-get install install -f
+
+Installation on Debian Ubuntu from nightly build
+------------------------------------------------
+
+Add the the apt repository
+
+ deb http://nightly.openerp.com/6.1/deb/ ./
+
+in your source.list and type:
+
+ $ sudo apt-get update
+ $ sudo apt-get install openerp
+
+Installation on RedHat, Fedora, CentOS
+--------------------------------------
+
+Install the required dependencies:
+
+ $ yum install python
+ $ easy_install pip
+ $ pip install .....
+
+Install the openerp rpm
+
+ $ rpm -i openerp-VERSION.rpm
+
+Installation on Windows
+-----------------------
+
+Installation on MacOSX
+-----------------------
+
+Setuping you first database
+---------------------------
+
+Point your browser to http://localhost:8069/ and click "Manage Databases", the
+default master password is "admin".
+
+Detailed System Requirements
+----------------------------
+
+You need the following software installed:
+
+ postgresql-client, python-dateutil, python-feedparser, python-gdata,
+ python-ldap, python-libxslt1, python-lxml, python-mako, python-openid,
+ python-psycopg2, python-pybabel, python-pychart, python-pydot,
+ python-pyparsing, python-reportlab, python-simplejson, python-tz,
+ python-vatnumber, python-vobject, python-webdav, python-werkzeug, python-xlwt,
+ python-yaml, python-zsi
+
+For Luxembourg localization, you also need:
+
+ pdftk (http://www.pdflabs.com/tools/pdftk-the-pdf-toolkit/)
+
=== added directory 'bin'
=== added file 'bin/openerp-server.py'
--- bin/openerp-server.py 1970-01-01 00:00:00 +0000
+++ bin/openerp-server.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,19 @@
+#! /usr/bin/env python
+# -*- coding: UTF-8 -*-
+
+import os
+import sys
+
+if __name__ == "__main__":
+ print '-' * 70
+ print "DEPRECATED: you are starting the OpenERP server with its old path,"
+ print "please use the new executable (available in the parent directory)."
+ print '-' * 70
+
+ # Change to the parent directory ...
+ os.chdir(os.path.normpath(os.path.dirname(__file__)))
+ os.chdir('..')
+ # ... and execute the new executable.
+ os.execv('openerp-server', sys.argv)
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added directory 'debian'
=== added file 'debian/changelog'
--- debian/changelog 1970-01-01 00:00:00 +0000
+++ debian/changelog 2012-04-19 18:12:21 +0000
@@ -0,0 +1,539 @@
+openerp (6.1-1) testing; urgency=low
+
+ * New major version, new packaging.
+
+ -- Antony Lesuisse <al@xxxxxxxxxxx> Sat, 01 Oct 2011 12:31:00 +0100
+
+openerp-server (6.0.2-1) testing; urgency=low
+
+ * Using upstream version 6.0.2
+
+ -- Vo Minh Thu <vmt@xxxxxxxxxxx> Tue, 05 Apr 2011 12:31:00 +0100
+
+openerp-server (6.0.1-1) unstable; urgency=low
+
+ * Translations from Rosetta (only zh_CN today)
+ * Require postgres 8.2, not 8.4
+ * Write changelog (recursive, isn't it?)
+ * Repackage, together with addons fixes
+
+ -- P. Christeas <xrg@xxxxxxxxxxx> Mon, 24 Jan 2011 12:50:00 +0100
+
+openerp-server (6.0.1-0) testing; urgency=low
+
+ * Update to version 6.0.1
+
+ -- P. Christeas <xrg@xxxxxxxxxxx> Thu, 20 Jan 2011 21:21:00 +0100
+
+openerp-server (6.0.0-0) testing; urgency=low
+
+ * Update to version 6.0.0
+
+ -- P. Christeas <xrg@xxxxxxxxxxx> Wed, 19 Jan 2011 09:12:00 +0100
+
+openerp-server (6.0.0~rc2-0) experimental; urgency=low
+
+ * Upgrade to 6.0.0-rc2, let it build
+
+ -- P. Christeas <xrg@xxxxxxxxxxx> Mon, 17 Jan 2011 14:18:00 +0100
+
+openerp-server (5.0.14-1) experimental; urgency=low
+
+ * Updating to standards version 3.9.1.
+ * Merging upstream version 5.0.14.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 15 Sep 2010 00:22:00 +0200
+
+openerp-server (5.0.13-1) experimental; urgency=low
+
+ * Merging upstream version 5.0.13.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 13 Sep 2010 09:14:10 +0200
+
+openerp-server (5.0.12-2) unstable; urgency=low
+
+ * Removing debhelper auto install overrides.
+ * Updating clean target in rules.
+ * Reverting to manual setup.py call, updated for version 5.0.12.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 14 Aug 2010 18:53:43 +0200
+
+openerp-server (5.0.12-1) unstable; urgency=low
+
+ * Updating standards version to 3.9.0.
+ * Merging upstream version 5.0.12.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 18 Jul 2010 19:46:39 +0200
+
+openerp-server (5.0.11-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.11.
+ * Adding patch from Timothy E. Harris <maintainer@xxxxxxxxxxxxxxxxxx>
+ to prevents creating a new database if the locale is not a UTF-8 one
+ (Closes: #584976).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 08 Jun 2010 11:42:23 +0200
+
+openerp-server (5.0.10-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.10.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Fri, 07 May 2010 15:02:31 +0200
+
+openerp-server (5.0.9-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.9.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Fri, 16 Apr 2010 06:47:02 +0200
+
+openerp-server (5.0.8-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.8.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 14 Apr 2010 20:19:21 +0200
+
+openerp-server (5.0.7-2) unstable; urgency=low
+
+ * Updating python build-depends.
+ * Adding patch to fix bad whatis entry in openerp-server manpage.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 07 Apr 2010 00:09:23 +0200
+
+openerp-server (5.0.7-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.7 (Closes: #573716):
+ * Updating copyright file.
+ * Resorting the dh call to more common order.
+ * Updating README.source.
+ * Dropping python-lxml patch, went upstream.
+ * Dropping postgresql-8.4.patch, went upstream.
+ * Adding some more python module build-depends to avoid some chicken-
+ egg problem with the new setup.py and quilt.
+ * Adding dependency to remote_fs in init script.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 13 Mar 2010 13:55:50 +0100
+
+openerp-server (5.0.6-4) unstable; urgency=low
+
+ * Adding explicit debian source version 1.0 until switch to 3.0.
+ * Updating year in copyright file.
+ * Updating to standards 3.8.4.
+ * Adding patch from Toni Mueller <support@xxxxxxxx> to fix SQL for
+ postgresql 8.4 (Closes: #568119).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 06 Feb 2010 10:22:05 +0100
+
+openerp-server (5.0.6-3) unstable; urgency=low
+
+ [ Daniel Baumann ]
+ * Setting last-translator for German debconf templates to me, no
+ intention do deal with debian-l10n-german in the future anymore.
+
+ [ Mathias Behrle ]
+ * Removing deprecated option -q for PostgreSQL client commands
+ (Closes: #548875).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 31 Oct 2009 09:20:27 +0100
+
+openerp-server (5.0.6-2) unstable; urgency=low
+
+ * Minimizing rules file.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 18 Oct 2009 21:19:57 +0200
+
+openerp-server (5.0.6-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.6.
+ * Rediffing python-lxml.patch.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 17 Oct 2009 08:32:56 +0200
+
+openerp-server (5.0.5-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.5.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 21 Sep 2009 20:38:00 +0200
+
+openerp-server (5.0.4-1) unstable; urgency=medium
+
+ * Merging upstream version 5.0.4:
+ - fixes a security problem.
+ * No longer calling debconf-updatepo in clean target of rules.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 21 Sep 2009 00:01:13 +0200
+
+openerp-server (5.0.3-0-2) unstable; urgency=low
+
+ * Adding README.source.
+ * Moving maintainer homepage from control to copyright.
+ * Updating README.source.
+ * Adding patch from upstream to use python-lxml instead of python-xml,
+ thanks to Alan Bell <alan.bell@xxxxxxxxxxxxxxxxxxxxxxxxx> (Closes:
+ #543947).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 16 Sep 2009 21:18:30 +0200
+
+openerp-server (5.0.3-0-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.3-0.
+ * Removing xmlrpc.patch, went upstream.
+ * Using dedicated storage directory in /var/lib/openerp-server, that
+ way the addons directory can stay read-only for the unprivileged
+ user.
+ * Commenting out db_name in config (Closes: #542391).
+ * Commenting out port in config (Closes: #542406).
+ * Renaming logfile to openerp-server.log for consistency.
+ * Commenting out pidfile in config (Closes: #542427).
+ * Removing debconf handling in postrm, not possible to do that.
+ * Removing local storage directory on purge.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 24 Aug 2009 20:16:55 +0200
+
+openerp-server (5.0.2-0-3) unstable; urgency=low
+
+ * Wrapping and sorting depends.
+ * Correcting spelling of Open ERP.
+ * Updating maintainer field.
+ * Updating vcs fields.
+ * Updating to standards version 3.8.3.
+ * Dropping old depends on python-xml (Closes: #543127).
+ * Adding maintainer homepage field to control.
+ * Marking maintainer homepage field to be also included in binary
+ packages and changelog.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 24 Aug 2009 18:23:54 +0200
+
+openerp-server (5.0.2-0-2) unstable; urgency=high
+
+ * Adding patch from Panos Christeas <p_christ@xxxxxx> to forbid RPC
+ calls without credentials. All versions of openerp-server affected.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Thu, 13 Aug 2009 14:45:17 +0200
+
+openerp-server (5.0.2-0-1) unstable; urgency=low
+
+ * Updating standards to 3.8.1.
+ * Rediffing autobuild.patch (Closes: #538625).
+ * Upgrading package to standards version 3.8.2.
+ * Managing setup of unprivileged user account with debconf.
+ * Using more common directory name to store local debian additions.
+ * Updating README.Debian to reflect that the database has to be
+ initialized through the client (Closes: #518675).
+ * Removing package leftovers in postrm script.
+ * Merging upstream version 5.0.2-0.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Thu, 13 Aug 2009 11:24:59 +0200
+
+openerp-server (5.0.1-0-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.1-0.
+ * Correcting path of openerp-server in README.Debian (Closes:
+ #520890).
+ * Correcting user handling in init script and config file (Closes:
+ #513263, #516348).
+ * Setting port to 8070.
+ * Also mentioning debug_mode and price_accuracy in config file
+ (Closes: #513264).
+ * Using correct rfc-2822 date formats in changelog.
+ * Rediffing shebang.patch.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 30 May 2009 12:53:39 +0200
+
+openerp-server (5.0.0-3-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.0-3.
+ * Improving init call in README.Debian, thanks to David Goodenough
+ <david.goodenough@xxxxxxxxxxxxx>.
+ * Fixed wrapping in README.Debian.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 14 Feb 2009 00:51:00 +0100
+
+openerp-server (5.0.0-2-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.0-2 (Closes: #514920).
+ * Updating README.Debian.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 14 Feb 2009 00:12:00 +0100
+
+openerp-server (5.0.0-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.0.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 07 Feb 2009 13:33:00 +0100
+
+openerp-server (5.0.0~rc3-1) unstable; urgency=low
+
+ * Adding note about initializing the database in README.Debian.
+ * Adding changelog for debian version 4.2.3.4-3.
+ * Merging upstream version 5.0.0~rc3.
+ * Using quilt rather than dpatch.
+ * Updating year in copyright file.
+ * Updating python-openssl depends.
+ * Updating lintian overrides.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Fri, 09 Jan 2009 18:31:00 -0500
+
+openerp-server (5.0.0~rc2-1) unstable; urgency=low
+
+ * Updating python xml depends (Closes: #508911).
+ * Merging upstream version 5.0.0~rc2.
+ * New upstream no longer uses embedded copies of pydot, pychart and
+ reportlab (Closes: #468104).
+ * Rediffing shebang.dpatch.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Thu, 25 Dec 2008 15:13:00 +0100
+
+openerp-server (5.0.0~rc1.1-2) unstable; urgency=low
+
+ * Adjusting sed call to correct path in /usr/bin/openerp-server.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 17 Dec 2008 08:32:00 +0100
+
+openerp-server (5.0.0~rc1.1-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.0~rc1.1.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 16 Dec 2008 13:08:00 +0100
+
+openerp-server (5.0.0~rc1-1) unstable; urgency=low
+
+ * Merging upstream version 5.0.0~rc1.
+ * Removing openerp.dpatch, went upstream.
+ * Rediffing shebang.dpatch.
+ * Removing workaround for import_xml.rng, not needed anymore.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 16 Dec 2008 12:51:00 +0100
+
+openerp-server (5.0.0~alpha-3) unstable; urgency=low
+
+ * Adding ghostscript, python-matplotlib, and python-pyopenssl to recommends.
+ * Correcting chown calls in postinst.
+ * Prefixing debhelper files with package name.
+ * Adding changelog for debian version 4.2.3.4-2.
+ * Dropping tinyerp-server transitional package, this allows to have both
+ packages available in unstable.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 07 Dec 2008 20:13:00 +0100
+
+openerp-server (5.0.0~alpha-2) experimental; urgency=low
+
+ * Renaming tinyerp-server to new upstream openerp-server name.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 09 Nov 2008 18:59:00 +0100
+
+tinyerp-server (5.0.0~alpha-1) experimental; urgency=low
+
+ * Merging upstream version 5.0.0~alpha.
+ * Rediffing autobuild.dpatch.
+ * Removing shebang.dpatch, not needed anymore.
+ * Removing python2.5.dpatch, not needed anymore.
+ * Rediffing openerp.dpatch.
+ * Rediffing migrate.dpatch.
+ * Not moving server to sbin anymore for the sake of consistency.
+ * Removing unneeded chmod call for tinyerp-server.py.
+ * Sorting build-depends, depends and recommends.
+ * Dropping /etc/default/tinyerp-server in favour of using
+ /etc/tinyerp-server.conf directly.
+ * Updating chmod call in rules to also cope with filenames that embedd
+ whitespaces.
+ * Adding patch to correct shebang in two addon files.
+ * Adding workaround for bug in setup.py that puts import_xml.rng into the
+ wrong location.
+ * Adding symlink for tinyerp_serverrc manpage to tinyerp-server.conf.
+ * Renaming everything except the package name itself from tinyerp-server to
+ openerp-server.
+ * Updating copyright file to current upstream.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 09 Nov 2008 15:52:00 +0100
+
+tinyerp-server (4.2.3.4-3) unstable; urgency=high
+
+ * Updating python depends (Closes: #506615).
+ * Adding note about initializising the database in README.Debian
+ (Closes: #464557).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 10 Nov 2008 12:40:00 +0100
+
+tinyerp-server (4.2.3.4-2) unstable; urgency=low
+
+ * Correcting chown calls in postinst.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 10 Nov 2008 12:40:00 +0100
+
+tinyerp-server (4.2.3.4-1) unstable; urgency=low
+
+ * Merging upstream version 4.2.3.4.
+ * Upgrading package to debhelper 7.
+ * Upgrading package to standards 3.8.0.
+ * Updating homepage field in control file.
+ * Adding vcs fields in control file.
+ * Rewriting copyright file in machine-interpretable format.
+ * Using lintian debhelper to install lintian overrides.
+ * Removing bind-exit.dpatch, went upstream.
+ * Updating default database port.
+ * Adding logfile handling.
+ * Updating postresql recommends.
+ * Reordering and splitting out rules file into individual debhelper files.
+ * Applying some shell cosmetics to init and maintainer scripts.
+ * Adding patch to update homepage location of tinyerp.
+ * Setting ownership of addons directory in postinst (Closes: #487112).
+ * Adding patch from Brian DeRocher <brian@xxxxxxxxxxxx> to fix sql syntax in
+ migrate script (Closes: #467517).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 09 Nov 2008 09:11:00 +0100
+
+tinyerp-server (4.2.2-2) unstable; urgency=medium
+
+ * Readding depends to python-psycopg (Closes: #463079, #493374).
+ * Adding depends to python-tz (Closes: #482359).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sun, 03 Aug 2008 00:20:00 +0200
+
+tinyerp-server (4.2.2-1) unstable; urgency=low
+
+ * New upstream release (Closes: #477698).
+ * Dropping depends against python-xml (Closes: #468619).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 26 Apr 2008 16:15:00 +0200
+
+tinyerp-server (4.2.1-1) unstable; urgency=low
+
+ * Maintainer upload from the Zuerich BSP.
+ * New upstream release.
+ * Bumping to new policy.
+ * Using new homepage field in control.
+ * Including documentation for migration and testing (Closes: #445464).
+ * Adjusting 04-bind-exit.dpatch to new upstream release.
+ * Added lintian overrides.
+ * Depending now on python-psycopg2, not python-psycopg anymore
+ (Closes: #445464).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 12 Jan 2008 15:20:00 +0100
+
+tinyerp-server (4.2.0-1) unstable; urgency=medium
+
+ * New upstream release.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 31 Oct 2007 21:31:00 +0100
+
+tinyerp-server (4.0.3-3) unstable; urgency=medium
+
+ * Setting database port to 5433 (Closes: #443626).
+ * Applied patch from Aldrin Martoq to make tinyerp-server compatible with
+ python 2.5.
+ * Applied patch from Luca Falavigna <dktrkranz@xxxxxxxxxx> to fix exception
+ raised when address is already in use.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Sat, 29 Sep 2007 17:07:00 +0200
+
+tinyerp-server (4.0.3-2) unstable; urgency=low
+
+ * Check for existence of deluser in postrm (Closes: #431532).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 03 Jul 2007 11:01:00 +0200
+
+tinyerp-server (4.0.3-1) unstable; urgency=low
+
+ * New upstream release.
+ * Taking package back, Jean-Marc seems to be MIA.
+ * Changed wording of 'listen to all interfaces' paragraph in README.Debian,
+ thanks to Gerfried Fuchs <alfie@xxxxxxxxxx>.
+ * Added lsb header to init script.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Fri, 01 Jun 2007 11:59:00 +0200
+
+tinyerp-server (4.0.2-3) unstable; urgency=low
+
+ * Setting maintainer to Jean-Marc, this time really :)
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 28 Mar 2007 21:48:00 +0100
+
+tinyerp-server (4.0.2-2) unstable; urgency=low
+
+ * Setting maintainer to Jean-Marc.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Wed, 07 Feb 2007 13:41:00 +0100
+
+tinyerp-server (4.0.2-1) unstable; urgency=low
+
+ * New upstream release.
+ * Some minor cleanups.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Thu, 18 Jan 2007 14:19:00 +0100
+
+tinyerp-server (4.0.1-1) unstable; urgency=low
+
+ * New upstream release.
+ * Removed 03-setup.dpatch, went upstream.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Fri, 29 Dec 2006 01:03:00 +0100
+
+tinyerp-server (4.0.0-1) unstable; urgency=low
+
+ * New upstream release.
+ * Added patch to fix a typo in setup.py.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 05 Dec 2006 17:43:00 +0100
+
+tinyerp-server (4.0.0~rc1-2) unstable; urgency=low
+
+ * Cleaned up build-depends.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 05 Dec 2006 13:19:00 +0100
+
+tinyerp-server (4.0.0~rc1-1) unstable; urgency=low
+
+ * New upstream release.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Tue, 05 Dec 2006 12:57:00 +0100
+
+tinyerp-server (3.5.0-1) experimental; urgency=low
+
+ * New upstream release.
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 23 Oct 2006 12:23:00 +0200
+
+tinyerp-server (3.4.2-1) unstable; urgency=low
+
+ * New upstream release.
+ * New email address.
+ * Complying with new python policy (Closes: #380973).
+ * Adjusted postgre depends (Closes: #376614).
+
+ -- Daniel Baumann <daniel@xxxxxxxxxx> Mon, 16 Oct 2006 14:45:00 +0200
+
+tinyerp-server (3.3.0-1) unstable; urgency=low
+
+ * New upstream release (Closes: #369769):
+ - fixed installation script to install all needed files (Closes: #355224)
+ * Updated README.Debian (Closes: #352322, #360222, #360223).
+ * Set to architecture to all (Closes: #356962).
+
+ -- Daniel Baumann <daniel.baumann@xxxxxxxxxxxxxxxxxxxx> Sun, 04 Jun 2006 00:50:00 +0100
+
+tinyerp-server (3.2.1-1) unstable; urgency=low
+
+ * New upstream release.
+
+ -- Daniel Baumann <daniel.baumann@xxxxxxxxxxxxxxxxxxxx> Thu, 02 Feb 2006 09:44:00 +0100
+
+tinyerp-server (3.2.0-1) unstable; urgency=low
+
+ * New upstream release.
+ * Adjusted shellbang in bin/addons/base/ir/workflow/pydot/dot_parser.py.
+
+ -- Daniel Baumann <daniel.baumann@xxxxxxxxxxxxxxxxxxxx> Tue, 24 Jan 2006 07:00:00 +0100
+
+tinyerp-server (3.1.99+3.2.0rc1-1) unstable; urgency=low
+
+ * New upstream release.
+
+ -- Daniel Baumann <daniel.baumann@xxxxxxxxxxxxxxxxxxxx> Tue, 27 Dec 2005 20:00:00 +0100
+
+tinyerp-server (3.1.1+debian-1) unstable; urgency=low
+
+ * Initial release (Closes: #301510).
+ * Rebuild orig.tar.gz to remove unnecessary files in upstreams debian/.
+ * Added changelog from website.
+
+ -- Daniel Baumann <daniel.baumann@xxxxxxxxxxxxxxxxxxxx> Sun, 16 Oct 2005 13:35:00 +0200
=== added file 'debian/compat'
--- debian/compat 1970-01-01 00:00:00 +0000
+++ debian/compat 2012-04-19 18:12:21 +0000
@@ -0,0 +1,1 @@
+7
=== added file 'debian/control'
--- debian/control 1970-01-01 00:00:00 +0000
+++ debian/control 2012-04-19 18:12:21 +0000
@@ -0,0 +1,52 @@
+Source: openerp
+Section: net
+Priority: optional
+Maintainer: OpenERP SA <al@xxxxxxxxxxx>
+Build-Depends: debhelper (>= 7.0.50~), python, rsync
+Standards-Version: 3.9.1
+Homepage: http://www.openerp.com/
+Vcs-Bzr: https://launchpad.net/openobject
+
+Package: openerp
+Section: net
+Architecture: all
+Depends:
+ ${misc:Depends},
+ adduser,
+ python,
+ postgresql-client,
+ python-dateutil,
+ python-feedparser,
+ python-gdata,
+ python-ldap,
+ python-libxslt1,
+ python-lxml,
+ python-mako,
+ python-openid,
+ python-psycopg2,
+ python-pybabel,
+ python-pychart,
+ python-pydot,
+ python-pyparsing,
+ python-reportlab,
+ python-simplejson,
+ python-tz,
+ python-vatnumber,
+ python-vobject,
+ python-webdav,
+ python-werkzeug,
+ python-xlwt,
+ python-yaml,
+ python-zsi
+Conflicts: tinyerp-server, openerp-server, openerp-web
+Replaces: tinyerp-server, openerp-server, openerp-web
+Recommends:
+ graphviz, ghostscript, postgresql, python-imaging, python-matplotlib
+Description: OpenERP Enterprise Resource Management
+ OpenERP, previously known as TinyERP, is a complete ERP and CRM. The main
+ features are accounting (analytic and financial), stock management, sales and
+ purchases management, tasks automation, marketing campaigns, help desk, POS,
+ etc. Technical features include a distributed server, flexible workflows, an
+ object database, a dynamic GUI, customizable reports, and NET-RPC and XML-RPC
+ interfaces.
+
=== added file 'debian/copyright'
--- debian/copyright 1970-01-01 00:00:00 +0000
+++ debian/copyright 2012-04-19 18:12:21 +0000
@@ -0,0 +1,207 @@
+Upstream-Contact: OpenERP <info@xxxxxxxxxxx>
+Upstream-Homepage: http://www.openerp.com/
+Maintainer-Contact: Debian OpenERP Maintainers <gnunet@xxxxxxxxxxxxxxxxxxxxxxxxxxxx>
+Maintainer-Homepage: http://open-object.debian-maintainers.org/
+
+Files: *
+Copyright: (C) 2004-2011 OpenERP SA. (www.openerp.com)
+License: GPL-3+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+ .
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+ .
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+ .
+ On Debian systems, the complete text of the GNU General Public License
+ can be found in /usr/share/common-licenses/GPL-3 file.
+
+Files:
+ bin/addons/account/report/general_ledger.py
+ bin/addons/account/report/general_ledger_landscape.py
+ bin/addons/account/wizard/wizard_statement_from_invoice.py
+Copyright: (C) 2005-2008 CamptoCamp
+License: GPL-2+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation; either version 2
+ of the License, or (at your option) any later version.
+ .
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+ .
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ .
+ On Debian systems, the complete text of the GNU General Public License
+ can be found in /usr/share/common-licenses/GPL-2 file.
+
+Files: bin/addons/auction/barcode/*
+Copyright: (C) 2000 Tyler C. Sarna <tsarna@xxxxxxxxx>
+License: BSD
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions
+ are met:
+ .
+ 1. Redistributions of source code must retain the above copyright
+ notice, this list of conditions and the following disclaimer.
+ 2. Redistributions in binary form must reproduce the above copyright
+ notice, this list of conditions and the following disclaimer in the
+ documentation and/or other materials provided with the distribution.
+ 3. All advertising materials mentioning features or use of this software
+ must display the following acknowledgement:
+ This product includes software developed by Tyler C. Sarna.
+ 4. Neither the name of the author nor the names of contributors
+ may be used to endorse or promote products derived from this software
+ without specific prior written permission.
+ .
+ THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS
+ BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ POSSIBILITY OF SUCH DAMAGE.
+
+Files:
+ bin/addons/base_report_designer/wizard/tiny_sxw2rml/normalized_oo2rml.xsl
+ bin/addons/base_report_designer/wizard/tiny_sxw2rml/tiny_sxw2rml.py
+Copyright: (C) 2005 Martin Simon
+License: LGPL-2.1
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+ .
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Library General Public License for more details.
+ .
+ You should have received a copy of the GNU Library General Public
+ License along with this library; if not, write to the Free
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ .
+ On Debian systems, the complete text of the GNU Library General Public License
+ can be found in /usr/share/common-licenses/LGPL-2.1 file.
+
+Files: bin/addons/document/ftpserver/*
+Copyright:
+ (C) 2007 Giampaolo Rodola <g.rodola@xxxxxxxxx>
+ (C) 2008 Fabien Pinckaers <fp@xxxxxxxxxxx>
+License: MIT
+ Permission to use, copy, modify, and distribute this software and
+ its documentation for any purpose and without fee is hereby
+ granted, provided that the above copyright notice appear in all
+ copies and that both that copyright notice and this permission
+ notice appear in supporting documentation, and that the name of
+ Giampaolo Rodola' not be used in advertising or publicity pertaining to
+ distribution of the software without specific, written prior
+ permission.
+ .
+ Giampaolo Rodola' DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
+ INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN
+ NO EVENT Giampaolo Rodola' BE LIABLE FOR ANY SPECIAL, INDIRECT OR
+ CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
+ OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
+ NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
+ CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+
+Files: bin/addons/hr_holidays/*
+Copyright:
+ (C) 2004-2008 Tiny.be <info@xxxxxxx>
+ (C) 2005-2006 Axelor SARL. <http://www.axelor.com/>
+License: GPL-2+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation; either version 2
+ of the License, or (at your option) any later version.
+ .
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+ .
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ .
+ On Debian systems, the complete text of the GNU General Public License
+ can be found in /usr/share/common-licenses/GPL-2 file.
+
+Files: bin/addons/l10n_uk/*
+Copyright:
+ (C) 2004-2008 Tiny.be <info@xxxxxxx>
+ (C) 2004-2008 Seath Solutions Ltd.
+License: GPL-2+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation; either version 2
+ of the License, or (at your option) any later version.
+ .
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+ .
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ .
+ On Debian systems, the complete text of the GNU General Public License
+ can be found in /usr/share/common-licenses/GPL-2 file.
+
+Files: bin/tools/threadinglocal.py
+Copyright: (C) 2004-2005 CherryPy Team <team@xxxxxxxxxxxx>
+License: BSD
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions are met:
+ .
+ * Redistributions of source code must retain the above copyright notice,
+ this list of conditions and the following disclaimer.
+ * Redistributions in binary form must reproduce the above copyright notice,
+ this list of conditions and the following disclaimer in the documentation
+ and/or other materials provided with the distribution.
+ * Neither the name of the CherryPy Team nor the names of its contributors
+ may be used to endorse or promote products derived from this software
+ without specific prior written permission.
+ .
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+ ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
+ FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+Files: bin/tools/decimal.py
+Copyright: (C) 2004 Python Software Foundation.
+License: other
+ This file is distributed under the Python Software License
+ (http://www.python.org/2.3/license.html).
+ .
+ Permission to use, copy, modify, and distribute this software and its
+ documentation for any purpose and without fee is hereby granted,
+ provided that the above copyright notice appear in all copies and that
+ both that copyright notice and this permission notice appear in
+ supporting documentation, and that the name of Stichting Mathematisch
+ Centrum or CWI not be used in advertising or publicity pertaining to
+ distribution of the software without specific, written prior
+ permission.
+
=== added file 'debian/openerp.init'
--- debian/openerp.init 1970-01-01 00:00:00 +0000
+++ debian/openerp.init 2012-04-19 18:12:21 +0000
@@ -0,0 +1,71 @@
+#!/bin/sh
+
+### BEGIN INIT INFO
+# Provides: openerp-server
+# Required-Start: $remote_fs $syslog
+# Required-Stop: $remote_fs $syslog
+# Should-Start: $network
+# Should-Stop: $network
+# Default-Start: 2 3 4 5
+# Default-Stop: 0 1 6
+# Short-Description: Enterprise Resource Management software
+# Description: Open ERP is a complete ERP and CRM software.
+### END INIT INFO
+
+PATH=/sbin:/bin:/usr/sbin:/usr/bin
+DAEMON=/usr/bin/openerp-server
+NAME=openerp-server
+DESC=openerp-server
+CONFIG=/etc/openerp/openerp-server.conf
+LOGFILE=/var/log/openerp-server.log
+USER=openerp
+
+test -x ${DAEMON} || exit 0
+
+set -e
+
+case "${1}" in
+ start)
+ echo -n "Starting ${DESC}: "
+
+ start-stop-daemon --start --quiet --pidfile /var/run/${NAME}.pid \
+ --chuid ${USER} --background --make-pidfile \
+ --exec ${DAEMON} -- --config=${CONFIG} \
+ --logfile=${LOGFILE}
+
+ echo "${NAME}."
+ ;;
+
+ stop)
+ echo -n "Stopping ${DESC}: "
+
+ start-stop-daemon --stop --quiet --pidfile /var/run/${NAME}.pid \
+ --oknodo
+
+ echo "${NAME}."
+ ;;
+
+ restart|force-reload)
+ echo -n "Restarting ${DESC}: "
+
+ start-stop-daemon --stop --quiet --pidfile /var/run/${NAME}.pid \
+ --oknodo
+
+ sleep 1
+
+ start-stop-daemon --start --quiet --pidfile /var/run/${NAME}.pid \
+ --chuid ${USER} --background --make-pidfile \
+ --exec ${DAEMON} -- --config=${CONFIG} \
+ --logfile=${LOGFILE}
+
+ echo "${NAME}."
+ ;;
+
+ *)
+ N=/etc/init.d/${NAME}
+ echo "Usage: ${NAME} {start|stop|restart|force-reload}" >&2
+ exit 1
+ ;;
+esac
+
+exit 0
=== added file 'debian/openerp.install'
--- debian/openerp.install 1970-01-01 00:00:00 +0000
+++ debian/openerp.install 2012-04-19 18:12:21 +0000
@@ -0,0 +1,2 @@
+install/openerp-server.conf /etc/openerp
+README /usr/share/doc/openerp
=== added file 'debian/openerp.postinst'
--- debian/openerp.postinst 1970-01-01 00:00:00 +0000
+++ debian/openerp.postinst 2012-04-19 18:12:21 +0000
@@ -0,0 +1,30 @@
+#!/bin/sh
+
+set -e
+
+case "${1}" in
+ configure)
+ if ! getent passwd | grep -q "^openerp:"; then
+ adduser --system --no-create-home --quiet --gecos 'OpenERP' --group openerp
+ fi
+ # Register "openerp" as a postgres superuser
+ su - postgres -c "createuser -s openerp" 2> /dev/null || true
+ chown openerp:openerp /etc/openerp/openerp-server.conf
+ chmod 0640 /etc/openerp/openerp-server.conf
+ # Creating log file
+ touch /var/log/openerp-server.log
+ chown openerp:openerp /var/log/openerp-server.log
+ chmod 0640 /var/log/openerp-server.log
+ # Creating local storage directory
+ mkdir -p /var/lib/openerp/filestore
+ chown openerp:openerp -R /var/lib/openerp
+ # update-python-modules NOW otherwise invoke-rc.d openerp start will fail
+ update-python-modules -p openerp.public
+ ;;
+ *)
+ ;;
+esac
+
+#DEBHELPER#
+
+exit 0
=== added file 'debian/openerp.postrm'
--- debian/openerp.postrm 1970-01-01 00:00:00 +0000
+++ debian/openerp.postrm 2012-04-19 18:12:21 +0000
@@ -0,0 +1,22 @@
+#!/bin/sh
+
+set -e
+
+case "${1}" in
+ remove)
+ deluser --quiet --system "openerp" || true
+ delgroup --quiet --system --only-if-empty "openerp" || true
+ ;;
+
+ purge)
+ rm -rf /var/lib/openerp-server
+ ;;
+
+ upgrade|failed-upgrade|abort-install|abort-upgrade|disappear)
+ ;;
+
+esac
+
+#DEBHELPER#
+
+exit 0
=== added file 'debian/rules'
--- debian/rules 1970-01-01 00:00:00 +0000
+++ debian/rules 2012-04-19 18:12:21 +0000
@@ -0,0 +1,17 @@
+#!/usr/bin/make -f
+# vim:noet:
+
+%:
+ dh ${@}
+
+override_dh_pysupport:
+ echo "rsync"
+ sh -c "[ -d debian/openerp/usr/lib/python2.6 ] && rsync -av openerp/ debian/openerp/usr/lib/python2.6/dist-packages/openerp/" || true
+ sh -c "[ -d debian/openerp/usr/lib/python2.7 ] && rsync -av openerp/ debian/openerp/usr/lib/python2.7/dist-packages/openerp/" || true
+ rm -Rf debian/openerp/usr/openerp debian/openerp/usr/lib/python2.6/dist-packages/tests debian/openerp/usr/lib/python2.7/dist-packages/tests
+ dh_pysupport
+ rm -Rf debian/openerp/usr/lib
+
+override_dh_installinit:
+ dh_installinit --update-rcd-params='defaults 21'
+
=== added file 'gunicorn.conf.py'
--- gunicorn.conf.py 1970-01-01 00:00:00 +0000
+++ gunicorn.conf.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,62 @@
+# Gunicorn sample configuration file.
+# See http://gunicorn.org/configure.html for more details.
+#
+# To run the OpenERP server via Gunicorn, change the appropriate
+# settings below, in order to provide the parameters that
+# would normally be passed in the command-line,
+# (at least `bind` and `conf['addons_path']`), then execute:
+# $ gunicorn openerp:wsgi.core.application -c gunicorn.conf.py
+# or if you want to run it behind a reverse proxy, add the line
+# import openerp.wsgi.proxied
+# in this file and execute:
+# $ gunicorn openerp:wsgi.proxied.application -c gunicorn.conf.py
+
+import openerp
+
+# Standard OpenERP XML-RPC port is 8069
+bind = '127.0.0.1:8069'
+
+pidfile = '.gunicorn.pid'
+
+# Gunicorn recommends 2-4 x number_of_cpu_cores, but
+# you'll want to vary this a bit to find the best for your
+# particular work load.
+workers = 4
+
+# Some application-wide initialization is needed.
+on_starting = openerp.wsgi.core.on_starting
+pre_request = openerp.wsgi.core.pre_request
+post_request = openerp.wsgi.core.post_request
+
+# openerp request-response cycle can be quite long for
+# big reports for example
+timeout = 240
+
+max_requests = 2000
+
+# Equivalent of --load command-line option
+openerp.conf.server_wide_modules = ['web']
+
+# internal TODO: use openerp.conf.xxx when available
+conf = openerp.tools.config
+
+# Path to the OpenERP Addons repository (comma-separated for
+# multiple locations)
+conf['addons_path'] = '/home/openerp/addons/trunk,/home/openerp/web/trunk/addons'
+
+# Optional database config if not using local socket
+#conf['db_name'] = 'mycompany'
+#conf['db_host'] = 'localhost'
+#conf['db_user'] = 'foo'
+#conf['db_port'] = 5432
+#conf['db_password'] = 'secret'
+
+# OpenERP Log Level
+# DEBUG=10, DEBUG_RPC=8, DEBUG_RPC_ANSWER=6, DEBUG_SQL=5, INFO=20,
+# WARNING=30, ERROR=40, CRITICAL=50
+# conf['log_level'] = 20
+
+# If --static-http-enable is used, path for the static web directory
+#conf['static_http_document_root'] = '/var/www'
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added directory 'history'
=== added file 'history/Changelog'
--- history/Changelog 1970-01-01 00:00:00 +0000
+++ history/Changelog 2012-04-19 18:12:21 +0000
@@ -0,0 +1,1822 @@
+2010-05-05: 5.0.10
+==================
+
+Bugfixes (server)
+-----------------
+
+ * Not linked to a bug report:
+ * Server Actions: Cleaner legend help and error message
+ * use of tail text in preprocessor of report engine
+ * added support for missing Persian/Farsi (official language in Iran), with backport of the translations from trunk for base module
+ * https://launchpad.net/bugs/534769
+ * https://launchpad.net/bugs/452854
+ * res_currency: revert to correct rounding mechanism
+ * https://launchpad.net/bugs/540840
+ * Groups if removed, should remove relavent access rights too
+ * https://launchpad.net/bugs/558460
+ * Add the pixmaps and win32 directories in the MANIFEST to have
+ * https://launchpad.net/bugs/559346
+ * Copy() of ir_model_fields corected
+ * https://launchpad.net/bugs/541545
+ * https://launchpad.net/bugs/574394
+ * Workflow : print of workflow should not be broken if there is no flow_stop
+ * https://launchpad.net/bugs/552386
+ * _store_function dictionary should get updated when field changes its type from function to any other storable
+ * https://launchpad.net/bugs/535559
+ * Illustration tag beahvior corrected
+ * https://launchpad.net/bugs/552457
+ * Raise a detailed exception if the record does not exist in the ir_model_data object
+ * https://launchpad.net/bugs/513278
+ * res_currency: revert to correct rounding mechanism
+ * https://launchpad.net/bugs/564926
+ * _constraints : Multiple constraints on the same field should be allowed
+
+
+Improvements (server)
+---------------------
+
+ * setup.cfg: Improve the setup of the server
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * Remove the bad translation files
+ * Rename the oc_OC translation files to oc_FR
+ * l10n_be: intracom declaration compliancy with Intervat 5.1.0
+ * l10n_be: compliancy of belgian vat declaration with Intervat 5.1.0 (from 05 feb 2010)
+ * account: fixed the onchange partner of bank_statement
+ * audittrail: context={} -> context=None in method signature
+ * audittrail: indentation problems
+ * audittrail: wrong class passed to super
+ * https://launchpad.net/bugs/515590
+ * https://launchpad.net/bugs/552455
+ * Account_analytic_default : Invoice creation from SO corected
+ * https://launchpad.net/bugs/546004
+ * Account : Overdue report corrected
+ * https://launchpad.net/bugs/552519
+ * account_invoice_layout : Added translation entries
+ * https://launchpad.net/bugs/571978
+ * https://launchpad.net/bugs/553881
+ * Account : Added a link to view unreconciled receivables/payables from Invoices
+ * https://launchpad.net/bugs/566185
+ * Remove the unused translation files
+ * https://launchpad.net/bugs/559478
+ * only Grouped field should appear in groupby clause, graph orientation corrected
+ * https://launchpad.net/bugs/570652
+ * Locations when M2O,should not be among view type
+ * https://launchpad.net/bugs/519133
+ * Account : Added centralization check on write() of move line
+ * https://launchpad.net/bugs/532728
+ * sale: UoS qty visible for everyone
+ * https://launchpad.net/bugs/559347
+ * Purchase : Product_uom_change should respect fiscal position related to product_id_change
+ * https://launchpad.net/bugs/570132
+ * Account : code improved for move line creation
+ * https://launchpad.net/bugs/551522
+ * Account : Manual reconcilation should work with the option of Skip Draft Entries of Journal
+ * https://launchpad.net/bugs/539408
+ * Audittrail : Correction made to avoid crash on configuration wizard
+ * https://launchpad.net/bugs/564530
+ * Account : Copying bank statement should not copy move lines
+ * https://launchpad.net/bugs/568537
+ * Account : __compute() optimized a little
+ * https://launchpad.net/bugs/461801
+ * https://launchpad.net/bugs/568436
+ * Purchase : Merge PO should consider fiscal position
+ * https://launchpad.net/bugs/552447
+ * Account : Tax :If type=code,python_compute has to be mandatory;if applicable_type=python_code,python_appliacble has to be mandatory
+ * https://launchpad.net/bugs/561318
+ * Account/Document_ICS/MRP_Operations : datetime.datetime.strptime() replaced by mx.DateTime.strptime()
+ * https://launchpad.net/bugs/559055
+ * account_payment: Remove the duplicated 'bank_id' field in the payment.line tree view
+ * https://launchpad.net/bugs/564779
+ * Mrp_repair : Corrected make invoice process and Quotation report
+ * https://launchpad.net/bugs/557501
+ * Account_Voucher : Correction in creating account.move from voucher
+ * https://launchpad.net/bugs/519034
+ * Sale : progressbar for picking should be set when SO is picked 100%(including its procurement is done)
+ * https://launchpad.net/bugs/569036
+ * mrp_subproduct : Corrected action_confirm method
+ * https://launchpad.net/bugs/562803
+ * Membership : Copy() overridden for setting membership lines blank
+ * https://launchpad.net/bugs/552503
+ * Account : Raising an exception when journal_id is missing
+ * https://launchpad.net/bugs/564486
+ * Base_report_creator : Export method corrected
+ * https://launchpad.net/bugs/532073
+ * https://launchpad.net/bugs/489239
+ * mrp_operations : starting production order should start work order too.
+ * https://launchpad.net/bugs/557373
+ * https://launchpad.net/bugs/515507
+ * Support for ftp_server_host for setting the FTP interface for DMS server,
+ * https://launchpad.net/bugs/535109
+ * Account:
+ * https://launchpad.net/bugs/399817
+ * https://launchpad.net/bugs/452854
+ * account: finish fix of generation of account.move.lines from invoice by providing extension hook
+ * account: corrected move balance check - rounding correctly based on price_accuracy
+ * https://launchpad.net/bugs/570561
+ * Account_payment : Import of move line should include the date of search due date
+ * https://launchpad.net/bugs/567987
+ * Account_analytic_default : Invoice creation from SO corected
+ * https://launchpad.net/bugs/563713
+ * account_analytic_plans : Minor correction on a method to unlink entries
+ * https://launchpad.net/bugs/513278
+ * account: corrected move balance check - rounding correctly based on price_accuracy
+ * https://launchpad.net/bugs/551570
+ * Account_payment : Date will be asked to user while importing payment order into bank statement
+ * https://launchpad.net/bugs/550742
+ * Account : Refund invoice wizard should have current_date as default
+
+
+Improvements (addons)
+---------------------
+
+ * Add the new version of Swiss Localization:
+ * sale: unit tests for bug #461801
+ * sale: warning instead of error in some unit tests
+ * sale: demo tax account type
+ * account: test case for bug #452854
+ * account: renamed test
+ * sale: minor test changes
+ * Account_followup : Domain improved for an act_window from Partner
+
+
+2010-04-06: 5.0.9
+=================
+
+Bugfixes (server)
+-----------------
+
+ * https://launchpad.net/bugs/556634
+ * By pass a missing field in the translation
+
+
+2010-04-02: 5.0.8
+=================
+
+Bugfixes (server)
+-----------------
+
+ * Not linked to a bug report:
+ * res_lang : if value of thousands_sep is not present in language,method will give error- 'moentary' name is not defined [IMP] clear cache of language on write,to be sure to get right value if value of language is changed before cache timeout
+ * bin/tools/convert.py: no need to import time since the eval(domain) is probably going to be removed or wrapped in an exception handler
+ * sql_db: avoid deadlock when releasing leaked cursors
+ * bin/tools/convert.py: reverted revision 2017.1.1: could not eval some strings. Need a dict with uid, active_id, active_ids, ...
+ * bin/tools/convert.py: missing time module
+ * i18n: fr_FR: missing information
+ * In the case we want to generate the RPM package, we change the version
+ * DONT pformat() each RPC request !
+ * reporting: change the way that para style are computed
+ * add cache to res.lang format() function
+ * fixed a bug in copy_data: it now copies the original (not translated) field value as the source value
+ * disabled "code" server action due to the security threat it poses, added --enable-code-actions command-line flag to enable it
+ * only admin can delete ir.property
+ * when deleting ir.property, do not delete the linked field
+ * correct import rng file
+ * 'Partner Manager' group should see the Partner menu
+ * removed python-xml from list of debian packages in doc/INSTALL
+ * remove ubuntu-related pyxml/python-xml hacks from openerp-server.py as pyxml shouldn't be used anywhere anymore
+ * Remove python-xml reference in setup.py
+ * https://launchpad.net/bugs/495948
+ * Corrected language code for Slovenian and Danish locales. Renamed corresponding PO files.
+ * https://launchpad.net/bugs/531430
+ * Remove the default values on the --no-netrpc and --no-xmlrpc
+ * https://launchpad.net/bugs/538399
+ * netrpc: Close the socket if there is a raised exception
+ * https://launchpad.net/bugs/532365
+ * Document : It should be allowed to browse through FTP,disregard to --no-databse-list option
+ * https://launchpad.net/bugs/531026
+ * Exploit Broken : Search should have checked access rights of read
+ * https://launchpad.net/bugs/513290
+ * Export should honor the current locale(language) settings of the user.
+ * https://launchpad.net/bugs/535551
+ * Uninstalling a board_* module removes dashboard action, but user shuold be allowed to login with default action
+ * https://launchpad.net/bugs/514273
+ * Remove the libxml2 and libxslt dependencies for the packaging
+ * https://launchpad.net/bugs/314973
+ * do not keep connections to template1, template0 and postgres in the connection pool
+ * https://launchpad.net/bugs/544087
+ * Behaviour of fields.related corrected for copy() and write() calls
+ * https://launchpad.net/bugs/551664
+ * Evaluate domain in act_window element is now possible
+ * https://launchpad.net/bugs/528624
+ * Import : Any exception should be raised in well-manner
+ * https://launchpad.net/bugs/543521
+ * Export : Correction made when selection field value if False.
+ * https://launchpad.net/bugs/516568
+ * retro-compatibility: 'obj' is available in ir.action.server code
+ * https://launchpad.net/bugs/380955
+ * setup.py: add the missing librairies for the windows packaging
+ * https://launchpad.net/bugs/497364
+ * base: respect the limit and offset arguments of the search method
+
+
+Improvements (server)
+---------------------
+
+ * sql_db: improve logging
+ * The act_window does not show groups.This adds groups and rearranges the view with a notebook to ensure that the addition of this m2m field doesnt introduce a scroll
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * base_contact: res.partner.job: when partner is set, the address is required. Add onchange on partner and on address.
+ * membership: bugfix + improved inheritance of membership_state field.function
+ * Base_contact : search() of job improved
+ * account_payment: added journal_id field in account.move.line.tree view
+ * Sale : Fiscal position from SO for invoice should be priorly taken from SO rather than Partner's properties
+ * Delivery : Better functional computation of weight based on move
+ * sale: move the product_uos_qty and product_uos fields to the
+ * event: made wizard of invoice creating more flexible (use onchange) + code refactoring
+ * audittrail: Check if the object exists or Not and raise an exception if it's not the case'
+ * hr_timesheet_sheet: Add a default value for the context keyword
+ * Improved mrp_jit smoke test in case the sale config wizard was run before installing mrp_jit. There is a side-effect but it's only on demo databases, and we'll fix this test in trunk when we can write better tests.
+ * account: product_id onchange on invoice lines were returning {} when no product_id was given. This was causing problems in other modules (account_analytic_default, account_analytic_plans) that inherited because of a key error 'value'. It now returns {'value':{}}.
+ * l10n_be: adaptation du module de localisation belge conformément à la nouvelle législation TVA pour les services intracom
+ * event: invoice creation from registrations
+ * purchase: security file update: added rights for manager. Fixed rights for user
+ * https://launchpad.net/bugs/524521
+ * Account : USer will be notified for unreconciling partial reconcilatins if he tries to cancel the invoice
+ * https://launchpad.net/bugs/540128
+ * https://launchpad.net/bugs/535098
+ * Account : Only those accounts are eligible to be Parents which have type=View
+ * https://launchpad.net/bugs/552455
+ * Sale : Make Invoice wizard should only create invoice for uninvoiced lines
+ * https://launchpad.net/bugs/528889
+ * Account : name_search() of account.tax.code overridden for better search
+ * https://launchpad.net/bugs/519220
+ * Delivery : Proper Weight calculation of stock picking
+ * https://launchpad.net/bugs/535058
+ * Purchase : Seperate packign should not be created if chained locations are used
+ * https://launchpad.net/bugs/545032
+ * Stock : Invoice from Stock should respect context for translations.
+ * stock: context lost in invoice wizard
+ * https://launchpad.net/bugs/530081
+ * Sale : Sale order's Invoice should have invoice reference of customer Invoice
+ * https://launchpad.net/bugs/545868
+ * Sale_crm : proper options set on wizard makesale
+ * https://launchpad.net/bugs/467880
+ * MRP : stock.warehouse.orderpoint for qty_multiple check of 0
+ * https://launchpad.net/bugs/544287
+ * Invoice object's Partner onchange had wrong parameter
+ * https://launchpad.net/bugs/535655
+ * Base_setup : Better display of Currency selection(Name + Code)
+ * https://launchpad.net/bugs/532728
+ * sale: Remove the product.group_uos group on the product_uos and product_uos_qty fields.
+ * https://launchpad.net/bugs/540443
+ * Sale : Fiscal position value has to be passed when Invoice is created from SO
+ * https://launchpad.net/bugs/532673
+ * delivery: replace 'id' with active_id in passing context of order(takes built in function id in webclient).
+ * https://launchpad.net/bugs/528871
+ * Account : Dupliacting tax code should not copy move lines
+ * https://launchpad.net/bugs/539707
+ * https://launchpad.net/bugs/514273
+ * Base_report_designer : Replaced libxslt/libxsml2 code by lxml
+ * https://launchpad.net/bugs/540946
+ * Hr_holidays : Constraint corrected for Holidays request(start date cannot be greater than end date)
+ * https://launchpad.net/bugs/548494
+ * Account : Account should not be removed/deactivated if it is linked to any property/partner
+ * https://launchpad.net/bugs/418080
+ * Document : Browse__files_using_ftp wizard corrected
+ * https://launchpad.net/bugs/541006
+ * MRP/Purchase : Seller delay has to be converted into integer for date calculations.
+ * https://launchpad.net/bugs/528978
+ * https://launchpad.net/bugs/528929
+ * Account : Tax code tree view should have company.
+ * https://launchpad.net/bugs/552461
+ * Scrum : Burndown chart was crashing when a taskwork entry is without date
+ * https://launchpad.net/bugs/553168
+ * Account : Journal's name_search() did not use context well
+ * https://launchpad.net/bugs/494352
+ * Sale : account_invoice_end() corrected/optimized so that it does not create any regression of duplicated pickings for SO
+ * https://launchpad.net/bugs/531238
+ * improved regression tests in sale and mrp_jit modules to test separately auto-chained locations. (bug 531238)
+ * mrp: use correct location chaining by calling action_confirm() on stock move instead of directly writing the status (bug 531238).
+ * https://launchpad.net/bugs/540151
+ * Event : Notify user before sending an email on confirming event
+ * https://launchpad.net/bugs/542379
+ * Account : Terp file had duplicated author,depends keys
+ * https://launchpad.net/bugs/539073
+ * account_date_check: If the date of the move line, is not in the
+ * https://launchpad.net/bugs/532073
+ * https://launchpad.net/bugs/526081
+ * MRP : Ondelete=cascade applied to important fields of stock.warehouse.orderpoint
+ * https://launchpad.net/bugs/535642
+ * Stock : Unlink() of Move corrected
+ * Stock :Picking removal should remove moves too
+ * https://launchpad.net/bugs/506431
+ * Use the file name instead of the content
+ * https://launchpad.net/bugs/531638
+ * Sale_crm : Code improved for partner onchange to take effect on SO
+ * https://launchpad.net/bugs/530926
+ * Account : Invoice group was missing access rights for tax and tax code
+ * https://launchpad.net/bugs/531416
+ * https://launchpad.net/bugs/535601
+ * Account : Proper query generation for computing debit.credit,balance
+ * https://launchpad.net/bugs/532365
+ * Document : It should be allowed to browse through FTP,disregard to --no-databse-list option
+ * https://launchpad.net/bugs/399817
+ * Sale : Cancelled partial packing should affect Sale order's Shipped field
+ * https://launchpad.net/bugs/538064
+ * Sale : Translations for RML texts entered into po/pot
+ * https://launchpad.net/bugs/531479
+ * Stock : drop view check added for stock_report_prodlots
+ * https://launchpad.net/bugs/504353
+ * Product : Conversion from unmatched categorized UoM now raises exception
+ * https://launchpad.net/bugs/532716
+ * MRP : Split production wizard corrected
+ * https://launchpad.net/bugs/538419
+
+
+Improvements (addons)
+---------------------
+
+ * base_contact: res.partner.address: use domain instead of value in context
+ * Stock :Layout for Moves under Picking Improved
+ * Account : Fiscalyear and Period now have name_search
+ * Product : Duplicated demo data corrected
+ * purchase: moved smoke test into separate test dir and renamed demo data for consistency with sale/mrp smoke tests
+ * l10n_be: attribution de nouveaux codes plus explicites pour les taxes
+ * Account_voucher : Accounting entries should only be available for non-view accounts
+ * Account : Better view of Reconciled and Partially Reconciled entried with Entry Lines
+ * Account : Setting tax code name translateable (to be consistent with tax name)
+
+
+2010-03-01: 5.0.7
+=================
+
+Bugfixes (server)
+-----------------
+
+ * Not linked to a bug report:
+ * --smtp-ssl is not a dependent on the server ssl mode
+ * bug:504718
+ * orm: ensure the cursor is valid before computing parent_store values
+ * correct ustr. avoid a crash if getlocale() return None
+ * Fields.function : if store={}/True is removed,column should be dropped with cascaded effect
+ * Base.sql : added relation field column to ir_model_feilds
+ * Fields : relational field was not getting written to ir_model_fields,in case of one2many
+ * allow to create menu executing ir.actions.server
+ * orm: bug when browsing _inherits object
+ * Search made working for function/related fields with store=True/{...} or fnct_search=method
+ * _inherits table may delete the record which is parental to other object but not required.
+ * remove the lock on database connections
+ * correct threading problems in cache
+ * Server Action : Email can be sent with non-English characters now
+ * quality_integration_server: if db exits, db should removed on database creation
+ * Currency : Rounding improved
+ * Importation when fails,needs cursor to be rolled back
+ * handle the case of missing "#:" formated comment in po files
+ * custom report xml creation
+ * better locking when accessing to template1 database
+ * remove minidom from report/custom, replace with lxml
+ * leftover call to minidom in ps_form even though minidom isn't imported there anymore
+ * Remove leftover instances of libxslt and libxml2, replace them by lxml
+ * hang in OSX when trying to shutdown server via SIGINT
+ * set absolute path for the config file to avoid the save() method breaking on single file, since os.path.exists('') returns false and you can't create the current directory
+ * quality_integration_server: fixed problem in make link
+ * translation: modify msg id where it contains python code in translations po files
+ * use env for python shebang rather than hardcoding /usr/bin/python
+ * base: wrong fr_FR translation for 'Delete Permission'
+ * db_exist method works as expected
+ * quality_integration_server : fixed bug on make link
+ * quality_integration_server: wrong web-service name
+ * Upgrade could have failed when its a change in name field,added cascade
+ * Expression : Making search easier for 'child_of'- Recursivity on field used as a Left operand
+ * solve problem of importing data from csv with constraints available on object
+ * act_window False domain problem - produce after dom to lxml conversion
+ * On update, fields with only numeric/int/float could have digits
+ * On Update, if only the size of column is changed,it should reflect into DB
+ * quality_integration_server : fixed problem in integration server on translation checking if translation file is changed on base module
+ * Avoid crash when no args
+ * Config : wrong calculation if cached_timeout comes from config file
+ * Expression : domain calculation failes, max. recursion error protected
+ * recursive calls
+ * allow to call write without ids on osv_memory objects
+ * Specify the name of the argument for the context, to avoir a critical bug
+ * <seq> problem Report Engine
+ * Workflow button desactivation regarding user roles
+ * Improved Previous bad commit for pagelayout error
+ * Import : Context of the action/screen passed,taken into consideration while importing
+ * quality_integration_server: ascci encoding problem in quality html log
+ * recursive child_of on one2many and many2many
+ * default context
+ * https://launchpad.net/bugs/463415
+ * https://launchpad.net/bugs/525962
+ * Ir_model : Made an offensive check of context
+ * https://launchpad.net/bugs/430133
+ * Name_search() is having now record limit to be 80 instead of None
+ * https://launchpad.net/bugs/407667
+ * Allowed SQL reserved keywords to be used in _order,group by ,etc.[Make sure , your _order should look like _order='to' instead of to]
+ * https://launchpad.net/bugs/495636
+ * Warning for reports for header attributes used in .py
+ * https://launchpad.net/bugs/523071
+ * Default_get : fields of _inherits for default values should be considered
+ * https://launchpad.net/bugs/493548
+ * Ir_actions : Unicode error corrected
+ * https://launchpad.net/bugs/409354
+ * Browse with _inherits issue fixed if more than one M2O to parent objct exists
+ * https://launchpad.net/bugs/430805
+ * Import made successful when field is O2M and it has relation under that.
+ * https://launchpad.net/bugs/462506
+ * Priority on fields.function with store dictionary made working.
+ * https://launchpad.net/bugs/483527
+ * https://launchpad.net/bugs/373176
+ * Behavior of server corrected if addons-path is wrong
+ * https://launchpad.net/bugs/489355
+ * fields: '_fnct_write' should pass context object to the 'write' method
+ * https://launchpad.net/bugs/491867
+ * revert bad fix
+ * fields.related were misbehaving
+ * https://launchpad.net/bugs/433886
+ * Update Module : Float8 to float and numeric to float casting made possible
+ * https://launchpad.net/bugs/410191
+ * Record rule : domain evaluation problem corrected
+ * https://launchpad.net/bugs/519468
+ * Fields : Only one2many fields can have relation_field,avoid checks for others
+ * https://launchpad.net/bugs/523971
+ * Missing imports of _ of tools.translate provided
+ * https://launchpad.net/bugs/500571
+ * Record Rules : domain_force made working
+ * https://launchpad.net/bugs/519204
+ * Base : Country can be searched on Country codes independent to case
+ * https://launchpad.net/bugs/493545
+ * Allowed <notebook> to be added into an inherited view(under field)
+ * https://launchpad.net/bugs/456978
+ * O2M should check existing relations for its concerned M2O
+ * https://launchpad.net/bugs/522227
+ * Fixed error notification on parent_store=true with a column without ondelete=cascade
+ * https://launchpad.net/bugs/516030
+ * Export translations + Cache on translations + Resynchronization wizard Corrections
+ * https://launchpad.net/bugs/430728
+ * Allowing sql keywords as fields(don't use them in order by clause)
+ * https://launchpad.net/bugs/480782
+ * https://launchpad.net/bugs/524588
+ * translate: error with workaround about \xa0 in decimal_point and thousands_sep
+ * https://launchpad.net/bugs/453269
+ * Amount_To_Text Corrected
+ * Amount to text conversions made better
+ * https://launchpad.net/bugs/490604
+ * RAW reports creation corrected
+ * https://launchpad.net/bugs/425350
+ * Menu attribute to report/wizard/url made behaving correctly
+ * https://launchpad.net/bugs/504584
+ * https://launchpad.net/bugs/495948
+ * Corrected language code for Slovenian and Danish locales. Renamed corresponding PO files.
+ * https://launchpad.net/bugs/480301
+ * M2M : values filtering on set()
+ * https://launchpad.net/bugs/503278
+ * Search : searching translated fields made possible(related,one2many,many2many)
+ * https://launchpad.net/bugs/504243
+ * https://launchpad.net/bugs/490125
+ * Custom fields should be removed from _columns too
+ * https://launchpad.net/bugs/490337
+ * Corrections made when removing a module and updating the module database: Entry from ir_model_data should also be removed when moudle is removed
+ * https://launchpad.net/bugs/496433
+ * Server Action: Help message of Legend corrected
+ * https://launchpad.net/bugs/417023
+ * Installation should alert user if any no pool record found for M2M/M2O.
+ * https://launchpad.net/bugs/493657
+ * Custom fields won't disturb anything while updating server
+ * https://launchpad.net/bugs/435933
+ * Encoding error corrected for client_action(ir_values-tree view)
+ * https://launchpad.net/bugs/514231
+ * M2O : Unfair behavior of M2O for access denial records and normal ones(All records were hidden by access denied if one had failed to meet access rights).
+ * https://launchpad.net/bugs/499501
+ * Report : Proper Message notification when RML file is not found
+ * https://launchpad.net/bugs/523762
+ * Expression.py corrected when M2O search returns no IDs
+ * https://launchpad.net/bugs/420507
+ * Domain was getting failed when trying to work upon M2M,O2M field of object
+ * https://launchpad.net/bugs/523123
+ * Not allowing Duplicate shortcuts
+ * https://launchpad.net/bugs/516469
+ * Wizard should raise exception to user when writte inside 'choice' type
+ * https://launchpad.net/bugs/488234
+ * connection pool when database password is provided (thanks to Syleam Crew)
+ * https://launchpad.net/bugs/491365
+ * Translation: Error parsing .po files when application puts comments in a single line
+ * https://launchpad.net/bugs/433395
+ * https://launchpad.net/bugs/462285
+ * Remove the useless cr.commit() in the get_id() method of the ir.sequence object
+ * https://launchpad.net/bugs/356628
+ * allow related fields to point to one2many and many2many fields
+ * https://launchpad.net/bugs/460560
+ * Ir_attachment : Context updation corrected on preview
+ * https://launchpad.net/bugs/437729
+ * Export Translation : Warning on Non-existing record instead of breaking flow
+ * https://launchpad.net/bugs/503445
+ * Partner : Name_get() of res.partner.address corrected
+ * https://launchpad.net/bugs/445252
+ * Translation was not getting inserted to DB on write()
+ * https://launchpad.net/bugs/497364
+ * revert previous patch about linked bug (lp:497364)
+ * Menu : Search method corrected for the non-Admin user
+ * https://launchpad.net/bugs/434341
+ * Export : Selection field gets imported by its external name if export is not import compatible
+ * https://launchpad.net/bugs/489573
+ * Manual object and field creation with searchable
+ * https://launchpad.net/bugs/520854
+ * https://launchpad.net/bugs/449516
+ * Warning raised for server action with SMS facility
+ * https://launchpad.net/bugs/519699
+ * Export translations: module name from path calculations corrected
+ * https://launchpad.net/bugs/516965
+ * User / Preferences should always display translatable languages.
+ * https://launchpad.net/bugs/516964
+ * default_FIELD from context should not overwrite modified FIELD value while creating record
+ * https://launchpad.net/bugs/516044
+ * Graph : report corrected
+ * https://launchpad.net/bugs/516962
+ * modifying a cron from client make it run concurrently multiple times
+ * https://launchpad.net/bugs/447819
+ * Ir_values : reading of default values correted
+ * https://launchpad.net/bugs/510600
+ * Import should raise an uncaught exception if not identified
+ * https://launchpad.net/bugs/413121
+ * Related with O2M behavior corrected
+ * https://launchpad.net/bugs/487836
+ * Custom Object xml arch needed encoding.
+ * https://launchpad.net/bugs/516969
+ * https://launchpad.net/bugs/487723
+ * Module informtion was not getting updated on upgrading module
+ * https://launchpad.net/bugs/372747
+ * Disable the cache for the ir.rules
+ * https://launchpad.net/bugs/478724
+ * Export : M2M field name was missing last character
+ * https://launchpad.net/bugs/497423
+ * FormatLang : Dates if specified into String,will be formatted into language-specific format
+ * https://launchpad.net/bugs/429519
+ * https://launchpad.net/bugs/479915
+ * Added lxml as required module on setup
+ * https://launchpad.net/bugs/495374
+ * Partner : titlee can have a choice to be null
+ * https://launchpad.net/bugs/509629
+ * Expression : Domain calculation of M2M/O2M corrected
+ * https://launchpad.net/bugs/504720
+ * https://launchpad.net/bugs/516568
+ * Server Actions: evaluating dict corrected
+ * https://launchpad.net/bugs/512682
+ * avoid sql injection in sequences
+ * https://launchpad.net/bugs/400614
+ * Use an alternative for the locale.RADIXCHAR if this one doesn't exist
+ * https://launchpad.net/bugs/491462
+ * Pickling issue solved with ir_values (get method)
+ * https://launchpad.net/bugs/507429
+ * Encoding problm corrected on report contents
+ * If RML contains unicode characters and title in the same <para>,it would have failed.
+
+
+Improvements (server)
+---------------------
+
+ * orm: allow import and record creation to defer the computation of parent_left/right
+ * orm: do not update parent_left/right if the parent haven't been changed
+ * Licensing options : Added AGPL-3 and others in choices
+ * Groups : Better duplication terminology.
+ * sql_db: better logging
+ * osv: log (in debug) access errors
+ * web_service: remove log (debug) when creating database
+ * exported method check_connectivity
+ * Sequence : Legend improved to help user understand the usage of %(year)s
+ * remove useless comment
+ * Launchpad export translation files
+ * removal of usages of the deprecated node.getchildren call, better usage of the attributes & tostring ET APIs, style fixes
+ * improve usage of the ET API, use SubElement instead of Element/append, kwarg attributes setting instead of node.set
+ * add option to disable the database listing
+ * quality_integration_server: added net_port option in script
+ * better connection pool (global)
+ * ir_cron : added active feild on list view
+ * Allow to specify the view via the context
+ * cron: check the arguments to avoid security issues
+ * cron: failed jobs are logged
+ * cron: clean code
+ * base_quality_interrrogation: put message if the score of quality less then minimal and remove unit test condition
+ * quality_integration_server: quality log : add new option to specify qualitylog path to store html pages of log
+ * default value for module
+ * updated changelog file for 5.0.6 release
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * event: make invoice wizard now creates invoice line with better label
+ * membership:
+ * Sale : Onchange of product/qty corrected when uos is present.Product: Help corrected for uom to uos conversion.
+ * Remove the bad translation files
+ * membership: membership amount field corect name of digits in field defination
+ * audittrail: correct dependencies
+ * audittrail: ensure cursor is closed
+ * invoice: translate the product description only if partner's language is set.
+ * account: avoid a traceback if credit/debit/balance sum can be computed
+ * mrp: fixed demo data when default_code is overridded in a custom module
+ * crm: removed debugging code
+ * document: fixed problem on window on filezilla
+ * sale_crm: CRM->Opportunities: 'convert to quote' now sets the salesman from the partner (or the user if there is none)
+ * sale: onchange on partner_id now set the partner's dedicated salesman as the sale salesman or the user if there is no dedicated salesman on that partner
+ * base_contact: search for a contact in a contact job now searches in firstname and lastname
+ * product: pricelist: ondelete cascade to avoid errors when deleting pricelists and versions ('null value in column "price_version_id" violates not-null constraint')
+ * sale_delivery_report: production lot reference was missing
+ * sale: onchange on partner_id now set the partner's dedicated salesman as the sale salesman
+ * sale_delivery_report: typo in french translation file
+ * Analytic_user_function : Corrected the Wrong way call to the method of product.uom
+ * base_contact: search in "Contact's Jobs" now also search in firstname and lastname of contacts
+ * Base_report_creator : ilike query generation problem corrected
+ * account: At the time of invoice cancel it will remove partial reconcile id from entry
+ * Account: Bank statement line,if has write-off entries,should pass write off account to move line
+ * account: set correct journal while opening customer and supplier invoices and refunds
+ * fix a prolem for the wiki content for the indexing
+ * product: Now pricelist objects price get function will pass context to price_get method of product and compute method of currency object
+ * base_module_quality: add import statment for _ and give size to name field on save report wizard so that it can display long name also
+ * Account : Wrong residual amount comes if company currency and invoice currency are different(provided no currency defined on journal)
+ * account: wizard of fiscal year closing fixed: the entries of all previous fiscal years have to be deffered, not only the last one
+ * l10n_be: fixed data of l10n_be module
+ * Analytic account report corrected
+ * Account_Voucher : Reports corrected
+ * Sale_CRM : write() was sending wrong data
+ * MRP : Accounting Entries were duplicated when processing production order with accounting configuration for locations.
+ * base_contact: domain problem on job object
+ * project: extra info tab of task view shouldn't be readonly if the task'state is 'draft'
+ * account_followup: the followup level of a partner which was removed from the proposed partner to remind was still raised although we didn't select him.
+ * change class names for all model in voucher from Account = account_account
+ * Base_report_creator : Wizard is available only for custom query,not for the custom result
+ * Point_of_sale : Receipt report corrected
+ * Account_tax_include : improvements when invoice lines are created prior to invoice
+ * Account_tax_include : Minor modif
+ * account_analytic_plans: analytic distribution are now created on invoice line when confirming sale orders (if a line is matching account analytic default rule)
+ * account: partial reconciliation check was wrongly computed
+ * base_module_quality: get_ids method problem
+ * account: no need to do a call to 'translate', method '_' is sufficient.
+ * base_module_quality: solve translate string error
+ * Stock: Moves have no state 'auto',its 'waiting'
+ * base_module_record second range problem when second is 59
+ * Project_timesheet : Removal of task with task work should affect Analytic lines
+ * Track Incoming / Outgoing products:
+ * account_analytic_default: add stock dependancy
+ * removed print statement
+ * picked in SO
+ * Project : remove unused import causing a DeprecationWarning under Python 2.6
+ * l10n_be: corrected internal type of vat account in l10n_be: set other instead of payable/receivable
+ * Hr_timesheet_sheet : setting type=workflow to 2 buttons
+ * Account: text made translatable
+ * fix the problem of menus uring installation
+ * Regression in SO from Jeroen and Jay, picked state see bug #491375
+ * Stock : Added Product UoS to the Stock Move view
+ * Base_contact : Making Email field of address visible on Address form view
+ * Stock : Added translations
+ * Account_invoice_layout : Reports improved and SXWs made compatible to RML
+ * membership: invoice membership wizard now calculate tax corectly and on product membership fields make readonly to false
+ * membership: change membership product date from and date to value with current year on demo data
+ * membership: solve problem of deleting membership invoice created with old membership product
+ * Account: Wizards were missing translation import statement
+ * Residual amount into invoice is now correct in every case and avoid rounding trouble even if rating has changed
+ * account: avoid translate tool missing import on strictier Python 2.6 versions; bare in mind that mx.Datetime should be eraticated from the surface of the earth
+ * account: removed pdb now that things are claimed fixed (after the commits messages)
+ * account_analytic_plans: Use etree instead of xml.dom
+ * fix the problem that appers in to the account move due to accout voucher
+ * Account_date_check : correction on a method
+ * Account_voucher : Typo corrected for Voucher type.
+ * Account : Corrected the malformed report of Partner Ledger
+ * purchase_manual: Import OSV
+ * python2.6 compatibility
+ * AuditTrail : View Logs should only show logs of current object and resources
+ * fix the problem of the reports account voucher
+ * #TODO: fix me sale module can not be used here,
+ * Import OSV in the wizard
+ * purchase: Use the price_accuracy
+ * Base_Report_Creator : xml record was malformed, corrected
+ * hr_expense: corrected error message
+ * account: avoid ZeroDivisionError
+ * Specify the name of the argument for the context, to avoir a critical bug
+ * CRM : Mailgate script added option -he was conflicting,improved
+ * Account :Invoice report had Partner name displayed at wrong position
+ * bugfix residual computation and multi-currencies
+ * Base_report_creator : Calendar view problems on custom report
+ * typo
+ * workcenter load graph
+ * set the access right
+ * base_module_quality: speed test if read method has exception
+ * account_analytic_plans: avoid encoding errors
+ * https://launchpad.net/bugs/528289
+ * membership: printing report crashes on graph view
+ * https://launchpad.net/bugs/522696
+ * Stock : Split moves wizard should respect current language
+ * https://launchpad.net/bugs/528281
+ * membership: membership state not correctly updated with associated partner
+ * https://launchpad.net/bugs/524425
+ * https://launchpad.net/bugs/416810
+ * Document: attachment linked with Files
+ * https://launchpad.net/bugs/470359
+ * https://launchpad.net/bugs/438725
+ * Purchase : Setting the value of payment term while creatying invoice from PO
+ * https://launchpad.net/bugs/492793
+ * Project_gtd : Improved fields_view_get() andmade it compatible to stable
+ * https://launchpad.net/bugs/525314
+ * membership: membership date from and to required now on product form
+ * https://launchpad.net/bugs/453030
+ * Avoid display write-off in pay invoice wizard : take care of partial payment
+ * Avoid display write-off in pay invoice wizard. Put the right date and currency for conversion
+ * https://launchpad.net/bugs/448591
+ * Account : Refund wizard wasnt calculating taxes for new invoices
+ * https://launchpad.net/bugs/489241
+ * mrp_operations : work order calculation corrected
+ * https://launchpad.net/bugs/493704
+ * Small stock tracking problem
+ * https://launchpad.net/bugs/518914
+ * Unable to validate supplier invoice/refund with reference greater than 32 characters. The reference is used as reference for the move lines and the analytic account line but the reference of these objects are limited to 32 characters, raising an sql error. It also broke the workflow of the invoice.
+ * https://launchpad.net/bugs/481130
+ * Stock: Shipping Address has to be in.po/.pot
+ * https://launchpad.net/bugs/427869
+ * Residual amount in invoice when currency rating change
+ * https://launchpad.net/bugs/474337
+ * [CRITICAL] warning : missing import statement for "_"
+ * https://launchpad.net/bugs/513983
+ * Sale : Order lines should be not editable for non-draft SO.
+ * https://launchpad.net/bugs/433898
+ * fix a problem Point of sale create outgoing shipments incl. service items
+ * https://launchpad.net/bugs/516746
+ * Account : Bank statements should not be altered/removed when state is confirmed
+ * https://launchpad.net/bugs/445267
+ * Mrp_subproduct : Wrong calculation of QTYs corrected(Product qty,UOS qty)
+ * https://launchpad.net/bugs/496889
+ * Account : wizard_pay_invoice corrected (Check made to calculate only receivable,payable lines)
+ * Account: Better calculation of invoice amount
+ * https://launchpad.net/bugs/428926
+ * account_payment when importing payment lines (currency not set correctly)
+ * https://launchpad.net/bugs/502984
+ * Hr_holidays: leaves' calculation corrected on removal of leaves
+ * https://launchpad.net/bugs/434628
+ * Account : In bank statements,Move Lines should be imported only once
+ * https://launchpad.net/bugs/503741
+ * Purchase : Purchase/user was missing account.tax access rights
+ * https://launchpad.net/bugs/457188
+ * Account_analytic_analysis : Summary of Months calculation Corrected
+ * https://launchpad.net/bugs/528292
+ * membership: membership cancel date is not updated
+ * https://launchpad.net/bugs/351083
+ * Account : Partner Balance report gets printed with respect to the company selected
+ * https://launchpad.net/bugs/497365
+ * Account : Supplier Invoices new record creation corrected for web client
+ * https://launchpad.net/bugs/435298
+ * Subscription : Disallowed to change the Object linked to the document type.
+ * https://launchpad.net/bugs/490883
+ * MRP: Proper context value passed for PO creation from packing via SO
+ * https://launchpad.net/bugs/479886
+ * Account : Total field on supplier invoice set to 0.0 to amke it Web-client compatible
+ * https://launchpad.net/bugs/398562
+ * MRP : Accounting Entries were duplicated when processing production order with accounting configuration for locations.
+ * https://launchpad.net/bugs/445547
+ * Stock: Picking report correction
+ * https://launchpad.net/bugs/507694
+ * Properly cancel a draft purchase.order when unlinking it, so correct workflow signals can be propagated to parent workflows if there are any.
+ * https://launchpad.net/bugs/460924
+ * Stock : force_assign won't create duplicate entries
+ * https://launchpad.net/bugs/516100
+ * Account : Invoice line should display complete name of product from the onchange
+ * Stock : Onchange corrected to have an effect of translations
+ * https://launchpad.net/bugs/492174
+ * Base_report_creator : encoding eror corrected on adding filters
+ * https://launchpad.net/bugs/446205
+ * CRM : Mailgate script has host as parameter now onwards
+ * https://launchpad.net/bugs/501625
+ * Account : General Ledger report in Landscape made transltable
+ * https://launchpad.net/bugs/440557
+ * Purchase : POL had a wrong tree view which is unused till now
+ * https://launchpad.net/bugs/452854
+ * Correct the validate function for balanced move into account.py (after Fabien Warning)
+ * Use price_accuracy to verify balanced entry insteed of fixed '0,0001'. Add price_accuracy on debit and credit move lines
+ * https://launchpad.net/bugs/522532
+ * Stock : Priority assigned to stock.location list view
+ * https://launchpad.net/bugs/522629
+ * https://launchpad.net/bugs/480035
+ * CRM : action name improved
+ * https://launchpad.net/bugs/439469
+ * Product : Pricelist types getting translated on Pricelist
+ * https://launchpad.net/bugs/512682
+ * avoid sql injection in sequences
+ * https://launchpad.net/bugs/476343
+ * https://launchpad.net/bugs/447402
+ * Project_timesheet : Wrong synchro on analytic line creation fro tasks(for name).
+ * https://launchpad.net/bugs/490318
+ * Account : Ondelete=cascade added to bank statement line
+ * https://launchpad.net/bugs/459027
+ * Sale : SOL's subtotal was missign price-accuracy
+ * https://launchpad.net/bugs/509496
+ * Account_tax_include : Refund of invioce was not counting price_type.
+ * https://launchpad.net/bugs/366944
+ * Base_vat : Spanish numbers validation corrected
+ * https://launchpad.net/bugs/488869
+ * Stock/MRP : Track line wizard improved
+ * https://launchpad.net/bugs/474340
+ * Stock : Wizard improvements from Lionel
+ * https://launchpad.net/bugs/445306
+ * document: put warning message in module descrition regarding lost files which are exits before installing document
+ * https://launchpad.net/bugs/491867
+ * base_contact: fix bad related field
+ * https://launchpad.net/bugs/481524
+ * Stock : Forecast report: unicode error corrected
+ * https://launchpad.net/bugs/493369
+ * Hr_attendance : Sign out entries were not possible when we 'change work'
+ * https://launchpad.net/bugs/438705
+ * Stock : Stock move lines on Production Order well-structured
+ * https://launchpad.net/bugs/500096
+ * Base_report_creator : Support of count(*) added
+ * https://launchpad.net/bugs/521106
+ * Account : Analytic charts of accounts was raising exception on displaying chart
+ * https://launchpad.net/bugs/464578
+ * project_timesheet: analytic entries are fully not updated, when changing task project
+ * https://launchpad.net/bugs/483583
+ * Sale/Purcghase : Function fields did not have digits attribute for precision accuracy
+ * https://launchpad.net/bugs/461720
+ * Scrum : Wrong view,widgetless fields on scrum view made correct
+ * https://launchpad.net/bugs/491898
+ * Purchase : Fields set readonly on done state
+ * https://launchpad.net/bugs/480856
+ * Warning : the super of onchange may return {},covered the same
+ * https://launchpad.net/bugs/496898
+ * Account : Fields were missing in Account chart template form view
+ * https://launchpad.net/bugs/502065
+ * Stock : Product Packaging field was missing domain
+ * https://launchpad.net/bugs/351167
+ * https://launchpad.net/bugs/459196
+ * Account : Partner Ledger Report formatting problem solved
+ * https://launchpad.net/bugs/465010
+ * Stock : Notification Message made translatable
+ * https://launchpad.net/bugs/491892
+ * Reconcilation problem corrected when foreign currency rate changes
+ * https://launchpad.net/bugs/504781
+ * Project : Task delegation was calling write() wrongly
+ * https://launchpad.net/bugs/494245
+ * Services product included on BOM now creates a task on Project
+ * https://launchpad.net/bugs/475135
+ * Account : Warning message was missing _ import
+ * https://launchpad.net/bugs/467880
+ * MRP : Procurement can only be confirmed when qty>0.0
+ * https://launchpad.net/bugs/401801
+ * Sale/Purchase : Worfklow instance had to ve removed while setting record's workflow back to draft state
+ * https://launchpad.net/bugs/449583
+ * Sale : Better error message when account is missing from SOL for Invioce
+ * https://launchpad.net/bugs/439041
+ * Report_project :wrong average of closing days counting
+ * https://launchpad.net/bugs/517018
+ * https://launchpad.net/bugs/487641
+ * Purchase : MOQ-pricing problem corrected
+ * https://launchpad.net/bugs/500062
+ * Account : On Confirming the statement, Moves shoould have the bank statement line date
+ * https://launchpad.net/bugs/525229
+ * call fields_view_get with not specify the context raise an exception on product with stock module installed
+ * https://launchpad.net/bugs/441609
+ * Account : Fiscal Position Template was missing a requireed field in form view
+ * https://launchpad.net/bugs/483723
+ * CRM : Case form view priority issue resolved
+ * https://launchpad.net/bugs/440734
+ * Stock : Picking did not have 'type' field on display(inconsistent behavior from eTiny,koo) to work upon domain.
+ * https://launchpad.net/bugs/419720
+ * Sale : Delivery Date delay computation made corrected when days are passed with fractions
+ * https://launchpad.net/bugs/439208
+ * Hr_timesheet : Allowing user to enter Analytic Journal if not linked with employee(Working hours tree view)
+ * https://launchpad.net/bugs/379118
+ * Stock : Partial Picking wizard was making the back order reference jump to 2 numbers,notification given on packing done.
+ * https://launchpad.net/bugs/526930
+ * Account : act_link added for better options of viewing move lines from partner
+ * Account : act_link from partners for account entries should contain only receivable/payable accounts
+ * https://launchpad.net/bugs/526417
+ * Sale_delivery_report : Report corrected
+ * https://launchpad.net/bugs/450180
+ * Hr_timesheet_invoice : Wrong domain was sent for opening invoices created
+ * https://launchpad.net/bugs/446391
+ * Base_report_creator : Allowing to use current userid
+ * https://launchpad.net/bugs/519225
+ * https://launchpad.net/bugs/522011
+ * fix a problem of 0 amount entries
+ * https://launchpad.net/bugs/505697
+ * Account : Analytic check report should consider expenses are debits
+ * https://launchpad.net/bugs/519220
+ * Weight on Picking has to be calculated from the Moves
+ * https://launchpad.net/bugs/519433
+ * Sale : Invoice from packing should pass proper notes to invoice
+ * https://launchpad.net/bugs/500078
+ * https://launchpad.net/bugs/527151
+ * CRM_configuration : Menu action for all Unassigned opportunities had wrong domain
+ * https://launchpad.net/bugs/486783
+ * Point_of_sale : Report for Reciept corrected
+ * https://launchpad.net/bugs/503894
+ * Base_report_crearor :Models with _inherits made working
+ * https://launchpad.net/bugs/371681
+ * Residual amount was calculated wrongly when invoice had payment term lines
+ * https://launchpad.net/bugs/454536
+ * Warning : Onchange Methods were malfunctioned.Corrected and made messages available for translations
+ * https://launchpad.net/bugs/504670
+ * Functional fields should have context as an argument when we use fnct_searc method
+ * https://launchpad.net/bugs/507094
+ * https://launchpad.net/bugs/396637
+ * account_analytic_analysis : Analytic account functional field methods corrected.
+ * Account : Analytic account functional field methods corrected.
+ * https://launchpad.net/bugs/495948
+ * Corrected language code for Slovenian and Danish locales and renamed corresponding PO files.
+ * https://launchpad.net/bugs/470815
+ * l10n_chart_uk_minimal : Demo account.tax.code needed negative sign
+ * https://launchpad.net/bugs/513240
+ * https://launchpad.net/bugs/421636
+ * Account : Restricting Payment term lines percentage insertion from 0 to 1
+ * https://launchpad.net/bugs/516636
+ * Project_timesheet: Product_uom supplied to Analytic entries
+ * https://launchpad.net/bugs/492211
+ * MRP : procurement does not need cancel button when its Running
+ * https://launchpad.net/bugs/401035
+ * Audittrail : Assigned Access Rights to non-admin user.
+ * https://launchpad.net/bugs/511198
+ * https://launchpad.net/bugs/499120
+ * Stock : While removing the picking,moves should not call picking's write()
+ * https://launchpad.net/bugs/438690
+ * Account : Accounts containing moves cannot be deleted
+ * https://launchpad.net/bugs/490965
+ * Sale : SO was getting stuck when invoice is cancelled and SOL is with product.
+ * https://launchpad.net/bugs/446520
+ * [account_followup] wrong sender for email
+ * https://launchpad.net/bugs/528418
+ * membership: all products are considered to be memberships
+ * https://launchpad.net/bugs/522862
+ * document: Fixed non-closed Cursor problem
+ * https://launchpad.net/bugs/451310
+ * https://launchpad.net/bugs/479747
+ * https://launchpad.net/bugs/486794
+ * Hr_holidays: Spell mistake corrected
+ * https://launchpad.net/bugs/443132
+ * Sale : Passing customer ref. of picking to invoice
+ * https://launchpad.net/bugs/481372
+ * Project : If company has no Project time unit,it would have crashed.
+ * https://launchpad.net/bugs/476428
+ * Stock : Partial Picking wizard was missing translation import statement
+ * https://launchpad.net/bugs/500591
+ * Account: Spell corrected in order to display separator on subscription wizard
+ * Account: Creation of Moves to Subscription entries Corrected
+ * https://launchpad.net/bugs/436174
+ * Account: Supplier invoices was not taking product price on onchange of product
+ * https://launchpad.net/bugs/488809
+ * Sale : State was written wrongly
+ * https://launchpad.net/bugs/490327
+ * Reverted bad commit from Joel@CamptoCamp
+ * https://launchpad.net/bugs/383057
+ * Stock-MRP : Split production wizard made individual to mrp if mrp is not installed
+ * https://launchpad.net/bugs/440711
+ * Purchase : PO with different pricelists should not be merged
+ * https://launchpad.net/bugs/516143
+ * Base_report_designer : Latin-1 encoding replaced by utf-8
+ * https://launchpad.net/bugs/525768
+ * membership: now membership state not depends on current date
+ * https://launchpad.net/bugs/513230
+ * Product :Uom conversion was made 2 times
+ * https://launchpad.net/bugs/522977
+ * Fixed mrp to ensure that mrp_jit can trigger the procurement assignation properly. See bug 522977.
+ * https://launchpad.net/bugs/510692
+ * Account : Onchange of product should affect price on supplier invoice line
+ * https://launchpad.net/bugs/458415
+ * document_ics : solved accent problem
+ * https://launchpad.net/bugs/428873
+ * purchase: chain location does not work
+ * https://launchpad.net/bugs/489355
+ * account, invoice, sale: description (product sold, invoice line and account entry line) was not translated
+ * https://launchpad.net/bugs/515590
+ * https://launchpad.net/bugs/499645
+ * Project_mrp: Better effect for service products creating tasks/projects
+ * https://launchpad.net/bugs/466658
+ * Account : Action window of anlytic entries was missing name
+ * https://launchpad.net/bugs/510217
+ * Added Missing import statements of translations( from tools.translate import _)
+ * https://launchpad.net/bugs/460701
+ * Document : Attachment with document can now be deleted
+ * https://launchpad.net/bugs/498047
+ * Account_tax_include : Rounding corrections
+ * https://launchpad.net/bugs/435160
+ * [IMP] Correct write-off date, add analytic account, better interface between all way to reconcile
+ * https://launchpad.net/bugs/458553
+ * Account : Onchange of amount/base amount of Invocie tax corrected
+ * https://launchpad.net/bugs/446681
+ * Account : Refund wuzard malfunctioned with modify invoice option
+ * https://launchpad.net/bugs/493444
+ * Account_analytic_default : Analytic Account value set from picking,sale
+ * account_analytic_default: now it will make entry in anayltic account on invoice line when picking done
+ * https://launchpad.net/bugs/395160
+ * Project_timesheet : Analytic line creation/edition takes user based information
+ * https://launchpad.net/bugs/425671
+ * Stock : Moves offer onchange on UOM to affect UOS
+ * https://launchpad.net/bugs/489083
+ * Account :customer refund was displaying supplier invoice view, corrected
+ * https://launchpad.net/bugs/499038
+ * CRM_profiling : Segmentation form was missing one field
+ * https://launchpad.net/bugs/496991
+ * HR_Timesheet_sheet : timesheet cannot be deleted which have attendance entries encoded
+ * https://launchpad.net/bugs/507638
+ * Account : General Ledger report corrected for debit/credit if 0
+ * https://launchpad.net/bugs/461801
+ * Sale : Workflow behaviour fixed when order is set to draft
+ * https://launchpad.net/bugs/516361
+ * POS : for Invoice created from POS,Consistency should be maintained as SO.
+ * https://launchpad.net/bugs/439027
+ * MRP :Arguemnt of context was missing
+ * https://launchpad.net/bugs/490342
+ * Account : making the default_get() eTiny compatible
+ * https://launchpad.net/bugs/504824
+ * account: credit/debit/balance of consolidated accounts
+ * https://launchpad.net/bugs/522632
+ * Sale : Sale order list view should have sum attribute
+ * https://launchpad.net/bugs/435178
+ * [CRITICAL]subscription: crash subscription process
+ * https://launchpad.net/bugs/522161
+ * base_module_quality: speed_test
+ * https://launchpad.net/bugs/487091
+ * Stock :Invoice created from manual picking might miss UoS.
+ * https://launchpad.net/bugs/379581
+ * Base_report_creator: Export of custom reports made working
+ * https://launchpad.net/bugs/479195
+ * Base_vat : Romania VAT validation corrected
+ * https://launchpad.net/bugs/436008
+ * Sale: Passing Contact address for invoices from SO
+ * https://launchpad.net/bugs/443069
+ * Project: wrong domain for 'Tasks in Progress' menuitem
+ * https://launchpad.net/bugs/518824
+ * Project : 100% completed project should dislay proper message on Gantt chart,instead of getting failed
+ * https://launchpad.net/bugs/471052
+ * Product : Pricelist Item cannot use Main pricelist as the other pricelist
+ * https://launchpad.net/bugs/458030
+ * Account : Ledger Report Landscape report adjusted for A4.
+ * https://launchpad.net/bugs/495933
+ * Account : Made amount field of account.move searchable
+ * https://launchpad.net/bugs/440248
+ * Hr_timesheet_invoice : Line once invoiced,should not be invoiced again
+ * https://launchpad.net/bugs/491241
+ * Stock : Removal of picking shuold affect product stock
+ * https://launchpad.net/bugs/510604
+ * Account: Sequence and main seq. should be different
+ * https://launchpad.net/bugs/436651
+ * mrp : workcentre load report had a query malformed
+
+
+Improvements (addons)
+---------------------
+
+ * Update Translations
+ * Don't specify default value for dict, that return None if value doesn't exists
+ * Account_payment: showing account feild on move line when importing invoice for payment
+ * Account/base_iban : bank and iban displayed on list view of O2M to partner
+ * MRP : BOM structure report should follow hierarchy.
+ * event_project: change the string on event object all task to remaining task and put the domain on retro planning wizard(open only projects with state=template)
+ * Account : Reference allocation to move/move.line improved
+ * Launchpad export translation files
+ * Added GNU licence
+ * Unit Test cases for Sale
+ * unit test in base quality module
+ * MRP : mrp.routing.workcenter made deletable on cascade effect
+ * Account : Entry Line action Name Improved
+ * Stock : Improved names of Stock move tree view
+ * account: make comment mandatory. Since it has a default value anyway, it doesn't reall y change anything, but makes the reconciliation UI looks consistent accross the whole OpenERP (eg invoice payment)
+ * Add support of analytic account into bank statement to be convenient with other method
+ * Add account field into bank statement line
+ * better python2.5/2.6 compatibility handling
+ * base_module_quality: styles on different tests
+ * base_module_quality: modify all tests result display for buildpot, use class on tag instead of css file
+ * base_module_quality: pylint test result display for buildpot, use class on tag instead of css file
+
+
+2009-09-22: 5.0.6
+=================
+
+Bugfixes (server)
+-----------------
+
+ * https://launchpad.net/bugs/421904
+ * Fields.function : Store value computation corrected
+ * https://launchpad.net/bugs/407332
+ * Price Accuracy : rounding made to be based on --price_accuracy option
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * fixed an "unsupported operand type(s) for +: 'bool' and 'str'" error.
+ * Sale_delivery_report : Delivery order report should take shipping address from picking itself
+ * account: bugfixed the fiscalyear closing wizard:
+ * Purchase_manual : certificate on terp displayed wrong value
+ * https://launchpad.net/bugs/431864
+ * hr_timesheet_sheet : casting correction for a view
+ * https://launchpad.net/bugs/431871
+ * Account : Move line creation was giving encoding error while automated entries were inserted,corrected
+ * https://launchpad.net/bugs/433979
+ * [CRITICAL]document: crash list of directory after rev:hmo@xxxxxxxxxxx-20090916110722-4kl5t5q71im6c76i
+ * https://launchpad.net/bugs/407332
+ * Account : Rounding problem based on price_accuracy
+ * https://launchpad.net/bugs/419720
+ * Sale : Delivery Date delay computation made corrected when days are passed with fractions
+ * https://launchpad.net/bugs/423726
+ * Sale : SO Boolean field picked behavior corrected
+ * https://launchpad.net/bugs/431821
+ * Account_followup : Sending email while sending follow up corrected.
+
+
+Improvements (addons)
+---------------------
+
+ * purchase_manual: do not redefine view: add fields by inheritance...
+ * purchase: improve views to be directly usable in portals...
+
+
+2009-09-17: 5.0.5
+=================
+
+Bugfixes (server)
+-----------------
+
+ * Not linked to a bug report:
+ * quality_integration_server: fixe problem on make link of extra-module in addons
+ * quality_integration_server : quality log : reduce overwrite last test log in other test logs
+ * base : ir_cron : take minimun next_call from database for job waiting. if database does not has any job, it will take 1 day for job waiting
+ * quality_integration_server: get message from base_quality_module if module can not success to reach minimun score
+ * regression in fields.function computation
+ * better log error, new line
+ * Report: context was missing while printing any report with header in a non-English Language
+ * quality_integration_server: fixe problem on make link of extra-module in addons
+ * https://launchpad.net/bugs/425131
+ * Better translation exportation.
+ * https://launchpad.net/bugs/379645
+ * Print screen : Correction when text for report is already encoded
+ * https://launchpad.net/bugs/421162
+ * Send Mail : Unicode error handled
+ * Send mail : Non-English characters were throwing error.
+ * https://launchpad.net/bugs/421137
+ * Base : 'Supplier Partners' menu will open new record with supplier=1,customer=0
+ * https://launchpad.net/bugs/425430
+ * Export : Error solved while Exporting O2M records with None value of any field
+ * https://launchpad.net/bugs/399208
+ * Translation issue with cache: it needed to restart server,SOLVED
+ * https://launchpad.net/bugs/422563
+ * Security Loophole corrected
+
+
+Improvements (server)
+---------------------
+
+ * quality_integration_server: make link of extra-addons module in addons module automatic on install-module command
+ * quality_integration_server: get message from base_quality_module if module can not success to reach minimun score
+ * Rng : Accepting Groups under/after/replacing Buttons
+ * quality_integration_server : quality html log
+ * quality_integration_server: put max_limit in server connection
+ * Base : Rate for ARS Added
+ * cchange version number
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * Purchase_manual : certificate on terp displayed wrong value
+ * fix the problem of message depending on the partner language
+ * fix a problem for the overdue payment message
+ * fix problem to get the detault message
+ * #416908 computation of invoice lines
+ * Project : Taks hours computed accurately.
+ * base_module_record: avoid duplications
+ * document: do not try to index binary documents
+ * +1 on the lengthmonth returns was too much, removed it
+ * Problem when using hr_holidays Summary Report when entering date 1 jan 2009 for example.
+ * multi currency reconciliations on bank statements weren't properly displayed
+ * multi currency payments weren't correctly computed on invoice's residual amount
+ * Project_gtd : Demo data defined for tasks(inboxes)
+ * Module:product Added report tag for product pricelist reportso that it can be modified using OODesigner
+ * Document : error on create if attachment not specified
+ * https://launchpad.net/bugs/422401
+ * project_gtd : timebox field re-arranged
+ * https://launchpad.net/bugs/421907
+ * Account : Aged Partner Balance report for Future analysis corrected
+ * https://launchpad.net/bugs/427388
+ * Project : task work behavior towards task hours corrected
+ * https://launchpad.net/bugs/422408
+ * Project_gtd : Hierarchical timeboxes allowed to open
+ * https://launchpad.net/bugs/403972
+ * Account : Reports from Chart of Accounts were not considering contextual value of MOVE(draft,posted)
+ * https://launchpad.net/bugs/430577
+ * Sale : Order Lines switches view from tree,form and view
+ * https://launchpad.net/bugs/425257
+ * Project_gtd : improved menuitems names to avoid user confusion,domain improved
+ * https://launchpad.net/bugs/422078
+ * Account_tax_include : floatdivision error corrected
+ * https://launchpad.net/bugs/423585
+ * https://launchpad.net/bugs/423581
+ * https://launchpad.net/bugs/416807
+ * report_document : Dashboard should not display partner with no files
+ * https://launchpad.net/bugs/430522
+ * https://launchpad.net/bugs/424214
+ * Account :Residual amount unclear when used with partial payments.
+ * https://launchpad.net/bugs/424177
+ * hr_timesheet_sheet : Rounding value problem in float_time widget
+ * https://launchpad.net/bugs/415056
+ * https://launchpad.net/bugs/421636
+ * added tooltip on tax and payment term
+ * https://launchpad.net/bugs/407290
+ * https://launchpad.net/bugs/407293
+ * Account : Making account.invoice.tax field language-depenant from account.tax
+ * https://launchpad.net/bugs/430043
+ * Hr_timesheet_invoice : Query calculation corrected
+ * https://launchpad.net/bugs/379645
+ * Base_report_creator : Print screen report is now available for custom reports
+ * https://launchpad.net/bugs/423260
+ * Account : Title of of Move Line widnows renamed
+ * https://launchpad.net/bugs/427982
+ * hr_timesheet_invoice : Invoicing analytic entries wizard corrected for product
+ * https://launchpad.net/bugs/426243
+ * Account : Context was missing in report
+ * https://launchpad.net/bugs/426831
+ * l10n_ch : default_value() of res.partner.bank corrected
+ * https://launchpad.net/bugs/430098
+ * Hr_holidays : Workflow actions validations corrected
+ * https://launchpad.net/bugs/430516
+ * https://launchpad.net/bugs/379191
+ * its better to aply the patch
+ * fix the problem for related fields, related fields act as a many2one fields
+ * https://launchpad.net/bugs/429203
+ * CRM : Mailgate script used default uid=3 instead of 1
+ * https://launchpad.net/bugs/399817
+ * Fixed Partial deliveries problem
+
+
+Improvements (addons)
+---------------------
+
+ * Invoice Supplier Control per line/manual
+ * add missing file for the followup date
+ * changed interval CRM calls to 4 hours instead of one -> efficient connection pooling with cron
+ * add inherited view for company
+ * add new filed to company object which will store the mesages
+ * add new data file which will add over due payment message to company
+ * Account : Analytic Account report following parental relationship approach(account with all its children
+ * hr_timesheet_invoice : Misleading string on invoice analytic entries' wizard
+ * base_module_quality: remove certificate tag from terp test
+ * report_dcoument : changed the misleading name of action
+
+
+2009-08-28: 5.0.4
+=================
+
+Bugfixes (server)
+-----------------
+
+ * Not linked to a bug report:
+ * no traceback when access denied
+ * Security fix
+ * remove bad translation files (bad name)
+ * Pagecount problem while all objects print on same page and printing special character on xsl report
+ * https://launchpad.net/bugs/415973
+ * import: support "<rel_field>:db_id" , better warning message
+ * https://launchpad.net/bugs/415391
+ * Functional fields with M2O relation can be printed on print screen now
+ * https://launchpad.net/bugs/415334
+ * ir_cron :function and its arguements are now editable
+
+
+Improvements (server)
+---------------------
+
+ * replace partner name and address in demo
+ * add translation names
+ * update translations files
+ * new translations
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * Document : error on create if attachment not specified
+ * report_dcoument : changed the misleading name of action
+ * point_of_sale: fixed a wrong domain
+ * sale: bad indentation
+ * https://launchpad.net/bugs/416807
+ * report_document : Dashboard should not display partner with no files
+ * https://launchpad.net/bugs/401110
+ * Audittrail : Logs set in descending order
+ * https://launchpad.net/bugs/418541
+ * Project : Delegated tasks from O2M didnt have project_id
+ * https://launchpad.net/bugs/416767
+ * Account_tax_include : onchange of product on invoice line price type issue
+
+
+Improvements (addons)
+---------------------
+
+ * update translations
+ * base_module_quality: make minimal score for all test, add message if the score is below limit,varible for whether to activate the test or not
+ * process view node now links to parent document directory if no record selected.
+ * purchase: Merge purchases wizard: added keyword='client_action_multi'
+ * Auction : improved code
+ * Auction : improved auction reports
+ * Age Partner Balance report executed 7 queries per partner, reduced this a total of 7 queries in total.
+
+
+2009-08-21: 5.0.3
+=================
+
+Bugfixes (server)
+-----------------
+
+ * Not linked to a bug report:
+ * set_alarm: removed unwanted comment
+ * report engine: context argument was passed at a wrong position. Now it's passed as a named argument.
+ * fields_get check access aginst write or create access
+ * Not allowing only white spaces text to be printed
+ * sequences: avoid an sql error when locking table...
+ * report engine: fixed a bug when the xml tag is empty
+ * bin/workflow: 'stack' variable was not initialized when sql query returned an empty set.
+ * security issue: avoid access to inactive users
+ * security issue: avoid access with 'None' password (Thanks to P. Christeas for the bug report)
+ * avoid a bug when look in stack when translate code strings
+ * https://launchpad.net/bugs/415257
+ * import of boolean fields in csv files.
+ * https://launchpad.net/bugs/415014
+ * correct translation tgz archive creation
+ * https://launchpad.net/bugs/362280
+ * https://launchpad.net/bugs/416883
+ * Print screen unicode-decode error solved
+ * https://launchpad.net/bugs/400378
+ * partner address search
+ * https://launchpad.net/bugs/415972
+ * do not get next sequence in its own cursor
+ * https://launchpad.net/bugs/413484
+ * Print Screen : was not considering field names with superscripted,subscripted characters(ex.m²)
+ * https://launchpad.net/bugs/406945
+ * import of boolean fields in csv files.
+ * https://launchpad.net/bugs/413586
+ * bug in cache system that altered some arguments passed to cached function
+ * https://launchpad.net/bugs/413594
+ * logger: convert the message in unicode before concatenate it with server environment
+ * https://launchpad.net/bugs/348217
+ * Secure option on config file
+
+
+Improvements (server)
+---------------------
+
+ * Makefile and quality_integration_server module for Integration server
+ * Speed impprovement: 2x faster for flow: sale -> invoice -> payment
+ * Speed improvement in creation of records (4 time faster on partners)
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * Purchase :copy method was not setting stock moves to be null for PO lines
+ * Module:account Fix keyerror in general_ledger report
+ * Access rules stock / worker
+ * mrp: fr_FR.po file had a duplicate message definition
+ * https://launchpad.net/bugs/413699
+ * https://launchpad.net/bugs/415014
+ * report_task: regenerate translations files
+ * https://launchpad.net/bugs/397100
+ * improving commit on report
+ * https://launchpad.net/bugs/416296
+ * Base_setup : Country passed in values only if filled
+ * https://launchpad.net/bugs/415218
+ * report_task : report_task_user_pipeline_open was having no uniqueness
+
+
+Improvements (addons)
+---------------------
+
+ * POS: improved the point_of_sale receipt
+
+
+
+2009-08-12: 5.0.2
+=================
+
+Bugfixes (server)
+-----------------
+
+ * Not Linked to a bug report:
+ * ensure sys is imported
+ * pass the context to check method of 'ir.model.access'
+ * increase size of field "name" of ir.model.data
+ * Corrected bug of expression calculation in previous commit
+ * sql expression: in search, add the time part to datetime field when it's not present
+ * setup.py: py2exe now adds 'zoneinfo' directory in library.zip
+ * Importation problem corrected for unicode.
+ * missing Import
+ * tools.amount_to_text_en: now displays cents
+ * size miss match for page and frame
+ * removed report etree warning of len
+ * security on wokflows bugfixed. The security has to be checked using the current uid, not the one that created the workflow instance!
+ * export window : use context for import compatable option in pass argument instend of added new argemenent
+ * py2exe: pytz on win32: 'zoneinfo' directory now included in library.zip
+ * module installation through -i module -d db --without-demo option corrected
+ * loading module sequence while creating new database
+ * Expression calculation(Query making) corrected for Translateable field
+ * CSV Export : null values handled
+ * sxw and odt reports
+ * Fixed odt2odt reports printing
+ * module:base made name field translatable in action.server (ref:mga)
+ * supply password problem with pg_dump, pg_restore on win32
+ * User with blank password(if so) allowed to log in.
+ * avoid required parameters rule (domain_force)
+ * Fixed oldxml at python2.6 for Ubuntu 8.0.4,9.04
+ * fix missing tail process and skip unnecessary whitespace characters
+ * ir_attachment preview method corrected
+ * launch signal after action in workflows
+ * Added PageCount tag in report engine
+ * report engine, better spacings -> like preceeding version
+ * fix &,<,> problem for html2html-url report
+ * fix &,<,> problem for html2html report
+ * xml: the tag <delete> delete also the reference to the deleted objects into ir_model_data
+ * translation export: catch the case when a object does not exists in database
+ * browse_record: raise a better exception when the id doesn't exists
+ * Bugfix translations and float/int format in reports
+ * Complete rng files
+ * load the module graph even if it containt only "base"
+ * remove base_setup (moving base_setup to server was a workaround)
+ * expression: correct the generated sql in case of _inherits
+ * the <delete> tag doesn't crash if the referenced id does not exists
+ * closed file pointer
+ * https://launchpad.net/bugs/380221
+ * https://launchpad.net/bugs/403652
+ * https://launchpad.net/bugs/369947
+ * https://launchpad.net/bugs/371496
+ * https://launchpad.net/bugs/371768
+ * bad tooltip
+ * https://launchpad.net/bugs/383938
+ * Mass mailing wizard has a mail body now.
+ * https://launchpad.net/bugs/409709
+ * Error reporting : library error corrected
+ * https://launchpad.net/bugs/394876
+ * Import : context provided for language translation
+ * https://launchpad.net/bugs/390167
+ * Custom report : sorted X-axis values
+ * https://launchpad.net/bugs/405921
+ * Expression calculation for Datetime Corrected
+ * https://launchpad.net/bugs/393858
+ * ir_model_data : SQL_Constraint failure covered
+ * https://launchpad.net/bugs/396955
+ * disallow the deletion of records set as default properties
+ * properties reset to default one correctly
+ * https://launchpad.net/bugs/399685
+ * Added sql_constraint on adding field having size<1
+ * https://launchpad.net/bugs/385544
+ * ir_translation : corrected entry insertion when adding translation
+ * https://launchpad.net/bugs/392187
+ * xml encoding in header for &.<.>
+ * https://launchpad.net/bugs/310918
+ * RuntimeError in the cache system
+ * https://launchpad.net/bugs/362280
+ * _inherits was misbehaving on search
+ * https://launchpad.net/bugs/385299
+ * Report Engine Regression
+ * Report Engine regression
+ * https://launchpad.net/bugs/407637
+ * Print screen now displays the report as per WYSIWYG
+ * https://launchpad.net/bugs/408550
+ * default_xxx in context was passed to relational fields,corrected.
+ * https://launchpad.net/bugs/385297
+ * bug in report engine
+ * https://launchpad.net/bugs/381204
+ * Character Truncation problem on updation solved
+ * https://launchpad.net/bugs/355491
+ * CSV Import : Accepting 'Value' of selection field from[(key,value)]
+ * https://launchpad.net/bugs/409343
+ * Login : Login and password accepting accented characters
+ * https://launchpad.net/bugs/376945
+ * Translation : Text with prefix '_' from py files included for exports.
+ * https://launchpad.net/bugs/385664
+ * Account Module : Typo corrected
+ * https://launchpad.net/bugs/405721
+ * DB operations(backup,restore) process corrected,were blocked if db_port was supplied
+ * https://launchpad.net/bugs/410186
+ * https://launchpad.net/bugs/355493
+ * SQL Constraint failure error on particular record while importing
+ * https://launchpad.net/bugs/392052
+ * Certificate in non-digit format will not be accepted
+ * https://launchpad.net/bugs/357045
+ * upgrade doesn't try to delete modules
+ * https://launchpad.net/bugs/404733
+ * ir_model : context key deletion
+ * https://launchpad.net/bugs/386273
+ * fields.related (m2o poiting to M2M/O2M should be skipped during write.
+ * https://launchpad.net/bugs/406489
+ * Accented characters are displayed on footer now
+ * https://launchpad.net/bugs/409861
+ * Context passed on copy()
+ * https://launchpad.net/bugs/389795
+ * Property : Removed old referenced values from property
+ * https://launchpad.net/bugs/384959
+ * ORM: Defult_field name in context belongs to curent object only, not to its relationals anymore
+ * https://launchpad.net/bugs/399811
+ * Print screen reports will behave acc. to locale for date,datetime
+ * https://launchpad.net/bugs/357945
+ * Export will consider float values as float and char as char
+ * https://launchpad.net/bugs/406945
+ * Importation problem for bool fields corrected
+ * https://launchpad.net/bugs/382352
+ * GIF image is previewed
+
+
+Improvements (server)
+---------------------
+
+ * Logger notification improved
+ * update po(t) files
+ * new method that allow the server to return a message that will be display on login page
+ * import/export : added Database ID, ID
+ * attributes of barcode
+ * ir_model_data: convert assert to sql constraint + exception
+ * Added new function called get_environment which will return the current environment of the System on which user is using OpenERP
+ * better error message
+ * added style for the url which are as text
+ * new method "exists" that verify that a given id exists in database (or in memory for osv_memory objects)
+ * maintenance: complete the remarks with the database name
+ * email_send: when debuging, output to the logger
+
+
+Bugfixes (addons)
+-----------------
+
+ * Not linked to a bug report:
+ * DMS directory not translatable + translations improvement
+ * Project : Searching active=no was failing, corrected
+ * problem with ncftp client
+ * stock_move auto_init function override but not return super clas result
+ * partner wasn't mandatory on sale_order, which lead to problems everywhere (stocks, shippings...) if a partner with sales was deleted. Added required=True on it to set the database field as 'not null'
+ * Product : Pricelist report corrected for suitable columns
+ * Stock : default value calculation corrected for stock move
+ * product price was wrong when margin is not set
+ * handle context when it equals None
+ * Product : Pricelist report corrected
+ * module:base_module_record fixed unicode string problem
+ * state name modified for the method - close
+ * explicit type cast for report.attendance
+ * explicit type cast
+ * module:account_voucher added confition for opening balance
+ * document: set default address to '' instead of 'localhost'
+ * fix ftp host address on Windows Vista
+ * document: better ip address detection (especially on win32)
+ * product: po file had duplicates
+ * sale_crm: typo in module description
+ * point_of_sale: if pickings are split because the sale order is not complete, invoices could not be created
+ * sale, stock: wrong translation
+ * point_of_sale: salesman_id: defaults to connected user
+ * point_of_sale: partner should be copied when creating a refund
+ * price unit calculation from context (web client issue).
+ * file attachment bug in x_object
+ * variants with extra on product list view
+ * [point_of_sale] security was not set for config/default_journal menu and pos.config.journal object
+ * fixed a bug when trying to search lines between 2 dates.
+ * on very big data, the query was way too long to execute. Speed is now greatly improved.
+ * point_of_sale: Sales of the day menu did not worked because the query did not matched any lines
+ * account: create move lines with date provide in wizard (bug reported by Alexis Deméaulte)
+ * Scheduler fix, introduced 5 days ago
+ * Translated Absences by Leaves
+ * multi-company modifs
+ * Account : Taxes Report Corrected
+ * Module: scrum,stock create task wizard in scrum and unreceived product wizard create new entry in stock
+ * typo
+ * general ledget report wizard (missing a field in view).
+ * soldeinit problem
+ * point_of_sale (receipt report): User and Date was lost
+ * changed size of receipt to fit cash register
+ * point_of_sale: invoice report should use the account.invoice object
+ * base_module_record: avoid a crash when calling a method with less than 6 arguments
+ * point_of_sale
+ * hr_holidays: wrong character in po files
+ * event: wrong character in po files
+ * work order orders
+ * stock value computation
+ * analytic account on advance invoices
+ * Analytic Analysis Stats
+ * layout of general ledger landscape
+ * bugfix in lot assignation on moves, bad signature
+ * hr_timesheet_invoice module : account_analytic_profit report sxw file--author-name= vra
+ * hr_timesheet_invoice module : account_analytic_profit report --author-name= vra
+ * crm rule : watcher email
+ * fix bug on crm rule to put proper wacher email
+ * Bug of referencing variable on split in production lot
+ * new cases should be created with the 'draft' state.
+ * account_balance Module : Fix the Total problem and Put Indentation in Reports.C
+ * onchange of product_id on stock move corrected
+ * correct display of pyflakes result quality module
+ * https://launchpad.net/bugs/310458
+ * Simplify Migrations
+ * https://launchpad.net/bugs/382641
+ * _get_stock corrected
+ * https://launchpad.net/bugs/382000
+ * remove except block from try..finally whioch is not supported in python2.4
+ * https://launchpad.net/bugs/379767
+ * Base_report_creator :Corrected Add filter wizard(ref:ACH)
+ * https://launchpad.net/bugs/373203
+ * https://launchpad.net/bugs/388346
+ * l10n_ch module : Improved Code.
+ * l10n_ch : corrected default_value method
+ * https://launchpad.net/bugs/399485
+ * point_of_sale : Pikcing display partner made from POS order.
+ * https://launchpad.net/bugs/388438
+ * Report_task : Corrected malfunctioned .po files
+ * https://launchpad.net/bugs/380480
+ * https://launchpad.net/bugs/386297
+ * purchase module : order report.
+ * Purchase: Corrected report and translation
+ * https://launchpad.net/bugs/356922
+ * Base_vat : VAT validation for Portugal,Bulgaria
+ * https://launchpad.net/bugs/397100
+ * Acccount,Account_invoice_layout : Minor necessary changes.
+ * https://launchpad.net/bugs/388347
+ * account_payment module : payment order report.
+ * account_payment : report corrected
+ * https://launchpad.net/bugs/407241
+ * sum() in query was returning null,corrected
+ * https://launchpad.net/bugs/387006
+ * Stock : context for address field on picking corrected
+ * https://launchpad.net/bugs/364010
+ * base_vat :sweden vat validation corrected
+ * https://launchpad.net/bugs/393798
+ * hr_timesheet_sheet : date interval corrected for attendances
+ * https://launchpad.net/bugs/409337
+ * https://launchpad.net/bugs/387029
+ * Account : Correction of search method arguements of account.analytic.line
+ * https://launchpad.net/bugs/394277
+ * Purchase,Product :description of POL made widen,partner_ref changes
+ * https://launchpad.net/bugs/394275
+ * Account : Charts of accounts - Tax reports corected
+ * Account : Charts of accounts - target move options corrected
+ * https://launchpad.net/bugs/404155
+ * point_of_sale :Partner info available for move line from POS,only draft/cancelled POS lines can be deleted
+ * https://launchpad.net/bugs/399824
+ * Sale : Weight field for SOL displayed
+ * https://launchpad.net/bugs/393824
+ * report_task : .po files corrected
+ * https://launchpad.net/bugs/394640
+ * Sale : sale order report corrected for translation
+ * https://launchpad.net/bugs/386513
+ * Purchase : stock moves assigned to purchase line
+ * https://launchpad.net/bugs/358302
+ * Account : Corrected bank journal code creation from template
+ * https://launchpad.net/bugs/402263
+ * Account : Invoice Lines will not be grouped if there are different maturity dates
+ * https://launchpad.net/bugs/394436
+ * Project : Xml record corrected for view
+ * https://launchpad.net/bugs/398805
+ * https://launchpad.net/bugs/338329
+ * availability of prodlot check when assigning a prodlot to a move: non optimal location_id control
+ * https://launchpad.net/bugs/391673
+ * Account :'note' field on Fiscal position,added on invoice report
+ * https://launchpad.net/bugs/391106
+ * Process : Corrected xml record
+ * https://launchpad.net/bugs/405891
+ * Module:purchase corrected delay time in picking
+ * https://launchpad.net/bugs/389540
+ * Account : Added Configuration wizard to make overdue payment report message configurable on company
+ * https://launchpad.net/bugs/400210
+ * Stock : partial packign wizard values made translated
+ * https://launchpad.net/bugs/377614
+ * https://launchpad.net/bugs/406827
+ * CRM : Mailgate script improved to have as much information on History.
+ * https://launchpad.net/bugs/404975
+ * document : create doc of any resource model with black name
+ * https://launchpad.net/bugs/401184
+ * module base_module_record Fixed when object has _rec_name
+ * https://launchpad.net/bugs/399642
+ * https://launchpad.net/bugs/393756
+ * Sale : Removed unused code
+ * https://launchpad.net/bugs/400326
+ * document : if name/dirname does not has value, dirname will be display like <objectname><id>
+ * document : use '=' operator instend of 'like' on serach directory nodes into DMS
+ * https://launchpad.net/bugs/383940
+ * Document : Logging enabled for abstracted_fs
+ * https://launchpad.net/bugs/403964
+ * STock : Locations structure wizard improved
+ * Stock: Location analysis wizard improved,date replaced by datetime field on wizard
+ * https://launchpad.net/bugs/385664
+ * Account Module : Typo corrected
+ * https://launchpad.net/bugs/380473
+ * https://launchpad.net/bugs/376804
+ * account_analytic_analysis : Months sorted
+ * https://launchpad.net/bugs/393840
+ * Account_tax_include corrected to resolve conflict with account_invoice_layout
+ * https://launchpad.net/bugs/405441
+ * delivery : context passed on picking form view
+ * https://launchpad.net/bugs/388901
+ * Product : Onchange on pricelist item corrected
+ * https://launchpad.net/bugs/395173
+ * Account : Corrected journal check on move line creation
+ * https://launchpad.net/bugs/388404
+ * report_crm,document_ics,account : Access Rules assigned
+ * Report_timesheet : Access rules
+ * https://launchpad.net/bugs/396254
+ * Account : Cancelled invoice will not be listed under unpaid state
+ * https://launchpad.net/bugs/404142
+ * point_of_sale :Partner info available for move line from POS,only draft/cancelled POS lines can be deleted
+ * https://launchpad.net/bugs/410779
+ * Document : made uninstallable
+ * https://launchpad.net/bugs/411469
+ * Wiki : Made uninstallable
+ * https://launchpad.net/bugs/394733
+ * https://launchpad.net/bugs/400093
+ * stock : Stock Valuation Entries Don't Adjust with UoM
+ * https://launchpad.net/bugs/395046
+ * Product : Corrected template view
+ * https://launchpad.net/bugs/407327
+ * CRM : Due to rules, duplicate watcher(CC) ids were entered.
+ * https://launchpad.net/bugs/389015
+ * Project : Copy Method corrected
+ * https://launchpad.net/bugs/411329
+ * module:mrp added on_change on bom_id for selecting routing
+
+
+Improvements (addons)
+---------------------
+
+ * update po(t) files
+ * Module:account Api changes def _refund_cleanup_lines(self, lines): added cr,uid arguments
+ * pyflakes test display result improve on base_module_quality
+ * crm: allow to put case description in action mail
+ * Account : Move line form view from MOVE shows date for better user readability
+ * mrp: pep8
+ * use inheritance instead of wrapping when changing behavior of services
+ * Module:Purchase Api change in inv_line_create added cr,uid parameters
+ * Improved views
+ * base_module_quality : gives warning to the user if pylint or pyflakes not installed
+ * stock: wizard_invoice_onshipping.py: pep8
+ * add base_module_quality module
+ * Sale : state name display corected
+ * Directory structure is translated to the users preference language in FTP Client
+ * reformated the wizard message
+ * account: invoice view: hide some fields to non employee users (portal i.e.)
+ * account_voucher : report voucher.
+ * mrp module : bom_structure.
+ * account module : Analytic reports.
+ * stock module : picking report.
+ * mrp Module : Production order report.
+ * account module : Tax Report.
+ * stock Module : reports.
+ * sale_delivery_report Module : Report Changes.
+ * event_certificate module : for Certificate report.
+ * purchase Module : order report and revert Changes : sale order Report.
+ * purchase,sale : order report.
+ * stock module : report improvement.
+ * stock,purchase module : report improvement.
+ * account_balance module : Improved Landscape report.
+ * account_balance Module : Report changes.
+ * account_balance Module : Minor report Change.
+ * account_balance Module : Modified reports.
+ * point_of_sale: receipt report: better date formatting
+ * point_of_sale: receipt report: Salesman instead of User
+ * module:stock improved views
+ * improved translations for crm_configuration
+
+
+
+2009-05-26: 5.0.1
+=================
+
+TODO
+
+2009-02-12: 5.0.0-3
+===================
+
+TODO
+
+2009-02-08: 5.0.0-2
+===================
+
+TODO
+
+2009-02-06: 5.0.0
+=================
+
+TODO
+
+2009-01-03: 5.0.0-rc3
+=====================
+
+TODO
+
+2008-12-22: 5.0.0-rc2
+=====================
+
+TODO
+
+2008-12-01: 5.0.0-rc1.1
+=======================
+
+TODO
+
+2008-11-28: 5.0.0-rc1
+=====================
+
+TODO
+
+2008-11-03: 5.0.0-alpha
+=======================
+
+TODO
+
=== added file 'history/Changelog-4.x'
--- history/Changelog-4.x 1970-01-01 00:00:00 +0000
+++ history/Changelog-4.x 2012-04-19 18:12:21 +0000
@@ -0,0 +1,951 @@
+4.2.1
+ Bugfixes
+ Fix context for source_count function
+ Create stock move on production for products without BOM lines
+ Add IBAN fields in bank view
+ Fix uninitialize variable in import data
+ Update due date on invoice when payment term change
+ Fix store on field function that have type many2one or one2one
+ Request summary must be truncate
+ Partner event name must be truncate
+ Remove parent field on partner contact view
+ Fix icon type on journal period
+ Remove exception on the size of char field
+ Fix reference on move line that comes from invoice (Customer != Supplier)
+ Add function search on sheet_id of timesheet_sheet
+ Don't return 0 for balance account if there is no fiscal year
+ Fix set to draft for expense, now really set to draft
+ Add product and partner in the recursive call of tax compute
+ Don't compute balance account for inactive account
+ Fix bad encoding in log message on report_sxw
+ Fix overdue report for refund lines
+ Don't start server in non secure mode if secure mode have been set
+ Fix default value of move line if move_id is not find
+ Fix _product_partner_ref for cannot concatenate 'str' and 'bool' objects
+ Add partner_id in the context of SO for browsing the product
+ Fix multi-tax code on invoice
+ Fix tax definition for Belgium chart
+ Remove compute debit/credit on inactive account
+ Fix the way the tax are rounded for invoice with tax included prices
+ Fix SO to use the right uom and price to create invoice
+ Fix on_chnage uos on SO to return the id not the browse record
+ Add condition on the button "Sending goods>Packing to be invoiced" to show
+ only customer packings
+ Fix zero division error when the quantity is zero on an invoice line
+ Fix duplicate timesheet line that have been invoiced
+ Fix invoice report for bad removeParentNode tag
+ Fix priority for product view
+ Fix tax line computation when encoding account lines manually
+ Fix refund supplier invoice to have the same journal
+ New chinese translation
+ Pass context to action_done on stock move
+ Add product_uom change on sale order line
+ Fix demo data for working time UOM
+ Fix _sheet function in timesheet_sheet when called with a list of non
+ unique id
+ Remove commit inside function validate on account move
+ Use one function to post account move
+ Fix computation of sale/purchase amount in segmentation module
+ Use standar uom converion in analytic lines
+ Add journal_id in context for account move line search in payment module
+ Fix wrong id used by pricelist based on partner form
+ Use partner reference from SO/PO for invoice name if there is one
+ Make analysis analytic module include child accounts
+
+4.2.0
+ Summary:
+ Add new view graph
+ REPORT_INTRASTAT: new module
+ KERNEL: add netrpc (speed improvement)
+ REPORT_STOCK: add report on stock by stock location and production lots
+ HR_TIMESHEET_INVOICE: add final invoice
+ MULTI_COMPANY_ACCOUNT: new module
+ ADD modules publication tools
+ KERNEL: add timezone
+ KERNEL: add concurnecy check
+ BASE: allow to specify many view_id in act_window
+ BASE: add ir.rules (acces base on record fields)
+ KERNEL: add search_count on objects
+ KERNEL: add assert tools (unit test)
+ KERNEL: improve workflow speed
+ KERNEL: move some modules to extra_addons
+ Bugfixes:
+ Fix pooler for multi-db
+ REPORT_ANALYTIC: new reports
+ BOARD_ACCOUNT: new dashboard for accountants
+ PURCHASE: allow multiple pickings for the same purchase order
+ STOCK: When refunding picking: confirm & Assign the newly generated picking
+ PRODUCT: add average price
+ STOCK: Fix workflow for stock
+ TOOLS: Fix export translate for wizard
+ KERNEL: add id in import_data
+ BASE: add history rate to currency
+ ACCOUNT: partner_id is now required for an invoice
+ HR_TIMESHEET: add exception if employee haven't product
+ I18N: new fr_CH file
+ HR_EXPENSE: fix domain
+ ACCOUNT: Fix invoice with currency and payment term
+ ACCOUNT: Fix currency
+ KERNEL: add pidfile
+ ACCOUNT,PURCHASE,SALE: use partner lang for description
+ Model Acces: Unlink permission (delete) is now available
+ KERNEL: Remove set for python2.3
+ HR: add id to Attendance menu
+ PRODUCT: add dimension to packaging
+ ACCOUNT: new cash_discount on payment term
+ KERNEL: Add price accuracy
+ BASE: Function to remove installed modules
+ REPORT_SALE: fix for sale without line
+ PURCHASE: remove use of currency
+ KERNEL: fix set without values
+ PURCHASE: fix domain pricelist
+ INVOICE: use date for currency rate
+ KERNEL: Fix import many2many by id
+ KERNEL: run the cron
+ ACCOUNT: bank statment line now have a ref t othe corresponding invoice
+ ACCOUNT: Add possibilitty to include tax amount in base amount for the computation of the next taxes
+ ACCOUNT: Add product in tax compute python code
+ KERNEL: use reportlab 2.0
+ BASE: fix import the same lang
+ ACCOUNT: fix tax code
+ ACCOUNT: define tax account for invoice and refund
+ ACCOUNT: add supplier tax to product
+ ACCOUNT: don't overwrite tax_code on the creation for account line
+ PURCHASE: use partner code for report order
+ KERNEL: fix pooler netsvc for multi-db
+ TOOLS: add ref to function tag
+ PRODUCT: fix digits on volume and weight, add weight_net
+ ACCOUNT: split to new module account_cash_discount
+ ORM : error message on python constraints are now displayed correctly
+ ACCOUNT: add partner to tax compute context
+ KERNEL: improve logger
+ PROJECT: add check_recursion for project
+ HR_TIMESHEET_INVOICE: improve create invoice
+ ACCOUNT: add product_id to analytic line create by invoice
+ KERNEL: fix the inheritance mechanism
+ KERNEL: Fix use always basename for cvs file
+ BASE: fix IBAN len to 27
+ INVOICE: fix invoice number for analytic
+ REPORT: add replace tag for custom header
+ ACCOUNT: add ref to analytic line
+ BASE: prevent exception in ir_cron
+ SALE: fix uos for tax_amount
+ MRP: fix dbname in _procure_confirm
+ HR_EXPENSE: add domain to analytic_account
+ KERNEL: use 0 instead of False for fix on _fnct_read
+ SUBSCRIPTION: add required to model
+ HR_TIMESHEET: add rounding on report
+ SALE: Fix cancel invoice and recreate invoice, now cancel also the order lines
+ STOCK-DELIVERY: add wizard invoice_onshipping from delivery to stock
+ STOCK: use tax from sale for invoice
+ BASE: improve copy of res.partner
+ ACCOUNT: pay only invoice if not in state draft
+ REPORT: fix rml translation, translate before eval
+ PRODUCT_EXTENDED: don't use seller price for bom price
+ ACCOUNT_TAX_INCLUDE: fix right amount in account move generate with tax_include
+ BASE: improve workflow print
+ SALE: fix workflow error when create invoice from wizard
+ MRP: Use company currency for Product Cost Structure
+ BASE: prevent recursion in company
+ KERNEL: Fix deleted property and many2one
+ KERNEL: allow directory for import csv
+ KERNEL: add store option to fields function
+ ACCOUNT: use property_account_tax on on_change_product
+ KERNEL: add right-click for translate label
+ KERNEL: fix log of backtrace
+ KERNEL: fix search on xxx2many
+ BASE: use tool to call popen.pipe2
+ KERNEL: fix print workflow on win32
+ BASE: fix US states
+ KERNEL: use python 2.3 format_exception
+ ACCOUNT: add multi-company into base accounting
+ KERNEL: check return code for exec_pg_command_pipe
+ KERNEL: fix search with active args
+ KERNEL: improve _sql_contsraints, now insert if doesn't exist
+ KERNEL: remove old inheritor and add _constraints and _sql_constraints to the fields inherited
+ CRM: bugfix mailgate
+ PURCHASE: fix the UOM for purchase line and improve update price unit
+ ACCOUNT: new invoice view
+ KERNEL,BASE: allow to create zip modules
+ BASE: add right-to-left
+ KERNEL: copy now ignore technical values ('create_date', 'create_uid', 'write_date' and 'write_uid')
+ ACCOUNT_TAX_INCLUDE: Now the module manage correctly the case when the taxes defined on the product differ from the taxes defined on the invoice line
+ ALL: fix colspan 3 -> 4
+ KERNEL: use context for search
+ ACCOUNT: improve speed of analytic account
+ ACCOUNT: fix search debit/credit on partner
+ ACCOUNT: fix refund invoice if no product_id nor uos_id on lines
+ MRP: fix scheduler location of product to produce and method, date of automatic orderpoint
+ KERNEL: many2many : fix unlink and link action
+ MRP: add default product_uom from context and add link from product to bom
+ PROJECT: improve speed for function fields
+ ALL: remove bad act_window name
+ KERNEL: modification for compatibility with postgres 7.4
+ KERNEL: fix size for selection field
+ KERNEL: fix compatibility for python2.5
+ KERNEL: add new win32 build script
+ KERNEL: add test for duplicate report and wizard
+ ACCOUNT: force round amount fixed in payment term
+ KERNEL: fix print screen
+ CRM: Better ergonomy
+ SERVER: add sum tag on tree view that display sum of the selected lines
+ KERNEL: allow subfield query on one2many
+ KERNEL: fix create_date and write_date as there are timestamp now
+ SERVER: improve language
+ KERNEL: fix search on fields function of type one2many, many2many
+ ACCOUNT: fix pay invoice to use period
+ ACCOUNT: add check recursion in account.tax.code
+ MRP: fix compute cycle for workcenter
+ BASE: add constraint uniq module name
+ BASE: improve update module list
+ ACCOUNT: add round to last payment term
+ KERNEL: don't modify the args of the call
+ KERNEL: don't use mutable as default value in function defintion
+ KERNEL: fix orm for sql query with reserved words
+
+16/03/2007
+4.0.3
+ Summary:
+ Improve the migration scripts
+ Some bugfixes
+ Print workflow on win32 (with ghostscript)
+
+ Bugfixes:
+ BASE: Fix "set default value"
+ HR_TIMESHEET_INVOICE: Improve invoice on timesheet
+ ACCOUNT: Fix tax amount
+ KERNEL: correct the delete for property
+ PURCHASE: fix the journal for invoice created by PO
+ KERNEL: fix the migration for id removed
+ Add id to some menuitem
+ BASE: prevent exception in ir_cron when the DB is dropped
+ HR: Fix sign-in/sign-out, the user is now allowed to provide a date in
+ the future
+ SALE: fix uos for the tax amount
+ MRP: fix wrong dbname in _procure_confirm
+ HR_EXPENSE: add domain to analytic_account
+ ACCOUNT: fix debit_get
+ SUBSCRIPTION: model is required now
+ HR_TIMESHEET: add rounding value to report
+ SALE: Fix cancel and recreate invoice, now cancel also the order lines
+ STOCK: use the tax define in sale for the invoice
+ ACCOUNT: add test to pay only if invoice not in state draft
+ KERNEL: root have access to all records
+ REPORT: fix rml translation to translate before the eval
+ ACCOUNT_TAX_INCLUDE: Use the right amount in account mmove generate
+ with tax_include
+ BASE: Improve the workflow print
+ SALE: Fix workflow error when creating invoice from the wizard
+ PRODUCT_EXTENDED: don't use pricelist to compute standard price
+ MRP: Use company currency for product cost structure
+ KERNEL: fix where clause when deleting false items
+ ACCOUNT: product source account depend on the invoice type now
+ ACCOUNT: use the property account tax for the on_change_product
+ ACCOUNT: use the invoice date for the date of analytic line
+ ACCOUNT: Fix the pay invoice when multi-currency
+ HR_TIMESHEET_PROJECT: use the right product
+ STOCK: Fix to assign picking with product consumable and call the
+ workflow
+ STOCK: Fix the split lot production
+ PURCHASE: fix workflow for purchase with manual invoice to not set
+ invoice and paid
+ DELIVERY: can use any type of journal for invoice
+ KERNEL: fix search on xxx2many
+ ACCOUNT: add id to sequence record
+ KERNEL: set properly the demo flag for module installed
+ KERNEL: Fix print workflow on win32
+ LETTER: fix print letter
+
+ Migration:
+ Fix migration for postreSQL 7.4
+ Fix the default value of demo in module
+ Fix migration of account_uos to product_uos
+
+Wed Jan 17 15:06:07 CET 2007
+4.0.2
+ Summary:
+ Improve the migration
+ Some bugfixes
+ Improve tax
+
+ Bugfixes:
+ Fix tax for invoice, refund, etc
+ SALE: fix view priority
+ PURCHASE: wizard may crash on some data
+ BASE: Fix import the same lang
+ BASE: start the cron
+ PURCHASE: fix domain for pricelist
+ KERNEL: fix object set without values
+ REPORT_SALE: fix for sale without line
+ KERNEL: add pidfile
+ BASE: remove 'set' for python2.3 compliant
+ Migration:
+ Migrate hr_timesheet user_id
+
+Fri Dec 22 12:01:26 CET 2006
+4.0.1
+ Summary:
+ Improve the migration
+ Some bugfixes
+
+ Bugfixes:
+ HR_EXPENSE: Fix domain
+ HR_TIMESHEET: Fix employee without product
+ TOOLS: Fix export translate
+ BASE: fix for concurrency of sequence number
+ MRP: fix report
+ CRM: fix graph report
+ KERNEL: fix instance of osv_pool
+ KERNEL: fix setup.py
+
+
+Mon Dec 4 18:01:55 CET 2006
+4.0.0
+ Summary:
+ Some bugfixes
+
+Tue Nov 28 14:44:20 CET 2006
+4.0.0-rc1
+ Summary:
+ This is a stable version (RC1) with lots of new features. Main
+ Improvements were:
+ Accounting: more functions, new modules, more stable
+ Much more better ergonomy
+ Lots of simplification to allows non IT people to use and
+ configure Tiny ERP: manage database, step by step configuration
+ menu, auto-installers, better help, ...
+
+ New:
+ Skill management module
+ ACCOUNT:
+ New and simpler bank statement form
+ New reports:
+ on Timesheets (analytic accounting)
+ Theorical revenue based on time spent
+ Global timesheet report by month
+ Chart of accounts
+ Different taxes methods supported
+ Gross (brut)
+ Net
+ Fixed amount
+ INVOICE:
+ invoice on shipping (manufacturing industry)
+ invoice on timesheet (services)
+ PURCHASE:
+ different invoicing control method (on order, on shipping,
+ manual)
+ Support of prices tax included /excluded in sales orders
+ New modules:
+ Sale_journal, stock_journal for bigger industries:
+ Divide works in different journals
+ New invoicing method from partner, to so, to picking
+ Daily, Monthly (grouped by partner or not)
+ New modules for prices with taxes included / excluded
+ New chart of accounts supported:
+ l10n_be/ l10n_chart_be_frnl/
+ l10n_chart_id/ l10n_chart_uk/
+ l10n_ca-qc/ l10n_chart_br/
+ l10n_chart_it/ l10n_chart_us_general/
+ l10n_ch/ l10n_chart_ca_en/
+ l10n_chart_it_cc2424/ l10n_chart_us_manufacturing/
+ l10n_ch_pcpbl_association/ l10n_chart_ca_fr/
+ l10n_chart_la/ l10n_chart_us_service/
+ l10n_ch_pcpbl_independant/ l10n_chart_ch_german/
+ l10n_chart_nl/ l10n_chart_us_ucoa/
+ l10n_ch_pcpbl_menage/ l10n_chart_cn/
+ l10n_chart_nl_standard/ l10n_chart_us_ucoa_ez/
+ l10n_ch_pcpbl_plangen/ l10n_chart_cn_traditional/
+ l10n_chart_no/ l10n_chart_ve/
+ l10n_ch_pcpbl_plangensimpl/ l10n_chart_co/
+ l10n_chart_pa/ l10n_fr/
+ l10n_ch_vat_brut/ l10n_chart_cz/
+ l10n_chart_pl/ l10n_se/
+ l10n_ch_vat_forfait/ l10n_chart_da/
+ l10n_chart_sp/ l10n_simple/
+ l10n_ch_vat_net/ l10n_chart_de_datev_skr03/
+ l10n_chart_sw/
+ l10n_chart_at/ l10n_chart_de_skr03/
+ l10n_chart_sw_church/
+ l10n_chart_au/ l10n_chart_hu/
+ l10n_chart_sw_food/
+ Step by step configuration menu
+ Setup wizard on first connection
+ Select a company profile, auto-install language, demo data, ...
+
+ Imrovements:
+ KERNEL: Demo data improved
+ Better import / export system
+ KERNEL: Multi-database management system
+ Backup, Restore, Create, Drop from the client
+ PRODUCT/PRODUCT_EXTD: Eavily change the product form, use the new
+ object to compute the pricelist
+ REPORTS:
+ Better Sale order, purchase order, invocies and customers reports
+ ACCOUNT: Support of taxes in accounts
+ management of the VAT taxes for most european countries:
+ Support of VAT codes in invoices
+ Better computation of default values in accounting entries
+ Preferences in partners, override products
+ Bugfix when closing a fiscal year
+ Better ergonomy when writting entries
+ New Module Management System:
+ Install / Upgrade new modules directly from the client
+ Install new languages
+ KERNEL:
+ Ability to add select=True at the object level for postgresql indexes
+ Bugfix in search in some inherited objects
+ Added the ability to call methods from a browse object
+ KERNEL+BASE: changed the way the migration system works for menuitems:
+ now you can change a menuitem defined elsewhere. And this will work
+ whether that menuitem has an id or not (it use the name of the
+ menuitem to find it)
+ KERNEL:
+ Installing a module from the client
+ Better Windows Auto-Installer
+ DELIVERY:
+ Delivery and invoicing on picking list
+ KERNEL:
+ Distinction between active (by default) and installable
+ ACCOUNT/PROJECT: Added support for the type of invoicing
+ CRM:
+ eMAil gateway
+ Management of different departments and sections
+ Rule system
+ About 20 new statistics reporting
+ eCommerce interface:
+ Better Joomla (virtuemart, OSCommerce) support
+ Joomla is now fully functionnal
+
+ Bugfixes:
+ ACCOUNT: tree view on reporting analytic account
+ KERNEL: Fix the bug that happened when mixing active and child_of
+ search
+ KERNEL: Check for the existance of active when computing child_of
+ PRODUCT: production computation with different UoM
+
+------------------------------------------------------------------------
+
+Fri Oct 6 14:44:05 CEST 2006
+Server 3.4.2
+ Improvements:
+ BASE: changed workflow print system so that it handles inexisting
+ workflows more gracefully (patch from Geoff Gardiner)
+ MRP: new view to take into account the orderpoint exceptions
+ MRP: made menu title more explicit
+
+ Bugfixes:
+ ACCOUNT: fixed typo in invoice + changed sxw file so that it is in
+ sync with the rml file
+ DELIVERY: fixed taxes on delivery line (patch from Brice Vissière)
+ PROJECT: skip tasks without user in Gantt charts (it crashed the report)
+ PRODUCT: fixed bug when no active pricelist version was found
+ PRODUCT_EXTENDED: correct recursive computation of the price
+ SALE: get product price from price list even when quantity is set after
+ the product is set
+ STOCK: fixed partial picking
+
+ Packaging:
+ Changed migration script so that it works on PostgreSQL 7.4
+
+------------------------------------------------------------------------
+
+Tue Sep 12 15:10:31 CEST 2006
+Server 3.4.1
+ Bugfixes:
+ ACCOUNT: fixed a bug which prevented to reconcile posted moves.
+
+------------------------------------------------------------------------
+
+Mon Sep 11 16:12:10 CEST 2006
+Server 3.4.0 (changes since 3.3.0)
+ New modules:
+ ESALE_JOOMLA: integration with Joomla CMS
+ HR_TIMESHEET_ICAL: import iCal to automatically complete timesheet
+ based on outlook meetings
+ PARTNER_LDAP: adds partner synchronization with an LDAP server
+ SALE_REBATE: adds rebates to sale orders
+
+ 4 new modules for reporting using postgresql views:
+ REPORT_CRM: reporting on CRM cases: by month, user, ...
+ REPORT_PROJECT: reporting on projects: tasks closed by project, user,
+ month, ...
+ REPORT_PURCHASE: reporting on purchases
+ REPORT_SALE: reporting on sales by periods and by product, category of
+ product, ...
+
+ New features:
+ KERNEL: Tiny ERP server and client may now communicate through HTTPS.
+ To launch the server with HTTPS, use the -S or --secure option
+ Note that if the server runs on HTTPS, the clients MUST connect
+ with the "secure" option checked.
+ KERNEL: the server can now run as a service on Windows
+ Printscreen function (Tree view print)
+ KERNEL: added a new --stop-after-init option which stops the server
+ just before it starts listening
+ KERNEL: added support for a new forcecreate attribute on XML record
+ fields: it is useful for records are in a data node marked as
+ "noupdate" but the record still needs to be added if it doesn't
+ exit yet. The typical use for that is when you add a new record
+ to a noupdate file/node.
+ KERNEL: manage SQL constraints with human-readable error message on the
+ client side, eg: Unique constraints
+ KERNEL: added a new system to be able to specify the tooltip for each
+ field in the definition of the field (by using the new help=""
+ attribute)
+ ACCOUNT: new report: aged trial balance system
+ ACCOUNT: added a wizard to pay an invoice from the invoice form
+ BASE: print on a module to print the reference guide using introspection
+ HR: added report on attendance errors
+ PRODUCT: products now support multi-Level variants
+
+ Improvements:
+ KERNEL: speed improvement in many parts of the system thanks to some
+ optimizations and a new caching system
+ KERNEL: New property system which replace the, now deprecated, ir_set
+ system. This leads to better migration of properties, more
+ practical use of them (they can be used like normal fields),
+ they can be translated, they are "multi-company aware", and
+ you can specify access rights for them on a per field basis.
+ KERNEL: Under windows, the server looks for its configuration file in
+ the "etc" sub directory (relative to the installation path).
+ This was needed so that the server can be run as a windows
+ service (using the SYSTEM profile).
+ KERNEL: added ability to import CSV files from the __terp__.py file
+ KERNEL: force freeing cursor when closing them, so that they are
+ available again immediately and not when garbage collected.
+ KERNEL: automatically drop not null/required constraints from removed
+ fields (ie which are in the database but not in the object)
+ KERNEL: added a command-line option to specify which smtp server to use
+ to send emails.
+ KERNEL: made browse_record hashable
+ ALL: removed shortcuts for the demo user.
+ ACCOUNT: better invoice report
+ ACCOUNT: Modifs for account chart, removed old stock_income account type
+ ACCOUNT: made the test_paid method on invoices more tolerant to buggy
+ data (open invoices without move/movelines)
+ ACCOUNT: better bank statement reconciliation system
+ ACCOUNT: accounting entries encoding improved a lot (using journal)
+ ACCOUNT: Adding a date and max Qty field in analytic accounts for
+ support contract
+ ACCOUNT: Adding the View type to analytic account / cost account
+ ACCOUNT: changed test_paid so that the workflow works even if there is
+ no move line
+ ACCOUNT: Cleanup credit/debit and balance computation methods. Should
+ be faster too.
+ ACCOUNT: use the normal sequence (from the journal) for the name of
+ moves generated from invoices instead of the longer name.
+ ACCOUNT: print Payment delay in invoices
+ ACCOUNT: account chart show subtotals
+ ACCOUNT: Subtotal in view accounts
+ ACCOUNT: Replaced some Typo: moves-> entries, Transaction -> entry
+ ACCOUNT: added quantities in analytic accounts view, and modified
+ cost ledger report for partners/customers
+ ACCOUNT: added default value for the currency field in invoices
+ ACCOUNT: added the comment/notes field on the invoice report
+ BASE: added menuitem (and action) to access partner functions (in the
+ definitions menu)
+ BASE: better demo data
+ BASE: duplicating a menu item now duplicates its action and submenus
+ BASE: Bank Details on Partners
+ CRM: View on all actions made on cases (used by our ISO9002 customer
+ to manage corrections to actions)
+ CRM: fixed wizard to create a sale order from a case
+ CRM: search on non active case, not desactivated by default
+ CRM: Case ID in fields with search
+ HR_TIMESHEET: new "sign_in, sign_out" using projects. It fills
+ timesheets and attendance at the same time.
+ HR_TIMESHEET: added cost unit to employee demo data
+ MRP: improvement in the scheduler
+ MRP: purchase order lines' description generated from a procurement
+ defaults to the product name instead of procurement name
+ MRP: Better traceability
+ MRP: Better view for procurement in exception
+ MRP: Added production delay in product forms. Use this delay for
+ average production delay for one product
+ MRP: dates scheduler, better computation
+ MRP: added constraint for non 0 BoM lines
+ PRODUCT: Better pricelist system (on template or variant of product)
+ PRODUCT_EXTENDED: Compute the price only if there is a supplier
+ PROJECT: when a task is closed, use the task's customer to warn the
+ customer if it is set, otherwise use the project contact.
+ PROJECT: better system to automatically send an email to the customer
+ when a task is closed or reopened.
+ PURCHASE: date_planned <= current_time line in red
+ PURCHASE: better purchase order report
+ PURCHASE: better purchase order duplication: you can now duplicate non
+ draft purchase orders and the new one will become draft.
+ SALE: better sale order report
+ SALE: better demo data for sale orders
+ SALE: better view for buttons in sale.order
+ SALE: select product => description = product name instead of code
+ SALE: warehouse field in shop is now required
+ SCRUM: lots of improvements for better useability
+ STOCK: allows to confirm empty picking lists.
+ STOCK: speed up stock computation methods
+
+ Bugfixes:
+ KERNEL: fix a huge bug in the search method for objects involving
+ "old-style" inheritance (inherits) which prevented some records
+ to be accessible in some cases. Most notable example was some
+ products were not accessible in the sale order lines if you had
+ more products in your database than the limit of your search
+ (80 by default).
+ KERNEL: fixed bug which caused OO (sxw) reports to behave badly (crash
+ on Windows and not print correctly on Linux) when data
+ contained XML entities (&, <, >)
+ KERNEL: reports are now fully concurrency compliant
+ KERNEL: fixed bug which caused menuitems without id to cause havoc on
+ update. The menuitems themselves were not created (which is
+ correct) but they created a bad "default" action for all
+ menuitems without action (such as all "menu folders").
+ KERNEL: fix a small security issue: we should check the password of the
+ user when a user asks for the result of a report (in addition
+ to the user id and id of that report)
+ KERNEL: bugfix in view inheritancy
+ KERNEL: fixed duplicating resource with a state field whose selection
+ doesn't contain a 'draft' value (for example project tasks). It
+ now uses the default value of the resource for that field.
+ KERNEL: fixed updating many2many fields using the (4, id) syntax
+ KERNEL: load/save the --logfile option correctly in the config file
+ KERNEL: fixed duplicating a resource with many2many fields
+ ALL: all properties should be inside a data tag with "noupdate" and
+ should have a forcecreate attribute.
+ ACCOUNT: fixed rounding bug in tax computation method
+ ACCOUNT: bugfix in balance and aged balance reports
+ ACCOUNT: fixing precision in function fields methods
+ ACCOUNT: fixed creation of account move lines without using the client
+ interface
+ ACCOUNT: fixed duplicating invoices
+ ACCOUNT: fixed opening an invoices whose description contained non
+ ASCII chars at specific position
+ ACCOUNT: small bugfixes in all accounting reports
+ ACCOUNT: fixed crash when --without-demo due to missing payment.term
+ ACCOUNT: fixed bug in automatic reconciliation
+ ACCOUNT: pass the address to the tax computation method so that it is
+ available in the tax "python applicable code"
+ BASE: allows to delete a request which has a history (it now deletes the
+ history as well as the request)
+ BASE: override copy method for users so that we can duplicate them
+ BASE: fixed bug when the user search for a partner by hitting on an
+ empty many2one field (it searched for a partner with ref=='')
+ BASE: making ir.sequence call thread-safe.
+ CRM: fixed a bug which introduced an invalid case state when closing a
+ case (Thanks to Leigh Willard)
+ HR: added domain to category tree view so that they are not displayed
+ twice
+ HR_TIMESHEET: fixed print graph
+ HR_TIMESHEET: fixed printing timesheet report
+ HR_TIMESHEET: Remove a timesheet entry removes the analytic line
+ MRP: bugfix on "force reservation"
+ MRP: fixed bugs in some reports and MRP scheduler when a partner has
+ no address
+ MRP: fix Force production button if no product available
+ MRP: when computing lots of procurements, the scheduler could raise
+ locking error at the database level. Fixed.
+ PRODUCT: added missing context to compute product list price
+ PRODUCT: fixed field type of qty_available and virtual_available
+ (integer->float). This prevented these fields to be displayed
+ in forms.
+ PROJECT: fixed the view of unassigned task (form and list) instead of
+ form only.
+ PURCHASE: fixed merging orders that made inventory errors when coming
+ from a procurement (orderpoint).
+ PURCHASE: fix bug which prevented to make a purchase order with
+ "manual" lines (ie without product)
+ PURCHASE: fix wizard to group purchase orders in several ways:
+ - only group orders if they are to the same location
+ - only group lines if they are the same except for qty and unit
+ - fix the workflow redirect method so that procurement are not
+ canceled when we merge orders
+ SALE: fixed duplicating a confirmed sale order
+ SALE: fixed making sale orders with "manual" lines (without product)
+ STOCK: future stock prevision bugfix (for move when date_planned < now)
+ STOCK: better view for stock.move
+ STOCK: fixed partial pickings (waiting for a production)
+ Miscellaneous minor bugfixes
+
+ Packaging:
+ Fixed bug in setup.py which didn't copy csv files nor some sub-
+ directories
+ Added a script to migrate a 3.3.0 server to 3.4.0 (you should read the
+ README file in doc/migrate/3.3.0-3.4.0)
+ Removed OsCommerce module
+
+------------------------------------------------------------------------
+
+Fri May 19 10:16:18 CEST 2006
+Server 3.3.0
+ New features:
+ NEW MODULE: hr_timesheet_project
+ Automatically maps projects and tasks to analytic account
+ So that hours spent closing tasks are automatically encoded
+ KERNEL: Added a logfile and a pidfile option (patch from Dan Horak)
+ STOCK: Added support for revisions of tracking numbers
+ STOCK: Added support for revision of production lots
+ STOCK: Added a "splitting and tracking lines" wizard
+ PRODUCT_EXTENDED: Added a method to compute the cost of a product
+ automatically from the cost of its parts
+
+ Improvements:
+ ALL: Small improvements in wizards (order of buttons)
+ PRODUCT: Remove packaging info from supplierinfo
+ PROJECT: Better task view (moved unused fields to other tab)
+ SALE: Keep formating for sale order lines' notes in the sale order report
+
+ Bugfixes:
+ KERNEL: Fixed bug which caused field names with non ascii chars didn't work
+ in list mode on Windows
+ KERNEL: Fix concurrency issue with UpdatableStr with the use of
+ threading.local
+ KERNEL: Removed browse_record __unicode__ method... It made the sale order
+ report crash when using product names with non ASCII characters
+ KERNEL: Fixed bug which caused the translation export to fail when the server
+ was not launched from the directory its source is.
+ BASE: Updating a menuitem now takes care its parent menus
+ BASE: Fixed a cursor locking issue with updates
+ BASE: Fixed viewing sequence types as a tree/list
+ HR: Month field needs to be required in the "hours spent" report
+ PURCHASE: fixed group purchase order wizard:
+ - if there were orders from several different suppliers, it created a purchase
+ order for only the first supplier but canceled other orders, even those which
+ weren't merged in the created order (closes bugzilla #236)
+ - doesn't trash "manual" lines (ie lines with no product)
+ - pay attentions to unit factors when adding several lines together
+ MRP: fixed workcenter load report (prints only the selected workcenters) and
+ does't crash if the user didn't select all workcenters
+
+ Miscellaneous:
+ Removed pydot from required dependencies
+
+------------------------------------------------------------------------
+
+Server 3.3.0-rc1
+================
+
+Changelog for Users
+-------------------
+
+New module: OS Commerce
+ Integration with Tiny ERP and OS Commerce
+ Synchronisation 100% automated with eSale;
+ Import of categories of products
+ Export of products (with photos support)
+ Import of Orders (with the eslae module)
+ Export of stock level
+ Import of OSCommerce Taxes
+ Multiple shop allowed with different rules/products
+ Simple Installation
+
+New Module: HR_TIMESHEET
+ Management by affair, timesheets creates analytic entries in the
+ accounting to get costs and revenue of each affairs. Affairs are
+ structured in trees.
+
+New Module: Account Follow Up
+ Multi-Level and configurable Follows ups for the accounting module
+
+New module; Productivity Analysis of users
+ A module to compare productivity of users of Tiny ERP
+ Generic module, you can compare everything (sales, products, partners,
+ ...)
+
+New Modules for localisations:
+ Accounting localisations for be, ca, fr, de, ch, sw
+ Fix: corrected encoding (latin1 to utf8) of Swedish account tree XML file
+
+New Module - Sandwich
+ Allows employees to order the lunch
+ Keeps employees preferences
+
+New Module TOOLS:
+ Email automatic importation/integration in the ERP
+
+New Module EDI:
+ Import of EDI sale orders
+ Export of shippings
+
+Multi-Company:
+ Tiny ERP is now fully multi-company !
+ New Company and configuration can be made in the client side.
+
+ACCOUNTING:
+ Better Entries > Standard Entries (Editable Tree, like in Excel)
+ Automatic creation of lines
+ Journal centralised or not
+ Counterpart of lines in one line or one counterpart per entry
+ Analytic accounting recoded from scratch
+ 5 new reports
+ Completly integrated with:
+ production,
+ hr_timesheet > Management by affairs
+ sales & purchases,
+ Tasks.
+ Added unreconciliation functionnalities
+ Added account tree fast rendering
+ Better tax computation system supporting worldwide specific countries
+ Better subscription system
+ Wizard to close a period
+ Wizard to clase a fiscal year
+ Very powerfull, simple and complete multi-currency system
+ in pricelists, sale order, purchases, ...
+ Added required fields in currencies (currency code)
+ Added decimal support
+ Better search on accounts (on code, shortcut or name)
+ Added constraint;
+ on users
+ on group
+ on accounts in a journal
+ added menuitem for automatic reconciliation; Multi-Levels
+ added factor to analytic units
+ added form view for budget items dotations
+ made number of digits in quantity field of the budget spread wizard coherent with the object field
+ fixed journal on purchase invoices/refunds (SugarCRM #6)
+ Better bank statement reconciliation
+ Fixed some reports
+
+STOCK:
+ Better view for location (using localisation of locations; posx, posy, posz)
+
+MARKETING:
+ fixed small bug when a partner has no adress
+ state field of marketing partner set as readonly
+ fixed marketing steps form view
+ better history view
+ disabled completely send sms wizard
+ fixed send email wizard
+ good priority -> high priority
+ fixed 'call again later' button
+
+NETWORK:
+ added tree view for login/password
+
+HR:
+ added holiday_status (=type of ...) to expense claim form view
+
+BASE (partner):
+ fixed email_send and _email_send methods
+ removed partner without addresses from demo data
+ Added a date field in the partner form
+
+MRP:
+ New report: workcenter futur loads
+ Analytic entries when production done.
+ SCHEDULER: better error msg in the generated request
+ Allows services in BoMs (for eg, subcontracting)
+
+Project/Service Management:
+ create orders from tasks; bugfixes
+ Completly integrated with the rest of the ERP
+ Services can now be MTO/MTS, Buy (subcontracting), produce (task), ...
+ Services can be used anywhere (sale.order, bom, ...)
+ See this graph;
+ http://tiny.be/download/flux/flux_procurement.png
+ tasks sorted by ... AND id, so that the order is not random
+ within a priority
+
+Automatic translations of all wizards
+
+Scrum Project Management
+ Better Ergonomy; click on a sprint to view tasks
+ Planned, Effetive hours and progress in backlog, project and sprint
+ Better Burndown Chart computation
+ Better (simpler) view of tasks
+
+Better demo Data
+ In All modules, eth converted to english
+
+PRODUCT:
+ computing the weight of the packaging
+ Added last order date
+ Alternative suppliers (with delay, prefs, ...) for one product
+
+PRICELISTS:
+ much more powerfull system
+ views simplified
+ one pricelist per usage: sale, order, pvc
+ price_type on product_view
+ Multi-Currency pricelist (EUR pricelist can depend on a $ one)
+
+HR-TIMESHEET: fixed bugs in hours report:
+ sum all lines for the same day instead of displaying only the first one
+ it now uses the analytic unit factor, so that mixing hours and days has some sense
+ close cursor
+
+SALE:
+ invoices generated from a sale order are pre-computed (taxes are computed)
+
+ new invoicing functionnality;
+ invoice on order quantities or,
+ invoice on shipped quantities
+
+ Invoice on a sale.order or a sale.order.line
+
+ added default value for uos_qty in sale order lines (default to 1)
+
+
+Changelog for Developers
+------------------------
+
+New option --debug, that opens a python interpreter when an exception
+occurs on the server side.
+
+Better wizard system. Arguements self, cr, uid, context are passed in all
+functions of the wizard like normal objects. All wizards converted.
+
+Speed improvements in many views; partners, sale.order, ...
+ less requests from client to server when opening a form
+
+Better translation system, wizard terms are exported.
+
+Script to render module dependency graph
+
+KERNEL+ALL: pass context to methods computing a selection.
+
+Modification for actions and view definitions:
+ Actions Window:
+ New field: view_mode = 'tree,form' or 'form,tree' -> default='form,tree'
+ New role of view_type: tree (with shortcuts), form (others with switch button)
+ If you need a form that opens in list mode:
+ view_mode = 'tree,form' or 'tree'
+ view_type = form
+ You can define a view in a view (for example sale.order.line in
+ sale.order)
+ less requests on the client side, no need to define 2 views
+
+Better command-line option message
+
+Fixed bug which prevented to search for names using non ASCII
+chars in many2one or many2many fields
+
+Report Engine: bugfix for concurrency
+
+Support of SQL constraints
+ Uniq, check, ...
+ Good error message in the client side (check an account entry with
+ credit and debit >0)
+
+Fixed: when an exception was raised, the cursor wasn't closed and this
+could cause a freeze in some cases
+
+Sequence can contains code: %(year)s, ... for prefix, suffix
+ EX: ORDER %(year)/0005
+
+Bugfixes for automatic migration system
+
+bugfix on default value with creation of inherits
+
+Improvement in report_sxw; you can redefine preprocess to do some
+preprocessing before printing
+
+Barcode support enabled by default
+
+Fixed OpenOffice reports when the server is not launched from the
+directory the code reside
+
+Print workflow use a pipe instead of using a temporary file (now workflows
+works on Windows Servers)
+
+Inheritancy improved (multiple arguments: replace, inside, after, before)
+
+Lots of small bugfixes
+
=== added file 'history/Changelog-6.x'
--- history/Changelog-6.x 1970-01-01 00:00:00 +0000
+++ history/Changelog-6.x 2012-04-19 18:12:21 +0000
@@ -0,0 +1,10 @@
+2010-07-XX: 6.0.0
+=================
+
+Improvements (server)
+---------------------
+
+ * support of 'ref' attribute for importing 'reference' field values, as for many2one fields.
+ * experimental xml2yml script in /tools for conversion of XML data/test files to the new YAML format
+
+
=== added file 'history/README.userchange'
--- history/README.userchange 1970-01-01 00:00:00 +0000
+++ history/README.userchange 2012-04-19 18:12:21 +0000
@@ -0,0 +1,31 @@
+Important note for OpenERP build >= 5.0.1-11xrg:
+
+THE USERNAME HAS CHANGED!!
+
+Former user "tinyerp" is now called "openerp".
+
+
+For that, you will have to make sure the following files are chowned
+to the new user:
+
+/var/log/openerp
+/var/spool/openerp
+/var/run/openerp
+/etc/openerp
+/etc/openerp/cert.cfg
+/etc/openerp-server.conf
+/etc/logrotate.d/openerp-server
+
+Then, rename the user in the postgres database:
+
+ psql -U postgres postgres
+
+ ALTER ROLE tinyerp RENAME TO openerp;
+
+Then, edit your openerp-server.conf to depict the change:
+- db_user = tinyerp
++ db_user = openerp
+
+Good luck!
+
+
=== added file 'history/change-loglevel.sh'
--- history/change-loglevel.sh 1970-01-01 00:00:00 +0000
+++ history/change-loglevel.sh 2012-04-19 18:12:21 +0000
@@ -0,0 +1,24 @@
+#!/bin/bash
+
+ADMIN_PASSWD='admin'
+method_1() {
+ cat '-' << EOF
+<xml>
+<methodCall>
+ <methodName>set_loglevel</methodName>
+ <params>
+ <param><value><string>$ADMIN_PASSWD</string></value>
+ </param>
+ <param>
+ <value><string>$1</string></value>
+ </param>
+ </params>
+</methodCall>
+EOF
+}
+LEVEL=10
+
+if [ -n "$1" ] ; then LEVEL=$1 ; fi
+
+method_1 $LEVEL | POST -c 'text/xml' http://localhost:8069/xmlrpc/common
+#eof
=== added file 'history/check_profile_l10n_all.py'
--- history/check_profile_l10n_all.py 1970-01-01 00:00:00 +0000
+++ history/check_profile_l10n_all.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,122 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+#
+# This script will automatically test all profiles, localisations and language
+# packs You must start the OpenERP server and not have a test database. You
+# may also have to change some data in the top of this file.
+#
+
+import xmlrpclib
+import time
+import base64
+
+url = 'http://localhost:8069/xmlrpc'
+profiles = [
+ 'profile_accounting',
+ 'profile_service',
+ 'profile_manufacturing'
+]
+l10n_charts = [
+ 'l10n_uk',
+ False,
+ 'l10n_be',
+ 'l10n_fr'
+]
+dbname = 'test'
+admin_passwd = 'admin'
+lang = False # List of langs of False for all
+
+
+sock = xmlrpclib.ServerProxy(url+'/object')
+sock2 = xmlrpclib.ServerProxy(url+'/db')
+sock3 = xmlrpclib.ServerProxy(url+'/common')
+sock4 = xmlrpclib.ServerProxy(url+'/wizard')
+demos = [True]
+
+langs = lang or (map(lambda x: x[0], sock2.list_lang()) + ['en_US'])
+
+def wait(id):
+ progress=0.0
+ while not progress==1.0:
+ time.sleep(3)
+ progress,users = sock2.get_progress(admin_passwd, id)
+ time.sleep(3)
+ return True
+
+def wizard_run(wizname, fieldvalues=None, endstate='end'):
+ if fieldvalues is None:
+ fieldvalues = {}
+ wiz_id = sock4.create(dbname, uid, 'admin', wizname)
+ state = 'init'
+ datas = {'form':{}}
+ while state!=endstate:
+ res = sock4.execute(dbname, uid, 'admin', wiz_id, datas, state, {})
+ if 'datas' in res:
+ datas['form'].update( res['datas'] )
+ if res['type']=='form':
+ for field in res['fields'].keys():
+ datas['form'][field] = res['fields'][field].get('value', False)
+ state = res['state'][-1][0]
+ datas['form'].update(fieldvalues)
+ elif res['type']=='state':
+ state = res['state']
+ return True
+
+for demo in demos:
+ for l10n in l10n_charts:
+ print 'Testing localisation', l10n, '...'
+ for prof in profiles:
+ print '\tTesting profile', prof, '...'
+ id = sock2.create(admin_passwd, dbname, demo, lang)
+ wait(id)
+ uid = sock3.login(dbname, 'admin','admin')
+
+ idprof = sock.execute(dbname, uid, 'admin', 'ir.module.module', 'search', [('name','=',prof)])
+ if l10n:
+ idl10n = sock.execute(dbname, uid, 'admin', 'ir.module.module', 'search', [('name','=',l10n)])
+ else:
+ idl10n = [-1]
+ wizard_run('base_setup.base_setup', {
+ 'profile': idprof[0],
+ 'charts': idl10n[0],
+ }, 'menu')
+ for lang in langs:
+ print '\t\tTesting Language', lang, '...'
+ wizard_run('module.lang.install', {'lang': lang})
+
+ ok = False
+ range = 4
+ while (not ok) and range:
+ try:
+ time.sleep(2)
+ id = sock2.drop(admin_passwd, dbname)
+ ok = True
+ except:
+ range -= 1
+ time.sleep(2)
+
+
+
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/clean-model.sql'
--- history/clean-model.sql 1970-01-01 00:00:00 +0000
+++ history/clean-model.sql 2012-04-19 18:12:21 +0000
@@ -0,0 +1,24 @@
+
+SELECT model, res_id, module FROM ir_model_data
+ WHERE model = 'ir.actions.act_window'
+ AND NOT EXISTS (SELECT 1 FROM ir_act_window WHERE id = ir_model_data.res_id);
+
+
+SELECT model, res_id, module FROM ir_model_data
+ WHERE model = 'ir.ui.menu'
+ AND NOT EXISTS (SELECT 1 FROM ir_ui_menu WHERE id = ir_model_data.res_id);
+
+SELECT model, res_id, module FROM ir_model_data
+ WHERE model = 'ir.ui.view'
+ AND NOT EXISTS (SELECT 1 FROM ir_ui_view WHERE id = ir_model_data.res_id);
+
+DONT DELETE FROM ir_model_data
+ WHERE model = 'ir.actions.act_window'
+ AND NOT EXISTS (SELECT 1 FROM ir_act_window WHERE id = ir_model_data.res_id);
+
+DONT DELETE FROM ir_model_data
+ WHERE model = 'ir.ui.menu'
+ AND NOT EXISTS (SELECT 1 FROM ir_ui_menu WHERE id = ir_model_data.res_id);
+-- Other cleanups:
+-- DELETE from ir_model_data where module = 'audittrail' AND model = 'ir.ui.view' AND NOT EXISTS( SELECT 1 FROM ir_ui_view WHERE ir_ui_view.id = ir_model_data.res_id);
+-- DELETE from ir_model_data where module = 'audittrail' AND model = 'ir.ui.menu' AND NOT EXISTS( SELECT 1 FROM ir_ui_menu WHERE id = ir_model_data.res_id);
\ No newline at end of file
=== added file 'history/gen_graph.sh'
--- history/gen_graph.sh 1970-01-01 00:00:00 +0000
+++ history/gen_graph.sh 2012-04-19 18:12:21 +0000
@@ -0,0 +1,32 @@
+#!/bin/bash
+##############################################################################
+#
+# Copyright (c) 2004-2009 TINY SPRL. (http://tiny.be)
+#
+# $Id$
+#
+# WARNING: This program as such is intended to be used by professional
+# programmers who take the whole responsability of assessing all potential
+# consequences resulting from its eventual inadequacies and bugs
+# End users who are looking for a ready-to-use solution with commercial
+# garantees and support are strongly adviced to contact a Free Software
+# Service Company
+#
+# This program is Free Software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+##############################################################################
+
+`dirname $0`/module_graph.py $@ | dot -Tpng -o > module_graph.png
+
=== added file 'history/get-srvstats.sh'
--- history/get-srvstats.sh 1970-01-01 00:00:00 +0000
+++ history/get-srvstats.sh 2012-04-19 18:12:21 +0000
@@ -0,0 +1,19 @@
+#!/bin/bash
+
+# ADMIN_PASSWD='admin'
+method_1() {
+ cat '-' << EOF
+<xml>
+<methodCall>
+ <methodName>get_stats</methodName>
+ <params>
+ </params>
+</methodCall>
+EOF
+}
+LEVEL=10
+
+if [ -n "$1" ] ; then LEVEL=$1 ; fi
+
+method_1 $LEVEL | POST -c 'text/xml' http://localhost:8069/xmlrpc/common
+#eof
=== added file 'history/list-services.sh'
--- history/list-services.sh 1970-01-01 00:00:00 +0000
+++ history/list-services.sh 2012-04-19 18:12:21 +0000
@@ -0,0 +1,16 @@
+#!/bin/bash
+
+# ADMIN_PASSWD='admin'
+method_1() {
+ cat '-' << EOF
+<xml>
+<methodCall>
+ <methodName>list_http_services</methodName>
+ <params>
+ </params>
+</methodCall>
+EOF
+}
+
+method_1 | POST -c 'text/xml' http://localhost:8069/xmlrpc/common
+#eof
=== added directory 'history/migrate'
=== added directory 'history/migrate/3.3.0-3.4.0'
=== added file 'history/migrate/3.3.0-3.4.0/README'
--- history/migrate/3.3.0-3.4.0/README 1970-01-01 00:00:00 +0000
+++ history/migrate/3.3.0-3.4.0/README 2012-04-19 18:12:21 +0000
@@ -0,0 +1,35 @@
+This document describes the steps to follow to migrate from a version 3.3.0 of Tiny ERP server to a version 3.4.0
+
+Warning: the migration scripts involved in this migration are only meant for
+a standard Tiny ERP installation. It might not work or even break some data
+if you added or modified some code to the default Tiny ERP distribution.
+
+To migrate a 3.3.0 server to version 3.4.0 you should:
+
+- stop Tiny ERP server 3.3.0
+
+- backup your database
+ For example: pg_dump terp330 > backup330.sql
+
+- run the pre.py script (located in this directory)
+ You might need to pass it some optional arguments so that it can connect
+ to the database.
+
+ For example: python pre.py -d terp330
+
+- run TinyERP server 3.4.0 with "-u all" in the parameters
+ For example: ./tinyerp-server.py -d terp330 -u all
+
+- stop TinyERP server 3.4.0
+
+- run the post.py script (located in this directory)
+
+ You might need to pass it some optional arguments so that it can connect
+ to the database.
+
+ For example: python post.py -d terp330
+
+- run TinyERP server 3.4.0 again with "-u all" in the parameters
+ For example: ./tinyerp-server.py -d terp330 -u all
+
+- you are ready to work with the new version.
=== added file 'history/migrate/3.3.0-3.4.0/post.py'
--- history/migrate/3.3.0-3.4.0/post.py 1970-01-01 00:00:00 +0000
+++ history/migrate/3.3.0-3.4.0/post.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,146 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Gaetan de Menten, <ged@xxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ------------------------------------------- #
+# convert partner payment terms to properties #
+# ------------------------------------------- #
+
+# setup
+
+cr.execute("select id from ir_model_fields where name='property_payment_term' and model='res.partner'")
+fields_id = cr.fetchone()[0]
+
+cr.execute("select company_id from res_users where company_id is not null limit 1")
+company_id = cr.fetchone()[0]
+
+# get partners
+cr.execute("SELECT c.relname FROM pg_class c, pg_attribute a WHERE c.relname='res_partner' AND a.attname='payment_term' AND c.oid=a.attrelid")
+partners=[]
+drop_payment_term=False
+if cr.rowcount:
+ drop_payment_term=True
+ cr.execute("select id, payment_term from res_partner where payment_term is not null")
+ partners = cr.dictfetchall()
+
+# loop over them
+
+for partner in partners:
+ value = 'account.payment.term,%d' % partner['payment_term']
+ res_id = 'res.partner,%d' % partner['id']
+ cr.execute(
+ "insert into ir_property(name, value, res_id, company_id, fields_id) "\
+ "values(%s, %s, %s, %d, %d)",
+ ('property_payment_term', value, res_id, company_id, fields_id))
+
+# remove the field
+if drop_payment_term:
+ cr.execute("alter table res_partner drop column payment_term")
+cr.execute("delete from ir_model_fields where model = 'res.partner' and name = 'payment_term'")
+
+cr.commit()
+
+# ------------------------ #
+# remove duplicate reports #
+# ------------------------ #
+
+cr.execute("select model, report_name from ir_act_report_xml group by model, report_name having count(*)>1")
+reports_wh_duplicates = cr.dictfetchall()
+
+cr.execute("select res_id from ir_model_data where model='ir.actions.report.xml'")
+registered_reports = cr.fetchall()
+reg_reports_ids = ','.join([str(id) for (id,) in registered_reports])
+
+for report in reports_wh_duplicates:
+ cr.execute("select id from ir_act_report_xml where model=%s and report_name=%s and id not in ("+reg_reports_ids+")", (report['model'], report['report_name']))
+ (id,) = cr.fetchone()
+ cr.execute("delete from ir_act_report_xml where id=%d", (id,))
+ cr.execute("delete from ir_values where value='ir.actions.report.xml,%d'", (id,))
+
+cr.commit()
+
+# ------------------------------------- #
+# remove duplicate workflow transitions #
+# ------------------------------------- #
+
+# this removes all transitions which are not registered in ir_model_data
+
+cr.execute("delete from wkf_transition where id not in (select res_id from ir_model_data where model='workflow.transition')")
+cr.commit()
+
+# -------------------------------- #
+# remove bad "default" menu action #
+# -------------------------------- #
+
+cr.execute("delete from ir_values where key='action' and model='ir.ui.menu' and res_id is null")
+cr.commit()
+
+cr.close()
+
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/migrate/3.3.0-3.4.0/pre.py'
--- history/migrate/3.3.0-3.4.0/pre.py 1970-01-01 00:00:00 +0000
+++ history/migrate/3.3.0-3.4.0/pre.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,112 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Gaetan de Menten, <ged@xxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ------------------------- #
+# change some columns types #
+# ------------------------- #
+
+def change_column(cr, table, column, new_type, copy):
+ commands = [
+ "ALTER TABLE %s RENAME COLUMN %s TO temp_column" % (table, column),
+ "ALTER TABLE %s ADD COLUMN %s %s" % (table, column, new_type),
+ "ALTER TABLE %s DROP COLUMN temp_column" % table
+ ]
+ if copy:
+ commands.insert(
+ 2,
+ "UPDATE %s SET %s=temp_column::%s" % (table, column, new_type))
+
+ for command in commands:
+ cr.execute(command)
+
+change_column(cr, 'account_account_type', 'code_from', 'varchar(10)', False)
+change_column(cr, 'account_account_type', 'code_to', 'varchar(10)', False)
+cr.commit()
+
+# ----------------------------------------------------- #
+# add some fields (which cannot be added automatically) #
+# ----------------------------------------------------- #
+
+for line in (
+ "alter table ir_model_fields add group_name varchar(64)",
+ "alter table ir_model_fields add view_load boolean",
+ "alter table ir_model_fields alter group_name set default ''",
+ "alter table ir_model_fields alter view_load set default False",
+ "delete from ir_values where value like '%,False'",
+ ):
+ try:
+ cr.execute(line)
+ except psycopg.ProgrammingError, e:
+ cr.commit()
+ print e
+
+cr.commit()
+cr.close()
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added directory 'history/migrate/3.4.0-4.0.0'
=== added file 'history/migrate/3.4.0-4.0.0/README'
--- history/migrate/3.4.0-4.0.0/README 1970-01-01 00:00:00 +0000
+++ history/migrate/3.4.0-4.0.0/README 2012-04-19 18:12:21 +0000
@@ -0,0 +1,29 @@
+This document describes the steps to follow to migrate from a version 3.4.0 of Tiny ERP server to a version 4.0.0
+
+Warning: the migration scripts involved in this migration are only meant for
+a standard Tiny ERP installation. It might not work or even break some data
+if you added or modified some code to the default Tiny ERP distribution.
+
+To migrate a 3.4.0 server to version 4.0.0 you should:
+
+- stop Tiny ERP server 3.4.0
+
+- backup your database
+ For example: pg_dump terp340 > backup340.sql
+
+- run the pre.py script (located in this directory)
+ You might need to pass it some optional arguments so that it can connect
+ to the database.
+
+ For example: python pre.py -d terp340
+
+- run TinyERP server 4.0.0 with "-d terp340 -u all" in the parameters
+ For example: ./tinyerp-server.py -d terp340 -u all
+
+- stop TinyERP server 4.0.0
+
+- run the post.py script (located in this directory)
+ You might need to pass it some optional arguments so that it can connect
+ to the database.
+
+- you are ready to work with the new version.
=== added file 'history/migrate/3.4.0-4.0.0/post-tiny.py'
--- history/migrate/3.4.0-4.0.0/post-tiny.py 1970-01-01 00:00:00 +0000
+++ history/migrate/3.4.0-4.0.0/post-tiny.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,87 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Gaetan de Menten, <ged@xxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# --------------- #
+# remove old menu #
+# --------------- #
+
+cr.execute("delete from ir_ui_menu where (id not in (select parent_id from ir_ui_menu where parent_id is not null)) and (id not in (select res_id from ir_values where model='ir.ui.menu'))")
+cr.commit()
+
+# --------------- #
+# remove ir_value #
+# --------------- #
+
+cr.execute("delete from ir_values where model = 'ir.ui.menu' and res_id is null")
+cr.commit()
+
+cr.close()
+
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/migrate/3.4.0-4.0.0/post.py'
--- history/migrate/3.4.0-4.0.0/post.py 1970-01-01 00:00:00 +0000
+++ history/migrate/3.4.0-4.0.0/post.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,116 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Gaetan de Menten, <ged@xxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ---------------------------------------------------------------- #
+# move user id from hr_analytic_timesheet to account_analytic_line #
+# ---------------------------------------------------------------- #
+
+cr.execute("UPDATE account_analytic_line SET user_id = hr_analytic_timesheet.user_id FROM hr_analytic_timesheet WHERE hr_analytic_timesheet.line_id = account_analytic_line.id")
+cr.commit()
+
+# --------------- #
+# remove old menu #
+# --------------- #
+
+while True:
+ cr.execute("select id from ir_ui_menu where (id not in (select parent_id from ir_ui_menu where parent_id is not null)) and (id not in (select res_id from ir_values where model='ir.ui.menu'))")
+ if not cr.rowcount:
+ break
+ cr.execute("delete from ir_ui_menu where (id not in (select parent_id from ir_ui_menu where parent_id is not null)) and (id not in (select res_id from ir_values where model='ir.ui.menu'))")
+cr.commit()
+
+# ----------------------------------------- #
+# add default value for discount in invoice #
+# ----------------------------------------- #
+
+cr.execute("update account_invoice_line set discount=0.0 where discount is null;")
+cr.commit()
+
+
+# -------------------------------------------------------------------------- #
+# update constraint account_invoice_line_uos_id_fkey on account_invoice_line #
+# -------------------------------------------------------------------------- #
+
+cr.execute("ALTER TABLE account_invoice_line DROP CONSTRAINT account_invoice_line_uos_id_fkey")
+cr.execute("ALTER TABLE account_invoice_line ADD FOREIGN KEY (uos_id) REFERENCES product_uom(id) ON DELETE SET NULL")
+cr.commit()
+
+print """
+WARNING: account_uos has been replaced by product_uom.
+It is not possible to migrate the data automatically so you need to create the old account_uos in the new product_uom.
+And then update the field uos_id of the table account_invoice to match the new id of product_uom.
+
+EXAMPLE:
+ UPDATE account_invoice SET uos_id = new_id WHERE uos_id = old_id;
+"""
+
+cr.close()
+
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/migrate/3.4.0-4.0.0/pre-tiny.py'
--- history/migrate/3.4.0-4.0.0/pre-tiny.py 1970-01-01 00:00:00 +0000
+++ history/migrate/3.4.0-4.0.0/pre-tiny.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,145 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Gaetan de Menten, <ged@xxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ------------------------- #
+# change some columns types #
+# ------------------------- #
+
+def change_column(cr, table, column, new_type, copy):
+ commands = [
+ "ALTER TABLE %s RENAME COLUMN %s TO temp_column" % (table, column),
+ "ALTER TABLE %s ADD COLUMN %s %s" % (table, column, new_type),
+ "ALTER TABLE %s DROP COLUMN temp_column" % table
+ ]
+ if copy:
+ commands.insert(
+ 2,
+ "UPDATE %s SET %s=temp_column::%s" % (table, column, new_type))
+
+ for command in commands:
+ cr.execute(command)
+
+#change_column(cr, 'crm_case', 'date_closed', 'timestamp', True)
+cr.commit()
+
+# -------------------- #
+# add module if needed #
+# -------------------- #
+
+cr.execute("SELECT name FROM ir_module_module")
+if not cr.rowcount:
+ for module in set(['base', 'marketing', 'subscription', 'account', 'base_partner_relation', 'audittrail', 'account_followup', 'product', 'hr', 'l10n_simple', 'crm', 'stock', 'hr_timesheet', 'purchase', 'report_purchase', 'mrp', 'sale', 'report_sale', 'delivery', 'project', 'sale_crm', 'hr_timesheet_project', 'scrum', 'report_project',
+'account_followup',
+'account',
+'audittrail',
+'base_partner_relation',
+'crm',
+'delivery',
+'edi',
+'hr_evaluation',
+'hr_expense',
+'hr',
+'hr_timesheet_invoice',
+'hr_timesheet_project',
+'hr_timesheet',
+'l10n_simple',
+'marketing',
+'mrp',
+'network',
+'product',
+'project',
+'purchase',
+'report_crm',
+'report_project',
+'report_purchase',
+'report_sale',
+'sale_crm',
+'sale',
+'sandwich',
+'scrum',
+'stock']):
+ cr.execute("INSERT INTO ir_module_module (name, state) VALUES ('%s', 'installed')" % module)
+ cr.commit()
+
+
+# ----------------------------------------------------- #
+# add some fields (which cannot be added automatically) #
+# ----------------------------------------------------- #
+
+for line in (
+ "ALTER TABLE ir_module_module ADD demo BOOLEAN DEFAULT False",
+ "delete from ir_values where value like '%,False'",
+ """UPDATE ir_ui_view set arch='<?xml version="1.0"?><tree string="Menu" toolbar="1"><field icon="icon" name="name"/></tree>' where name='ir.ui.menu.tree' and type='tree' and field_parent='child_id'""",
+ ):
+ cr.execute(line)
+
+cr.commit()
+cr.close()
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/migrate/3.4.0-4.0.0/pre.py'
--- history/migrate/3.4.0-4.0.0/pre.py 1970-01-01 00:00:00 +0000
+++ history/migrate/3.4.0-4.0.0/pre.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,127 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Gaetan de Menten, <ged@xxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ------------------------- #
+# change some columns types #
+# ------------------------- #
+
+def change_column(cr, table, column, new_type, copy):
+ commands = [
+ "ALTER TABLE %s RENAME COLUMN %s TO temp_column" % (table, column),
+ "ALTER TABLE %s ADD COLUMN %s %s" % (table, column, new_type),
+ "ALTER TABLE %s DROP COLUMN temp_column" % table
+ ]
+ if copy:
+ commands.insert(
+ 2,
+ "UPDATE %s SET %s=temp_column::%s" % (table, column, new_type))
+
+ for command in commands:
+ cr.execute(command)
+
+change_column(cr, 'crm_case', 'date_closed', 'timestamp', True)
+cr.commit()
+
+# -------------------- #
+# add module if needed #
+# -------------------- #
+
+cr.execute("SELECT name FROM ir_module_module")
+if not cr.rowcount:
+ for module in ('base', 'marketing', 'subscription', 'account', 'base_partner_relation', 'audittrail', 'account_followup', 'product', 'hr', 'l10n_simple', 'crm', 'stock', 'hr_timesheet', 'purchase', 'report_purchase', 'mrp', 'sale', 'report_sale', 'delivery', 'project', 'sale_crm', 'hr_timesheet_project', 'scrum', 'report_project'):
+ cr.execute("INSERT INTO ir_module_module (name, state) VALUES ('%s', 'installed')" % module)
+ cr.commit()
+
+# --------------- #
+# remove old menu #
+# --------------- #
+
+while True:
+ cr.execute("select id from ir_ui_menu where id not in (select parent_id from ir_ui_menu where parent_id is not null) and id not in (select res_id from ir_model_data where model='ir.ui.menu')")
+ if not cr.rowcount:
+ break
+ cr.execute("delete from ir_ui_menu where id not in (select parent_id from ir_ui_menu where parent_id is not null) and id not in (select res_id from ir_model_data where model='ir.ui.menu')")
+cr.commit()
+
+# ----------------------------------------------------- #
+# add some fields (which cannot be added automatically) #
+# ----------------------------------------------------- #
+
+for line in (
+ "ALTER TABLE ir_module_module ADD demo BOOLEAN",
+ "ALTER TABLE ir_module_module SET demo DEFAULT False",
+ "DELETE FROM ir_values WHERE VALUE LIKE '%,False'",
+ """UPDATE ir_ui_view set arch='<?xml version="1.0"?><tree string="Menu" toolbar="1"><field icon="icon" name="name"/></tree>' where name='ir.ui.menu.tree' and type='tree' and field_parent='child_id'""",
+ ):
+ cr.execute(line)
+
+cr.commit()
+cr.close()
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added directory 'history/migrate/4.0.0-4.2.0'
=== added file 'history/migrate/4.0.0-4.2.0/pre.py'
--- history/migrate/4.0.0-4.2.0/pre.py 1970-01-01 00:00:00 +0000
+++ history/migrate/4.0.0-4.2.0/pre.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,247 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Cédric Krier, <ced@xxxxxxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ------------------------ #
+# change currency rounding #
+# ------------------------ #
+
+cr.execute("""SELECT c.relname,a.attname,a.attlen,a.atttypmod,a.attnotnull,a.atthasdef,t.typname,CASE WHEN a.attlen=-1 THEN a.atttypmod-4 ELSE a.attlen END as size FROM pg_class c,pg_attribute a,pg_type t WHERE c.relname='res_currency' AND a.attname='rounding' AND c.oid=a.attrelid AND a.atttypid=t.oid""")
+res = cr.dictfetchall()
+if res[0]['typname'] != 'numeric':
+ for line in (
+ "ALTER TABLE res_currency RENAME rounding TO rounding_bak",
+ "ALTER TABLE res_currency ADD rounding NUMERIC(12,6)",
+ "UPDATE res_currency SET rounding = power(10, - rounding_bak)",
+ "ALTER TABLE res_currency DROP rounding_bak",
+ ):
+ cr.execute(line)
+cr.commit()
+
+# ----------------------------- #
+# drop constraint on ir_ui_view #
+# ----------------------------- #
+
+cr.execute('SELECT conname FROM pg_constraint where conname = \'ir_ui_view_type\'')
+if cr.fetchall():
+ cr.execute('ALTER TABLE ir_ui_view DROP CONSTRAINT ir_ui_view_type')
+cr.commit()
+
+# ------------------------ #
+# update res.partner.bank #
+# ------------------------ #
+
+cr.execute('SELECT a.attname FROM pg_class c, pg_attribute a WHERE c.relname = \'res_partner_bank\' AND a.attname = \'iban\' AND c.oid = a.attrelid')
+if cr.fetchall():
+ cr.execute('ALTER TABLE res_partner_bank RENAME iban TO acc_number')
+cr.commit()
+
+# ------------------------------------------- #
+# Add perm_id to ir_model and ir_model_fields #
+# ------------------------------------------- #
+
+cr.execute('SELECT a.attname FROM pg_class c, pg_attribute a WHERE c.relname = \'ir_model\' AND a.attname = \'perm_id\' AND c.oid = a.attrelid')
+if not cr.fetchall():
+ cr.execute("ALTER TABLE ir_model ADD perm_id int references perm on delete set null")
+cr.commit()
+
+cr.execute('SELECT a.attname FROM pg_class c, pg_attribute a WHERE c.relname = \'ir_model_fields\' AND a.attname = \'perm_id\' AND c.oid = a.attrelid')
+if not cr.fetchall():
+ cr.execute("ALTER TABLE ir_model_fields ADD perm_id int references perm on delete set null")
+cr.commit()
+
+
+# --------------------------------- #
+# remove name for all ir_act_window #
+# --------------------------------- #
+
+cr.execute("UPDATE ir_act_window SET name = ''")
+cr.commit()
+
+# ------------------------------------------------------------------------ #
+# Create a "allow none" default access to keep the behaviour of the system #
+# ------------------------------------------------------------------------ #
+
+cr.execute('SELECT model_id FROM ir_model_access')
+res= cr.fetchall()
+for r in res:
+ cr.execute('SELECT id FROM ir_model_access WHERE model_id = %d AND group_id IS NULL', (r[0],))
+ if not cr.fetchall():
+ cr.execute("INSERT into ir_model_access (name,model_id,group_id) VALUES ('Auto-generated access by migration',%d,NULL)",(r[0],))
+cr.commit()
+
+# ------------------------------------------------- #
+# Drop view report_account_analytic_line_to_invoice #
+# ------------------------------------------------- #
+
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_account_analytic_line_to_invoice\'')
+if cr.fetchall():
+ cr.execute('DROP VIEW report_account_analytic_line_to_invoice')
+cr.commit()
+
+# --------------------------- #
+# Drop state from hr_employee #
+# --------------------------- #
+
+cr.execute('SELECT * FROM pg_class c, pg_attribute a WHERE c.relname=\'hr_employee\' AND a.attname=\'state\' AND c.oid=a.attrelid')
+if cr.fetchall():
+ cr.execute('ALTER TABLE hr_employee DROP state')
+cr.commit()
+
+# ------------ #
+# Add timezone #
+# ------------ #
+
+cr.execute('SELECT id FROM ir_values where model=\'res.users\' AND key=\'meta\' AND name=\'tz\'')
+if not cr.fetchall():
+ import pytz, pickle
+ meta = pickle.dumps({'type':'selection', 'string':'Timezone', 'selection': [(x, x) for x in pytz.all_timezones]})
+ value = pickle.dumps(False)
+ cr.execute('INSERT INTO ir_values (name, key, model, meta, key2, object, value) VALUES (\'tz\', \'meta\', \'res.users\', %s, \'tz\', %s, %s)', (meta,False, value))
+cr.commit()
+
+# ------------------------- #
+# change product_uom factor #
+# ------------------------- #
+
+cr.execute('SELECT a.attname FROM pg_class c, pg_attribute a, pg_type t WHERE c.relname = \'product_uom\' AND a.attname = \'factor\' AND c.oid = a.attrelid AND a.atttypid = t.oid AND t.typname = \'float8\'')
+if cr.fetchall():
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_account_analytic_planning_stat_account\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_account_analytic_planning_stat_account')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_account_analytic_planning_stat\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_account_analytic_planning_stat')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_account_analytic_planning_stat_user\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_account_analytic_planning_stat_user')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_purchase_order_product\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_purchase_order_product')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_purchase_order_category\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_purchase_order_category')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_sale_order_product\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_sale_order_product')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_sale_order_category\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_sale_order_category')
+ cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_hr_timesheet_invoice_journal\'')
+ if cr.fetchall():
+ cr.execute('DROP VIEW report_hr_timesheet_invoice_journal')
+
+ cr.execute('ALTER TABLE product_uom RENAME COLUMN factor to temp_column')
+ cr.execute('ALTER TABLE product_uom ADD COLUMN factor NUMERIC(12,6)')
+ cr.execute('UPDATE product_uom SET factor = temp_column')
+ cr.execute('ALTER TABLE product_uom ALTER factor SET NOT NULL')
+ cr.execute('ALTER TABLE product_uom DROP COLUMN temp_column')
+cr.commit()
+
+
+# ------------------------------------------------- #
+# Drop name_uniq constraint on stock_production_lot #
+# ------------------------------------------------- #
+
+cr.execute('SELECT conname FROM pg_constraint where conname = \'stock_production_lot_name_uniq\'')
+if cr.fetchall():
+ cr.execute('ALTER TABLE stock_production_lot DROP CONSTRAINT stock_production_lot_name_uniq')
+cr.commit()
+
+# ------------------------------------ #
+# Put country/state code in upper case #
+# ------------------------------------ #
+
+cr.execute('UPDATE res_country SET code = UPPER(code)')
+cr.execute('UPDATE res_country_state SET code = UPPER(code)')
+cr.commit()
+
+# --------------------------------------------- #
+# Add primary key on tables inherits ir_actions #
+# --------------------------------------------- #
+
+cr.execute('SELECT indexname FROm pg_indexes WHERE indexname = \'ir_act_report_xml_pkey\' and tablename = \'ir_act_report_xml\'')
+if not cr.fetchall():
+ cr.execute('ALTER TABLE ir_act_report_xml ADD PRIMARY KEY (id)')
+cr.execute('SELECT indexname FROm pg_indexes WHERE indexname = \'ir_act_report_custom_pkey\' and tablename = \'ir_act_report_custom\'')
+if not cr.fetchall():
+ cr.execute('ALTER TABLE ir_act_report_custom ADD PRIMARY KEY (id)')
+cr.execute('SELECT indexname FROm pg_indexes WHERE indexname = \'ir_act_group_pkey\' and tablename = \'ir_act_group\'')
+if not cr.fetchall():
+ cr.execute('ALTER TABLE ir_act_group ADD PRIMARY KEY (id)')
+cr.execute('SELECT indexname FROm pg_indexes WHERE indexname = \'ir_act_execute_pkey\' and tablename = \'ir_act_execute\'')
+if not cr.fetchall():
+ cr.execute('ALTER TABLE ir_act_execute ADD PRIMARY KEY (id)')
+cr.execute('SELECT indexname FROm pg_indexes WHERE indexname = \'ir_act_wizard_pkey\' and tablename = \'ir_act_wizard\'')
+if not cr.fetchall():
+ cr.execute('ALTER TABLE ir_act_wizard ADD PRIMARY KEY (id)')
+cr.commit()
+
+cr.close
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added directory 'history/migrate/4.0.0-4.2.0/tiny'
=== added file 'history/migrate/4.0.0-4.2.0/tiny/README'
--- history/migrate/4.0.0-4.2.0/tiny/README 1970-01-01 00:00:00 +0000
+++ history/migrate/4.0.0-4.2.0/tiny/README 2012-04-19 18:12:21 +0000
@@ -0,0 +1,1 @@
+Those scripts are provide as example of customization of migration scripts
=== added file 'history/migrate/4.0.0-4.2.0/tiny/pre-tiny.py'
--- history/migrate/4.0.0-4.2.0/tiny/pre-tiny.py 1970-01-01 00:00:00 +0000
+++ history/migrate/4.0.0-4.2.0/tiny/pre-tiny.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,188 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__author__ = 'Cédric Krier, <ced@xxxxxxxxxxx>'
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+raise Exception('This script is provided as an example, you must custom it before')
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# fix country
+
+
+cr.execute('SELECT code from res_country where code is not null group by code')
+res = cr.fetchall()
+
+for c in res:
+ cr.execute('SELECT max(id) from res_country where code = %s group by code', (c[0],))
+ res2 = cr.fetchone()
+ cr.execute('SELECT id from res_country where code = %s', (c[0],))
+ ids = ','.join(map(lambda x: str(x[0]), cr.fetchall()))
+ cr.execute('UPDATE res_partner_address set country_id = %d where country_id in ('+ids+')', (res2[0],))
+ cr.execute('DELETE FROM res_country WHERE code = %s and id <> %d', (c[0], res2[0],))
+cr.commit()
+
+
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_account_analytic_planning_stat\'')
+if cr.fetchall():
+ cr.execute('DROP VIEW report_account_analytic_planning_stat')
+cr.commit()
+
+
+cr.execute('SELECT name from ( SELECT name, count(name) AS n FROM res_partner GROUP BY name ) AS foo WHERE n > 1')
+res = cr.fetchall()
+
+
+for p in res:
+ cr.execute('SELECT max(id) FROM res_partner WHERE name = %s GROUP BY name', (p[0],))
+ res2 = cr.fetchone()
+ cr.execute('UPDATE res_partner set active = False WHERE name = %s and id <> %d', (p[0], res2[0],))
+ cr.execute('SELECT id FROM res_partner WHERE name = %s AND id <> %d', (p[0], res2[0],))
+ res3 = cr.fetchall()
+ i = 0
+ for id in res3:
+ name = p[0]+' old'
+ if i:
+ name = name + ' ' + str(i)
+ cr.execute('UPDATE res_partner set name = %s WHERE id = %d', (name, id[0]))
+ i += 1
+cr.commit()
+
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_account_analytic_line_to_invoice\'')
+if cr.fetchall():
+ cr.execute('DROP VIEW report_account_analytic_line_to_invoice')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_timesheet_invoice\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_timesheet_invoice')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_purchase_order_category\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_purchase_order_category')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_purchase_order_product\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_purchase_order_product')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_sale_order_category\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_sale_order_category')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_sale_order_product\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_sale_order_product')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_timesheet_user\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_timesheet_user')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'report_task_user_pipeline_open\'')
+if cr.fetchall():
+ cr.execute('drop VIEW report_task_user_pipeline_open')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'hr_timesheet_sheet_sheet_day\'')
+if cr.fetchall():
+ cr.execute('drop VIEW hr_timesheet_sheet_sheet_day')
+cr.execute('SELECT viewname FROM pg_views WHERE viewname = \'hr_timesheet_sheet_sheet_account\'')
+if cr.fetchall():
+ cr.execute('drop VIEW hr_timesheet_sheet_sheet_account')
+cr.execute('SELECT viewname from pg_views where viewname = \'sale_journal_sale_stats\'')
+if cr.fetchall():
+ cr.execute('drop VIEW sale_journal_sale_stats')
+cr.execute('SELECT viewname from pg_views where viewname = \'sale_journal_picking_stats\'')
+if cr.fetchall():
+ cr.execute('drop VIEW sale_journal_picking_stats')
+cr.execute('SELECT viewname from pg_views where viewname = \'sale_journal_invoice_type_stats\'')
+if cr.fetchall():
+ cr.execute('drop VIEW sale_journal_invoice_type_stats')
+
+cr.execute('ALTER TABLE product_template ALTER list_price TYPE numeric(16,2)')
+cr.execute('ALTER TABLE product_template ALTER standard_price TYPE numeric(16,2)')
+cr.execute('ALTER TABLE product_product ALTER price_extra TYPE numeric(16,2)')
+cr.execute('ALTER TABLE product_product ALTER price_margin TYPE numeric(16,2)')
+cr.execute('ALTER TABLE pricelist_partnerinfo ALTER price TYPE numeric(16,2)')
+cr.execute('ALTER TABLE account_invoice_line ALTER price_unit TYPE numeric(16,2)')
+cr.execute('ALTER TABLE purchase_order_line ALTER price_unit TYPE numeric(16,2)')
+cr.execute('ALTER TABLE sale_order_line ALTER price_unit TYPE numeric(16,2)')
+cr.commit()
+
+
+cr.execute('SELECT tablename FROM pg_tables WHERE tablename = \'subscription_document_fields\'')
+if cr.fetchall():
+ cr.execute('DROP TABLE subscription_document_fields')
+cr.execute('SELECT tablename FROM pg_tables WHERE tablename = \'subscription_document\'')
+if cr.fetchall():
+ cr.execute('DROP TABLE subscription_document')
+cr.execute('SELECT tablename FROM pg_tables WHERE tablename = \'subscription_subscription_history\'')
+if cr.fetchall():
+ cr.execute('DROP TABLE subscription_subscription_history')
+cr.commit()
+
+# -------------------- #
+# Change currency rate #
+# -------------------- #
+
+cr.execute('SELECT a.attname FROM pg_class c, pg_attribute a WHERE c.relname = \'res_currency_rate\' AND a.attname = \'rate_old\' AND c.oid = a.attrelid')
+if not cr.fetchall():
+ cr.execute('ALTER TABLE res_currency_rate ADD rate_old NUMERIC(12,6)')
+ cr.execute('UPDATE res_currency_rate SET rate_old = rate')
+ cr.execute('UPDATE res_currency_rate SET rate = (1 / rate_old)')
+cr.commit()
+
+cr.close
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added directory 'history/migrate/4.2.0-4.4.0'
=== added file 'history/migrate/4.2.0-4.4.0/pre.py'
--- history/migrate/4.2.0-4.4.0/pre.py 1970-01-01 00:00:00 +0000
+++ history/migrate/4.2.0-4.4.0/pre.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,110 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+__version__ = '0.1.0'
+
+import psycopg
+import optparse
+import ConfigParser
+
+# -----
+
+parser = optparse.OptionParser(version="Tiny ERP server migration script " + __version__)
+
+parser.add_option("-c", "--config", dest="config", help="specify path to Tiny ERP config file")
+
+group = optparse.OptionGroup(parser, "Database related options")
+group.add_option("--db_host", dest="db_host", help="specify the database host")
+group.add_option("--db_port", dest="db_port", help="specify the database port")
+group.add_option("-d", "--database", dest="db_name", help="specify the database name")
+group.add_option("-r", "--db_user", dest="db_user", help="specify the database user name")
+group.add_option("-w", "--db_password", dest="db_password", help="specify the database password")
+parser.add_option_group(group)
+
+options = optparse.Values()
+options.db_name = 'terp' # default value
+parser.parse_args(values=options)
+
+if hasattr(options, 'config'):
+ configparser = ConfigParser.ConfigParser()
+ configparser.read([options.config])
+ for name, value in configparser.items('options'):
+ if not (hasattr(options, name) and getattr(options, name)):
+ if value in ('true', 'True'):
+ value = True
+ if value in ('false', 'False'):
+ value = False
+ setattr(options, name, value)
+
+# -----
+
+host = hasattr(options, 'db_host') and "host=%s" % options.db_host or ''
+port = hasattr(options, 'db_port') and "port=%s" % options.db_port or ''
+name = "dbname=%s" % options.db_name
+user = hasattr(options, 'db_user') and "user=%s" % options.db_user or ''
+password = hasattr(options, 'db_password') and "password=%s" % options.db_password or ''
+
+db = psycopg.connect('%s %s %s %s %s' % (host, port, name, user, password), serialize=0)
+cr = db.cursor()
+
+# ------------------------------ #
+# drop not null on ir_attachment #
+# ------------------------------ #
+
+cr.execute('ALTER TABLE ir_attachment \
+ ALTER COLUMN res_model DROP NOT NULL, \
+ ALTER COLUMN res_id DROP NOT NULL')
+cr.commit()
+
+# ---------------------------------- #
+# change case date_deadline rounding #
+# ---------------------------------- #
+
+cr.execute("""SELECT
+c.relname,a.attname,a.attlen,a.atttypmod,a.attnotnull,a.atthasdef,t.typname,CASE
+WHEN a.attlen=-1 THEN a.atttypmod-4 ELSE a.attlen END as size FROM pg_class
+c,pg_attribute a,pg_type t WHERE c.relname='crm_case' AND
+a.attname='date_deadline' AND c.oid=a.attrelid AND a.atttypid=t.oid""")
+
+res = cr.dictfetchall()
+if res[0]['typname'] != 'timestamp':
+ for line in (
+ "ALTER TABLE crm_case RENAME date_deadline TO date_deadline_bak",
+ "ALTER TABLE crm_case ADD date_deadline timestamp",
+ "UPDATE crm_case SET date_deadline = date_deadline_bak",
+ "ALTER TABLE crm_case DROP date_deadline_bak",
+ ):
+ cr.execute(line)
+cr.commit()
+
+cr.execute('drop view report_task_user_pipeline_open');
+cr.commit()
+
+cr.execute('alter table ir_model_fields add state varchar(26)')
+cr.execute('alter table ir_model_fields add select_level varchar(3)')
+cr.execute('alter table ir_act_wizard add primary key(id)')
+cr.commit()
+
+
+cr.close()
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/module_graph.py'
--- history/module_graph.py 1970-01-01 00:00:00 +0000
+++ history/module_graph.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,87 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+# TODO handle the case of zip modules
+
+import os
+import optparse
+import sys
+import glob
+
+# TODO use the same function provided in openerp.modules
+def load_information_from_description_file(module):
+ """
+ :param module: The name of the module (sale, purchase, ...)
+ """
+ for filename in ['__openerp__.py', '__terp__.py']:
+ description_file = os.path.join(module, filename)
+ if os.path.isfile(description_file):
+ return eval(file(description_file).read())
+
+ return {}
+
+def get_valid_path(paths, module):
+ for path in paths:
+ full = os.path.join(path, module)
+ if os.path.exists(full):
+ return full
+ return None
+
+parser = optparse.OptionParser(usage="%prog [options] [module1 [module2 ...]]")
+parser.add_option("-p", "--addons-path", dest="path", help="addons directory", action="append")
+(opt, args) = parser.parse_args()
+
+modules = []
+if not opt.path:
+ opt.path = ["."]
+
+if not args:
+ for path in opt.path:
+ modules += map(os.path.dirname, glob.glob(os.path.join(path, '*', '__openerp__.py')))
+ modules += map(os.path.dirname, glob.glob(os.path.join(path, '*', '__terp__.py')))
+else:
+ for module in args:
+ valid_path = get_valid_path(opt.path, module)
+ if valid_path:
+ modules.append(valid_path)
+
+all_modules = set(map(os.path.basename, modules))
+print 'digraph G {'
+while len(modules):
+ f = modules.pop(0)
+ module_name = os.path.basename(f)
+ all_modules.add(module_name)
+ info = load_information_from_description_file(f)
+ if info.get('installable', True):
+ for name in info.get('depends',[]):
+ valid_path = get_valid_path(opt.path, name)
+ if name not in all_modules:
+ if valid_path:
+ modules.append(valid_path)
+ else:
+ all_modules.add(name)
+ print '\t%s [color=red]' % (name,)
+ print '\t%s -> %s;' % (module_name, name)
+print '}'
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'history/xml2yml.py'
--- history/xml2yml.py 1970-01-01 00:00:00 +0000
+++ history/xml2yml.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,347 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2010 OpenERP SA (<http://openerp.com>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+"""
+Experimental script for conversion between OpenERP's XML serialization format
+and the new YAML serialization format introduced in OpenERP 6.0.
+Intended to be used as a quick preprocessor for converting data/test files, then
+to be fine-tuned manually.
+"""
+
+import yaml
+import logging
+from lxml import etree
+
+__VERSION__ = '0.0.2'
+
+def toString(value):
+ value='"' + value + '"'
+ return value
+
+class XmlTag(etree.ElementBase):
+ def _to_yaml(self):
+ child_tags = []
+ for node in self:
+ if hasattr(node, '_to_yaml'):
+ child_tags.append(node._to_yaml())
+ return self.tag(attrib=self.attrib, child_tags=child_tags)
+
+class YamlTag(object):
+ """
+ Superclass for constructors of custom tags defined in yaml file.
+ """
+ def __init__(self, **kwargs):
+ self.__dict__.update(kwargs)
+ self.attrib = self.__dict__.get('attrib', {})
+ self.child_tags = self.__dict__.get('child_tags', '')
+ def __getitem__(self, key):
+ return getattr(self, key)
+ def __getattr__(self, attr):
+ return None
+ def __repr__(self):
+ for k,v in self.attrib.iteritems():
+ if str(v) and str(v)[0] in ['[', '{', '#', '*', '(']:
+ self.attrib[k] = toString(self.attrib[k]).replace("'", '')
+ st = self.yaml_tag + ' ' + str(self.attrib)
+ return st
+
+# attrib tags
+class ref(YamlTag):
+ yaml_tag = u'!ref'
+ def __init__(self, expr="False"):
+ self.expr = expr
+ def __repr__(self):
+ return "'%s'"%str(self.expr)
+
+class Eval(YamlTag):
+ yaml_tag = u'!eval'
+ def __init__(self, expr="False"):
+ self.expr = expr
+ def __repr__(self):
+ value=str(self.expr)
+ if value.find("6,") != -1:
+ value = eval(str(eval(value)))
+ value=value[0][2]
+ value = [[value]]
+ else:
+ try:
+ value=int(value)
+ except:
+ if value and value[0] in ['[', '{', '#', '*', '(']:
+ value = value.replace('"', r'\"')
+ value = toString(value)
+ else:
+ try:
+ value = eval(value)
+ except Exception:
+ pass
+ return value
+
+class Search(YamlTag):
+ yaml_tag = u'!ref'
+
+# test tag
+class xml_test(XmlTag):
+ def _to_yaml(self):
+ expr = self.attrib.get('expr')
+ text = self.text
+ if text:
+ expr = expr + ' == ' + '"%s"'%text
+ return [[expr]]
+
+class xml_data(etree.ElementBase):
+ def _to_yaml(self):
+ value = self.attrib.get('noupdate', "0")
+ return data(value)
+
+# field tag:
+class xml_field(etree.ElementBase):
+ def _to_yaml(self):
+ field = ' ' + self.attrib.pop('name','unknown')
+
+ if self.attrib.get('search', None):
+ value = Search(attrib=self.attrib, child_tags='').__repr__()
+ else:
+ attr = (self.attrib.get('ref', None) and 'ref') or (self.attrib.get('eval', None) and 'eval') or 'None'
+ value = Eval(self.attrib.get(attr, self.text)).__repr__() or ''
+ return {field: value}
+
+# value tag
+class xml_value(etree.ElementBase):
+ def _to_yaml(self):
+
+ if self.attrib.get('eval', None):
+ key, val = 'eval', '"'+self.attrib.get('eval')+'"'
+ elif self.attrib.get('model', None):
+ key, val = 'model', self.attrib.get('model')
+ val=val.replace("'",'""')
+ self.attrib.pop(key)
+ d={}
+ for k,v in self.attrib.iteritems():
+ if k == 'search':
+ v = '"' + v + '"'
+ k='--' + k
+ v=v.replace("'",'""')
+ d[k] = v
+ if d:
+ ls=[[{key:val},dict(d)]]
+ else:
+ ls=[[{key:val}]]
+ return ls
+
+# data tag
+class data(YamlTag):
+ yaml_tag = u'!context'
+ def __init__(self, noupdate="0"):
+ self.child_tags = {' noupdate':noupdate}
+ def __repr__(self):
+ return "!!context"
+
+# Record tag
+class Record(YamlTag):
+ yaml_tag = u'!record'
+class xml_record(XmlTag):
+ tag=Record
+ def _to_yaml(self):
+ child_tags = {}
+ for node in self:
+ if hasattr(node, '_to_yaml'):
+ child_tags.update(node._to_yaml())
+ return Record(attrib=self.attrib, child_tags=child_tags)
+
+# ir_set tag
+class Ir_Set(YamlTag):
+ yaml_tag = u'!ir_set'
+ def __repr__(self):
+ st = self.yaml_tag
+ return st
+class xml_ir_set(XmlTag):
+ tag=Ir_Set
+ def _to_yaml(self):
+ child_tags = {}
+ for node in self:
+ if hasattr(node, '_to_yaml'):
+ child_tags.update(node._to_yaml())
+ return Ir_Set(attrib=self.attrib, child_tags=child_tags)
+
+# workflow tag
+class Workflow(YamlTag):
+ yaml_tag = u'!workflow'
+class xml_workflow(XmlTag):
+ tag=Workflow
+
+# function tag
+class Function(YamlTag):
+ yaml_tag = u'!function'
+class xml_function(XmlTag):
+ tag=Function
+
+# function tag
+class Assert(YamlTag):
+ yaml_tag = u'!assert'
+class xml_assert(XmlTag):
+ tag=Assert
+
+# menuitem tagresult.append(yaml.safe_dump(obj, default_flow_style=False, allow_unicode=True).replace("'",''))
+class MenuItem(YamlTag):
+ yaml_tag = u'!menuitem'
+class xml_menuitem(XmlTag):
+ tag=MenuItem
+
+# act_window tag
+class ActWindow(YamlTag):
+ yaml_tag = u'!act_window'
+class xml_act_window(XmlTag):
+ tag=ActWindow
+
+# report tag
+class Report(YamlTag):
+ yaml_tag = u'!report'
+class xml_report(XmlTag):
+ tag=Report
+
+# deletes tag
+class Delete(YamlTag):
+ yaml_tag = u'!delete'
+class xml_delete(XmlTag):
+ tag=Delete
+
+# python tag
+class Python(YamlTag):
+ yaml_tag = u'!python'
+class xml_python(XmlTag):
+ tag=Python
+
+# context tag
+class Context(YamlTag):
+ yaml_tag = u'!context'
+class xml_context(XmlTag):
+ tag=Context
+
+# url tag
+class Url(YamlTag):
+ yaml_tag = u'!url'
+class xml_url(XmlTag):
+ tag=Url
+
+# delete tag
+class Delete(YamlTag):
+ yaml_tag = u'!delete'
+class xml_delete(XmlTag):
+ tag=Delete
+
+def represent_data(dumper, data):
+ return dumper.represent_mapping(u'tag:yaml.org,2002:map', [('!'+str(data), data.child_tags)])
+
+yaml.SafeDumper.add_representer(Record, represent_data)
+yaml.SafeDumper.add_representer(data, represent_data)
+yaml.SafeDumper.add_representer(Workflow, represent_data)
+yaml.SafeDumper.add_representer(Function, represent_data)
+yaml.SafeDumper.add_representer(Assert, represent_data)
+yaml.SafeDumper.add_representer(MenuItem, represent_data)
+yaml.SafeDumper.add_representer(Ir_Set, represent_data)
+yaml.SafeDumper.add_representer(Python, represent_data)
+yaml.SafeDumper.add_representer(Context, represent_data)
+
+class MyLookup(etree.CustomElementClassLookup):
+ def lookup(self, node_type, document, namespace, name):
+ if node_type=='element':
+ return {
+ 'data': xml_data,
+ 'record': xml_record,
+ 'field': xml_field,
+ 'workflow': xml_workflow,
+ 'function': xml_function,
+ 'value': xml_value,
+ 'assert': xml_assert,
+ 'test': xml_test,
+ 'menuitem': xml_menuitem,
+ 'act_window': xml_act_window,
+ 'report': xml_report,
+ 'delete': xml_delete,
+ 'python': xml_python,
+ 'context': xml_context,
+ 'url': xml_url,
+ 'ir_set': xml_ir_set,
+ }.get(name, None)
+ elif node_type=='comment':
+ return None#xml_comment
+ return None
+
+class xml_parse(object):
+ def __init__(self):
+ self.context = {}
+ def parse(self, fname):
+ parser = etree.XMLParser()
+ parser.setElementClassLookup(MyLookup())
+ result = []
+ self.root = etree.XML(file(fname).read(), parser)
+ for data in self.root:
+ if hasattr(data, '_to_yaml'):
+ obj = data._to_yaml()
+ if obj.yaml_tag == '!context':
+ result.append(yaml.dump(str(obj)).replace("'",'').split('\n')[0])
+ result.append(yaml.dump(obj.child_tags, default_flow_style=False).replace("'",''))
+ else:
+ result.append(yaml.safe_dump(obj, default_flow_style=False, allow_unicode=True).replace("'",''))
+ self.context.update(data.attrib)
+ for tag in data:
+ if tag.tag == etree.Comment:
+ result.append(tag)
+ else:
+ if hasattr(tag, '_to_yaml'):
+ obj = tag._to_yaml()
+ if not obj.child_tags:
+ result.append(yaml.dump('!'+str(obj), default_flow_style=False, allow_unicode=True, width=999).replace("'",''))
+ else:
+ result.append(yaml.safe_dump(obj, default_flow_style=False, allow_unicode=True, width=999).replace('\n:', ':\n').replace("'",''))
+ print "# Experimental OpenERP xml-to-yml conversion! (v%s)"%__VERSION__
+ print "# Please use this as a first conversion/preprocessing step,"
+ print "# not as a production-ready tool!"
+ for record in result:
+ if type(record) != type(''):
+ record=str(record)
+ l= record.split("\n")
+ for line in l:
+ print '#' + str(line)
+ continue
+ record=str(record)
+ record = record.replace('- --',' ') #for value tag
+ record = record.replace('!!', '- \n !') #for all parent tags
+ record = record.replace('- - -', ' -') #for many2many fields
+ record = record.replace('? ', '') #for long expressions
+ record = record.replace('""', "'") #for string-value under value tag
+ print record
+
+if __name__=='__main__':
+ import optparse
+ import sys
+ parser = optparse.OptionParser(
+ usage = '%s file.xml' % sys.argv[0])
+ (opt, args) = parser.parse_args()
+ if len(args) != 1:
+ parser.error("incorrect number of arguments")
+ fname = sys.argv[1]
+ p = xml_parse()
+ p.parse(fname)
+
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added directory 'install'
=== added file 'install/openerp-header.bmp'
Binary files install/openerp-header.bmp 1970-01-01 00:00:00 +0000 and install/openerp-header.bmp 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp-header.png'
Binary files install/openerp-header.png 1970-01-01 00:00:00 +0000 and install/openerp-header.png 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp-icon.ico'
Binary files install/openerp-icon.ico 1970-01-01 00:00:00 +0000 and install/openerp-icon.ico 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp-icon.png'
Binary files install/openerp-icon.png 1970-01-01 00:00:00 +0000 and install/openerp-icon.png 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp-intro.bmp'
Binary files install/openerp-intro.bmp 1970-01-01 00:00:00 +0000 and install/openerp-intro.bmp 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp-server.1'
--- install/openerp-server.1 1970-01-01 00:00:00 +0000
+++ install/openerp-server.1 2012-04-19 18:12:21 +0000
@@ -0,0 +1,229 @@
+.\" DO NOT MODIFY THIS FILE! It was generated by help2man 1.36.
+.TH OPENERP "1" "December 2010" "OpenERP Server 6.0.0-rc1" "User Commands"
+.SH NAME
+OpenERP \- manual page for OpenERP Server 6.0.0-rc1
+.SH SYNOPSIS
+.B openerp-server.py
+[\fIoptions\fR]
+.SH OPTIONS
+.TP
+\fB\-\-version\fR
+show program's version number and exit
+.TP
+\fB\-h\fR, \fB\-\-help\fR
+show this help message and exit
+.TP
+\fB\-c\fR CONFIG, \fB\-\-config\fR=\fICONFIG\fR
+specify alternate config file
+.TP
+\fB\-s\fR, \fB\-\-save\fR
+save configuration to ~/.openerp_serverrc
+.TP
+\fB\-\-pidfile\fR=\fIPIDFILE\fR
+file where the server pid will be stored
+.TP
+\fB\-i\fR INIT, \fB\-\-init\fR=\fIINIT\fR
+init a module (use "all" for all modules)
+.TP
+\fB\-\-without\-demo\fR=\fIWITHOUT_DEMO\fR
+load demo data for a module (use "all" for all
+modules)
+.TP
+\fB\-u\fR UPDATE, \fB\-\-update\fR=\fIUPDATE\fR
+update a module (use "all" for all modules)
+.TP
+\fB\-\-cache\-timeout\fR=\fICACHE_TIMEOUT\fR
+set the timeout for the cache system
+.TP
+\fB\-t\fR TIMEZONE, \fB\-\-timezone\fR=\fITIMEZONE\fR
+specify reference timezone for the server (e.g.
+Europe/Brussels
+.TP
+\fB\-\-stop\-after\-init\fR
+stop the server after it initializes
+.TP
+\fB\-\-debug\fR
+enable debug mode
+.TP
+\fB\-\-assert\-exit\-level\fR=\fIASSERT_EXIT_LEVEL\fR
+specify the level at which a failed assertion will
+stop the server. Accepted values: ['info',
+\&'debug_rpc', 'warn', 'test', 'critical', 'debug_sql',
+\&'error', 'debug', 'debug_rpc_answer', 'notset']
+.IP
+XML\-RPC Configuration:
+.TP
+\fB\-\-xmlrpc\-interface\fR=\fIXMLRPC_INTERFACE\fR
+specify the TCP IP address for the XML\-RPC protocol
+.TP
+\fB\-\-xmlrpc\-port\fR=\fIXMLRPC_PORT\fR
+specify the TCP port for the XML\-RPC protocol
+.TP
+\fB\-\-no\-xmlrpc\fR
+disable the XML\-RPC protocol
+.IP
+XML\-RPC Secure Configuration:
+.TP
+\fB\-\-xmlrpcs\-interface\fR=\fIXMLRPCS_INTERFACE\fR
+specify the TCP IP address for the XML\-RPC Secure
+protocol
+.TP
+\fB\-\-xmlrpcs\-port\fR=\fIXMLRPCS_PORT\fR
+specify the TCP port for the XML\-RPC Secure protocol
+.TP
+\fB\-\-no\-xmlrpcs\fR
+disable the XML\-RPC Secure protocol
+.TP
+\fB\-\-cert\-file\fR=\fISECURE_CERT_FILE\fR
+specify the certificate file for the SSL connection
+.TP
+\fB\-\-pkey\-file\fR=\fISECURE_PKEY_FILE\fR
+specify the private key file for the SSL connection
+.IP
+NET\-RPC Configuration:
+.TP
+\fB\-\-netrpc\-interface\fR=\fINETRPC_INTERFACE\fR
+specify the TCP IP address for the NETRPC protocol
+.TP
+\fB\-\-netrpc\-port\fR=\fINETRPC_PORT\fR
+specify the TCP port for the NETRPC protocol
+.TP
+\fB\-\-no\-netrpc\fR
+disable the NETRPC protocol
+.IP
+Static HTTP service:
+.TP
+\fB\-\-static\-http\-enable\fR
+enable static HTTP service for serving plain HTML
+files
+.TP
+\fB\-\-static\-http\-document\-root\fR=\fISTATIC_HTTP_DOCUMENT_ROOT\fR
+specify the directory containing your static HTML
+files (e.g '/var/www/')
+.TP
+\fB\-\-static\-http\-url\-prefix\fR=\fISTATIC_HTTP_URL_PREFIX\fR
+specify the URL root prefix where you want web
+browsers to access your static HTML files (e.g '/')
+.IP
+Testing Configuration:
+.TP
+\fB\-\-test\-file\fR=\fITEST_FILE\fR
+Launch a YML test file.
+.TP
+\fB\-\-test\-report\-directory\fR=\fITEST_REPORT_DIRECTORY\fR
+If set, will save sample of all reports in this
+directory.
+.TP
+\fB\-\-test\-disable\fR
+Disable loading test files.
+.TP
+\fB\-\-test\-commit\fR
+Commit database changes performed by tests.
+.IP
+Logging Configuration:
+.TP
+\fB\-\-logfile\fR=\fILOGFILE\fR
+file where the server log will be stored
+.TP
+\fB\-\-no\-logrotate\fR
+do not rotate the logfile
+.TP
+\fB\-\-syslog\fR
+Send the log to the syslog server
+.TP
+\fB\-\-log\-level\fR=\fILOG_LEVEL\fR
+specify the level of the logging. Accepted values:
+['info', 'debug_rpc', 'warn', 'test', 'critical',
+\&'debug_sql', 'error', 'debug', 'debug_rpc_answer',
+\&'notset']
+.IP
+SMTP Configuration:
+.TP
+\fB\-\-email\-from\fR=\fIEMAIL_FROM\fR
+specify the SMTP email address for sending email
+.TP
+\fB\-\-smtp\fR=\fISMTP_SERVER\fR
+specify the SMTP server for sending email
+.TP
+\fB\-\-smtp\-port\fR=\fISMTP_PORT\fR
+specify the SMTP port
+.TP
+\fB\-\-smtp\-ssl\fR
+specify the SMTP server support SSL or not
+.TP
+\fB\-\-smtp\-user\fR=\fISMTP_USER\fR
+specify the SMTP username for sending email
+.TP
+\fB\-\-smtp\-password\fR=\fISMTP_PASSWORD\fR
+specify the SMTP password for sending email
+.IP
+Database related options:
+.TP
+\fB\-d\fR DB_NAME, \fB\-\-database\fR=\fIDB_NAME\fR
+specify the database name
+.TP
+\fB\-r\fR DB_USER, \fB\-\-db_user\fR=\fIDB_USER\fR
+specify the database user name
+.TP
+\fB\-w\fR DB_PASSWORD, \fB\-\-db_password\fR=\fIDB_PASSWORD\fR
+specify the database password
+.TP
+\fB\-\-pg_path\fR=\fIPG_PATH\fR
+specify the pg executable path
+.TP
+\fB\-\-db_host\fR=\fIDB_HOST\fR
+specify the database host
+.TP
+\fB\-\-db_port\fR=\fIDB_PORT\fR
+specify the database port
+.TP
+\fB\-\-db_maxconn\fR=\fIDB_MAXCONN\fR
+specify the the maximum number of physical connections
+to posgresql
+.TP
+\fB\-P\fR IMPORT_PARTIAL, \fB\-\-import\-partial\fR=\fIIMPORT_PARTIAL\fR
+Use this for big data importation, if it crashes you
+will be able to continue at the current state. Provide
+a filename to store intermediate importation states.
+.IP
+Internationalisation options:
+.IP
+Use these options to translate OpenERP to another language.See i18n
+section of the user manual. Option '\-d' is mandatory.Option '\-l' is
+mandatory in case of importation
+.TP
+\fB\-l\fR LANGUAGE, \fB\-\-language\fR=\fILANGUAGE\fR
+specify the language of the translation file. Use it
+with \fB\-\-i18n\-export\fR or \fB\-\-i18n\-import\fR
+.TP
+\fB\-\-i18n\-export\fR=\fITRANSLATE_OUT\fR
+export all sentences to be translated to a CSV file, a
+PO file or a TGZ archive and exit
+.TP
+\fB\-\-i18n\-import\fR=\fITRANSLATE_IN\fR
+import a CSV or a PO file with translations and exit.
+The '\-l' option is required.
+.TP
+\fB\-\-modules\fR=\fITRANSLATE_MODULES\fR
+specify modules to export. Use in combination with
+\fB\-\-i18n\-export\fR
+.TP
+\fB\-\-addons\-path\fR=\fIADDONS_PATH\fR
+specify an alternative addons path.
+.IP
+Security\-related options:
+.TP
+\fB\-\-no\-database\-list\fR
+disable the ability to return the list of databases
+.SH "SEE ALSO"
+The full documentation for
+.B OpenERP
+is maintained as a Texinfo manual. If the
+.B info
+and
+.B OpenERP
+programs are properly installed at your site, the command
+.IP
+.B info OpenERP
+.PP
+should give you access to the complete manual.
=== added file 'install/openerp-server.conf'
--- install/openerp-server.conf 1970-01-01 00:00:00 +0000
+++ install/openerp-server.conf 2012-04-19 18:12:21 +0000
@@ -0,0 +1,7 @@
+[options]
+; This is the password that allows database operations:
+; admin_passwd = admin
+db_host = False
+db_port = False
+db_user = openerp
+db_password = False
=== added file 'install/openerp-server.init'
--- install/openerp-server.init 1970-01-01 00:00:00 +0000
+++ install/openerp-server.init 2012-04-19 18:12:21 +0000
@@ -0,0 +1,147 @@
+#!/bin/bash
+# openerp-server This shell script takes care of starting and stopping
+# OpenERP server
+#
+# chkconfig: 345 95 05
+# description: OpenERP server
+#
+# pidfile: /var/run/openerp-server.pid
+# config: /etc/openerp-server.conf
+
+### BEGIN INIT INFO
+# Provides: openerp-server
+# Required-Start: postgresql
+# Required-Stop: postgresql
+# Should-Start: $network harddrake
+# Default-Start: 345
+# Short-Description: Launches the OpenERP server.
+# Description: This startup script launches the OpenERP server.
+### END INIT INFO
+
+# Source function library.
+. /etc/rc.d/init.d/functions
+
+PIDFILE=/var/run/openerp/openerp-server.pid
+LOCKFILE=/var/lock/subsys/openerp-server
+LOGFILE=/var/log/openerp/openerp-server.log
+
+OPTS="--pidfile=$PIDFILE --logfile=$LOGFILE"
+
+prog="openerp-server"
+desc="OpenERP Server Daemon"
+
+# check if the openerp-server conf file is present, then use it
+if [ -f /etc/openerp-server.conf ]; then
+ OPTS="$OPTS -c /etc/openerp-server.conf"
+fi
+
+# Source function library
+if [ -f /etc/init.d/functions ] ; then
+ . /etc/init.d/functions
+elif [ -f /etc/rc.d/init.d/functions ] ; then
+ . /etc/rc.d/init.d/functions
+else
+ exit 0
+fi
+
+# check the existence of the openerp-server script
+[ -z "/usr/bin/openerp-server" ] && exit 0
+
+RETVAL=0
+
+start() {
+ if [ -d /etc/openerp/start.d ] ; then
+ echo -n $"Preparing $desc: "
+ run-parts --exit-on-error /etc/openerp/start.d
+ RETVAL=$?
+ echo
+ [ $RETVAL -ne 0 ] && return $RETVAL
+ fi
+
+ echo -n $"Starting $desc ($prog): "
+ daemon --user openerp --check openerp-server \
+ "/usr/bin/setsid /usr/bin/openerp-server \
+ -c /etc/openerp-server.conf \
+ --pidfile=$PIDFILE \
+ --logfile=$LOGFILE &"
+
+ RETVAL=$?
+ echo
+ [ $RETVAL -eq 0 ] && touch $LOCKFILE
+ return $RETVAL
+}
+
+stop() {
+ echo -n $"Stopping $desc ($prog): "
+ kill -TERM `cat $PIDFILE` > /dev/null 2>&1
+ RETVAL=$?
+ if [ $RETVAL -eq 0 ] ; then
+ rm -f $LOCKFILE
+
+ echo_success
+ echo
+ else
+ echo_failure
+ echo
+ fi
+ if [ -d /etc/openerp/stop.d ] ; then
+ echo -n $"Clearing $desc: "
+ run-parts /etc/openerp/stop.d
+ echo
+ fi
+ return $RETVAL
+}
+
+restart() {
+ stop
+ start
+}
+
+condrestart() {
+ [ -e $LOCKFILE ] && restart || :
+}
+
+status() {
+ if [ -f $PIDFILE ] ; then
+ checkpid `cat $PIDFILE`
+ RETVAL=$?
+ if [ $RETVAL -eq 0 ] ; then
+ echo $"$prog is running..."
+ else
+ echo $"$prog is stopped"
+ fi
+ else
+ echo $"$prog is stopped"
+ fi
+ return $RETVAL
+}
+
+case "$1" in
+start)
+ start
+ ;;
+
+stop)
+ stop
+ ;;
+
+restart|reload)
+ restart
+ ;;
+
+condrestart)
+ condrestart
+ ;;
+
+status)
+ status
+ ;;
+
+probe)
+ exit 0
+ ;;
+
+*)
+ echo $"Usage: $0 {start|stop|status|restart|condrestart|reload}"
+ exit 1
+esac
=== added file 'install/openerp-server.logrotate'
--- install/openerp-server.logrotate 1970-01-01 00:00:00 +0000
+++ install/openerp-server.logrotate 2012-04-19 18:12:21 +0000
@@ -0,0 +1,5 @@
+/var/log/openerp/*.log {
+ copytruncate
+ missingok
+ notifempty
+}
=== added file 'install/openerp-slogan.bmp'
Binary files install/openerp-slogan.bmp 1970-01-01 00:00:00 +0000 and install/openerp-slogan.bmp 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp.ico'
Binary files install/openerp.ico 1970-01-01 00:00:00 +0000 and install/openerp.ico 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp.png'
Binary files install/openerp.png 1970-01-01 00:00:00 +0000 and install/openerp.png 2012-04-19 18:12:21 +0000 differ
=== added file 'install/openerp_serverrc.5'
--- install/openerp_serverrc.5 1970-01-01 00:00:00 +0000
+++ install/openerp_serverrc.5 2012-04-19 18:12:21 +0000
@@ -0,0 +1,113 @@
+.TH openerp_serverrc 5
+
+.SH NAME
+openerp_serverrc \- configuration file for OpenERP
+
+.SH SYNOPSIS
+[options]
+.br
+$option\ =\ " someValue "
+.br
+ ...
+
+.SH DESCRIPTION
+A setup file consists of a section, lead by a "[options]" header,
+.br
+and followed by "option_name = value" entries, with continuations and such in
+.br
+the style of RFC 822.
+
+.SH OPTIONS
+.TP
+.IR verbose
+Enable the debugging mode
+.br
+(default False)
+.TP
+.IR pidfile
+The file where the server pid will be stored
+.br
+(default False)
+.TP
+.IR logfile
+The file where the server log will be stored
+.br
+(default False)
+.TP
+.IR interface
+The IP address on which the server will bind.
+.br
+If empty, it will bind on all interfaces (default empty)
+.TP
+.IR port
+The TCP port on which the server will listen.
+.br
+(default 8069)
+.TP
+.IR debug_mode
+Enable debug mode
+.br
+(default False)
+.TP
+.IR secure
+Launch server over https instead of http.
+.br
+(default False)
+.TP
+.IR smtp_server
+Specify the SMTP server for sending email.
+.br
+(default localhost)
+.TP
+.IR smtp_user
+Specify the SMTP user for sending email.
+.br
+(default False)
+.TP
+.IR smtp_password
+Specify the SMTP password for sending email.
+.br
+(default False)
+.TP
+.IR db_name
+Specify the database name.
+.TP
+.IR db_user
+Specify the database user name.
+.br
+(default None)
+.TP
+.IR db_password
+Specify the database password for db_user.
+.br
+(default None)
+.TP
+.IR pg_path
+Specify the PostgreSQL executable path.
+.br
+(default None)
+.TP
+.IR db_host
+Specify the database host.
+.br
+(default localhost)
+.TP
+.IR db_port
+Specify the database port.
+.br
+(default None)
+.TP
+.IR price_accuracy
+Specify the price accuracy.
+.br
+
+.SH AUTHORS
+
+OpenERP is a product of \fBTiny.be\fR (\fIhttp://www.tiny.be\fR)
+
+.SH SEE ALSO
+openerp-server(1)
+.br
+\fIhttp://www.openerp.com\fR : Open ERP official website
+.br
+\fIhttp://doc.openerp.com\fR : Open ERP documentation
=== added file 'install/ssl-cert.cfg'
--- install/ssl-cert.cfg 1970-01-01 00:00:00 +0000
+++ install/ssl-cert.cfg 2012-04-19 18:12:21 +0000
@@ -0,0 +1,89 @@
+# X.509 Certificate options
+#
+# DN options
+
+# The organization of the subject.
+organization = "Some organization."
+
+# The organizational unit of the subject.
+unit = "ERP dept."
+
+# The locality of the subject.
+# locality =
+
+# The state of the certificate owner.
+state = "State"
+
+# The country of the subject. Two letter code.
+country = BE
+
+# The common name of the certificate owner.
+cn = "Some company"
+
+# A user id of the certificate owner.
+#uid = "clauper"
+
+# If the supported DN OIDs are not adequate you can set
+# any OID here.
+# For example set the X.520 Title and the X.520 Pseudonym
+# by using OID and string pairs.
+#dn_oid = "2.5.4.12" "Dr." "2.5.4.65" "jackal"
+
+# This is deprecated and should not be used in new
+# certificates.
+# pkcs9_email = "none@xxxxxxxx"
+
+# The serial number of the certificate
+serial = 001
+
+# In how many days, counting from today, this certificate will expire.
+expiration_days = 700
+
+# X.509 v3 extensions
+
+# A dnsname in case of a WWW server.
+#dns_name = "www.none.org"
+#dns_name = "www.morethanone.org"
+
+# An IP address in case of a server.
+#ip_address = "192.168.1.1"
+
+# An email in case of a person
+email = "none@xxxxxxxx"
+
+# An URL that has CRLs (certificate revocation lists)
+# available. Needed in CA certificates.
+#crl_dist_points = "http://www.getcrl.crl/getcrl/"
+
+# Whether this is a CA certificate or not
+#ca
+
+# Whether this certificate will be used for a TLS client
+#tls_www_client
+
+# Whether this certificate will be used for a TLS server
+tls_www_server
+
+# Whether this certificate will be used to sign data (needed
+# in TLS DHE ciphersuites).
+#signing_key
+
+# Whether this certificate will be used to encrypt data (needed
+# in TLS RSA ciphersuites). Note that it is prefered to use different
+# keys for encryption and signing.
+encryption_key
+
+# Whether this key will be used to sign other certificates.
+#cert_signing_key
+
+# Whether this key will be used to sign CRLs.
+#crl_signing_key
+
+# Whether this key will be used to sign code.
+#code_signing_key
+
+# Whether this key will be used to sign OCSP data.
+#ocsp_signing_key
+
+# Whether this key will be used for time stamping.
+#time_stamping_key
=== added directory 'openerp'
=== added file 'openerp-server'
--- openerp-server 1970-01-01 00:00:00 +0000
+++ openerp-server 2012-04-19 18:12:21 +0000
@@ -0,0 +1,273 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+"""
+OpenERP - Server
+OpenERP is an ERP+CRM program for small and medium businesses.
+
+The whole source code is distributed under the terms of the
+GNU Public Licence.
+
+(c) 2003-TODAY, Fabien Pinckaers - OpenERP SA
+"""
+
+import imp
+import logging
+import os
+import signal
+import sys
+import threading
+import traceback
+import time
+
+sys.path.insert("/usr/share")
+import openerp
+__author__ = openerp.release.author
+__version__ = openerp.release.version
+
+# Also use the `openerp` logger for the main script.
+_logger = logging.getLogger('openerp')
+
+def check_root_user():
+ """ Exit if the process's user is 'root' (on POSIX system)."""
+ if os.name == 'posix':
+ import pwd
+ if pwd.getpwuid(os.getuid())[0] == 'root' :
+ sys.stderr.write("Running as user 'root' is a security risk, aborting.\n")
+ sys.exit(1)
+
+def check_postgres_user():
+ """ Exit if the configured database user is 'postgres'.
+
+ This function assumes the configuration has been initialized.
+ """
+ config = openerp.tools.config
+ if config['db_user'] == 'postgres':
+ sys.stderr.write("Using the database user 'postgres' is a security risk, aborting.")
+ sys.exit(1)
+
+def report_configuration():
+ """ Log the server version and some configuration values.
+
+ This function assumes the configuration has been initialized.
+ """
+ config = openerp.tools.config
+ _logger.info("OpenERP version %s", __version__)
+ for name, value in [('addons paths', config['addons_path']),
+ ('database hostname', config['db_host'] or 'localhost'),
+ ('database port', config['db_port'] or '5432'),
+ ('database user', config['db_user'])]:
+ _logger.info("%s: %s", name, value)
+
+def setup_pid_file():
+ """ Create a file with the process id written in it.
+
+ This function assumes the configuration has been initialized.
+ """
+ config = openerp.tools.config
+ if config['pidfile']:
+ fd = open(config['pidfile'], 'w')
+ pidtext = "%d" % (os.getpid())
+ fd.write(pidtext)
+ fd.close()
+
+def preload_registry(dbname):
+ """ Preload a registry, and start the cron."""
+ try:
+ db, registry = openerp.pooler.get_db_and_pool(dbname, update_module=config['init'] or config['update'], pooljobs=False)
+
+ # jobs will start to be processed later, when openerp.cron.start_master_thread() is called by openerp.service.start_services()
+ registry.schedule_cron_jobs()
+ except Exception:
+ _logger.exception('Failed to initialize database `%s`.', dbname)
+
+def run_test_file(dbname, test_file):
+ """ Preload a registry, possibly run a test file, and start the cron."""
+ try:
+ db, registry = openerp.pooler.get_db_and_pool(dbname, update_module=config['init'] or config['update'], pooljobs=False)
+ cr = db.cursor()
+ _logger.info('loading test file %s', test_file)
+ openerp.tools.convert_yaml_import(cr, 'base', file(test_file), {}, 'test', True)
+ cr.rollback()
+ cr.close()
+ except Exception:
+ _logger.exception('Failed to initialize database `%s` and run test file `%s`.', dbname, test_file)
+
+
+def export_translation():
+ config = openerp.tools.config
+ dbname = config['db_name']
+
+ if config["language"]:
+ msg = "language %s" % (config["language"],)
+ else:
+ msg = "new language"
+ _logger.info('writing translation file for %s to %s', msg,
+ config["translate_out"])
+
+ fileformat = os.path.splitext(config["translate_out"])[-1][1:].lower()
+ buf = file(config["translate_out"], "w")
+ cr = openerp.pooler.get_db(dbname).cursor()
+ openerp.tools.trans_export(config["language"],
+ config["translate_modules"] or ["all"], buf, fileformat, cr)
+ cr.close()
+ buf.close()
+
+ _logger.info('translation file written successfully')
+
+def import_translation():
+ config = openerp.tools.config
+ context = {'overwrite': config["overwrite_existing_translations"]}
+ dbname = config['db_name']
+
+ cr = openerp.pooler.get_db(dbname).cursor()
+ openerp.tools.trans_load( cr, config["translate_in"], config["language"],
+ context=context)
+ cr.commit()
+ cr.close()
+
+# Variable keeping track of the number of calls to the signal handler defined
+# below. This variable is monitored by ``quit_on_signals()``.
+quit_signals_received = 0
+
+def signal_handler(sig, frame):
+ """ Signal handler: exit ungracefully on the second handled signal.
+
+ :param sig: the signal number
+ :param frame: the interrupted stack frame or None
+ """
+ global quit_signals_received
+ quit_signals_received += 1
+ if quit_signals_received > 1:
+ # logging.shutdown was already called at this point.
+ sys.stderr.write("Forced shutdown.\n")
+ os._exit(0)
+
+def dumpstacks(sig, frame):
+ """ Signal handler: dump a stack trace for each existing thread."""
+ # code from http://stackoverflow.com/questions/132058/getting-stack-trace-from-a-running-python-application#answer-2569696
+ # modified for python 2.5 compatibility
+ thread_map = dict(threading._active, **threading._limbo)
+ id2name = dict([(threadId, thread.getName()) for threadId, thread in thread_map.items()])
+ code = []
+ for threadId, stack in sys._current_frames().items():
+ code.append("\n# Thread: %s(%d)" % (id2name.get(threadId,'n/a'), threadId))
+ for filename, lineno, name, line in traceback.extract_stack(stack):
+ code.append('File: "%s", line %d, in %s' % (filename, lineno, name))
+ if line:
+ code.append(" %s" % (line.strip()))
+ _logger.info("\n".join(code))
+
+def setup_signal_handlers():
+ """ Register the signal handler defined above. """
+ SIGNALS = map(lambda x: getattr(signal, "SIG%s" % x), "INT TERM".split())
+ if os.name == 'posix':
+ map(lambda sig: signal.signal(sig, signal_handler), SIGNALS)
+ signal.signal(signal.SIGQUIT, dumpstacks)
+ elif os.name == 'nt':
+ import win32api
+ win32api.SetConsoleCtrlHandler(lambda sig: signal_handler(sig, None), 1)
+
+def quit_on_signals():
+ """ Wait for one or two signals then shutdown the server.
+
+ The first SIGINT or SIGTERM signal will initiate a graceful shutdown while
+ a second one if any will force an immediate exit.
+
+ """
+ # Wait for a first signal to be handled. (time.sleep will be interrupted
+ # by the signal handler.) The try/except is for the win32 case.
+ try:
+ while quit_signals_received == 0:
+ time.sleep(60)
+ except KeyboardInterrupt, e:
+ pass
+
+ if config['pidfile']:
+ os.unlink(config['pidfile'])
+
+ openerp.service.stop_services()
+ sys.exit(0)
+
+def configure_babel_localedata_path():
+ # Workaround: py2exe and babel.
+ if hasattr(sys, 'frozen'):
+ import babel
+ babel.localedata._dirname = os.path.join(os.path.dirname(sys.executable), '/usr/share/openerp/localedata')
+
+if __name__ == "__main__":
+
+ os.environ["TZ"] = "UTC"
+
+ check_root_user()
+ openerp.tools.config.parse_config(sys.argv[1:])
+
+ check_postgres_user()
+ openerp.netsvc.init_logger()
+ report_configuration()
+
+ config = openerp.tools.config
+
+ configure_babel_localedata_path()
+
+ setup_signal_handlers()
+
+ if config["test_file"]:
+ run_test_file(config['db_name'], config['test_file'])
+ sys.exit(0)
+
+ if config["translate_out"]:
+ export_translation()
+ sys.exit(0)
+
+ if config["translate_in"]:
+ import_translation()
+ sys.exit(0)
+
+ if not config["stop_after_init"]:
+ # Some module register themselves when they are loaded so we need the
+ # services to be running before loading any registry.
+ openerp.service.start_services()
+
+ for m in openerp.conf.server_wide_modules:
+ try:
+ openerp.modules.module.load_openerp_module(m)
+ except Exception:
+ msg = ''
+ if m == 'web':
+ msg = """
+The `web` module is provided by the addons found in the `openerp-web` project.
+Maybe you forgot to add those addons in your addons_path configuration."""
+ _logger.exception('Failed to load server-wide module `%s`.%s', m, msg)
+
+ if config['db_name']:
+ for dbname in config['db_name'].split(','):
+ preload_registry(dbname)
+
+ if config["stop_after_init"]:
+ sys.exit(0)
+
+ setup_pid_file()
+ _logger.info('OpenERP server is running, waiting for connections...')
+ quit_on_signals()
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'openerp/.apidoc'
--- openerp/.apidoc 1970-01-01 00:00:00 +0000
+++ openerp/.apidoc 2012-04-19 18:12:21 +0000
@@ -0,0 +1,1 @@
+excludes: pychart release openerp-server test run_tests addons/base_quality_interrogation
\ No newline at end of file
=== added file 'openerp/PKG-INFO'
--- openerp/PKG-INFO 1970-01-01 00:00:00 +0000
+++ openerp/PKG-INFO 2012-04-19 18:12:21 +0000
@@ -0,0 +1,18 @@
+Metadata-Version: 1.1
+Name: OpenERP
+Version: 6.0.0
+Author: OpenERP S.A.
+Author-email: fp at openerp com
+Maintainer: OpenERP S.A.
+Maintainer-email: fp at openerp com
+Home-page: http://www.openerp.com
+Download-url: http://www.openerp.com/downloads.html
+Summary: OpenERP is an Enterprise Resource Management written entirely in python.
+License: GPL-3
+Description: OpenERP is a complete ERP and CRM. The main features are accounting (analytic
+ and financial), stock management, sales and purchases management, tasks
+ automation, marketing campaigns, help desk, POS, etc. Technical features include
+ a distributed server, flexible workflows, an object database, a dynamic GUI,
+ customizable reports, and NET-RPC and XML-RPC interfaces.
+Keywords: ERP, Accounting, Stock, CRM, Enterprise, Logistics, Management, Sales, Purchases
+Platform: Linux, Win32
=== added file 'openerp/__init__.py'
--- openerp/__init__.py 1970-01-01 00:00:00 +0000
+++ openerp/__init__.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,56 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+""" OpenERP core library.
+
+"""
+# The hard-coded super-user id (a.k.a. administrator, or root user).
+SUPERUSER_ID = 1
+
+import addons
+import conf
+import loglevels
+import modules
+import netsvc
+import osv
+import pooler
+import pychart
+import release
+import report
+import run_tests
+import service
+import sql_db
+import test
+import tiny_socket
+import tools
+import wizard
+import workflow
+import wsgi
+
+# Is the server running in multi-process mode (e.g. behind Gunicorn).
+# If this is True, the processes have to communicate some events,
+# e.g. database update or cache invalidation. Each process has also
+# its own copy of the data structure and we don't need to care about
+# locks between threads.
+multi_process = False
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added directory 'openerp/addons'
=== added file 'openerp/addons/__init__.py'
--- openerp/addons/__init__.py 1970-01-01 00:00:00 +0000
+++ openerp/addons/__init__.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,40 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+# Copyright (C) 2010-2011 OpenERP s.a. (<http://openerp.com>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+""" Addons module.
+
+This module serves to contain all OpenERP addons, across all configured addons
+paths. For the code to manage those addons, see openerp.modules.
+
+Addons are made available under `openerp.addons` after
+openerp.tools.config.parse_config() is called (so that the addons paths are
+known).
+
+This module also conveniently reexports some symbols from openerp.modules.
+Importing them from here is deprecated.
+
+"""
+
+# get_module_path is used only by base_module_quality
+from openerp.modules import get_module_resource, get_module_path
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added directory 'openerp/addons/base'
=== added file 'openerp/addons/base/__init__.py'
--- openerp/addons/base/__init__.py 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/__init__.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,30 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+import ir
+import module
+import res
+import publisher_warranty
+import report
+import test
+
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
+
=== added file 'openerp/addons/base/__openerp__.py'
--- openerp/addons/base/__openerp__.py 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/__openerp__.py 2012-04-19 18:12:21 +0000
@@ -0,0 +1,105 @@
+# -*- coding: utf-8 -*-
+##############################################################################
+#
+# OpenERP, Open Source Management Solution
+# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
+# Copyright (C) 2010 OpenERP s.a. (<http://openerp.com>).
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+##############################################################################
+
+
+{
+ 'name': 'Base',
+ 'version': '1.3',
+ 'category': 'Hidden',
+ 'description': """The kernel of OpenERP, needed for all installation.""",
+ 'author': 'OpenERP SA',
+ 'maintainer': 'OpenERP SA',
+ 'website': 'http://www.openerp.com',
+ 'depends': [],
+ 'init_xml': [
+ 'base_data.xml',
+ 'security/base_security.xml',
+ 'base_menu.xml',
+ 'res/res_security.xml',
+ 'res/res_config.xml',
+ 'data/res.country.state.csv'
+ ],
+ 'update_xml': [
+ 'base_update.xml',
+ 'ir/wizard/wizard_menu_view.xml',
+ 'ir/ir.xml',
+ 'ir/ir_config_parameter_view.xml',
+ 'ir/workflow/workflow_view.xml',
+ 'ir/report/ir_report.xml',
+ 'module/module_view.xml',
+ 'module/module_data.xml',
+ 'module/module_report.xml',
+ 'module/wizard/base_module_import_view.xml',
+ 'module/wizard/base_module_update_view.xml',
+ 'module/wizard/base_language_install_view.xml',
+ 'module/wizard/base_import_language_view.xml',
+ 'module/wizard/base_module_upgrade_view.xml',
+ 'module/wizard/base_module_configuration_view.xml',
+ 'module/wizard/base_export_language_view.xml',
+ 'module/wizard/base_update_translations_view.xml',
+ 'res/res_request_view.xml',
+ 'res/res_lang_view.xml',
+ 'res/res_log_view.xml',
+ 'res/res_partner_report.xml',
+ 'res/res_partner_view.xml',
+ 'res/res_partner_shortcut_data.xml',
+ 'res/res_bank_view.xml',
+ 'res/res_country_view.xml',
+ 'res/res_currency_view.xml',
+ 'res/res_partner_event_view.xml',
+ 'res/wizard/partner_sms_send_view.xml',
+ 'res/wizard/partner_wizard_massmail_view.xml',
+ 'res/wizard/partner_clear_ids_view.xml',
+ 'res/wizard/partner_wizard_ean_check_view.xml',
+ 'res/res_partner_data.xml',
+ 'res/ir_property_view.xml',
+ 'security/base_security.xml',
+ 'publisher_warranty/publisher_warranty_view.xml',
+ 'security/ir.model.access.csv',
+ 'res/res_widget_view.xml',
+ 'res/res_widget_data.xml',
+ 'publisher_warranty/publisher_warranty_data.xml',
+ ],
+ 'demo_xml': [
+ 'base_demo.xml',
+ 'res/res_partner_demo.xml',
+ 'res/res_widget_demo.xml',
+ ],
+ 'test': [
+ 'test/base_test.xml',
+ 'test/base_test.yml',
+ 'test/test_context.xml',
+ 'test/bug_lp541545.xml',
+ 'test/test_osv_expression.yml',
+ 'test/test_ir_rule.yml', # <-- These tests modify/add/delete ir_rules.
+ 'test/test_ir_values.yml',
+ # Commented because this takes some time.
+ # This must be (un)commented with the corresponding import statement
+ # in test/__init__.py.
+ # 'test/test_ir_cron.yml', # <-- These tests perform a roolback.
+ ],
+ 'installable': True,
+ 'auto_install': True,
+ 'certificate': '0076807797149',
+ "css": [ 'static/src/css/modules.css' ],
+}
+# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
=== added file 'openerp/addons/base/base.sql'
--- openerp/addons/base/base.sql 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/base.sql 2012-04-19 18:12:21 +0000
@@ -0,0 +1,360 @@
+-------------------------------------------------------------------------
+-- Pure SQL
+-------------------------------------------------------------------------
+
+-------------------------------------------------------------------------
+-- IR dictionary
+-------------------------------------------------------------------------
+
+create table ir_values
+(
+ id serial,
+ name varchar(128) not null,
+ key varchar(128) not null,
+ key2 varchar(256) not null,
+ model varchar(128) not null,
+ value text,
+ meta text default NULL,
+ res_id integer default null,
+ primary key (id)
+);
+
+-------------------------------------------------------------------------
+-- Modules Description
+-------------------------------------------------------------------------
+
+CREATE TABLE ir_model (
+ id serial,
+ model varchar(64) DEFAULT ''::varchar NOT NULL,
+ name varchar(64),
+ state varchar(16),
+ info text,
+ primary key(id)
+);
+
+CREATE TABLE ir_model_fields (
+ id serial,
+ model varchar(64) DEFAULT ''::varchar NOT NULL,
+ model_id int references ir_model on delete cascade,
+ name varchar(64) DEFAULT ''::varchar NOT NULL,
+ relation varchar(64),
+ select_level varchar(4),
+ field_description varchar(256),
+ ttype varchar(64),
+ state varchar(64) default 'base',
+ view_load boolean,
+ relate boolean default False,
+ relation_field varchar(128),
+ translate boolean default False,
+ primary key(id)
+);
+
+ALTER TABLE ir_model_fields ADD column serialization_field_id int references ir_model_fields on delete cascade;
+
+
+-------------------------------------------------------------------------
+-- Actions
+-------------------------------------------------------------------------
+
+CREATE TABLE ir_actions (
+ id serial NOT NULL,
+ name varchar(64) DEFAULT ''::varchar NOT NULL,
+ "type" varchar(32) DEFAULT 'window'::varchar NOT NULL,
+ usage varchar(32) DEFAULT null,
+ primary key(id)
+);
+
+CREATE TABLE ir_act_window (
+ view_id integer,
+ res_model varchar(64),
+ view_type varchar(16),
+ "domain" varchar(250),
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+CREATE TABLE ir_act_report_xml (
+ model varchar(64) NOT NULL,
+ report_name varchar(64) NOT NULL,
+ report_xsl varchar(256),
+ report_xml varchar(256),
+ auto boolean default true,
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+create table ir_act_report_custom (
+ report_id int,
+-- report_id int references ir_report_custom
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+CREATE TABLE ir_act_wizard (
+ wiz_name varchar(64) NOT NULL,
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+CREATE TABLE ir_act_url (
+ url text NOT NULL,
+ target varchar(64) NOT NULL,
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+CREATE TABLE ir_act_server (
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+CREATE TABLE ir_act_client (
+ primary key(id)
+)
+INHERITS (ir_actions);
+
+
+CREATE TABLE ir_ui_view (
+ id serial NOT NULL,
+ name varchar(64) DEFAULT ''::varchar NOT NULL,
+ model varchar(64) DEFAULT ''::varchar NOT NULL,
+ "type" varchar(64) DEFAULT 'form'::varchar NOT NULL,
+ arch text NOT NULL,
+ field_parent varchar(64),
+ priority integer DEFAULT 5 NOT NULL,
+ primary key(id)
+);
+
+CREATE TABLE ir_ui_menu (
+ id serial NOT NULL,
+ parent_id int references ir_ui_menu on delete set null,
+ name varchar(64) DEFAULT ''::varchar NOT NULL,
+ icon varchar(64) DEFAULT ''::varchar,
+ primary key (id)
+);
+
+select setval('ir_ui_menu_id_seq', 2);
+
+---------------------------------
+-- Res users
+---------------------------------
+
+-- level:
+-- 0 RESTRICT TO USER
+-- 1 RESTRICT TO GROUP
+-- 2 PUBLIC
+
+CREATE TABLE res_users (
+ id serial NOT NULL,
+ name varchar(64) not null,
+ active boolean default True,
+ login varchar(64) NOT NULL UNIQUE,
+ password varchar(64) default null,
+ email varchar(64) default null,
+ context_tz varchar(64) default null,
+ signature text,
+ context_lang varchar(64) default '',
+ -- No FK references below, will be added later by ORM
+ -- (when the destination rows exist)
+ company_id int,
+ primary key(id)
+);
+alter table res_users add constraint res_users_login_uniq unique (login);
+
+CREATE TABLE res_groups (
+ id serial NOT NULL,
+ name varchar(64) NOT NULL,
+ primary key(id)
+);
+
+CREATE TABLE res_groups_users_rel (
+ uid integer NOT NULL references res_users on delete cascade,
+ gid integer NOT NULL references res_groups on delete cascade,
+ UNIQUE("uid","gid")
+);
+
+create index res_groups_users_rel_uid_idx on res_groups_users_rel (uid);
+create index res_groups_users_rel_gid_idx on res_groups_users_rel (gid);
+
+
+---------------------------------
+-- Workflows
+---------------------------------
+
+create table wkf
+(
+ id serial,
+ name varchar(64),
+ osv varchar(64),
+ on_create bool default False,
+ primary key(id)
+);
+
+create table wkf_activity
+(
+ id serial,
+ wkf_id int references wkf on delete cascade,
+ subflow_id int references wkf on delete set null,
+ split_mode varchar(3) default 'XOR',
+ join_mode varchar(3) default 'XOR',
+ kind varchar(16) not null default 'dummy',
+ name varchar(64),
+ signal_send varchar(32) default null,
+ flow_start boolean default False,
+ flow_stop boolean default False,
+ action text default null,
+ primary key(id)
+);
+
+create table wkf_transition
+(
+ id serial,
+ act_from int references wkf_activity on delete cascade,
+ act_to int references wkf_activity on delete cascade,
+ condition varchar(128) default NULL,
+
+ trigger_type varchar(128) default NULL,
+ trigger_expr_id varchar(128) default NULL,
+
+ signal varchar(64) default null,
+ group_id int references res_groups on delete set null,
+
+ primary key(id)
+);
+
+create table wkf_instance
+(
+ id serial,
+ wkf_id int references wkf on delete restrict,
+ uid int default null,
+ res_id int not null,
+ res_type varchar(64) not null,
+ state varchar(32) not null default 'active',
+ primary key(id)
+);
+
+create table wkf_workitem
+(
+ id serial,
+ act_id int not null references wkf_activity on delete cascade,
+ inst_id int not null references wkf_instance on delete cascade,
+ subflow_id int references wkf_instance on delete cascade,
+ state varchar(64) default 'blocked',
+ primary key(id)
+);
+
+create table wkf_witm_trans
+(
+ trans_id int not null references wkf_transition on delete cascade,
+ inst_id int not null references wkf_instance on delete cascade
+);
+
+create index wkf_witm_trans_inst_idx on wkf_witm_trans (inst_id);
+
+create table wkf_logs
+(
+ id serial,
+ res_type varchar(128) not null,
+ res_id int not null,
+ uid int references res_users on delete set null,
+ act_id int references wkf_activity on delete set null,
+ time time not null,
+ info varchar(128) default NULL,
+ primary key(id)
+);
+
+---------------------------------
+-- Modules
+---------------------------------
+
+CREATE TABLE ir_module_category (
+ id serial NOT NULL,
+ create_uid integer references res_users on delete set null,
+ create_date timestamp without time zone,
+ write_date timestamp without time zone,
+ write_uid integer references res_users on delete set null,
+ parent_id integer REFERENCES ir_module_category ON DELETE SET NULL,
+ name character varying(128) NOT NULL,
+ primary key(id)
+);
+
+
+CREATE TABLE ir_module_module (
+ id serial NOT NULL,
+ create_uid integer references res_users on delete set null,
+ create_date timestamp without time zone,
+ write_date timestamp without time zone,
+ write_uid integer references res_users on delete set null,
+ website character varying(256),
+ name character varying(128) NOT NULL,
+ author character varying(128),
+ url character varying(128),
+ icon character varying(64),
+ state character varying(16),
+ latest_version character varying(64),
+ shortdesc character varying(256),
+ complexity character varying(32),
+ category_id integer REFERENCES ir_module_category ON DELETE SET NULL,
+ certificate character varying(64),
+ description text,
+ application boolean default False,
+ demo boolean default False,
+ web boolean DEFAULT FALSE,
+ license character varying(32),
+ sequence integer DEFAULT 100,
+ auto_install boolean default False,
+ primary key(id)
+);
+ALTER TABLE ir_module_module add constraint name_uniq unique (name);
+
+CREATE TABLE ir_module_module_dependency (
+ id serial NOT NULL,
+ create_uid integer references res_users on delete set null,
+ create_date timestamp without time zone,
+ write_date timestamp without time zone,
+ write_uid integer references res_users on delete set null,
+ name character varying(128),
+ version_pattern character varying(128) default NULL,
+ module_id integer REFERENCES ir_module_module ON DELETE cascade,
+ primary key(id)
+);
+
+CREATE TABLE res_company (
+ id serial NOT NULL,
+ name character varying(64) not null,
+ parent_id integer references res_company on delete set null,
+ primary key(id)
+);
+
+CREATE TABLE res_lang (
+ id serial PRIMARY KEY,
+ name VARCHAR(64) NOT NULL UNIQUE,
+ code VARCHAR(16) NOT NULL UNIQUE
+);
+
+CREATE TABLE ir_model_data (
+ id serial NOT NULL,
+ create_uid integer,
+ create_date timestamp without time zone,
+ write_date timestamp without time zone,
+ write_uid integer,
+ noupdate boolean,
+ name character varying(128) NOT NULL,
+ date_init timestamp without time zone,
+ date_update timestamp without time zone,
+ module character varying(64) NOT NULL,
+ model character varying(64) NOT NULL,
+ res_id integer, primary key(id)
+);
+
+---------------------------------
+-- Users
+---------------------------------
+
+insert into res_users (id,login,password,name,active,company_id,context_lang) values (1,'admin','admin','Administrator',True,1,'en_US');
+insert into ir_model_data (name,module,model,noupdate,res_id) values ('user_root','base','res.users',True,1);
+
+-- Compatibility purpose, to remove V6.0
+insert into ir_model_data (name,module,model,noupdate,res_id) values ('user_admin','base','res.users',True,1);
+
+select setval('res_users_id_seq', 2);
=== added file 'openerp/addons/base/base_data.xml'
--- openerp/addons/base/base_data.xml 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/base_data.xml 2012-04-19 18:12:21 +0000
@@ -0,0 +1,1752 @@
+<?xml version="1.0" encoding="utf-8"?>
+<openerp>
+ <data noupdate="1">
+ <record id="view_menu" model="ir.ui.view">
+ <field name="name">ir.ui.menu.tree</field>
+ <field name="model">ir.ui.menu</field>
+ <field name="type">tree</field>
+ <field name="arch" type="xml">
+ <tree string="Menu" toolbar="1">
+ <field icon="icon" name="name"/>
+ </tree>
+ </field>
+ <field name="field_parent">child_id</field>
+ </record>
+ <record id="action_menu_admin" model="ir.actions.act_window">
+ <field name="name">Menu</field>
+ <field name="usage">menu</field>
+ <field name="type">ir.actions.act_window</field>
+ <field name="view_id" ref="view_menu"/>
+ <field name="res_model">ir.ui.menu</field>
+ <field name="view_type">tree</field>
+ <field name="domain">[('parent_id', '=', False)]</field>
+ </record>
+
+ <record id="lang_en" model="res.lang">
+ <field name="code">en_US</field>
+ <field name="name">English</field>
+ <field name="translatable">True</field>
+ </record>
+
+ <function name="install_lang" model="res.lang"/>
+
+ <record id="ad" model="res.country">
+ <field name="name">Andorra, Principality of</field>
+ <field name="code">ad</field>
+ </record>
+ <record id="ae" model="res.country">
+ <field name="name">United Arab Emirates</field>
+ <field name="code">ae</field>
+ </record>
+ <record id="af" model="res.country">
+ <field name="name">Afghanistan, Islamic State of</field>
+ <field name="code">af</field>
+ </record>
+ <record id="ag" model="res.country">
+ <field name="name">Antigua and Barbuda</field>
+ <field name="code">ag</field>
+ </record>
+ <record id="ai" model="res.country">
+ <field name="name">Anguilla</field>
+ <field name="code">ai</field>
+ </record>
+ <record id="al" model="res.country">
+ <field name="name">Albania</field>
+ <field name="code">al</field>
+ </record>
+ <record id="am" model="res.country">
+ <field name="name">Armenia</field>
+ <field name="code">am</field>
+ </record>
+ <record id="an" model="res.country">
+ <field name="name">Netherlands Antilles</field>
+ <field name="code">an</field>
+ </record>
+ <record id="ao" model="res.country">
+ <field name="name">Angola</field>
+ <field name="code">ao</field>
+ </record>
+ <record id="aq" model="res.country">
+ <field name="name">Antarctica</field>
+ <field name="code">aq</field>
+ </record>
+ <record id="ar" model="res.country">
+ <field name="name">Argentina</field>
+ <field name="code">ar</field>
+ </record>
+ <record id="as" model="res.country">
+ <field name="name">American Samoa</field>
+ <field name="code">as</field>
+ </record>
+ <record id="at" model="res.country">
+ <field name="name">Austria</field>
+ <field name="code">at</field>
+ </record>
+ <record id="au" model="res.country">
+ <field name="name">Australia</field>
+ <field name="code">au</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s %(state_code)s %(zip)s\n%(country_name)s'" />
+ </record>
+ <record id="aw" model="res.country">
+ <field name="name">Aruba</field>
+ <field name="code">aw</field>
+ </record>
+ <record id="ax" model="res.country">
+ <field name="name">Åland Islands</field>
+ <field name="code">ax</field>
+ </record>
+ <record id="az" model="res.country">
+ <field name="name">Azerbaijan</field>
+ <field name="code">az</field>
+ </record>
+ <record id="ba" model="res.country">
+ <field name="name">Bosnia-Herzegovina</field>
+ <field name="code">ba</field>
+ </record>
+ <record id="bb" model="res.country">
+ <field name="name">Barbados</field>
+ <field name="code">bb</field>
+ </record>
+ <record id="bd" model="res.country">
+ <field name="name">Bangladesh</field>
+ <field name="code">bd</field>
+ </record>
+ <record id="be" model="res.country">
+ <field name="name">Belgium</field>
+ <field name="code">be</field>
+ <field name="address_format" eval="'%(street)s\n%(zip)s, %(city)s\n%(country_name)s'" />
+ </record>
+ <record id="bf" model="res.country">
+ <field name="name">Burkina Faso</field>
+ <field name="code">bf</field>
+ </record>
+ <record id="bg" model="res.country">
+ <field name="name">Bulgaria</field>
+ <field name="code">bg</field>
+ </record>
+ <record id="bh" model="res.country">
+ <field name="name">Bahrain</field>
+ <field name="code">bh</field>
+ </record>
+ <record id="bi" model="res.country">
+ <field name="name">Burundi</field>
+ <field name="code">bi</field>
+ </record>
+ <record id="bj" model="res.country">
+ <field name="name">Benin</field>
+ <field name="code">bj</field>
+ </record>
+ <record id="bl" model="res.country">
+ <field name="name">Saint Barthélémy</field>
+ <field name="code">bl</field>
+ </record>
+ <record id="bm" model="res.country">
+ <field name="name">Bermuda</field>
+ <field name="code">bm</field>
+ </record>
+ <record id="bn" model="res.country">
+ <field name="name">Brunei Darussalam</field>
+ <field name="code">bn</field>
+ </record>
+ <record id="bo" model="res.country">
+ <field name="name">Bolivia</field>
+ <field name="code">bo</field>
+ </record>
+ <record id="bq" model="res.country">
+ <field name="name">Bonaire, Sint Eustatius and Saba</field>
+ <field name="code">bq</field>
+ </record>
+ <record id="br" model="res.country">
+ <field name="name">Brazil</field>
+ <field name="code">br</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(city)s,%(state_code)s %(zip)s%(country_name)s'" />
+ </record>
+ <record id="bs" model="res.country">
+ <field name="name">Bahamas</field>
+ <field name="code">bs</field>
+ </record>
+ <record id="bt" model="res.country">
+ <field name="name">Bhutan</field>
+ <field name="code">bt</field>
+ </record>
+ <record id="bv" model="res.country">
+ <field name="name">Bouvet Island</field>
+ <field name="code">bv</field>
+ </record>
+ <record id="bw" model="res.country">
+ <field name="name">Botswana</field>
+ <field name="code">bw</field>
+ </record>
+ <record id="by" model="res.country">
+ <field name="name">Belarus</field>
+ <field name="code">by</field>
+ </record>
+ <record id="bz" model="res.country">
+ <field name="name">Belize</field>
+ <field name="code">bz</field>
+ </record>
+ <record id="ca" model="res.country">
+ <field name="name">Canada</field>
+ <field name="code">ca</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(city)s, %(state_code)s %(zip)s\n%(country_name)s'" />
+ </record>
+ <record id="cc" model="res.country">
+ <field name="name">Cocos (Keeling) Islands</field>
+ <field name="code">cc</field>
+ </record>
+ <record id="cf" model="res.country">
+ <field name="name">Central African Republic</field>
+ <field name="code">cf</field>
+ </record>
+ <record id="cd" model="res.country">
+ <field name="name">Congo, Democratic Republic of the</field>
+ <field name="code">cd</field>
+ </record>
+ <record id="cg" model="res.country">
+ <field name="name">Congo</field>
+ <field name="code">cg</field>
+ </record>
+ <record id="ch" model="res.country">
+ <field name="name">Switzerland</field>
+ <field name="code">ch</field>
+ </record>
+ <record id="ci" model="res.country">
+ <field name="name">Ivory Coast (Cote D'Ivoire)</field>
+ <field name="code">ci</field>
+ </record>
+ <record id="ck" model="res.country">
+ <field name="name">Cook Islands</field>
+ <field name="code">ck</field>
+ </record>
+ <record id="cl" model="res.country">
+ <field name="name">Chile</field>
+ <field name="code">cl</field>
+ </record>
+ <record id="cm" model="res.country">
+ <field name="name">Cameroon</field>
+ <field name="code">cm</field>
+ </record>
+ <record id="cn" model="res.country">
+ <field name="name">China</field>
+ <field name="code">cn</field>
+ </record>
+ <record id="co" model="res.country">
+ <field name="name">Colombia</field>
+ <field name="code">co</field>
+ </record>
+ <record id="cr" model="res.country">
+ <field name="name">Costa Rica</field>
+ <field name="code">cr</field>
+ </record>
+ <record id="cu" model="res.country">
+ <field name="name">Cuba</field>
+ <field name="code">cu</field>
+ </record>
+ <record id="cv" model="res.country">
+ <field name="name">Cape Verde</field>
+ <field name="code">cv</field>
+ </record>
+ <record id="cw" model="res.country">
+ <field name="name">Curaçao</field>
+ <field name="code">cw</field>
+ </record>
+ <record id="cx" model="res.country">
+ <field name="name">Christmas Island</field>
+ <field name="code">cx</field>
+ </record>
+ <record id="cy" model="res.country">
+ <field name="name">Cyprus</field>
+ <field name="code">cy</field>
+ </record>
+ <record id="cz" model="res.country">
+ <field name="name">Czech Republic</field>
+ <field name="code">cz</field>
+ </record>
+ <record id="de" model="res.country">
+ <field name="name">Germany</field>
+ <field name="code">de</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(zip)s %(city)s\n%(country_name)s'" />
+ </record>
+ <record id="dj" model="res.country">
+ <field name="name">Djibouti</field>
+ <field name="code">dj</field>
+ </record>
+ <record id="dk" model="res.country">
+ <field name="name">Denmark</field>
+ <field name="code">dk</field>
+ </record>
+ <record id="dm" model="res.country">
+ <field name="name">Dominica</field>
+ <field name="code">dm</field>
+ </record>
+ <record id="do" model="res.country">
+ <field name="name">Dominican Republic</field>
+ <field name="code">do</field>
+ </record>
+ <record id="dz" model="res.country">
+ <field name="name">Algeria</field>
+ <field name="code">dz</field>
+ </record>
+ <record id="ec" model="res.country">
+ <field name="name">Ecuador</field>
+ <field name="code">ec</field>
+ </record>
+ <record id="ee" model="res.country">
+ <field name="name">Estonia</field>
+ <field name="code">ee</field>
+ </record>
+ <record id="eg" model="res.country">
+ <field name="name">Egypt</field>
+ <field name="code">eg</field>
+ </record>
+ <record id="eh" model="res.country">
+ <field name="name">Western Sahara</field>
+ <field name="code">eh</field>
+ </record>
+ <record id="er" model="res.country">
+ <field name="name">Eritrea</field>
+ <field name="code">er</field>
+ </record>
+ <record id="es" model="res.country">
+ <field name="name">Spain</field>
+ <field name="code">es</field>
+ <field name="address_format" eval="'%(street)s\n%(zip)s %(city)s,%(state_name)s\n%(country_name)s'" />
+ </record>
+ <record id="et" model="res.country">
+ <field name="name">Ethiopia</field>
+ <field name="code">et</field>
+ </record>
+ <record id="fi" model="res.country">
+ <field name="name">Finland</field>
+ <field name="code">fi</field>
+ </record>
+ <record id="fj" model="res.country">
+ <field name="name">Fiji</field>
+ <field name="code">fj</field>
+ </record>
+ <record id="fk" model="res.country">
+ <field name="name">Falkland Islands</field>
+ <field name="code">fk</field>
+ </record>
+ <record id="fm" model="res.country">
+ <field name="name">Micronesia</field>
+ <field name="code">fm</field>
+ </record>
+ <record id="fo" model="res.country">
+ <field name="name">Faroe Islands</field>
+ <field name="code">fo</field>
+ </record>
+ <record id="fr" model="res.country">
+ <field name="name">France</field>
+ <field name="code">fr</field>
+ <field name="address_format" eval="'%(street)s\n%(zip)s %(city)s\n%(country_name)s'" />
+ </record>
+ <record id="ga" model="res.country">
+ <field name="name">Gabon</field>
+ <field name="code">ga</field>
+ </record>
+ <record id="gd" model="res.country">
+ <field name="name">Grenada</field>
+ <field name="code">gd</field>
+ </record>
+ <record id="ge" model="res.country">
+ <field name="name">Georgia</field>
+ <field name="code">ge</field>
+ </record>
+ <record id="gf" model="res.country">
+ <field name="name">French Guyana</field>
+ <field name="code">gf</field>
+ </record>
+ <record id="gh" model="res.country">
+ <field name="name">Ghana</field>
+ <field name="code">gh</field>
+ </record>
+ <record id="gi" model="res.country">
+ <field name="name">Gibraltar</field>
+ <field name="code">gi</field>
+ </record>
+ <record id="gg" model="res.country">
+ <field name="name">Guernsey</field>
+ <field name="code">gg</field>
+ </record>
+ <record id="gl" model="res.country">
+ <field name="name">Greenland</field>
+ <field name="code">gl</field>
+ </record>
+ <record id="gm" model="res.country">
+ <field name="name">Gambia</field>
+ <field name="code">gm</field>
+ </record>
+ <record id="gn" model="res.country">
+ <field name="name">Guinea</field>
+ <field name="code">gn</field>
+ </record>
+ <record id="gp" model="res.country">
+ <field name="name">Guadeloupe (French)</field>
+ <field name="code">gp</field>
+ </record>
+ <record id="gq" model="res.country">
+ <field name="name">Equatorial Guinea</field>
+ <field name="code">gq</field>
+ </record>
+ <record id="gr" model="res.country">
+ <field name="name">Greece</field>
+ <field name="code">gr</field>
+ </record>
+ <record id="gs" model="res.country">
+ <field name="name">South Georgia and the South Sandwich Islands</field>
+ <field name="code">gs</field>
+ </record>
+ <record id="gt" model="res.country">
+ <field name="name">Guatemala</field>
+ <field name="code">gt</field>
+ </record>
+ <record id="gu" model="res.country">
+ <field name="name">Guam (USA)</field>
+ <field name="code">gu</field>
+ </record>
+ <record id="gw" model="res.country">
+ <field name="name">Guinea Bissau</field>
+ <field name="code">gw</field>
+ </record>
+ <record id="gy" model="res.country">
+ <field name="name">Guyana</field>
+ <field name="code">gy</field>
+ </record>
+ <record id="hk" model="res.country">
+ <field name="name">Hong Kong</field>
+ <field name="code">hk</field>
+ </record>
+ <record id="hm" model="res.country">
+ <field name="name">Heard and McDonald Islands</field>
+ <field name="code">hm</field>
+ </record>
+ <record id="hn" model="res.country">
+ <field name="name">Honduras</field>
+ <field name="code">hn</field>
+ </record>
+ <record id="hr" model="res.country">
+ <field name="name">Croatia</field>
+ <field name="code">hr</field>
+ </record>
+ <record id="ht" model="res.country">
+ <field name="name">Haiti</field>
+ <field name="code">ht</field>
+ </record>
+ <record id="hu" model="res.country">
+ <field name="name">Hungary</field>
+ <field name="code">hu</field>
+ </record>
+ <record id="id" model="res.country">
+ <field name="name">Indonesia</field>
+ <field name="code">id</field>
+ </record>
+ <record id="ie" model="res.country">
+ <field name="name">Ireland</field>
+ <field name="code">ie</field>
+ </record>
+ <record id="il" model="res.country">
+ <field name="name">Israel</field>
+ <field name="code">il</field>
+ </record>
+ <record id="im" model="res.country">
+ <field name="name">Isle of Man</field>
+ <field name="code">im</field>
+ </record>
+ <record id="in" model="res.country">
+ <field name="name">India</field>
+ <field name="code">in</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(city)s, %(zip)s\n%(state_name)s%(country_name)s'" />
+ </record>
+ <record id="io" model="res.country">
+ <field name="name">British Indian Ocean Territory</field>
+ <field name="code">io</field>
+ </record>
+ <record id="iq" model="res.country">
+ <field name="name">Iraq</field>
+ <field name="code">iq</field>
+ </record>
+ <record id="ir" model="res.country">
+ <field name="name">Iran</field>
+ <field name="code">ir</field>
+ </record>
+ <record id="is" model="res.country">
+ <field name="name">Iceland</field>
+ <field name="code">is</field>
+ </record>
+ <record id="it" model="res.country">
+ <field name="name">Italy</field>
+ <field name="code">it</field>
+ </record>
+ <record id="je" model="res.country">
+ <field name="name">Jersey</field>
+ <field name="code">je</field>
+ </record>
+ <record id="jm" model="res.country">
+ <field name="name">Jamaica</field>
+ <field name="code">jm</field>
+ </record>
+ <record id="jo" model="res.country">
+ <field name="name">Jordan</field>
+ <field name="code">jo</field>
+ </record>
+ <record id="jp" model="res.country">
+ <field name="name">Japan</field>
+ <field name="code">jp</field>
+ </record>
+ <record id="ke" model="res.country">
+ <field name="name">Kenya</field>
+ <field name="code">ke</field>
+ </record>
+ <record id="kg" model="res.country">
+ <field name="name">Kyrgyz Republic (Kyrgyzstan)</field>
+ <field name="code">kg</field>
+ </record>
+ <record id="kh" model="res.country">
+ <field name="name">Cambodia, Kingdom of</field>
+ <field name="code">kh</field>
+ </record>
+ <record id="ki" model="res.country">
+ <field name="name">Kiribati</field>
+ <field name="code">ki</field>
+ </record>
+ <record id="km" model="res.country">
+ <field name="name">Comoros</field>
+ <field name="code">km</field>
+ </record>
+ <record id="kn" model="res.country">
+ <field name="name">Saint Kitts & Nevis Anguilla</field>
+ <field name="code">kn</field>
+ </record>
+ <record id="kp" model="res.country">
+ <field name="name">North Korea</field>
+ <field name="code">kp</field>
+ </record>
+ <record id="kr" model="res.country">
+ <field name="name">South Korea</field>
+ <field name="code">kr</field>
+ </record>
+ <record id="kw" model="res.country">
+ <field name="name">Kuwait</field>
+ <field name="code">kw</field>
+ </record>
+ <record id="ky" model="res.country">
+ <field name="name">Cayman Islands</field>
+ <field name="code">ky</field>
+ </record>
+ <record id="kz" model="res.country">
+ <field name="name">Kazakhstan</field>
+ <field name="code">kz</field>
+ </record>
+ <record id="la" model="res.country">
+ <field name="name">Laos</field>
+ <field name="code">la</field>
+ </record>
+ <record id="lb" model="res.country">
+ <field name="name">Lebanon</field>
+ <field name="code">lb</field>
+ </record>
+ <record id="lc" model="res.country">
+ <field name="name">Saint Lucia</field>
+ <field name="code">lc</field>
+ </record>
+ <record id="li" model="res.country">
+ <field name="name">Liechtenstein</field>
+ <field name="code">li</field>
+ </record>
+ <record id="lk" model="res.country">
+ <field name="name">Sri Lanka</field>
+ <field name="code">lk</field>
+ </record>
+ <record id="lr" model="res.country">
+ <field name="name">Liberia</field>
+ <field name="code">lr</field>
+ </record>
+ <record id="ls" model="res.country">
+ <field name="name">Lesotho</field>
+ <field name="code">ls</field>
+ </record>
+ <record id="lt" model="res.country">
+ <field name="name">Lithuania</field>
+ <field name="code">lt</field>
+ </record>
+ <record id="lu" model="res.country">
+ <field name="name">Luxembourg</field>
+ <field name="code">lu</field>
+ </record>
+ <record id="lv" model="res.country">
+ <field name="name">Latvia</field>
+ <field name="code">lv</field>
+ </record>
+ <record id="ly" model="res.country">
+ <field name="name">Libya</field>
+ <field name="code">ly</field>
+ </record>
+ <record id="ma" model="res.country">
+ <field name="name">Morocco</field>
+ <field name="code">ma</field>
+ </record>
+ <record id="mc" model="res.country">
+ <field name="name">Monaco</field>
+ <field name="code">mc</field>
+ </record>
+ <record id="md" model="res.country">
+ <field name="name">Moldavia</field>
+ <field name="code">md</field>
+ </record>
+ <record id="me" model="res.country">
+ <field name="name">Montenegro</field>
+ <field name="code">me</field>
+ </record>
+ <record id="mf" model="res.country">
+ <field name="name">Saint Martin (French part)</field>
+ <field name="code">mf</field>
+ </record>
+ <record id="mg" model="res.country">
+ <field name="name">Madagascar</field>
+ <field name="code">mg</field>
+ </record>
+ <record id="mh" model="res.country">
+ <field name="name">Marshall Islands</field>
+ <field name="code">mh</field>
+ </record>
+ <record id="mk" model="res.country">
+ <field name="name">Macedonia, the former Yugoslav Republic of</field>
+ <field name="code">mk</field>
+ </record>
+ <record id="ml" model="res.country">
+ <field name="name">Mali</field>
+ <field name="code">ml</field>
+ </record>
+ <record id="mm" model="res.country">
+ <field name="name">Myanmar</field>
+ <field name="code">mm</field>
+ </record>
+ <record id="mn" model="res.country">
+ <field name="name">Mongolia</field>
+ <field name="code">mn</field>
+ </record>
+ <record id="mo" model="res.country">
+ <field name="name">Macau</field>
+ <field name="code">mo</field>
+ </record>
+ <record id="mp" model="res.country">
+ <field name="name">Northern Mariana Islands</field>
+ <field name="code">mp</field>
+ </record>
+ <record id="mq" model="res.country">
+ <field name="name">Martinique (French)</field>
+ <field name="code">mq</field>
+ </record>
+ <record id="mr" model="res.country">
+ <field name="name">Mauritania</field>
+ <field name="code">mr</field>
+ </record>
+ <record id="ms" model="res.country">
+ <field name="name">Montserrat</field>
+ <field name="code">ms</field>
+ </record>
+ <record id="mt" model="res.country">
+ <field name="name">Malta</field>
+ <field name="code">mt</field>
+ </record>
+ <record id="mu" model="res.country">
+ <field name="name">Mauritius</field>
+ <field name="code">mu</field>
+ </record>
+ <record id="mv" model="res.country">
+ <field name="name">Maldives</field>
+ <field name="code">mv</field>
+ </record>
+ <record id="mw" model="res.country">
+ <field name="name">Malawi</field>
+ <field name="code">mw</field>
+ </record>
+ <record id="mx" model="res.country">
+ <field name="name">Mexico</field>
+ <field name="code">mx</field>
+ </record>
+ <record id="my" model="res.country">
+ <field name="name">Malaysia</field>
+ <field name="code">my</field>
+ </record>
+ <record id="mz" model="res.country">
+ <field name="name">Mozambique</field>
+ <field name="code">mz</field>
+ </record>
+ <record id="na" model="res.country">
+ <field name="name">Namibia</field>
+ <field name="code">na</field>
+ </record>
+ <record id="nc" model="res.country">
+ <field name="name">New Caledonia (French)</field>
+ <field name="code">nc</field>
+ </record>
+ <record id="ne" model="res.country">
+ <field name="name">Niger</field>
+ <field name="code">ne</field>
+ </record>
+ <record id="nf" model="res.country">
+ <field name="name">Norfolk Island</field>
+ <field name="code">nf</field>
+ </record>
+ <record id="ng" model="res.country">
+ <field name="name">Nigeria</field>
+ <field name="code">ng</field>
+ </record>
+ <record id="ni" model="res.country">
+ <field name="name">Nicaragua</field>
+ <field name="code">ni</field>
+ </record>
+ <record id="nl" model="res.country">
+ <field name="name">Netherlands</field>
+ <field name="code">nl</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(zip)s %(city)s\n%(country_name)s'" />
+ </record>
+ <record id="no" model="res.country">
+ <field name="name">Norway</field>
+ <field name="code">no</field>
+ </record>
+ <record id="np" model="res.country">
+ <field name="name">Nepal</field>
+ <field name="code">np</field>
+ </record>
+ <record id="nr" model="res.country">
+ <field name="name">Nauru</field>
+ <field name="code">nr</field>
+ </record>
+ <record id="nt" model="res.country">
+ <field name="name">Neutral Zone</field>
+ <field name="code">nt</field>
+ </record>
+ <record id="nu" model="res.country">
+ <field name="name">Niue</field>
+ <field name="code">nu</field>
+ </record>
+ <record id="nz" model="res.country">
+ <field name="name">New Zealand</field>
+ <field name="code">nz</field>
+ </record>
+ <record id="om" model="res.country">
+ <field name="name">Oman</field>
+ <field name="code">om</field>
+ </record>
+ <record id="pa" model="res.country">
+ <field name="name">Panama</field>
+ <field name="code">pa</field>
+ </record>
+ <record id="pe" model="res.country">
+ <field name="name">Peru</field>
+ <field name="code">pe</field>
+ </record>
+ <record id="pf" model="res.country">
+ <field name="name">Polynesia (French)</field>
+ <field name="code">pf</field>
+ </record>
+ <record id="pg" model="res.country">
+ <field name="name">Papua New Guinea</field>
+ <field name="code">pg</field>
+ </record>
+ <record id="ph" model="res.country">
+ <field name="name">Philippines</field>
+ <field name="code">ph</field>
+ </record>
+ <record id="pk" model="res.country">
+ <field name="name">Pakistan</field>
+ <field name="code">pk</field>
+ </record>
+ <record id="pl" model="res.country">
+ <field name="name">Poland</field>
+ <field name="code">pl</field>
+ </record>
+ <record id="pm" model="res.country">
+ <field name="name">Saint Pierre and Miquelon</field>
+ <field name="code">pm</field>
+ </record>
+ <record id="pn" model="res.country">
+ <field name="name">Pitcairn Island</field>
+ <field name="code">pn</field>
+ </record>
+ <record id="pr" model="res.country">
+ <field name="name">Puerto Rico</field>
+ <field name="code">pr</field>
+ </record>
+ <record id="ps" model="res.country">
+ <field name="name">Palestinian Territory, Occupied</field>
+ <field name="code">ps</field>
+ </record>
+ <record id="pt" model="res.country">
+ <field name="name">Portugal</field>
+ <field name="code">pt</field>
+ </record>
+ <record id="pw" model="res.country">
+ <field name="name">Palau</field>
+ <field name="code">pw</field>
+ </record>
+ <record id="py" model="res.country">
+ <field name="name">Paraguay</field>
+ <field name="code">py</field>
+ </record>
+ <record id="qa" model="res.country">
+ <field name="name">Qatar</field>
+ <field name="code">qa</field>
+ </record>
+ <record id="re" model="res.country">
+ <field name="name">Reunion (French)</field>
+ <field name="code">re</field>
+ </record>
+ <record id="ro" model="res.country">
+ <field name="name">Romania</field>
+ <field name="code">ro</field>
+ </record>
+ <record id="rs" model="res.country">
+ <field name="name">Serbia</field>
+ <field name="code">rs</field>
+ </record>
+ <record id="ru" model="res.country">
+ <field name="name">Russian Federation</field>
+ <field name="code">ru</field>
+ </record>
+ <record id="rw" model="res.country">
+ <field name="name">Rwanda</field>
+ <field name="code">rw</field>
+ </record>
+ <record id="sa" model="res.country">
+ <field name="name">Saudi Arabia</field>
+ <field name="code">sa</field>
+ </record>
+ <record id="sb" model="res.country">
+ <field name="name">Solomon Islands</field>
+ <field name="code">sb</field>
+ </record>
+ <record id="sc" model="res.country">
+ <field name="name">Seychelles</field>
+ <field name="code">sc</field>
+ </record>
+ <record id="sd" model="res.country">
+ <field name="name">Sudan</field>
+ <field name="code">sd</field>
+ </record>
+ <record id="se" model="res.country">
+ <field name="name">Sweden</field>
+ <field name="code">se</field>
+ </record>
+ <record id="sg" model="res.country">
+ <field name="name">Singapore</field>
+ <field name="code">sg</field>
+ </record>
+ <record id="sh" model="res.country">
+ <field name="name">Saint Helena</field>
+ <field name="code">sh</field>
+ </record>
+ <record id="si" model="res.country">
+ <field name="name">Slovenia</field>
+ <field name="code">si</field>
+ </record>
+ <record id="sj" model="res.country">
+ <field name="name">Svalbard and Jan Mayen Islands</field>
+ <field name="code">sj</field>
+ </record>
+ <record id="sk" model="res.country">
+ <field name="name">Slovakia</field>
+ <field name="code">sk</field>
+ </record>
+ <record id="sl" model="res.country">
+ <field name="name">Sierra Leone</field>
+ <field name="code">sl</field>
+ </record>
+ <record id="sm" model="res.country">
+ <field name="name">San Marino</field>
+ <field name="code">sm</field>
+ </record>
+ <record id="sn" model="res.country">
+ <field name="name">Senegal</field>
+ <field name="code">sn</field>
+ </record>
+ <record id="so" model="res.country">
+ <field name="name">Somalia</field>
+ <field name="code">so</field>
+ </record>
+ <record id="sr" model="res.country">
+ <field name="name">Suriname</field>
+ <field name="code">sr</field>
+ </record>
+ <record id="ss" model="res.country">
+ <field name="name">South Sudan</field>
+ <field name="code">ss</field>
+ </record>
+ <record id="st" model="res.country">
+ <field name="name">Saint Tome (Sao Tome) and Principe</field>
+ <field name="code">st</field>
+ </record>
+ <record id="sv" model="res.country">
+ <field name="name">El Salvador</field>
+ <field name="code">sv</field>
+ </record>
+ <record id="sx" model="res.country">
+ <field name="name">Sint Maarten (Dutch part)</field>
+ <field name="code">sx</field>
+ </record>
+ <record id="sy" model="res.country">
+ <field name="name">Syria</field>
+ <field name="code">sy</field>
+ </record>
+ <record id="sz" model="res.country">
+ <field name="name">Swaziland</field>
+ <field name="code">sz</field>
+ </record>
+ <record id="tc" model="res.country">
+ <field name="name">Turks and Caicos Islands</field>
+ <field name="code">tc</field>
+ </record>
+ <record id="td" model="res.country">
+ <field name="name">Chad</field>
+ <field name="code">td</field>
+ </record>
+ <record id="tf" model="res.country">
+ <field name="name">French Southern Territories</field>
+ <field name="code">tf</field>
+ </record>
+ <record id="tg" model="res.country">
+ <field name="name">Togo</field>
+ <field name="code">tg</field>
+ </record>
+ <record id="th" model="res.country">
+ <field name="name">Thailand</field>
+ <field name="code">th</field>
+ </record>
+ <record id="tj" model="res.country">
+ <field name="name">Tajikistan</field>
+ <field name="code">tj</field>
+ </record>
+ <record id="tk" model="res.country">
+ <field name="name">Tokelau</field>
+ <field name="code">tk</field>
+ </record>
+ <record id="tm" model="res.country">
+ <field name="name">Turkmenistan</field>
+ <field name="code">tm</field>
+ </record>
+ <record id="tn" model="res.country">
+ <field name="name">Tunisia</field>
+ <field name="code">tn</field>
+ </record>
+ <record id="to" model="res.country">
+ <field name="name">Tonga</field>
+ <field name="code">to</field>
+ </record>
+ <record id="tp" model="res.country">
+ <field name="name">East Timor</field>
+ <field name="code">tp</field>
+ </record>
+ <record id="tr" model="res.country">
+ <field name="name">Turkey</field>
+ <field name="code">tr</field>
+ </record>
+ <record id="tt" model="res.country">
+ <field name="name">Trinidad and Tobago</field>
+ <field name="code">tt</field>
+ </record>
+ <record id="tv" model="res.country">
+ <field name="name">Tuvalu</field>
+ <field name="code">tv</field>
+ </record>
+ <record id="tw" model="res.country">
+ <field name="name">Taiwan</field>
+ <field name="code">tw</field>
+ </record>
+ <record id="tz" model="res.country">
+ <field name="name">Tanzania</field>
+ <field name="code">tz</field>
+ </record>
+ <record id="ua" model="res.country">
+ <field name="name">Ukraine</field>
+ <field name="code">ua</field>
+ </record>
+ <record id="ug" model="res.country">
+ <field name="name">Uganda</field>
+ <field name="code">ug</field>
+ </record>
+ <record id="uk" model="res.country">
+ <field name="name">United Kingdom</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(city)s\n%(country_name)s\n%(zip)s'" />
+ <field name="code">gb</field>
+ </record>
+ <record id="um" model="res.country">
+ <field name="name">USA Minor Outlying Islands</field>
+ <field name="code">um</field>
+ </record>
+ <record id="us" model="res.country">
+ <field name="name">United States</field>
+ <field name="code">us</field>
+ <field name="address_format" eval="'%(street)s\n%(street2)s\n%(city)s, %(state_code)s %(zip)s\n%(country_name)s'" />
+ </record>
+ <record id="uy" model="res.country">
+ <field name="name">Uruguay</field>
+ <field name="code">uy</field>
+ </record>
+ <record id="uz" model="res.country">
+ <field name="name">Uzbekistan</field>
+ <field name="code">uz</field>
+ </record>
+ <record id="va" model="res.country">
+ <field name="name">Holy See (Vatican City State)</field>
+ <field name="code">va</field>
+ </record>
+ <record id="vc" model="res.country">
+ <field name="name">Saint Vincent & Grenadines</field>
+ <field name="code">vc</field>
+ </record>
+ <record id="ve" model="res.country">
+ <field name="name">Venezuela</field>
+ <field name="code">ve</field>
+ </record>
+ <record id="vg" model="res.country">
+ <field name="name">Virgin Islands (British)</field>
+ <field name="code">vg</field>
+ </record>
+ <record id="vi" model="res.country">
+ <field name="name">Virgin Islands (USA)</field>
+ <field name="code">vi</field>
+ </record>
+ <record id="vn" model="res.country">
+ <field name="name">Vietnam</field>
+ <field name="code">vn</field>
+ </record>
+ <record id="vu" model="res.country">
+ <field name="name">Vanuatu</field>
+ <field name="code">vu</field>
+ </record>
+ <record id="wf" model="res.country">
+ <field name="name">Wallis and Futuna Islands</field>
+ <field name="code">wf</field>
+ </record>
+ <record id="ws" model="res.country">
+ <field name="name">Samoa</field>
+ <field name="code">ws</field>
+ </record>
+ <record id="ye" model="res.country">
+ <field name="name">Yemen</field>
+ <field name="code">ye</field>
+ </record>
+ <record id="yt" model="res.country">
+ <field name="name">Mayotte</field>
+ <field name="code">yt</field>
+ </record>
+ <record id="yu" model="res.country">
+ <field name="name">Yugoslavia</field>
+ <field name="code">yu</field>
+ </record>
+ <record id="za" model="res.country">
+ <field name="name">South Africa</field>
+ <field name="code">za</field>
+ </record>
+ <record id="zm" model="res.country">
+ <field name="name">Zambia</field>
+ <field name="code">zm</field>
+ </record>
+ <!-- DEPRECATED, New name of Zaire is Democratic Republic of the Congo ! -->
+ <record id="zr" model="res.country">
+ <field name="name">Zaire</field>
+ <field name="code">zr</field>
+ </record>
+ <record id="zw" model="res.country">
+ <field name="name">Zimbabwe</field>
+ <field name="code">zw</field>
+ </record>
+
+ <record id="main_partner" model="res.partner">
+ <field name="name">Your Company</field>
+ <!-- Address and Company ID will be set later -->
+ <field name="address" eval="[]"/>
+ <field name="company_id" eval="None"/>
+ <field name="customer" eval="False"/>
+ </record>
+ <record id="main_address" model="res.partner.address">
+ <field name="partner_id" ref="main_partner"/>
+ <field name="type">default</field>
+ <field name="company_id" eval="None"/>
+ </record>
+
+ <!-- Currencies -->
+ <record id="EUR" model="res.currency">
+ <field name="name">EUR</field>
+ <field name="symbol">€</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <!-- Company ID will be set later -->
+ <field name="company_id" eval="None"/>
+ </record>
+ <record id="rateEUR" model="res.currency.rate">
+ <field name="rate">1.0</field>
+ <field name="currency_id" ref="EUR"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <!-- Basic Company -->
+ <record id="main_company" model="res.company">
+ <field name="name">Your Company</field>
+ <field name="partner_id" ref="main_partner"/>
+ <field name="rml_footer1">Web: www.companyname.com - Tel: +1-212-555-12345</field>
+ <field name="rml_footer2">IBAN: XX12 3456 7890 1234 5678 - SWIFT: SWIFTCODE - VAT: Company vat number</field>
+ <field name="currency_id" ref="base.EUR"/>
+ </record>
+
+ <record model="res.users" id="base.user_root">
+ <field name="signature">Administrator</field>
+ <field name="company_id" ref="main_company"/>
+ <field name="menu_id" ref="action_menu_admin"/>
+ <field name="company_ids" eval="[(4, ref('main_company'))]"/>
+ </record>
+
+ <record id="main_partner" model="res.partner">
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="main_address" model="res.partner.address">
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="EUR" model="res.currency">
+ <field name="company_id" ref="main_company"/>
+ </record>
+
+ <!-- The Following currency rates are considered as on 1st Jan,2010 against EUR. -->
+ <!-- Currencies -->
+ <record id="EUR" model="res.currency">
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="USD" model="res.currency">
+ <field name="name">USD</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateUSD" model="res.currency.rate">
+ <field name="rate">1.2834</field>
+ <field name="currency_id" ref="USD"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <!-- VEF was previously VEB -->
+ <record id="VEF" model="res.currency">
+ <field name="name">VEF</field>
+ <field name="symbol">Bs.F</field>
+ <field name="rounding">0.0001</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateVEF" model="res.currency.rate">
+ <field name="rate">5.864</field>
+ <field name="currency_id" ref="VEF"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="CAD" model="res.currency">
+ <field name="name">CAD</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCAD" model="res.currency.rate">
+ <field name="rate">1.3388</field>
+ <field name="currency_id" ref="CAD"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+
+ <record id="CHF" model="res.currency">
+ <field name="name">CHF</field>
+ <field name="symbol">CHF</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCHF" model="res.currency.rate">
+ <field name="rate">1.3086</field>
+ <field name="currency_id" ref="CHF"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="BRL" model="res.currency">
+ <field name="name">BRL</field>
+ <field name="symbol">R$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateBRL" model="res.currency.rate">
+ <field name="rate">2.2344</field>
+ <field name="currency_id" ref="BRL"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="CNY" model="res.currency">
+ <field name="name">CNY</field>
+ <field name="symbol">¥</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCNY" model="res.currency.rate">
+ <field name="rate">8.7556</field>
+ <field name="currency_id" ref="CNY"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+
+ <record id="COP" model="res.currency">
+ <field name="name">COP</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCOP" model="res.currency.rate">
+ <field name="rate">2933.8378</field>
+ <field name="currency_id" ref="COP"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="CZK" model="res.currency">
+ <field name="name">CZK</field>
+ <field name="symbol">Kč</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCZK" model="res.currency.rate">
+ <field name="rate">26.5634</field>
+ <field name="currency_id" ref="CZK"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="DKK" model="res.currency">
+ <field name="name">DKK</field>
+ <field name="symbol">kr</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateDKK" model="res.currency.rate">
+ <field name="rate">7.4445</field>
+ <field name="currency_id" ref="DKK"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+
+ <record id="HUF" model="res.currency">
+ <field name="name">HUF</field>
+ <field name="symbol">Ft</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateHUF" model="res.currency.rate">
+ <field name="rate">271.5621</field>
+ <field name="currency_id" ref="HUF"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="IDR" model="res.currency">
+ <field name="name">IDR</field>
+ <field name="symbol">Rp</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateIDR1" model="res.currency.rate">
+ <field name="rate">14352.00</field>
+ <field name="currency_id" ref="IDR"/>
+ <field eval="time.strftime('2009-01-01')" name="name"/>
+ </record>
+ <record id="rateIDR" model="res.currency.rate">
+ <field name="rate">11796.39</field>
+ <field name="currency_id" ref="IDR"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="LVL" model="res.currency">
+ <field name="name">LVL</field>
+ <field name="symbol">Ls</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateLVL" model="res.currency.rate">
+ <field name="rate">0.7086</field>
+ <field name="currency_id" ref="LVL"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+
+ <record id="NOK" model="res.currency">
+ <field name="name">NOK</field>
+ <field name="symbol">kr</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateNOK" model="res.currency.rate">
+ <field name="rate">7.8668</field>
+ <field name="currency_id" ref="NOK"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="XPF" model="res.currency">
+ <field name="name">XPF</field>
+ <field name="symbol">XPF</field>
+ <field name="rounding">1.00</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateXPF" model="res.currency.rate">
+ <field name="rate">119.331742</field>
+ <field name="currency_id" ref="XPF"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="PAB" model="res.currency">
+ <field name="name">PAB</field>
+ <field name="symbol">B/.</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="ratePAB" model="res.currency.rate">
+ <field name="rate">1.2676</field>
+ <field name="currency_id" ref="PAB"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="PLN" model="res.currency">
+ <field name="name">PLN</field>
+ <field name="symbol">zł</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="ratePLN" model="res.currency.rate">
+ <field name="rate">4.1005</field>
+ <field name="currency_id" ref="PLN"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="SEK" model="res.currency">
+ <field name="name">SEK</field>
+ <field name="symbol">kr</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateSEK" model="res.currency.rate">
+ <field name="rate">10.3004</field>
+ <field name="currency_id" ref="SEK"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="GBP" model="res.currency">
+ <field name="name">GBP</field>
+ <field name="symbol">£</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateGBP" model="res.currency.rate">
+ <field name="rate">0.8333</field>
+ <field name="currency_id" ref="GBP"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="ARS" model="res.currency">
+ <field name="name">ARS</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateARS" model="res.currency.rate">
+ <field name="rate">5.0881</field>
+ <field name="currency_id" ref="ARS"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="INR" model="res.currency">
+ <field name="name">INR</field>
+ <field name="symbol">₹</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateINR" model="res.currency.rate">
+ <field name="rate">59.9739</field>
+ <field name="currency_id" ref="INR"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="AUD" model="res.currency">
+ <field name="name">AUD</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateAUD" model="res.currency.rate">
+ <field name="rate">1.4070</field>
+ <field name="currency_id" ref="AUD"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="UAH" model="res.currency">
+ <field name="name">UAH</field>
+ <field name="symbol">₴</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateUAH" model="res.currency.rate">
+ <field name="rate">10.1969</field>
+ <field name="currency_id" ref="UAH"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="VND" model="res.currency">
+ <field name="name">VND</field>
+ <field name="symbol">₫</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateVND" model="res.currency.rate">
+ <field name="rate">26330.01</field>
+ <field name="currency_id" ref="VND"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="HKD" model="res.currency">
+ <field name="name">HKD</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateHKD" model="res.currency.rate">
+ <field name="rate">11.1608</field>
+ <field name="currency_id" ref="HKD"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="JPY" model="res.currency">
+ <field name="name">JPY</field>
+ <field name="symbol">¥</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateJPY" model="res.currency.rate">
+ <field name="rate">133.62</field>
+ <field name="currency_id" ref="JPY"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="BGN" model="res.currency">
+ <field name="name">BGN</field>
+ <field name="symbol">лв</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateBGN" model="res.currency.rate">
+ <field name="rate">1.9558</field>
+ <field name="currency_id" ref="BGN"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="LTL" model="res.currency">
+ <field name="name">LTL</field>
+ <field name="symbol">Lt</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateLTL" model="res.currency.rate">
+ <field name="rate">3.4528</field>
+ <field name="currency_id" ref="LTL"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="RON" model="res.currency">
+ <field name="name">RON</field>
+ <field name="symbol">lei</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateRON" model="res.currency.rate">
+ <field name="rate">4.2253</field>
+ <field name="currency_id" ref="RON"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="HRK" model="res.currency">
+ <field name="name">HRK</field>
+ <field name="symbol">kn</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateHRK" model="res.currency.rate">
+ <field name="rate">7.2936</field>
+ <field name="currency_id" ref="HRK"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="RUB" model="res.currency">
+ <field name="name">RUB</field>
+ <field name="symbol">руб</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateRUB" model="res.currency.rate">
+ <field name="rate">43.16</field>
+ <field name="currency_id" ref="RUB"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="TRY" model="res.currency">
+ <field name="name">TRY</field>
+ <field name="symbol">TL</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateTRY" model="res.currency.rate">
+ <field name="rate">2.1411</field>
+ <field name="currency_id" ref="TRY"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="KRW" model="res.currency">
+ <field name="name">KRW</field>
+ <field name="symbol">₩</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateKRW" model="res.currency.rate">
+ <field name="rate">1662.37</field>
+ <field name="currency_id" ref="KRW"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="MXN" model="res.currency">
+ <field name="name">MXN</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateMXN" model="res.currency.rate">
+ <field name="rate">18.6664</field>
+ <field name="currency_id" ref="MXN"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="MYR" model="res.currency">
+ <field name="name">MYR</field>
+ <field name="symbol">RM</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateMYR" model="res.currency.rate">
+ <field name="rate">4.8887</field>
+ <field name="currency_id" ref="MYR"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="NZD" model="res.currency">
+ <field name="name">NZD</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateNZD" model="res.currency.rate">
+ <field name="rate">1.9764</field>
+ <field name="currency_id" ref="NZD"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="PHP" model="res.currency">
+ <field name="name">PHP</field>
+ <field name="symbol">Php</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="ratePHP" model="res.currency.rate">
+ <field name="rate">66.1</field>
+ <field name="currency_id" ref="PHP"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="SGD" model="res.currency">
+ <field name="name">SGD</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateSGD" model="res.currency.rate">
+ <field name="rate">2.0126</field>
+ <field name="currency_id" ref="SGD"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="THB" model="res.currency">
+ <field name="name">THB</field>
+ <field name="symbol">฿</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateTHB" model="res.currency.rate">
+ <field name="rate">47.779</field>
+ <field name="currency_id" ref="THB"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="ZAR" model="res.currency">
+ <field name="name">ZAR</field>
+ <field name="symbol">R</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateZAR" model="res.currency.rate">
+ <field name="rate">10.5618</field>
+ <field name="currency_id" ref="ZAR"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="res_bank_1" model="res.bank">
+ <field name="name">Reserve</field>
+ </record>
+
+ <record id="CRC" model="res.currency">
+ <field name="name">CRC</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="symbol">¢</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCRC" model="res.currency.rate">
+ <field name="rate">691.3153</field>
+ <field name="currency_id" ref="CRC"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="ir_mail_server_localhost0" model="ir.mail_server">
+ <field name="name">localhost</field>
+ <field name="smtp_host">localhost</field>
+ <field eval="25" name="smtp_port"/>
+ <field eval="10" name="sequence"/>
+ </record>
+
+ <record id="MUR" model="res.currency">
+ <field name="name">MUR</field>
+ <field name="symbol">Rs</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateMUR" model="res.currency.rate">
+ <field name="rate">40.28</field>
+ <field name="currency_id" ref="MUR"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="XOF" model="res.currency">
+ <field name="name">XOF</field>
+ <field name="symbol">CFA</field>
+ <field name="rounding">1</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateXOF" model="res.currency.rate">
+ <field name="rate">655.957</field>
+ <field name="currency_id" ref="XOF"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="XAF" model="res.currency">
+ <field name="name">XAF</field>
+ <field name="symbol">FCFA</field>
+ <field name="rounding">1</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateXAF" model="res.currency.rate">
+ <field name="rate">655.957</field>
+ <field name="currency_id" ref="XAF"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="UGX" model="res.currency">
+ <field name="name">UGX</field>
+ <field name="symbol">USh</field>
+ <field name="rounding">1</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateUGX" model="res.currency.rate">
+ <field name="rate">3401.91388</field>
+ <field name="currency_id" ref="UGX"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <record id="HNL" model="res.currency">
+ <field name="name">HNL</field>
+ <field name="symbol">L</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateHNL" model="res.currency.rate">
+ <field name="rate">25</field>
+ <field name="currency_id" ref="HNL"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <!-- Chilean peso -->
+ <record id="CLP" model="res.currency">
+ <field name="name">CLP</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateCLP" model="res.currency.rate">
+ <field name="rate">710</field>
+ <field name="currency_id" ref="CLP"/>
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ </record>
+
+ <!-- Uruguayan peso -->
+ <record id="UYU" model="res.currency">
+ <field name="name">UYU</field>
+ <field name="symbol">$</field>
+ <field name="rounding">0.01</field>
+ <field name="accuracy">4</field>
+ <field name="company_id" ref="main_company"/>
+ </record>
+ <record id="rateUYU" model="res.currency.rate">
+ <field name="currency_id" ref="UYU" />
+ <field eval="time.strftime('%Y-01-01')" name="name"/>
+ <field name="rate">28.36</field>
+ </record>
+
+ </data>
+</openerp>
=== added file 'openerp/addons/base/base_demo.xml'
--- openerp/addons/base/base_demo.xml 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/base_demo.xml 2012-04-19 18:12:21 +0000
@@ -0,0 +1,26 @@
+<?xml version="1.0" encoding="utf-8"?>
+<openerp>
+ <data noupdate="1">
+
+ <record id="demo_address" model="res.partner.address">
+ <field name="name">Fabien Dupont</field>
+ <field name="street">Chaussee de Namur</field>
+ <field name="zip">1367</field>
+ <field name="city">Gerompont</field>
+ <field name="phone">(+32).81.81.37.00</field>
+ <field name="type">default</field>
+ <field model="res.country" name="country_id" ref="be"/>
+ <!-- Company ID will be set later -->
+ <field name="company_id" eval="None"/>
+ </record>
+
+ <record id="user_demo" model="res.users">
+ <field name="login">demo</field>
+ <field name="password">demo</field>
+ <field name="name">Demo User</field>
+ <field name="signature">Mr Demo</field>
+ <field name="company_id" ref="main_company"/>
+ <field name="groups_id" eval="[(6,0,[ref('base.group_user')])]"/>
+ </record>
+ </data>
+</openerp>
=== added file 'openerp/addons/base/base_menu.xml'
--- openerp/addons/base/base_menu.xml 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/base_menu.xml 2012-04-19 18:12:21 +0000
@@ -0,0 +1,34 @@
+<?xml version="1.0" encoding="utf-8"?>
+<openerp>
+ <data>
+ <menuitem icon="terp-administration" id="menu_administration"
+ name="Settings" sequence="50"
+ web_icon="data/administration.png"
+ web_icon_hover="data/administration-hover.png"/>
+
+ <menuitem icon="terp-administration" id="menu_administration_shortcut" parent="menu_administration" name="Custom Shortcuts" sequence="50"/>
+ <menuitem id="menu_custom" name="Customization"
+ parent="base.menu_administration" sequence="6"
+ groups="base.group_extended"/>
+ <menuitem id="next_id_4" name="Low Level Objects"
+ parent="base.menu_custom" sequence="30"/>
+ <menuitem id="menu_low_workflow" name="Workflows" parent="base.next_id_4"/>
+ <menuitem id="menu_custom_action" name="Actions" parent="base.menu_custom" groups="base.group_extended" sequence="20"/>
+ <menuitem id="menu_config" name="Configuration" parent="base.menu_administration" sequence="1"/>
+ <menuitem id="menu_translation" name="Translations" parent="base.menu_administration" sequence="6"/>
+ <menuitem id="menu_translation_app" name="Application Terms" parent="base.menu_translation" sequence="4" groups="base.group_extended"/>
+ <menuitem id="menu_translation_export" name="Import / Export"
+ groups="base.group_extended" parent="base.menu_translation" sequence="3"/>
+ <menuitem id="menu_users" name="Users" parent="base.menu_administration" sequence="4"/>
+ <menuitem id="menu_security" name="Security" parent="base.menu_administration" sequence="5"
+ groups="base.group_extended"/>
+ <menuitem id="menu_management" name="Modules" parent="base.menu_administration" sequence="0"/>
+ <menuitem id="reporting_menu"
+ parent="base.menu_custom" name="Reporting" sequence="30"
+ />
+
+ <menuitem id="base.menu_reporting" name="Reporting" parent="base.menu_administration" sequence="11"
+ groups="base.group_extended"/>
+ <menuitem id="menu_audit" name="Audit" parent="base.menu_reporting" sequence="50"/>
+ </data>
+</openerp>
=== added file 'openerp/addons/base/base_update.xml'
--- openerp/addons/base/base_update.xml 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/base_update.xml 2012-04-19 18:12:21 +0000
@@ -0,0 +1,301 @@
+<?xml version="1.0" encoding="utf-8"?>
+<openerp>
+ <data>
+ <!--
+ ======================
+ Languages
+ ======================
+ -->
+ <menuitem id="next_id_2" name="User Interface" parent="base.menu_custom" groups="base.group_extended"/>
+
+ <!--
+ ======================
+ Groups
+ ======================
+ -->
+ <record id="view_groups_form" model="ir.ui.view">
+ <field name="name">res.groups.form</field>
+ <field name="model">res.groups</field>
+ <field name="type">form</field>
+ <field name="arch" type="xml">
+ <form string="Groups">
+ <field name="category_id" select="1"/>
+ <field name="name" select="1"/>
+ <notebook colspan="4">
+ <page string="Users">
+ <field colspan="4" name="users" nolabel="1"/>
+ </page>
+ <page string="Inherited">
+ <label colspan="4" string="Users added to this group are automatically added in the following groups."/>
+ <field colspan="4" name="implied_ids" nolabel="1"/>
+ </page>
+ <page string="Menus">
+ <field colspan="4" name="menu_access" nolabel="1"/>
+ </page>
+ <page string="Access Rights">
+ <field colspan="4" name="model_access" nolabel="1">
+ <tree string="Access Rules" editable="top">
+ <field name="model_id"/>
+ <field name="perm_read"/>
+ <field name="perm_write"/>
+ <field name="perm_create"/>
+ <field name="perm_unlink"/>
+ <field name="name"/>
+ </tree>
+ <form string="Access Controls">
+ <field colspan="4" name="name" select="1"/>
+ <field name="model_id" select="1"/>
+ <newline/>
+ <field name="perm_read"/>
+ <field name="perm_write"/>
+ <field name="perm_create"/>
+ <field name="perm_unlink"/>
+ </form>
+ </field>
+ </page>
+ <page string="Rules">
+ <field colspan="4" name="rule_groups" nolabel="1">
+ <tree string="Rules">
+ <field name="name"/>
+ <field name="model_id"/>
+ <field name="global"/>
+ </tree>
+ </field>
+ </page><page string="Notes">
+ <field colspan="4" name="comment" nolabel="1"/>
+ </page>
+ </notebook>
+ </form>
+ </field>
+ </record>
+
+ <!--
+ ======================
+ Users
+ ======================
+ -->
+
+ <record id="view_users_form_simple_modif" model="ir.ui.view">
+ <field name="name">res.users.preferences.form</field>
+ <field name="model">res.users</field>
+ <field name="type">form</field>
+ <field eval="18" name="priority"/>
+ <field name="arch" type="xml">
+ <form string="Users">
+ <field name="name" readonly="1"/>
+ <newline/>
+ <group colspan="2" col="2">
+ <separator string="Preferences" colspan="2"/>
+ <field name="view" readonly="0"/>
+ <field name="context_lang" readonly="0"/>
+ <field name="context_tz" readonly="0"/>
+ <field name="menu_tips" readonly="0" groups="base.group_no_one"/>
+ </group>
+ <group name="default_filters" colspan="2" col="2">
+ <separator string="Default Filters" colspan="2"/>
+ <field name="company_id" widget="selection" readonly="0"
+ groups="base.group_multi_company" on_change="on_change_company_id(company_id)"/>
+ </group>
+ <separator string="Email Preferences" colspan="4"/>
+ <field colspan="4" name="user_email" widget="email" readonly="0"/>
+ <field colspan="4" name="signature" readonly="0"/>
+ </form>
+ </field>
+ </record>
+
+ <record id="view_users_form" model="ir.ui.view">
+ <field name="name">res.users.form</field>
+ <field name="model">res.users</field>
+ <field name="type">form</field>
+ <field name="arch" type="xml">
+ <form string="Users">
+ <group colspan="4" col="6">
+ <field name="name" select="1"/>
+ <field name="login" select="1"/>
+ <field name="id" invisible="1"/>
+ <field name="new_password" password="True" attrs="{'required': [('id','=',False)]}"/>
+ <field name="active"/>
+ </group>
+ <notebook colspan="4">
+ <page string="User">
+ <group colspan="4" col="6">
+ <!-- Second nested group to avoid misalignment with email prefs groups
+ in simplified view -->
+ <group colspan="6" col="6">
+ <group col="2" colspan="2">
+ <separator string="Preferences" colspan="2"/>
+ <field name="context_lang"/>
+ <field name="context_tz"/>
+ <field name="menu_tips"/>
+ </group>
+ <group name="default_filters" colspan="2" col="2">
+ <separator string="Default Filters" colspan="2"/>
+ <field name="company_id" required="1" context="{'user_preference': 0}" groups="base.group_multi_company"/>
+ </group>
+ <group colspan="2" col="2" groups="base.group_extended">
+ <separator string="Action" colspan="2"/>
+ <field name="action_id"/>
+ <field domain="[('usage','=','menu')]" name="menu_id" required="True"/>
+ </group>
+ </group>
+ <group colspan="6" col="2">
+ <separator string="Email Preferences" colspan="2"/>
+ <field name="user_email" widget="email"/>
+ <field name="signature"/>
+ </group>
+ </group>
+ </page>
+ <page string="Access Rights">
+ <field nolabel="1" name="groups_id"/>
+ </page>
+ <page string="Allowed Companies" groups="base.group_multi_company">
+ <field colspan="4" nolabel="1" name="company_ids" select="1"/>
+ </page>
+ </notebook>
+ </form>
+ </field>
+ </record>
+
+ <record id="user_groups_view" model="ir.ui.view">
+ <field name="name">res.users.groups</field>
+ <field name="model">res.users</field>
+ <field name="inherit_id" ref="view_users_form"/>
+ <field name="arch" type="xml">
+ <!-- dummy, will be modified by groups -->
+ <field name="groups_id" position="after"/>
+ </field>
+ </record>
+
+ <record id="view_users_tree" model="ir.ui.view">
+ <field name="name">res.users.tree</field>
+ <field name="model">res.users</field>
+ <field name="type">tree</field>
+ <field name="arch" type="xml">
+ <tree string="Users">
+ <field name="name"/>
+ <field name="login"/>
+ <field name="context_lang"/>
+ <field name="date"/>
+ </tree>
+ </field>
+ </record>
+
+ <record id="view_users_search" model="ir.ui.view">
+ <field name="name">res.users.search</field>
+ <field name="model">res.users</field>
+ <field name="type">search</field>
+ <field name="arch" type="xml">
+ <search string="Users">
+ <field name="name"/>
+ <field name="login"/>
+ <field name="company_ids" string="Company" groups="base.group_multi_company"/>
+ </search>
+ </field>
+ </record>
+
+ <!--
+ ======================
+ Company
+ ======================
+ -->
+
+ <report id="preview_report" model="res.company" name="preview.report" multi="True"
+ rml="base/report/preview_report.rml" string="Preview Report"/>
+
+ <record id="bank_account_update" model="ir.actions.act_window">
+ <field name="name">Company Bank Accounts</field>
+ <field name="res_model">res.partner.bank</field>
+ <field name="view_type">form</field>
+ <field name="view_mode">tree,form</field>
+ <field name="context" eval="{'default_partner_id':ref('base.main_partner'), 'company_hide':False, 'default_company_id':ref('base.main_company'), 'search_default_my_bank':1}"/>
+ <field name="help">Configure your company's bank accounts and select those that must appear on the report footer. You can reorder bank accounts from the list view. If you use the accounting application of OpenERP, journals and accounts will be created automatically based on these data.</field>
+ </record>
+
+
+ <record id="view_company_form" model="ir.ui.view">
+ <field name="name">res.company.form</field>
+ <field name="model">res.company</field>
+ <field name="type">form</field>
+ <field name="arch" type="xml">
+ <form string="Company">
+ <group colspan="4" col="6">
+ <group colspan="4" col="4">
+ <field name="name"/>
+ <field name="partner_id" readonly="1" required="0" groups="base.group_extended"/>
+ <field name="parent_id" groups="base.group_multi_company"/>
+ </group>
+ <group colspan="2" col="2">
+ <field name="logo" nolabel="1" widget="image"/>
+ </group>
+ </group>
+ <notebook colspan="4">
+ <page string="General Information">
+ <separator string="Address Information" colspan="4"/>
+ <field name="street" colspan="4"/>
+ <field name="street2" invisible="1"/>
+ <field name="zip"/>
+ <field name="city"/>
+ <field name="country_id"/>
+ <field name="state_id"/>
+ <field name="phone" on_change="on_change_header(phone, email, fax, website, vat, company_registry)"/>
+ <field name="email" on_change="on_change_header(phone, email, fax, website, vat, company_registry)"/>
+ <field name="fax" on_change="on_change_header(phone, email, fax, website, vat, company_registry)"/>
+ <field name="website" on_change="on_change_header(phone, email, fax, website, vat, company_registry)"/>
+ <field name="vat" on_change="on_change_header(phone, email, fax, website, vat, company_registry)"/>
+ <field name="company_registry" on_change="on_change_header(phone, email, fax, website, vat, company_registry)"/>
+ <separator string="Header/Footer of Reports" colspan="4"/>
+ <group colspan="4" col="3">
+ <field name="rml_header1" colspan="3"/>
+ <newline/>
+ <field name="rml_footer1" colspan="3" groups="base.group_extended"/>
+ <newline/>
+ <field name="rml_footer2" colspan="2"/>
+ <button name="%(bank_account_update)d" string="Set Bank Accounts" type="action" icon="gtk-go-forward"/>
+ <newline/>
+ <label string="" colspan="2"/>
+ <button name="%(preview_report)d" string="Preview Header" type="action" icon="gtk-print"/>
+ </group>
+ </page>
+ <page string="Header/Footer" groups="base.group_extended">
+ <group colspan="2" col="4">
+ <field name="paper_format" on_change="onchange_paper_format(paper_format)"/>
+ </group>
+ <field colspan="4" name="rml_header" nolabel="1"/>
+ </page>
+ <page string="Internal Header/Footer" groups="base.group_extended">
+ <separator string="Portrait" colspan="2"/>
+ <separator string="Landscape" colspan="2"/>
+ <field colspan="2" name="rml_header2" nolabel="1"/>
+ <field colspan="2" name="rml_header3" nolabel="1"/>
+ </page>
+ <page string="Configuration">
+ <separator string="Accounting" colspan="4"/>
+ <field name="currency_id" colspan="2"/>
+ <newline/>
+ </page>
+ <page string="Bank Accounts" groups="base.group_extended">
+ <field name="bank_ids" nolabel="1"/>
+ </page>
+ </notebook>
+ </form>
+ </field>
+ </record>
+ <record id="view_company_tree" model="ir.ui.view">
+ <field name="name">res.company.tree</field>
+ <field name="model">res.company</field>
+ <field name="type">tree</field>
+ <field name="field_parent">child_ids</field>
+ <field name="arch" type="xml">
+ <tree string="Companies">
+ <field name="name"/>
+ <field name="partner_id"/>
+ </tree>
+ </field>
+ </record>
+
+ <record id="category_administration_config" model="ir.actions.todo.category">
+ <field name="name">Administration</field>
+ <field name="sequence">1</field>
+ </record>
+ </data>
+</openerp>
=== added directory 'openerp/addons/base/data'
=== added file 'openerp/addons/base/data/administration-hover.png'
Binary files openerp/addons/base/data/administration-hover.png 1970-01-01 00:00:00 +0000 and openerp/addons/base/data/administration-hover.png 2012-04-19 18:12:21 +0000 differ
=== added file 'openerp/addons/base/data/administration.png'
Binary files openerp/addons/base/data/administration.png 1970-01-01 00:00:00 +0000 and openerp/addons/base/data/administration.png 2012-04-19 18:12:21 +0000 differ
=== added file 'openerp/addons/base/data/res.country.state.csv'
--- openerp/addons/base/data/res.country.state.csv 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/data/res.country.state.csv 2012-04-19 18:12:21 +0000
@@ -0,0 +1,52 @@
+"id","country_id:id","name","code"
+state_us_1,us,"Alabama","AL"
+state_us_2,us,"Alaska","AK"
+state_us_3,us,"Arizona","AZ"
+state_us_4,us,"Arkansas","AR"
+state_us_5,us,"California","CA"
+state_us_6,us,"Colorado","CO"
+state_us_7,us,"Connecticut","CT"
+state_us_8,us,"Delaware","DE"
+state_us_9,us,"District of Columbia","DC"
+state_us_10,us,"Florida","FL"
+state_us_11,us,"Georgia","GA"
+state_us_12,us,"Hawaii","HI"
+state_us_13,us,"Idaho","ID"
+state_us_14,us,"Illinois","IL"
+state_us_15,us,"Indiana","IN"
+state_us_16,us,"Iowa","IA"
+state_us_17,us,"Kansas","KS"
+state_us_18,us,"Kentucky","KY"
+state_us_19,us,"Louisiana","LA"
+state_us_20,us,"Maine","ME"
+state_us_21,us,"Montana","MT"
+state_us_22,us,"Nebraska","NE"
+state_us_23,us,"Nevada","NV"
+state_us_24,us,"New Hampshire","NH"
+state_us_25,us,"New Jersey","NJ"
+state_us_26,us,"New Mexico","NM"
+state_us_27,us,"New York","NY"
+state_us_28,us,"North Carolina","NC"
+state_us_29,us,"North Dakota","ND"
+state_us_30,us,"Ohio","OH"
+state_us_31,us,"Oklahoma","OK"
+state_us_32,us,"Oregon","OR"
+state_us_33,us,"Maryland","MD"
+state_us_34,us,"Massachusetts","MA"
+state_us_35,us,"Michigan","MI"
+state_us_36,us,"Minnesota","MN"
+state_us_37,us,"Mississippi","MS"
+state_us_38,us,"Missouri","MO"
+state_us_39,us,"Pennsylvania","PA"
+state_us_40,us,"Rhode Island","RI"
+state_us_41,us,"South Carolina","SC"
+state_us_42,us,"South Dakota","SD"
+state_us_43,us,"Tennessee","TN"
+state_us_44,us,"Texas","TX"
+state_us_45,us,"Utah","UT"
+state_us_46,us,"Vermont","VT"
+state_us_47,us,"Virginia","VA"
+state_us_48,us,"Washington","WA"
+state_us_49,us,"West Virginia","WV"
+state_us_50,us,"Wisconsin","WI"
+state_us_51,us,"Wyoming","WY"
=== added file 'openerp/addons/base/data/sales-hover.png'
Binary files openerp/addons/base/data/sales-hover.png 1970-01-01 00:00:00 +0000 and openerp/addons/base/data/sales-hover.png 2012-04-19 18:12:21 +0000 differ
=== added file 'openerp/addons/base/data/sales.png'
Binary files openerp/addons/base/data/sales.png 1970-01-01 00:00:00 +0000 and openerp/addons/base/data/sales.png 2012-04-19 18:12:21 +0000 differ
=== added directory 'openerp/addons/base/i18n'
=== added file 'openerp/addons/base/i18n/ab.po'
--- openerp/addons/base/i18n/ab.po 1970-01-01 00:00:00 +0000
+++ openerp/addons/base/i18n/ab.po 2012-04-19 18:12:21 +0000
@@ -0,0 +1,15176 @@
+# Translation of OpenERP Server.
+# This file contains the translation of the following modules:
+# * base
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: OpenERP Server 5.0.4\n"
+"Report-Msgid-Bugs-To: support@xxxxxxxxxxx\n"
+"POT-Creation-Date: 2012-02-08 00:44+0000\n"
+"PO-Revision-Date: 2012-02-27 08:09+0000\n"
+"Last-Translator: Xavier (Open ERP) <Unknown>\n"
+"Language-Team: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Launchpad-Export-Date: 2012-02-28 06:29+0000\n"
+"X-Generator: Launchpad (build 14874)\n"
+
+#. module: base
+#: model:res.country,name:base.sh
+msgid "Saint Helena"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.report.xml:0
+msgid "Other Configuration"
+msgstr ""
+
+#. module: base
+#: selection:ir.property,type:0
+msgid "DateTime"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_project_mailgate
+msgid "Tasks-Mail Integration"
+msgstr ""
+
+#. module: base
+#: code:addons/fields.py:582
+#, python-format
+msgid ""
+"The second argument of the many2many field %s must be a SQL table !You used "
+"%s, which is not a valid SQL table name."
+msgstr ""
+
+#. module: base
+#: field:ir.ui.view,arch:0
+#: field:ir.ui.view.custom,arch:0
+msgid "View Architecture"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_project
+msgid ""
+"\n"
+"Project management module tracks multi-level projects, tasks, work done on "
+"tasks, eso.\n"
+"============================================================================="
+"=========\n"
+"\n"
+"It is able to render planning, order tasks, eso.\n"
+"\n"
+"Dashboard for project members that includes:\n"
+"--------------------------------------------\n"
+" * List of my open tasks\n"
+" * List of my delegated tasks\n"
+" * Graph of My Projects: Planned vs Total Hours\n"
+" * Graph of My Remaining Hours by Project\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:base.language.import,code:0
+msgid "Code (eg:en__US)"
+msgstr ""
+
+#. module: base
+#: view:workflow:0
+#: view:workflow.activity:0
+#: field:workflow.activity,wkf_id:0
+#: field:workflow.instance,wkf_id:0
+#: field:workflow.transition,wkf_id:0
+#: field:workflow.workitem,wkf_id:0
+msgid "Workflow"
+msgstr ""
+
+#. module: base
+#: selection:ir.sequence,implementation:0
+msgid "No gap"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Hungarian / Magyar"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (PY) / Español (PY)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,description:base.module_category_project_management
+msgid ""
+"Helps you manage your projects and tasks by tracking them, generating "
+"plannings, etc..."
+msgstr ""
+
+#. module: base
+#: field:ir.actions.act_window,display_menu_tip:0
+msgid "Display Menu Tips"
+msgstr ""
+
+#. module: base
+#: help:ir.cron,model:0
+msgid ""
+"Model name on which the method to be called is located, e.g. 'res.partner'."
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+msgid "Created Views"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:532
+#, python-format
+msgid ""
+"You can not write in this document (%s) ! Be sure your user belongs to one "
+"of these groups: %s."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_event_project
+msgid ""
+"\n"
+"Organization and management of events.\n"
+"======================================\n"
+"\n"
+"This module allows you to create retro planning for managing your events.\n"
+msgstr ""
+
+#. module: base
+#: help:ir.model.fields,domain:0
+msgid ""
+"The optional domain to restrict possible values for relationship fields, "
+"specified as a Python expression defining a list of triplets. For example: "
+"[('color','=','red')]"
+msgstr ""
+
+#. module: base
+#: field:res.partner,ref:0
+msgid "Reference"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_be_invoice_bba
+msgid "Belgium - Structured Communication"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.act_window,target:0
+msgid "Target Window"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_sale_analytic_plans
+msgid "Sales Analytic Distribution"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_web_process
+msgid "Process"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_analytic_journal_billing_rate
+msgid "Billing Rates on Contracts"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_users.py:558
+#, python-format
+msgid "Warning!"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:344
+#, python-format
+msgid ""
+"Properties of base fields cannot be altered in this manner! Please modify "
+"them through Python code, preferably through a custom addon!"
+msgstr ""
+
+#. module: base
+#: code:addons/osv.py:129
+#, python-format
+msgid "Constraint Error"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_ui_view_custom
+msgid "ir.ui.view.custom"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:313
+#, python-format
+msgid "Renaming sparse field \"%s\" is not allowed"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.sz
+msgid "Swaziland"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:4206
+#, python-format
+msgid "created."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_tr
+msgid "Turkey - Accounting"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_mrp_subproduct
+msgid "MRP Subproducts"
+msgstr ""
+
+#. module: base
+#: code:addons/base/module/module.py:390
+#, python-format
+msgid ""
+"Some installed modules depend on the module you plan to Uninstall :\n"
+" %s"
+msgstr ""
+
+#. module: base
+#: field:ir.sequence,number_increment:0
+msgid "Increment Number"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_res_company_tree
+#: model:ir.ui.menu,name:base.menu_action_res_company_tree
+msgid "Company's Structure"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Inuktitut / ᐃᓄᒃᑎᑐᑦ"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.todo.category,name:base.category_sales_management_config
+#: model:ir.module.category,name:base.module_category_sales_management
+#: model:ir.module.module,shortdesc:base.module_sale
+msgid "Sales Management"
+msgstr ""
+
+#. module: base
+#: view:res.partner:0
+msgid "Search Partner"
+msgstr ""
+
+#. module: base
+#: code:addons/base/module/wizard/base_export_language.py:60
+#, python-format
+msgid "new"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.report.xml,multi:0
+msgid "On multiple doc."
+msgstr ""
+
+#. module: base
+#: field:ir.module.category,module_nr:0
+msgid "Number of Modules"
+msgstr ""
+
+#. module: base
+#: help:multi_company.default,company_dest_id:0
+msgid "Company to store the current record"
+msgstr ""
+
+#. module: base
+#: field:res.partner.bank.type.field,size:0
+msgid "Max. Size"
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,name:base.module_category_reporting
+#: model:ir.ui.menu,name:base.menu_lunch_reporting
+#: model:ir.ui.menu,name:base.menu_project_report
+#: model:ir.ui.menu,name:base.menu_report_association
+#: model:ir.ui.menu,name:base.menu_report_marketing
+#: model:ir.ui.menu,name:base.menu_reporting
+#: model:ir.ui.menu,name:base.next_id_64
+#: model:ir.ui.menu,name:base.next_id_73
+#: model:ir.ui.menu,name:base.reporting_menu
+msgid "Reporting"
+msgstr ""
+
+#. module: base
+#: view:res.partner:0
+#: field:res.partner,subname:0
+#: field:res.partner.address,name:0
+msgid "Contact Name"
+msgstr ""
+
+#. module: base
+#: code:addons/base/module/wizard/base_export_language.py:56
+#, python-format
+msgid ""
+"Save this document to a %s file and edit it with a specific software or a "
+"text editor. The file encoding is UTF-8."
+msgstr ""
+
+#. module: base
+#: help:ir.values,key2:0
+msgid ""
+"For actions, one of the possible action slots: \n"
+" - client_action_multi\n"
+" - client_print_multi\n"
+" - client_action_relate\n"
+" - tree_but_open\n"
+"For defaults, an optional condition"
+msgstr ""
+
+#. module: base
+#: sql_constraint:res.lang:0
+msgid "The name of the language must be unique !"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_import_base
+msgid ""
+"\n"
+" This module provide a class import_framework to help importing \n"
+" complex data from other software\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:ir.actions.wizard,wiz_name:0
+msgid "Wizard Name"
+msgstr ""
+
+#. module: base
+#: model:res.groups,name:base.group_partner_manager
+msgid "Partner Manager"
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,name:base.module_category_customer_relationship_management
+msgid "Customer Relationship Management"
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+msgid "Extra"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:2526
+#, python-format
+msgid "Invalid group_by"
+msgstr ""
+
+#. module: base
+#: field:ir.module.category,child_ids:0
+msgid "Child Applications"
+msgstr ""
+
+#. module: base
+#: field:res.partner,credit_limit:0
+msgid "Credit Limit"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_web_graph
+msgid "Openerp web graph view"
+msgstr ""
+
+#. module: base
+#: field:ir.model.data,date_update:0
+msgid "Update Date"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_base_action_rule
+msgid "Automated Action Rules"
+msgstr ""
+
+#. module: base
+#: view:ir.attachment:0
+msgid "Owner"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.act_window,src_model:0
+msgid "Source Object"
+msgstr ""
+
+#. module: base
+#: model:res.partner.bank.type,format_layout:base.bank_normal
+msgid "%(bank_name)s: %(acc_number)s"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.todo:0
+msgid "Config Wizard Steps"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_ui_view_sc
+msgid "ir.ui.view_sc"
+msgstr ""
+
+#. module: base
+#: field:res.widget.user,widget_id:0
+#: field:res.widget.wizard,widgets_list:0
+msgid "Widget"
+msgstr ""
+
+#. module: base
+#: view:ir.model.access:0
+#: field:ir.model.access,group_id:0
+msgid "Group"
+msgstr ""
+
+#. module: base
+#: constraint:res.lang:0
+msgid ""
+"Invalid date/time format directive specified. Please refer to the list of "
+"allowed directives, displayed when you edit a language."
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:3895
+#, python-format
+msgid ""
+"One of the records you are trying to modify has already been deleted "
+"(Document type: %s)."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_pad_project
+msgid "Specifications on PADs"
+msgstr ""
+
+#. module: base
+#: help:ir.filters,user_id:0
+msgid ""
+"The user this filter is available to. When left empty the filter is usable "
+"by the system only."
+msgstr ""
+
+#. module: base
+#: help:res.partner,website:0
+msgid "Website of Partner."
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window,views:0
+msgid ""
+"This function field computes the ordered list of views that should be "
+"enabled when displaying the result of an action, federating view mode, views "
+"and reference view. The result is returned as an ordered list of pairs "
+"(view_id,view_mode)."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.tv
+msgid "Tuvalu"
+msgstr ""
+
+#. module: base
+#: selection:ir.model,state:0
+msgid "Custom Object"
+msgstr ""
+
+#. module: base
+#: field:res.lang,date_format:0
+msgid "Date Format"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_base_report_designer
+msgid "OpenOffice Report Designer"
+msgstr ""
+
+#. module: base
+#: field:res.bank,email:0
+#: field:res.partner.address,email:0
+msgid "E-Mail"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.an
+msgid "Netherlands Antilles"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ro
+msgid "Romania"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_users.py:396
+#, python-format
+msgid ""
+"You can not remove the admin user as it is used internally for resources "
+"created by OpenERP (updates, module installation, ...)"
+msgstr ""
+
+#. module: base
+#: view:ir.values:0
+msgid "Action Binding"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.gf
+msgid "French Guyana"
+msgstr ""
+
+#. module: base
+#: field:ir.ui.view.custom,ref_id:0
+msgid "Original View"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Bosnian / bosanski jezik"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.report.xml,attachment_use:0
+msgid ""
+"If you check this, then the second time the user prints with same attachment "
+"name, it returns the previous report."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_sale_layout
+msgid "Sales Orders Print Layout"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (VE) / Español (VE)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_hr_timesheet_invoice
+msgid "Invoice on Timesheets"
+msgstr ""
+
+#. module: base
+#: view:base.module.upgrade:0
+msgid "Your system will be updated."
+msgstr ""
+
+#. module: base
+#: field:ir.actions.todo,note:0
+#: selection:ir.property,type:0
+msgid "Text"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_account_followup
+msgid ""
+"\n"
+"Module to automate letters for unpaid invoices, with multi-level recalls.\n"
+"==========================================================================\n"
+"\n"
+"You can define your multiple levels of recall through the menu:\n"
+" Accounting/Configuration/Miscellaneous/Follow-Ups\n"
+"\n"
+"Once it is defined, you can automatically print recalls every day through "
+"simply clicking on the menu:\n"
+" Accounting/Periodical Processing/Billing/Send followups\n"
+"\n"
+"It will generate a PDF with all the letters according to the the\n"
+"different levels of recall defined. You can define different policies\n"
+"for different companies. You can also send mail to the customer.\n"
+"\n"
+"Note that if you want to check the followup level for a given "
+"partner/account entry, you can do from in the menu:\n"
+" Accounting/Reporting/Generic Reporting/Partners/Follow-ups Sent\n"
+"\n"
+msgstr ""
+
+#. module: base
+#: field:res.country,name:0
+msgid "Country Name"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.co
+msgid "Colombia"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:1390
+#, python-format
+msgid "Key/value '%s' not found in selection field '%s'"
+msgstr ""
+
+#. module: base
+#: help:res.country,code:0
+msgid ""
+"The ISO country code in two chars.\n"
+"You can use this field for quick search."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.pw
+msgid "Palau"
+msgstr ""
+
+#. module: base
+#: view:res.partner:0
+msgid "Sales & Purchases"
+msgstr ""
+
+#. module: base
+#: view:ir.translation:0
+msgid "Untranslated"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window,context:0
+msgid ""
+"Context dictionary as Python expression, empty by default (Default: {})"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.ir_action_wizard
+#: view:ir.actions.wizard:0
+#: model:ir.ui.menu,name:base.menu_ir_action_wizard
+msgid "Wizards"
+msgstr ""
+
+#. module: base
+#: model:res.partner.category,name:base.res_partner_category_miscellaneoussuppliers0
+msgid "Miscellaneous Suppliers"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:287
+#, python-format
+msgid "Custom fields must have a name that starts with 'x_' !"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_mx
+msgid "Mexico - Accounting"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.server,action_id:0
+msgid "Select the Action Window, Report, Wizard to be executed."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ai
+msgid "Anguilla"
+msgstr ""
+
+#. module: base
+#: view:base.language.export:0
+msgid "Export done"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_plugin_outlook
+msgid "Outlook Plug-In"
+msgstr ""
+
+#. module: base
+#: view:ir.model:0
+#: field:ir.model,name:0
+msgid "Model Description"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window,src_model:0
+msgid ""
+"Optional model name of the objects on which this action should be visible"
+msgstr ""
+
+#. module: base
+#: field:workflow.transition,trigger_expr_id:0
+msgid "Trigger Expression"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.jo
+msgid "Jordan"
+msgstr ""
+
+#. module: base
+#: help:ir.cron,nextcall:0
+msgid "Next planned execution date for this job."
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:139
+#, python-format
+msgid "You can not remove the model '%s' !"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.er
+msgid "Eritrea"
+msgstr ""
+
+#. module: base
+#: sql_constraint:res.company:0
+msgid "The company name must be unique !"
+msgstr ""
+
+#. module: base
+#: view:res.config:0
+#: view:res.config.installer:0
+msgid "description"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_base_action_rule
+#: model:ir.ui.menu,name:base.menu_base_action_rule_admin
+msgid "Automated Actions"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_ro
+msgid "Romania - Accounting"
+msgstr ""
+
+#. module: base
+#: view:partner.wizard.ean.check:0
+msgid "Want to check Ean ? "
+msgstr ""
+
+#. module: base
+#: help:ir.actions.server,mobile:0
+msgid ""
+"Provides fields that be used to fetch the mobile number, e.g. you select the "
+"invoice, then `object.invoice_address_id.mobile` is the field which gives "
+"the correct mobile number"
+msgstr ""
+
+#. module: base
+#: view:ir.mail_server:0
+msgid "Security and Authentication"
+msgstr ""
+
+#. module: base
+#: view:base.language.export:0
+msgid ""
+"OpenERP translations (core, modules, clients) are managed through "
+"Launchpad.net, our open source project management facility. We use their "
+"online interface to synchronize all translations efforts."
+msgstr ""
+
+#. module: base
+#: help:ir.actions.todo,type:0
+msgid ""
+"Manual: Launched manually.\n"
+"Automatic: Runs whenever the system is reconfigured.\n"
+"Launch Manually Once: after hacing been launched manually, it sets "
+"automatically to Done."
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Swedish / svenska"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.rs
+msgid "Serbia"
+msgstr ""
+
+#. module: base
+#: selection:ir.translation,type:0
+msgid "Wizard View"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.kh
+msgid "Cambodia, Kingdom of"
+msgstr ""
+
+#. module: base
+#: field:base.language.import,overwrite:0
+#: field:base.language.install,overwrite:0
+msgid "Overwrite Existing Terms"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_base_language_import
+msgid "Language Import"
+msgstr ""
+
+#. module: base
+#: help:ir.cron,interval_number:0
+msgid "Repeat every x."
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Albanian / Shqip"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_crm_config_opportunity
+msgid "Opportunities"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_base_language_export
+msgid "base.language.export"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.server,write_id:0
+msgid ""
+"Provide the field name that the record id refers to for the write operation. "
+"If it is empty it will refer to the active id of the object."
+msgstr ""
+
+#. module: base
+#: help:ir.actions.report.xml,report_type:0
+msgid "Report Type, e.g. pdf, html, raw, sxw, odt, html2html, mako2html, ..."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_document_webdav
+msgid "Shared Repositories (WebDAV)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_import_google
+msgid ""
+"The module adds google contact in partner address and add google calendar "
+"events details in Meeting"
+msgstr ""
+
+#. module: base
+#: view:res.users:0
+msgid "Email Preferences"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_audittrail
+msgid ""
+"\n"
+"This module lets administrator track every user operation on all the objects "
+"of the system.\n"
+"============================================================================="
+"==============\n"
+"\n"
+"The administrator can subscribe to rules for read, write and\n"
+"delete on objects and can check logs.\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:res.partner.category,name:base.res_partner_category_4
+msgid "Basic Partner"
+msgstr ""
+
+#. module: base
+#: report:ir.module.reference.graph:0
+msgid ","
+msgstr ""
+
+#. module: base
+#: view:res.partner:0
+msgid "My Partners"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.report.xml:0
+msgid "XML Report"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.es
+msgid "Spain"
+msgstr ""
+
+#. module: base
+#: view:base.module.update:0
+msgid "Please be patient, as this operation may take a few seconds..."
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window,domain:0
+msgid ""
+"Optional domain filtering of the destination data, as a Python expression"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_view_base_module_upgrade
+#: model:ir.model,name:base.model_base_module_upgrade
+msgid "Module Upgrade"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (UY) / Español (UY)"
+msgstr ""
+
+#. module: base
+#: field:res.partner,mobile:0
+#: field:res.partner.address,mobile:0
+msgid "Mobile"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.om
+msgid "Oman"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_mrp
+msgid "MRP"
+msgstr ""
+
+#. module: base
+#: report:ir.module.reference.graph:0
+msgid "1cm 28cm 20cm 28cm"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.nu
+msgid "Niue"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_membership
+msgid "Membership Management"
+msgstr ""
+
+#. module: base
+#: selection:ir.module.module,license:0
+msgid "Other OSI Approved Licence"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.act_menu_create
+#: view:wizard.ir.model.menu.create:0
+msgid "Create Menu"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.in
+msgid "India"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.res_request_link-act
+#: model:ir.ui.menu,name:base.menu_res_request_link_act
+msgid "Request Reference Types"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_google_base_account
+msgid "Google Users"
+msgstr ""
+
+#. module: base
+#: help:ir.server.object.lines,value:0
+msgid ""
+"Expression containing a value specification. \n"
+"When Formula type is selected, this field may be a Python expression that "
+"can use the same values as for the condition field on the server action.\n"
+"If Value type is selected, the value will be used directly without "
+"evaluation."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ad
+msgid "Andorra, Principality of"
+msgstr ""
+
+#. module: base
+#: field:res.partner.category,child_ids:0
+msgid "Child Categories"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_config_parameter
+msgid "ir.config_parameter"
+msgstr ""
+
+#. module: base
+#: selection:base.language.export,format:0
+msgid "TGZ Archive"
+msgstr ""
+
+#. module: base
+#: view:res.groups:0
+msgid ""
+"Users added to this group are automatically added in the following groups."
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid "%B - Full month name."
+msgstr ""
+
+#. module: base
+#: field:ir.actions.todo,type:0
+#: view:ir.attachment:0
+#: field:ir.attachment,type:0
+#: field:ir.model,state:0
+#: field:ir.model.fields,state:0
+#: field:ir.property,type:0
+#: field:ir.server.object.lines,type:0
+#: field:ir.translation,type:0
+#: view:ir.ui.view:0
+#: view:ir.values:0
+#: field:ir.values,key:0
+#: view:res.partner:0
+#: view:res.partner.address:0
+msgid "Type"
+msgstr ""
+
+#. module: base
+#: field:ir.mail_server,smtp_user:0
+msgid "Username"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:398
+#, python-format
+msgid ""
+"Language with code \"%s\" is not defined in your system !\n"
+"Define it through the Administration menu."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.gu
+msgid "Guam (USA)"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_users.py:558
+#, python-format
+msgid "Setting empty passwords is not allowed for security reasons!"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_mail_server.py:192
+#, python-format
+msgid "Connection test failed!"
+msgstr ""
+
+#. module: base
+#: selection:ir.actions.server,state:0
+#: selection:workflow.activity,kind:0
+msgid "Dummy"
+msgstr ""
+
+#. module: base
+#: constraint:ir.ui.view:0
+msgid "Invalid XML for View Architecture!"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ky
+msgid "Cayman Islands"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.kr
+msgid "South Korea"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_workflow_transition_form
+#: model:ir.ui.menu,name:base.menu_workflow_transition
+#: view:workflow.activity:0
+msgid "Transitions"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:4615
+#, python-format
+msgid "Record #%d of %s not found, cannot copy!"
+msgstr ""
+
+#. module: base
+#: field:ir.module.module,contributors:0
+msgid "Contributors"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_project_planning
+msgid ""
+"Keep track of your planning\n"
+"This module helps you to manage your plannings.\n"
+"===============================================\n"
+"\n"
+"This module is based on the analytic accounting and is totally integrated "
+"with\n"
+"* the timesheets encoding\n"
+"* the holidays management\n"
+"* the project management\n"
+"\n"
+"So that, each department manager can know if someone in his team has still "
+"unallocated time for a given planning (taking in consideration the validated "
+"leaves) or if he still needs to encode tasks.\n"
+"\n"
+"At the end of the month, the planning manager can also check if the encoded "
+"timesheets are respecting the planned time on each analytic account.\n"
+msgstr ""
+
+#. module: base
+#: selection:ir.property,type:0
+msgid "Char"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Slovak / Slovenský jazyk"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (AR) / Español (AR)"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ug
+msgid "Uganda"
+msgstr ""
+
+#. module: base
+#: field:ir.model.access,perm_unlink:0
+msgid "Delete Access"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ne
+msgid "Niger"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Chinese (HK)"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ba
+msgid "Bosnia-Herzegovina"
+msgstr ""
+
+#. module: base
+#: view:base.language.export:0
+msgid ""
+"To improve or expand the official translations, you should use directly "
+"Lauchpad's web interface (Rosetta). If you need to perform mass translation, "
+"Launchpad also allows uploading full .po files at once"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (GT) / Español (GT)"
+msgstr ""
+
+#. module: base
+#: field:ir.mail_server,smtp_port:0
+msgid "SMTP Port"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_import_sugarcrm
+msgid "SugarCRM Import"
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid ""
+"%W - Week number of the year (Monday as the first day of the week) as a "
+"decimal number [00,53]. All days in a new year preceding the first Monday "
+"are considered to be in week 0."
+msgstr ""
+
+#. module: base
+#: code:addons/base/module/wizard/base_language_install.py:55
+#, python-format
+msgid "Language Pack"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_web_tests
+msgid "Tests"
+msgstr ""
+
+#. module: base
+#: field:ir.ui.view_sc,res_id:0
+msgid "Resource Ref."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.gs
+msgid "S. Georgia & S. Sandwich Isls."
+msgstr ""
+
+#. module: base
+#: field:ir.actions.url,url:0
+msgid "Action URL"
+msgstr ""
+
+#. module: base
+#: field:base.module.import,module_name:0
+msgid "Module Name"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.mh
+msgid "Marshall Islands"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:368
+#, python-format
+msgid "Changing the model of a field is forbidden!"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ht
+msgid "Haiti"
+msgstr ""
+
+#. module: base
+#: view:ir.ui.view:0
+#: selection:ir.ui.view,type:0
+msgid "Search"
+msgstr ""
+
+#. module: base
+#: code:addons/osv.py:132
+#, python-format
+msgid ""
+"The operation cannot be completed, probably due to the following:\n"
+"- deletion: you may be trying to delete a record while other records still "
+"reference it\n"
+"- creation/update: a mandatory field is not correctly set"
+msgstr ""
+
+#. module: base
+#: field:ir.module.category,parent_id:0
+msgid "Parent Application"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_users.py:222
+#, python-format
+msgid "Operation Canceled"
+msgstr ""
+
+#. module: base
+#: help:base.language.export,lang:0
+msgid "To export a new language, do not select a language."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_document
+#: model:ir.module.module,shortdesc:base.module_knowledge
+msgid "Document Management System"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_crm_claim
+msgid "Claims Management"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_purchase_root
+msgid "Purchases"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.md
+msgid "Moldavia"
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+msgid "Features"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,help:base.bank_account_update
+msgid ""
+"Configure your company's bank accounts and select those that must appear on "
+"the report footer. You can reorder bank accounts from the list view. If you "
+"use the accounting application of OpenERP, journals and accounts will be "
+"created automatically based on these data."
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+#: report:ir.module.reference.graph:0
+msgid "Version"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_sale_order_dates
+msgid ""
+"\n"
+"Add additional date information to the sales order.\n"
+"===================================================\n"
+"\n"
+"You can add the following additional dates to a sale order:\n"
+" * Requested Date\n"
+" * Commitment Date\n"
+" * Effective Date\n"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_account_sequence
+msgid "Entries Sequence Numbering"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_exports
+msgid "ir.exports"
+msgstr ""
+
+#. module: base
+#: code:addons/base/module/wizard/base_update_translations.py:38
+#, python-format
+msgid "No language with code \"%s\" exists"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_document
+msgid ""
+"\n"
+"This is a complete document management system.\n"
+"==============================================\n"
+"\n"
+" * User Authentication\n"
+" * Document Indexation :- .pptx and .docx files are not supported in "
+"Windows platform.\n"
+" * Dashboard for Document that includes:\n"
+" * New Files (list)\n"
+" * Files by Resource Type (graph)\n"
+" * Files by Partner (graph)\n"
+" * Files Size by Month (graph)\n"
+"\n"
+"ATTENTION:\n"
+" - When you install this module in a running company that have already "
+"PDF files stored into the database,\n"
+" you will lose them all.\n"
+" - After installing this module PDF's are no longer stored into the "
+"database,\n"
+" but in the servers rootpad like /server/bin/filestore.\n"
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid "%Y - Year with century."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_web_gantt
+msgid ""
+"\n"
+" OpenERP Web gantt chart view.\n"
+" "
+msgstr ""
+
+#. module: base
+#: report:ir.module.reference.graph:0
+msgid "-"
+msgstr ""
+
+#. module: base
+#: view:publisher_warranty.contract.wizard:0
+msgid ""
+"This wizard helps you register a publisher warranty contract in your OpenERP "
+"system. After the contract has been registered, you will be able to send "
+"issues directly to OpenERP."
+msgstr ""
+
+#. module: base
+#: view:wizard.ir.model.menu.create:0
+msgid "Create _Menu"
+msgstr ""
+
+#. module: base
+#: field:res.payterm,name:0
+msgid "Payment Term (short name)"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_res_bank
+#: view:res.bank:0
+#: field:res.partner.bank,bank:0
+msgid "Bank"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_exports_line
+msgid "ir.exports.line"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_html_view
+msgid ""
+"\n"
+"This is the test module which shows HTML tag support in normal XML form "
+"view.\n"
+"============================================================================="
+"\n"
+"\n"
+"Creates a sample form-view using HTML tags. It is visible only in OpenERP "
+"Web.\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,description:base.module_category_purchase_management
+msgid ""
+"Helps you manage your purchase-related processes such as requests for "
+"quotations, supplier invoices, etc..."
+msgstr ""
+
+#. module: base
+#: help:base.language.install,overwrite:0
+msgid ""
+"If you check this box, your customized translations will be overwritten and "
+"replaced by the official ones."
+msgstr ""
+
+#. module: base
+#: field:ir.actions.report.xml,report_rml:0
+msgid "Main report file path"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.ir_action_report_xml
+#: field:ir.module.module,reports_by_module:0
+#: model:ir.ui.menu,name:base.menu_ir_action_report_xml
+msgid "Reports"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window.view,multi:0
+#: help:ir.actions.report.xml,multi:0
+msgid ""
+"If set to true, the action will not be displayed on the right toolbar of a "
+"form view."
+msgstr ""
+
+#. module: base
+#: field:workflow,on_create:0
+msgid "On Create"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:681
+#, python-format
+msgid ""
+"'%s' contains too many dots. XML ids should not contain dots ! These are "
+"used to refer to other modules data, as in module.reference_id"
+msgstr ""
+
+#. module: base
+#: field:partner.sms.send,user:0
+#: field:res.users,login:0
+msgid "Login"
+msgstr ""
+
+#. module: base
+#: view:base.update.translations:0
+#: model:ir.actions.act_window,name:base.action_wizard_update_translations
+#: model:ir.ui.menu,name:base.menu_wizard_update_translations
+msgid "Synchronize Terms"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+msgid ""
+"Access all the fields related to the current object using expressions, i.e. "
+"object.partner_id.name "
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_event
+msgid ""
+"\n"
+"Organization and management of Events.\n"
+"======================================\n"
+"\n"
+"This module allows you\n"
+" * to manage your events and their registrations\n"
+" * to use emails to automatically confirm and send acknowledgements for "
+"any registration to an event\n"
+" * ...\n"
+"\n"
+"Note that:\n"
+" - You can define new types of events in\n"
+" Association / Configuration / Types of Events\n"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_tools
+msgid "Tools"
+msgstr ""
+
+#. module: base
+#: selection:ir.property,type:0
+msgid "Float"
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,name:base.module_category_warehouse_management
+#: model:ir.module.module,shortdesc:base.module_stock
+msgid "Warehouse Management"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_res_request_link
+msgid "res.request.link"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.wizard,name:0
+msgid "Wizard Info"
+msgstr ""
+
+#. module: base
+#: view:base.language.export:0
+#: model:ir.actions.act_window,name:base.action_wizard_lang_export
+#: model:ir.ui.menu,name:base.menu_wizard_lang_export
+msgid "Export Translation"
+msgstr ""
+
+#. module: base
+#: help:res.log,secondary:0
+msgid ""
+"Do not display this log if it belongs to the same object the user is working "
+"on"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_lu
+msgid "Luxembourg - Accounting"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.tp
+msgid "East Timor"
+msgstr ""
+
+#. module: base
+#: model:res.company,follow_up_msg:base.main_company
+msgid ""
+"Date : %(date)s\n"
+"\n"
+"Dear %(partner_name)s,\n"
+"\n"
+"Please find in attachment a reminder of all your unpaid invoices, for a "
+"total amount due of:\n"
+"\n"
+"%(followup_amount).2f %(company_currency)s\n"
+"\n"
+"Thanks,\n"
+"--\n"
+"%(user_signature)s\n"
+"%(company_name)s"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_share
+msgid ""
+"\n"
+"This module adds generic sharing tools to your current OpenERP database.\n"
+"========================================================================\n"
+"\n"
+"It specifically adds a 'share' button that is available in the Web client "
+"to\n"
+"share any kind of OpenERP data with colleagues, customers, friends, etc.\n"
+"\n"
+"The system will work by creating new users and groups on the fly, and by\n"
+"combining the appropriate access rights and ir.rules to ensure that the\n"
+"shared users only have access to the data that has been shared with them.\n"
+"\n"
+"This is extremely useful for collaborative work, knowledge sharing,\n"
+"synchronization with other companies, etc.\n"
+"\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:res.currency,accuracy:0
+msgid "Computational Accuracy"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_lunch
+msgid ""
+"\n"
+" The base module to manage lunch\n"
+"\n"
+" keep track for the Lunch Order ,Cash Moves ,CashBox ,Product.\n"
+" Apply Different Category for the product.\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.kg
+msgid "Kyrgyz Republic (Kyrgyzstan)"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_wizard_ir_model_menu_create_line
+msgid "wizard.ir.model.menu.create.line"
+msgstr ""
+
+#. module: base
+#: field:ir.attachment,res_id:0
+msgid "Attached ID"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_base_vat
+msgid ""
+"\n"
+"VAT validation for Partners' VAT numbers\n"
+"========================================\n"
+"\n"
+"After installing this module, values entered in the VAT field of Partners "
+"will\n"
+"be validated for all supported countries. The country is inferred from the\n"
+"2-letter country code that prefixes the VAT number, e.g. ``BE0477472701``\n"
+"will be validated using the Belgian rules.\n"
+"\n"
+"There are two different levels of VAT number validation:\n"
+"\n"
+" * By default, a simple off-line check is performed using the known "
+"validation\n"
+" rules for the country, usually a simple check digit. This is quick and \n"
+" always available, but allows numbers that are perhaps not truly "
+"allocated,\n"
+" or not valid anymore.\n"
+" * When the \"VAT VIES Check\" option is enabled (in the configuration of "
+"the user's\n"
+" Company), VAT numbers will be instead submitted to the online EU VIES\n"
+" database, which will truly verify that the number is valid and currently\n"
+" allocated to a EU company. This is a little bit slower than the simple\n"
+" off-line check, requires an Internet connection, and may not be "
+"available\n"
+" all the time. If the service is not available or does not support the\n"
+" requested country (e.g. for non-EU countries), a simple check will be "
+"performed\n"
+" instead.\n"
+"\n"
+"Supported countries currently include EU countries, and a few non-EU "
+"countries\n"
+"such as Chile, Colombia, Mexico, Norway or Russia. For unsupported "
+"countries,\n"
+"only the country code will be validated.\n"
+"\n"
+" "
+msgstr ""
+
+#. module: base
+#: view:ir.sequence:0
+msgid "Day: %(day)s"
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,description:base.module_category_point_of_sale
+msgid ""
+"Helps you get the most out of your points of sales with fast sale encoding, "
+"simplified payment mode encoding, automatic picking lists generation and "
+"more."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.mv
+msgid "Maldives"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_idea
+msgid ""
+"\n"
+"This module allows your user to easily and efficiently participate in "
+"enterprise innovation.\n"
+"============================================================================="
+"===============\n"
+"\n"
+"It allows everybody to express ideas about different subjects.\n"
+"Then, other users can comment on these ideas and vote for particular ideas.\n"
+"Each idea has a score based on the different votes.\n"
+"The managers can obtain an easy view of best ideas from all the users.\n"
+"Once installed, check the menu 'Ideas' in the 'Tools' main menu."
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_rule
+msgid "ir.rule"
+msgstr ""
+
+#. module: base
+#: selection:ir.cron,interval_type:0
+msgid "Days"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_web_rpc
+msgid "OpenERP Web web"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_html_view
+msgid "Html View"
+msgstr ""
+
+#. module: base
+#: field:res.currency,position:0
+msgid "Symbol position"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_process
+msgid "Enterprise Process"
+msgstr ""
+
+#. module: base
+#: help:ir.cron,function:0
+msgid "Name of the method to be called when this job is processed."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_hr_evaluation
+msgid "Employee Appraisals"
+msgstr ""
+
+#. module: base
+#: selection:ir.actions.server,state:0
+msgid "Write Object"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_company.py:66
+#: code:addons/base/res/res_partner.py:175
+#, python-format
+msgid " (copy)"
+msgstr ""
+
+#. module: base
+#: field:res.company,rml_footer1:0
+msgid "General Information Footer"
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid "7. %H:%M:%S ==> 18:25:20"
+msgstr ""
+
+#. module: base
+#: view:res.partner:0
+#: view:res.partner.category:0
+#: field:res.partner.category,partner_ids:0
+msgid "Partners"
+msgstr ""
+
+#. module: base
+#: field:res.partner.category,parent_left:0
+msgid "Left parent"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_project_mrp
+msgid "Create Tasks on SO"
+msgstr ""
+
+#. module: base
+#: field:ir.attachment,res_model:0
+msgid "Attached Model"
+msgstr ""
+
+#. module: base
+#: field:res.partner.bank,footer:0
+msgid "Display on Reports"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_cn
+msgid ""
+"\n"
+" 添加中文省份数据\n"
+" 科目类型\\会计科目表模板\\增值税\\辅助核算类别\\管理会计凭证簿\\财务会计凭证簿\n"
+" ============================================================\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_model_access
+msgid "ir.model.access"
+msgstr ""
+
+#. module: base
+#: field:ir.cron,priority:0
+#: field:ir.mail_server,sequence:0
+#: field:res.request,priority:0
+#: field:res.request.link,priority:0
+msgid "Priority"
+msgstr ""
+
+#. module: base
+#: field:workflow.transition,act_from:0
+msgid "Source Activity"
+msgstr ""
+
+#. module: base
+#: view:ir.sequence:0
+msgid "Legend (for prefix, suffix)"
+msgstr ""
+
+#. module: base
+#: selection:ir.server.object.lines,type:0
+msgid "Formula"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_users.py:396
+#, python-format
+msgid "Can not remove root user!"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.mw
+msgid "Malawi"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_ec
+msgid ""
+"\n"
+"This is the base module to manage the accounting chart for Ecuador in "
+"OpenERP.\n"
+"============================================================================="
+"=\n"
+"\n"
+"Accounting chart and localization for Ecuador.\n"
+" "
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_filters.py:38
+#: code:addons/base/res/res_users.py:80
+#: code:addons/base/res/res_users.py:420
+#, python-format
+msgid "%s (copy)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_account_chart
+msgid "Template of Charts of Accounts"
+msgstr ""
+
+#. module: base
+#: field:res.partner.address,type:0
+msgid "Address Type"
+msgstr ""
+
+#. module: base
+#: view:ir.ui.menu:0
+msgid "Full Path"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_br
+msgid ""
+"\n"
+"Base module for the Brazilian localization\n"
+"==========================================\n"
+"\n"
+"This module consists in:\n"
+"\n"
+" - Generic Brazilian chart of accounts\n"
+" - Brazilian taxes such as:\n"
+"\n"
+" - IPI\n"
+" - ICMS\n"
+" - PIS\n"
+" - COFINS\n"
+" - ISS\n"
+" - IR\n"
+" - IRPJ\n"
+" - CSLL\n"
+"\n"
+" - Tax Situation Code (CST) required for the electronic fiscal invoicing "
+"(NFe)\n"
+"\n"
+"The field tax_discount has also been added in the account.tax.template and "
+"account.tax objects to allow the proper computation of some Brazilian VATs "
+"such as ICMS. The chart of account creation wizard has been extended to "
+"propagate those new data properly.\n"
+"\n"
+"It's important to note however that this module lack many implementations to "
+"use OpenERP properly in Brazil. Those implementations (such as the "
+"electronic fiscal Invoicing which is already operational) are brought by "
+"more than 15 additional modules of the Brazilian Launchpad localization "
+"project https://launchpad.net/openerp.pt-br-localiz and their dependencies "
+"in the extra addons branch. Those modules aim at not breaking with the "
+"remarkable OpenERP modularity, this is why they are numerous but small. One "
+"of the reasons for maintaining those modules apart is that Brazilian "
+"Localization leaders need commit rights agility to complete the localization "
+"as companies fund the remaining legal requirements (such as soon fiscal "
+"ledgers, accounting SPED, fiscal SPED and PAF ECF that are still missing as "
+"September 2011). Those modules are also strictly licensed under AGPL V3 and "
+"today don't come with any additional paid permission for online use of "
+"'private modules'."
+msgstr ""
+
+#. module: base
+#: view:res.request:0
+msgid "References"
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid ""
+"%U - Week number of the year (Sunday as the first day of the week) as a "
+"decimal number [00,53]. All days in a new year preceding the first Sunday "
+"are considered to be in week 0."
+msgstr ""
+
+#. module: base
+#: view:ir.ui.view:0
+msgid "Advanced"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.fi
+msgid "Finland"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_company.py:156
+#, python-format
+msgid "Website: "
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_administration
+msgid "Settings"
+msgstr ""
+
+#. module: base
+#: selection:ir.actions.act_window,view_type:0
+#: selection:ir.actions.act_window.view,view_mode:0
+#: view:ir.ui.view:0
+#: selection:ir.ui.view,type:0
+#: selection:wizard.ir.model.menu.create.line,view_type:0
+msgid "Tree"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_analytic_multicurrency
+msgid "Multi-Currency in Analytic"
+msgstr ""
+
+#. module: base
+#: view:base.language.export:0
+msgid "https://help.launchpad.net/Translations"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.act_window,view_mode:0
+msgid "View Mode"
+msgstr ""
+
+#. module: base
+#: help:res.partner.bank,footer:0
+msgid ""
+"Display this bank account on the footer of printed documents like invoices "
+"and sales orders."
+msgstr ""
+
+#. module: base
+#: view:base.language.import:0
+msgid ""
+"When using CSV format, please also check that the first line of your file is "
+"one of the following:"
+msgstr ""
+
+#. module: base
+#: view:res.log:0
+msgid "Logs"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish / Español"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Korean (KP) / 한국어 (KP)"
+msgstr ""
+
+#. module: base
+#: view:base.module.update:0
+msgid ""
+"This wizard will scan all module repositories on the server side to detect "
+"newly added modules as well as any change to existing modules."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_sale_journal
+msgid ""
+"\n"
+"The sales journal modules allows you to categorise your sales and deliveries "
+"(picking lists) between different journals.\n"
+"============================================================================="
+"===========================================\n"
+"\n"
+"This module is very helpful for bigger companies that\n"
+"works by departments.\n"
+"\n"
+"You can use journal for different purposes, some examples:\n"
+" * isolate sales of different departments\n"
+" * journals for deliveries by truck or by UPS\n"
+"\n"
+"Journals have a responsible and evolves between different status:\n"
+" * draft, open, cancel, done.\n"
+"\n"
+"Batch operations can be processed on the different journals to\n"
+"confirm all sales at once, to validate or invoice packing, ...\n"
+"\n"
+"It also supports batch invoicing methods that can be configured by partners "
+"and sales orders, examples:\n"
+" * daily invoicing,\n"
+" * monthly invoicing, ...\n"
+"\n"
+"Some statistics by journals are provided.\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:res.company,logo:0
+msgid "Logo"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_cr
+msgid "Costa Rica - Accounting"
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+msgid "Uninstall (beta)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_hr_expense
+msgid ""
+"\n"
+"This module aims to manage employee's expenses.\n"
+"===============================================\n"
+"\n"
+"The whole workflow is implemented:\n"
+" * Draft expense\n"
+" * Confirmation of the sheet by the employee\n"
+" * Validation by his manager\n"
+" * Validation by the accountant and invoice creation\n"
+" * Payment of the invoice to the employee\n"
+"\n"
+"This module also uses the analytic accounting and is compatible with\n"
+"the invoice on timesheet module so that you will be able to automatically\n"
+"re-invoice your customer's expenses if your work by project.\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:ir.values,action_id:0
+msgid "Action (change only)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_subscription
+msgid "Recurring Documents"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.bs
+msgid "Bahamas"
+msgstr ""
+
+#. module: base
+#: selection:res.request,state:0
+msgid "active"
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_partner.py:273
+#, python-format
+msgid ""
+"Couldn't generate the next id because some partners have an alphabetic id !"
+msgstr ""
+
+#. module: base
+#: view:ir.attachment:0
+msgid "Attachment"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.ie
+msgid "Ireland"
+msgstr ""
+
+#. module: base
+#: field:base.module.update,update:0
+msgid "Number of modules updated"
+msgstr ""
+
+#. module: base
+#: field:ir.cron,function:0
+msgid "Method"
+msgstr ""
+
+#. module: base
+#: view:res.partner.event:0
+msgid "General Description"
+msgstr ""
+
+#. module: base
+#: view:workflow.activity:0
+msgid "Workflow Activity"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,help:base.action_ui_view
+msgid ""
+"Views allows you to personalize each view of OpenERP. You can add new "
+"fields, move fields, rename them or delete the ones that you do not need."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_base_setup
+msgid "Initial Setup Tools"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.act_window,groups_id:0
+#: model:ir.actions.act_window,name:base.action_res_groups
+#: view:ir.actions.report.xml:0
+#: field:ir.actions.report.xml,groups_id:0
+#: view:ir.actions.todo:0
+#: field:ir.actions.todo,groups_id:0
+#: field:ir.actions.wizard,groups_id:0
+#: view:ir.model:0
+#: field:ir.model.fields,groups:0
+#: field:ir.rule,groups:0
+#: view:ir.ui.menu:0
+#: field:ir.ui.menu,groups_id:0
+#: model:ir.ui.menu,name:base.menu_action_res_groups
+#: view:res.groups:0
+#: field:res.users,groups_id:0
+msgid "Groups"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (CL) / Español (CL)"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.bz
+msgid "Belize"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.report.xml,header:0
+msgid "Add or not the corporate RML header"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_hr_recruitment
+msgid ""
+"\n"
+"Manages job positions and the recruitment process.\n"
+"==================================================\n"
+"\n"
+"It's integrated with the survey module to allow you to define interview for "
+"different jobs.\n"
+"\n"
+"This module is integrated with the mail gateway to automatically tracks "
+"email\n"
+"sent to jobs@xxxxxxxxxxxxxxx. It's also integrated with the document "
+"management\n"
+"system to store and search in your CV base.\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_res_widget_wizard
+msgid "Homepage Widgets Management"
+msgstr ""
+
+#. module: base
+#: field:res.company,rml_header1:0
+msgid "Report Header / Company Slogan"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.pl
+msgid "Poland"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window,view_mode:0
+msgid ""
+"Comma-separated list of allowed view modes, such as 'form', 'tree', "
+"'calendar', etc. (Default: tree,form)"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:3615
+#, python-format
+msgid "A document was modified since you last viewed it (%s:%d)"
+msgstr ""
+
+#. module: base
+#: view:workflow:0
+msgid "Workflow Editor"
+msgstr ""
+
+#. module: base
+#: selection:ir.module.module,state:0
+#: selection:ir.module.module.dependency,state:0
+msgid "To be removed"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_sequence
+msgid "ir.sequence"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.server,expression:0
+msgid ""
+"Enter the field/expression that will return the list. E.g. select the sale "
+"order in Object, and you can have loop on the sales order line. Expression = "
+"`object.order_line`."
+msgstr ""
+
+#. module: base
+#: field:ir.mail_server,smtp_debug:0
+msgid "Debugging"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_crm_helpdesk
+msgid ""
+"\n"
+"Helpdesk Management.\n"
+"====================\n"
+"\n"
+"Like records and processing of claims, Helpdesk and Support are good tools\n"
+"to trace your interventions. This menu is more adapted to oral "
+"communication,\n"
+"which is not necessarily related to a claim. Select a customer, add notes\n"
+"and categorize your interventions with a channel and a priority level.\n"
+" "
+msgstr ""
+
+#. module: base
+#: sql_constraint:ir.ui.view_sc:0
+msgid "Shortcut for this menu already exists!"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_resource
+msgid ""
+"\n"
+"Module for resource management.\n"
+"===============================\n"
+"\n"
+"A resource represent something that can be scheduled\n"
+"(a developer on a task or a work center on manufacturing orders).\n"
+"This module manages a resource calendar associated to every resource.\n"
+"It also manages the leaves of every resource.\n"
+"\n"
+" "
+msgstr ""
+
+#. module: base
+#: view:ir.rule:0
+msgid "Groups (no group = global)"
+msgstr ""
+
+#. module: base
+#: selection:res.users,view:0
+msgid "Simplified"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.st
+msgid "Saint Tome (Sao Tome) and Principe"
+msgstr ""
+
+#. module: base
+#: selection:res.partner.address,type:0
+msgid "Invoice"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Portugese (BR) / Português (BR)"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.bb
+msgid "Barbados"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_base_synchro
+msgid ""
+"\n"
+"Synchronization with all objects.\n"
+"=================================\n"
+"\n"
+"Configure servers and trigger synchronization with its database objects.\n"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.mg
+msgid "Madagascar"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:116
+#, python-format
+msgid ""
+"The Object name must start with x_ and not contain any special character !"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.configuration.wizard,note:0
+msgid "Next Wizard"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_menu_admin
+#: view:ir.ui.menu:0
+#: field:ir.ui.menu,name:0
+msgid "Menu"
+msgstr ""
+
+#. module: base
+#: field:res.currency,rate:0
+msgid "Current Rate"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_idea
+msgid "Ideas"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_sale_crm
+msgid "Opportunity to Quotation"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_sale_analytic_plans
+msgid ""
+"\n"
+"The base module to manage analytic distribution and sales orders.\n"
+"=================================================================\n"
+"\n"
+"Using this module you will be able to link analytic accounts to sales "
+"orders.\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:ir.actions.url,target:0
+msgid "Action Target"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_base_calendar
+msgid "Calendar Layer"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.report.xml,name:base.report_ir_model_overview
+msgid "Model Overview"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_product_margin
+msgid "Margins by Products"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_invoiced
+msgid "Invoicing"
+msgstr ""
+
+#. module: base
+#: field:ir.ui.view_sc,name:0
+msgid "Shortcut Name"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.act_window,limit:0
+msgid "Default limit for the list view"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.pg
+msgid "Papua New Guinea"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.zw
+msgid "Zimbabwe"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.io
+msgid "British Indian Ocean Territory"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_translation_export
+msgid "Import / Export"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.todo.category,name:base.category_tools_customization_config
+msgid "Tools / Customization"
+msgstr ""
+
+#. module: base
+#: field:ir.model.data,res_id:0
+#: field:ir.values,res_id:0
+msgid "Record ID"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.server,email:0
+msgid "Email Address"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "French (BE) / Français (BE)"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+#: field:workflow.activity,action_id:0
+msgid "Server Action"
+msgstr ""
+
+#. module: base
+#: help:ir.actions.client,params:0
+msgid "Arguments sent to the client along withthe view tag"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_project_gtd
+msgid ""
+"\n"
+"This module implements all concepts defined by the Getting Things Done "
+"methodology.\n"
+"============================================================================="
+"======\n"
+"\n"
+"This module implements a simple personnal Todo list based on tasks. It adds "
+"in\n"
+"the project application an editable list of tasks simplified to the minimum\n"
+"required fields.\n"
+"\n"
+"The todo list is based on the GTD methodology. This world-wide used "
+"methodology\n"
+"is used for personal time management improvement.\n"
+"\n"
+"Getting Things Done (commonly abbreviated as GTD) is an action management\n"
+"method created by David Allen, and described in a book of the same name.\n"
+"\n"
+"GTD rests on the principle that a person needs to move tasks out of the mind "
+"by\n"
+"recording them externally. That way, the mind is freed from the job of\n"
+"remembering everything that needs to be done, and can concentrate on "
+"actually\n"
+"performing those tasks.\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.tt
+msgid "Trinidad and Tobago"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.lv
+msgid "Latvia"
+msgstr ""
+
+#. module: base
+#: view:partner.sms.send:0
+msgid "SMS - Gateway: clickatell"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+msgid "Field Mappings"
+msgstr ""
+
+#. module: base
+#: code:addons/base/publisher_warranty/publisher_warranty.py:125
+#: code:addons/base/publisher_warranty/publisher_warranty.py:163
+#, python-format
+msgid "Error during communication with the publisher warranty server."
+msgstr ""
+
+#. module: base
+#: model:res.groups,name:base.group_sale_manager
+#: model:res.groups,name:base.group_tool_manager
+msgid "Manager"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_custom
+msgid "Customization"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.py
+msgid "Paraguay"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_actions_act_window_close
+msgid "ir.actions.act_window_close"
+msgstr ""
+
+#. module: base
+#: field:ir.server.object.lines,col1:0
+msgid "Destination"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.lt
+msgid "Lithuania"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_view_partner_clear_ids
+#: model:ir.model,name:base.model_partner_clear_ids
+#: view:partner.clear.ids:0
+msgid "Clear IDs"
+msgstr ""
+
+#. module: base
+#: view:res.groups:0
+msgid "Inherited"
+msgstr ""
+
+#. module: base
+#: field:ir.model.fields,serialization_field_id:0
+msgid "Serialization Field"
+msgstr ""
+
+#. module: base
+#: model:ir.module.category,description:base.module_category_report_designer
+msgid ""
+"Lets you install various tools to simplify and enhance OpenERP's report "
+"creation."
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid "%y - Year without century [00,99]."
+msgstr ""
+
+#. module: base
+#: code:addons/base/res/res_company.py:155
+#, python-format
+msgid "Fax: "
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.si
+msgid "Slovenia"
+msgstr ""
+
+#. module: base
+#: help:res.currency,name:0
+msgid "Currency Code (ISO 4217)"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.res_log_act_window
+#: model:ir.ui.menu,name:base.menu_res_log_act_window
+msgid "Client Logs"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:1883
+#: code:addons/orm.py:1894
+#, python-format
+msgid "Invalid Object Architecture!"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:311
+#: code:addons/base/ir/ir_model.py:313
+#: code:addons/base/ir/ir_model.py:343
+#: code:addons/base/ir/ir_model.py:357
+#: code:addons/base/ir/ir_model.py:359
+#: code:addons/base/ir/ir_model.py:361
+#: code:addons/base/ir/ir_model.py:368
+#: code:addons/base/ir/ir_model.py:371
+#: code:addons/base/module/wizard/base_update_translations.py:38
+#, python-format
+msgid "Error!"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_l10n_fr_rib
+msgid "French RIB Bank Details"
+msgstr ""
+
+#. module: base
+#: view:res.lang:0
+msgid "%p - Equivalent of either AM or PM."
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+msgid "Iteration Actions"
+msgstr ""
+
+#. module: base
+#: help:multi_company.default,company_id:0
+msgid "Company where the user is connected"
+msgstr ""
+
+#. module: base
+#: field:publisher_warranty.contract,date_stop:0
+msgid "Ending Date"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.nz
+msgid "New Zealand"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_pad_project
+msgid ""
+"\n"
+"This module adds a PAD in all project kanban views\n"
+"==================================================\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,help:base.action_country
+msgid ""
+"Display and manage the list of all countries that can be assigned to your "
+"partner records. You can create or delete countries to make sure the ones "
+"you are working on will be maintained."
+msgstr ""
+
+#. module: base
+#: model:res.partner.category,name:base.res_partner_category_7
+msgid "Openstuff.net"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.nf
+msgid "Norfolk Island"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Korean (KR) / 한국어 (KR)"
+msgstr ""
+
+#. module: base
+#: help:ir.model.fields,model:0
+msgid "The technical name of the model this field belongs to"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.server,action_id:0
+#: selection:ir.actions.server,state:0
+msgid "Client Action"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.bd
+msgid "Bangladesh"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_project_retro_planning
+msgid "Project Retro-planning"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_stock_planning
+msgid "Master Procurement Schedule"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_module_category
+#: field:ir.module.module,application:0
+#: field:res.groups,category_id:0
+msgid "Application"
+msgstr ""
+
+#. module: base
+#: selection:publisher_warranty.contract,state:0
+msgid "Valid"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_decimal_precision
+msgid ""
+"\n"
+"Configure the price accuracy you need for different kinds of usage: "
+"accounting, sales, purchases, etc.\n"
+"============================================================================="
+"=========================\n"
+"\n"
+"The decimal precision is configured per company.\n"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_pl
+msgid ""
+"\n"
+"This is the module to manage the accounting chart and taxes for Poland in "
+"OpenERP.\n"
+"============================================================================="
+"=====\n"
+"\n"
+"To jest moduł do tworzenia wzorcowego planu kont i podstawowych ustawień do "
+"podatków\n"
+"VAT 0%, 7% i 22%. Moduł ustawia też konta do kupna i sprzedaży towarów "
+"zakładając,\n"
+"że wszystkie towary są w obrocie hurtowym.\n"
+" "
+msgstr ""
+
+#. module: base
+#: field:ir.actions.client,params_store:0
+msgid "Params storage"
+msgstr ""
+
+#. module: base
+#: code:addons/base/module/module.py:409
+#, python-format
+msgid "Can not upgrade module '%s'. It is not installed."
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.cu
+msgid "Cuba"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_crm_profiling
+msgid ""
+"\n"
+"This module allows users to perform segmentation within partners.\n"
+"=================================================================\n"
+"\n"
+"It uses the profiles criteria from the earlier segmentation module and "
+"improve it. Thanks to the new concept of questionnaire. You can now regroup "
+"questions into a questionnaire and directly use it on a partner.\n"
+"\n"
+"It also has been merged with the earlier CRM & SRM segmentation tool because "
+"they were overlapping.\n"
+"\n"
+" * Note: this module is not compatible with the module segmentation, "
+"since it's the same which has been renamed.\n"
+" "
+msgstr ""
+
+#. module: base
+#: code:addons/report_sxw.py:434
+#, python-format
+msgid "Unknown report type: %s"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:282
+#, python-format
+msgid "For selection fields, the Selection Options must be given!"
+msgstr ""
+
+#. module: base
+#: model:res.widget,title:base.facebook_widget
+msgid "Facebook"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.am
+msgid "Armenia"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.ir_property_form
+#: model:ir.ui.menu,name:base.menu_ir_property_form_all
+msgid "Configuration Parameters"
+msgstr ""
+
+#. module: base
+#: constraint:ir.cron:0
+msgid "Invalid arguments"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.se
+msgid "Sweden"
+msgstr ""
+
+#. module: base
+#: selection:ir.actions.act_window.view,view_mode:0
+#: selection:ir.ui.view,type:0
+#: selection:wizard.ir.model.menu.create.line,view_type:0
+msgid "Gantt"
+msgstr ""
+
+#. module: base
+#: view:ir.property:0
+msgid "Property"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_res_partner_bank_type
+#: field:res.partner.bank,state:0
+#: view:res.partner.bank.type:0
+msgid "Bank Account Type"
+msgstr ""
+
+#. module: base
+#: field:base.language.export,config_logo:0
+#: field:base.language.import,config_logo:0
+#: field:base.language.install,config_logo:0
+#: field:base.module.import,config_logo:0
+#: field:base.module.update,config_logo:0
+#: field:base.update.translations,config_logo:0
+#: field:ir.actions.configuration.wizard,config_logo:0
+#: field:ir.wizard.screen,config_logo:0
+#: field:publisher_warranty.contract.wizard,config_logo:0
+#: field:res.config,config_logo:0
+#: field:res.config.installer,config_logo:0
+msgid "Image"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+msgid "Iteration Action Configuration"
+msgstr ""
+
+#. module: base
+#: selection:publisher_warranty.contract,state:0
+msgid "Canceled"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.at
+msgid "Austria"
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+msgid "Cancel Install"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_be_invoice_bba
+msgid ""
+"\n"
+" \n"
+"Belgian localisation for in- and outgoing invoices (prereq to "
+"account_coda):\n"
+" - Rename 'reference' field labels to 'Communication'\n"
+" - Add support for Belgian Structured Communication\n"
+"\n"
+"A Structured Communication can be generated automatically on outgoing "
+"invoices according to the following algorithms:\n"
+" 1) Random : +++RRR/RRRR/RRRDD+++\n"
+" R..R = Random Digits, DD = Check Digits\n"
+" 2) Date : +++DOY/YEAR/SSSDD+++\n"
+" DOY = Day of the Year, SSS = Sequence Number, DD = Check Digits)\n"
+" 3) Customer Reference +++RRR/RRRR/SSSDDD+++\n"
+" R..R = Customer Reference without non-numeric characters, SSS = "
+"Sequence Number, DD = Check Digits) \n"
+" \n"
+"The preferred type of Structured Communication and associated Algorithm can "
+"be specified on the Partner records. \n"
+"A 'random' Structured Communication will generated if no algorithm is "
+"specified on the Partner record. \n"
+"\n"
+" "
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_wiki_quality_manual
+msgid "Wiki: Quality Manual"
+msgstr ""
+
+#. module: base
+#: selection:ir.actions.act_window.view,view_mode:0
+#: model:ir.ui.menu,name:base.menu_calendar_configuration
+#: selection:ir.ui.view,type:0
+#: selection:wizard.ir.model.menu.create.line,view_type:0
+msgid "Calendar"
+msgstr ""
+
+#. module: base
+#: field:res.partner.address,partner_id:0
+msgid "Partner Name"
+msgstr ""
+
+#. module: base
+#: field:workflow.activity,signal_send:0
+msgid "Signal (subflow.*)"
+msgstr ""
+
+#. module: base
+#: model:res.partner.category,name:base.res_partner_category_17
+msgid "HR sector"
+msgstr ""
+
+#. module: base
+#: model:ir.ui.menu,name:base.menu_dashboard_admin
+msgid "Administration Dashboard"
+msgstr ""
+
+#. module: base
+#: code:addons/orm.py:4408
+#, python-format
+msgid ""
+"Invalid \"order\" specified. A valid \"order\" specification is a comma-"
+"separated list of valid field names (optionally followed by asc/desc for the "
+"direction)"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_ir_module_module_dependency
+msgid "Module dependency"
+msgstr ""
+
+#. module: base
+#: selection:publisher_warranty.contract.wizard,state:0
+msgid "Draft"
+msgstr ""
+
+#. module: base
+#: selection:res.users,view:0
+msgid "Extended"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,help:base.action_partner_title_contact
+msgid ""
+"Manage the contact titles you want to have available in your system and the "
+"way you want to print them in letters and other documents. Some example: "
+"Mr., Mrs. "
+msgstr ""
+
+#. module: base
+#: view:ir.model.access:0
+#: view:res.groups:0
+#: field:res.groups,model_access:0
+msgid "Access Controls"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_model.py:237
+#, python-format
+msgid ""
+"The Selection Options expression is not a valid Pythonic expression.Please "
+"provide an expression in the [('key','Label'), ...] format."
+msgstr ""
+
+#. module: base
+#: model:res.groups,name:base.group_survey_user
+msgid "Survey / User"
+msgstr ""
+
+#. module: base
+#: view:ir.module.module:0
+#: field:ir.module.module,dependencies_id:0
+msgid "Dependencies"
+msgstr ""
+
+#. module: base
+#: field:multi_company.default,company_id:0
+msgid "Main Company"
+msgstr ""
+
+#. module: base
+#: field:ir.ui.menu,web_icon_hover:0
+msgid "Web Icon File (hover)"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_web_diagram
+msgid "Openerp web Diagram view"
+msgstr ""
+
+#. module: base
+#: model:res.groups,name:base.group_hr_user
+msgid "HR Officer"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_hr_contract
+msgid "Employee Contracts"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_wiki_faq
+msgid ""
+"\n"
+"This module provides a Wiki FAQ Template.\n"
+"=========================================\n"
+"\n"
+"It provides demo data, thereby creating a Wiki Group and a Wiki Page\n"
+"for Wiki FAQ.\n"
+" "
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+msgid ""
+"If you use a formula type, use a python expression using the variable "
+"'object'."
+msgstr ""
+
+#. module: base
+#: constraint:res.company:0
+msgid "Error! You can not create recursive companies."
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_res_users
+#: field:ir.default,uid:0
+#: model:ir.ui.menu,name:base.menu_action_res_users
+#: model:ir.ui.menu,name:base.menu_users
+#: view:res.groups:0
+#: field:res.groups,users:0
+#: view:res.users:0
+msgid "Users"
+msgstr ""
+
+#. module: base
+#: field:res.partner.address,birthdate:0
+msgid "Birthdate"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_partner_title_contact
+#: model:ir.ui.menu,name:base.menu_partner_title_contact
+msgid "Contact Titles"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_product_manufacturer
+msgid "Products Manufacturers"
+msgstr ""
+
+#. module: base
+#: code:addons/base/ir/ir_mail_server.py:217
+#, python-format
+msgid "SMTP-over-SSL mode unavailable"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_survey
+msgid "Survey"
+msgstr ""
+
+#. module: base
+#: view:base.language.import:0
+msgid ""
+"Please double-check that the file encoding is set to UTF-8 (sometimes called "
+"Unicode) when the translator exports it."
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Spanish (DO) / Español (DO)"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.na
+msgid "Namibia"
+msgstr ""
+
+#. module: base
+#: model:ir.model,name:base.model_workflow_activity
+msgid "workflow.activity"
+msgstr ""
+
+#. module: base
+#: help:ir.ui.view_sc,res_id:0
+msgid ""
+"Reference of the target resource, whose model/table depends on the 'Resource "
+"Name' field."
+msgstr ""
+
+#. module: base
+#: field:ir.model.fields,select_level:0
+msgid "Searchable"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.uy
+msgid "Uruguay"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_fetchmail_crm
+msgid "eMail Gateway for Leads"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Finnish / Suomi"
+msgstr ""
+
+#. module: base
+#: field:ir.rule,perm_write:0
+msgid "Apply For Write"
+msgstr ""
+
+#. module: base
+#: field:ir.sequence,prefix:0
+msgid "Prefix"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "German / Deutsch"
+msgstr ""
+
+#. module: base
+#: view:ir.actions.server:0
+msgid "Fields Mapping"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_web_dashboard
+msgid "web Dashboard"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_sale
+msgid ""
+"\n"
+"The base module to manage quotations and sales orders.\n"
+"======================================================\n"
+"\n"
+"Workflow with validation steps:\n"
+"-------------------------------\n"
+" * Quotation -> Sales order -> Invoice\n"
+"\n"
+"Invoicing methods:\n"
+"------------------\n"
+" * Invoice on order (before or after shipping)\n"
+" * Invoice on delivery\n"
+" * Invoice on timesheets\n"
+" * Advance invoice\n"
+"\n"
+"Partners preferences:\n"
+"---------------------\n"
+" * shipping\n"
+" * invoicing\n"
+" * incoterm\n"
+"\n"
+"Products stocks and prices\n"
+"--------------------------\n"
+"\n"
+"Delivery methods:\n"
+"-----------------\n"
+" * all at once\n"
+" * multi-parcel\n"
+" * delivery costs\n"
+"\n"
+"Dashboard for Sales Manager that includes:\n"
+"------------------------------------------\n"
+" * Quotations\n"
+" * Sales by Month\n"
+" * Graph of Sales by Salesman in last 90 days\n"
+" * Graph of Sales per Customer in last 90 days\n"
+" * Graph of Sales by Product's Category in last 90 days\n"
+" "
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Portugese / Português"
+msgstr ""
+
+#. module: base
+#: model:res.partner.title,name:base.res_partner_title_sir
+msgid "Sir"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_ca
+msgid ""
+"\n"
+"This is the module to manage the English and French - Canadian accounting "
+"chart in OpenERP.\n"
+"============================================================================="
+"==============\n"
+"\n"
+"Canadian accounting charts and localizations.\n"
+" "
+msgstr ""
+
+#. module: base
+#: view:base.module.import:0
+msgid "Select module package to import (.zip file):"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "French / Français"
+msgstr ""
+
+#. module: base
+#: model:res.country,name:base.mt
+msgid "Malta"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.server,fields_lines:0
+msgid "Field Mappings."
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_l10n_lu
+msgid ""
+"\n"
+"This is the base module to manage the accounting chart for Luxembourg.\n"
+"======================================================================\n"
+"\n"
+" * the KLUWER Chart of Accounts,\n"
+" * the Tax Code Chart for Luxembourg\n"
+" * the main taxes used in Luxembourg"
+msgstr ""
+
+#. module: base
+#: field:ir.module.module,demo:0
+msgid "Demo data"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,description:base.module_portal
+msgid ""
+"\n"
+"This module defines 'portals' to customize the access to your OpenERP "
+"database\n"
+"for external users.\n"
+"\n"
+"A portal defines customized user menu and access rights for a group of "
+"users\n"
+"(the ones associated to that portal). It also associates user groups to "
+"the\n"
+"portal users (adding a group in the portal automatically adds it to the "
+"portal\n"
+"users, etc). That feature is very handy when used in combination with the\n"
+"module 'share'.\n"
+" "
+msgstr ""
+
+#. module: base
+#: selection:res.request,priority:0
+msgid "High"
+msgstr ""
+
+#. module: base
+#: field:ir.attachment,description:0
+#: field:ir.mail_server,name:0
+#: field:ir.module.category,description:0
+#: view:ir.module.module:0
+#: field:ir.module.module,description:0
+#: view:res.partner.event:0
+#: field:res.partner.event,description:0
+#: view:res.request:0
+msgid "Description"
+msgstr ""
+
+#. module: base
+#: model:ir.actions.act_window,name:base.action_workflow_instance_form
+#: model:ir.ui.menu,name:base.menu_workflow_instance
+msgid "Instances"
+msgstr ""
+
+#. module: base
+#: help:ir.mail_server,smtp_host:0
+msgid "Hostname or IP of SMTP server"
+msgstr ""
+
+#. module: base
+#: selection:base.language.install,lang:0
+msgid "Japanese / 日本語"
+msgstr ""
+
+#. module: base
+#: field:ir.actions.report.xml,auto:0
+msgid "Custom python parser"
+msgstr ""
+
+#. module: base
+#: view:base.language.import:0
+msgid "_Import"
+msgstr ""
+
+#. module: base
+#: selection:ir.translation,type:0
+msgid "XSL"
+msgstr ""
+
+#. module: base
+#: field:res.lang,grouping:0
+msgid "Separator Format"
+msgstr ""
+
+#. module: base
+#: constraint:res.partner.bank:0
+msgid "The RIB and/or IBAN is not valid"
+msgstr ""
+
+#. module: base
+#: model:ir.module.module,shortdesc:base.module_report_webkit
+msgid "Webkit Report Engine"
+msgstr ""
+
+#. module: base
+#: selection:publisher_warranty.contract,state:0
+msgid "Unvalidated"
+msgstr ""
+
+#. module: base
+#: model:ir
Follow ups