More tweaking to cleanly support bin and run directories.
authorArt Cancro <ajc@citadel.org>
Sun, 12 Jun 2022 04:01:58 +0000 (00:01 -0400)
committerArt Cancro <ajc@citadel.org>
Sun, 12 Jun 2022 04:01:58 +0000 (00:01 -0400)
40 files changed:
citadel/COPYING [deleted file]
citadel/Makefile
citadel/Makefile.in [deleted file]
citadel/README.txt
citadel/configure.ac [deleted file]
citadel/license.txt [new file with mode: 0644]
citadel/mkinstalldirs [deleted file]
citadel/server/citadel_dirs.h
citadel/server/modules/autocompletion/.gitignore [deleted file]
citadel/server/modules/bio/.gitignore [deleted file]
citadel/server/modules/bio/serv_bio.c
citadel/server/modules/calendar/.gitignore [deleted file]
citadel/server/modules/checkpoint/.gitignore [deleted file]
citadel/server/modules/clamav/.gitignore [deleted file]
citadel/server/modules/crypto/.gitignore [deleted file]
citadel/server/modules/expire/.gitignore [deleted file]
citadel/server/modules/fulltext/.gitignore [deleted file]
citadel/server/modules/imap/.gitignore [deleted file]
citadel/server/modules/inboxrules/.gitignore [deleted file]
citadel/server/modules/inetcfg/.gitignore [deleted file]
citadel/server/modules/instmsg/.gitignore [deleted file]
citadel/server/modules/listsub/.gitignore [deleted file]
citadel/server/modules/migrate/.gitignore [deleted file]
citadel/server/modules/newuser/.gitignore [deleted file]
citadel/server/modules/notes/.gitignore [deleted file]
citadel/server/modules/openid/.gitignore [deleted file]
citadel/server/modules/pop3/.gitignore [deleted file]
citadel/server/modules/pop3client/.gitignore [deleted file]
citadel/server/modules/roomchat/.gitignore [deleted file]
citadel/server/modules/rssclient/.gitignore [deleted file]
citadel/server/modules/rwho/.gitignore [deleted file]
citadel/server/modules/smtp/.gitignore [deleted file]
citadel/server/modules/spam/.gitignore [deleted file]
citadel/server/modules/test/.gitignore [deleted file]
citadel/server/modules/upgrade/.gitignore [deleted file]
citadel/server/modules/vcard/.gitignore [deleted file]
citadel/server/modules/wiki/.gitignore [deleted file]
citadel/server/modules/xmpp/.gitignore [deleted file]
citadel/server/modules_init.c
citadel/utils/guesstimezone.sh [changed mode: 0644->0755]

diff --git a/citadel/COPYING b/citadel/COPYING
deleted file mode 100644 (file)
index 9192340..0000000
+++ /dev/null
@@ -1,675 +0,0 @@
-
-Copyright: (C) 1987-2022 Citadel development team; GPL V3
-
-* As a special exception, it is officialy resolved that our
-  favorite type of software is called "open source" -- NOT "free
-  software" -- and that our favorite operating system is called
-  "Linux" -- NOT "GNU/Linux".
-
-* We reject and oppose Richard M. Stallman because he contributes
-  nothing but trouble to the open source community.
-
-* As a special exception, the copyright holders of the Citadel
-  system grant permission to link Citadel with non-GPL-compatible
-  libraries, including OpenSSL, in the sole case that such linking
-  is done to build the Citadel system itself.
-
-                       GENERAL PUBLIC LICENSE
-                       Version 3, 29 June 2007
-
-                            Preamble
-
-  The General Public License is an open source license for 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,
-the General Public License is intended to guarantee your freedom to
-share and change all versions of a program--to make sure it remains open
-source for all its users.  The Free Software Foundation uses the
-General Public License for most of its software; it applies also to
-any other work released this way by its authors.  You can apply it to
-your programs, too.
-
-  When we speak of free software, we are referring to freedom, not
-price.  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.
-
-  To protect your rights, we need to prevent others from denying you
-these rights or asking you to surrender the rights.  Therefore, you have
-certain responsibilities if you distribute copies of the software, or if
-you modify it: responsibilities to respect the freedom of others.
-
-  For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must pass on to the recipients the same
-freedoms that you received.  You must make sure that they, too, receive
-or can get the source code.  And you must show them these terms so they
-know their rights.
-
-  Developers that use the GPL protect your rights with two steps:
-(1) assert copyright on the software, and (2) offer you this License
-giving you legal permission to copy, distribute and/or modify it.
-
-  For the developers' and authors' protection, the GPL clearly explains
-that there is no warranty for this open source software.  For both users'
-and authors' sake, the GPL requires that modified versions be marked as
-changed, so that their problems will not be attributed erroneously to
-authors of previous versions.
-
-  Some devices are designed to deny users access to install or run
-modified versions of the software inside them, although the manufacturer
-can do so.  This is fundamentally incompatible with the aim of
-protecting users' freedom to change the software.  The systematic
-pattern of such abuse occurs in the area of products for individuals to
-use, which is precisely where it is most unacceptable.  Therefore, we
-have designed this version of the GPL to prohibit the practice for those
-products.  If such problems arise substantially in other domains, we
-stand ready to extend this provision to those domains in future versions
-of the GPL, as needed to protect the freedom of users.
-
-  Finally, every program is threatened constantly by software patents.
-States should not allow patents to restrict development and use of
-software on general-purpose computers, but in those that do, we wish to
-avoid the special danger that patents applied to an open source program
-could make it effectively proprietary.  To prevent this, the GPL assures
-that patents cannot be used to render the program closed-source.
-
-  The precise terms and conditions for copying, distribution and
-modification follow.
-
-                       TERMS AND CONDITIONS
-
-  0. Definitions.
-
-  "This License" refers to version 3 of the 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 open
-source 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. Use with the Affero General Public License.
-
-  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 Affero 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 special requirements of the Affero General Public License,
-section 13, concerning interaction through a network will apply to the
-combination as such.
-
-  14. Revised Versions of this License.
-
-  The Free Software Foundation may publish revised and/or new versions of
-the 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 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
-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 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
-
-
-
-
-
-CRC16 license:
-
-   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 Indigo Systems Corporation 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.
-
-MD5 license:
-
-   This code was written by Colin Plumb in 1993, no copyright is claimed.
-   This code is in the public domain; do with it what you wish.
-
-Copyright for CRC16: (C) 2002-2003 Indigo Systems Corporation; 
-         Artistic license + Non advertising clause
-
-Copyright for MD5 implementation: (C) 1993 Colin Plumb; Public Domain
-
index d1cf0450e6955e99ced4420cc03835be6ccab562..ab939b439488b11b7ed208ec104021dc17e8cefe 100644 (file)
@@ -54,10 +54,10 @@ clean:
 distclean: clean
        rm -vf config.mk
 
-install: $(all)
+install: $(all) utils/*.sh
        #
        # Installing to ${CTDLDIR}
        #
-       @for x in $(all) ; do \
-               install -v -D -t ${CTDLDIR} $$x ;\
+       @for x in $(all) utils/*.sh ; do \
+               install -v -C -D -t ${CTDLDIR} $$x ;\
        done
diff --git a/citadel/Makefile.in b/citadel/Makefile.in
deleted file mode 100644 (file)
index c4040db..0000000
+++ /dev/null
@@ -1,343 +0,0 @@
-########################################################################
-#
-# Makefile for Citadel Server
-#
-# NOTE: normally you should not have to modify the Makefile.  All
-# system-dependent configuration is in the "configure" script, which
-# uses "Makefile.in" to generate a "Makefile".  In the rare instance
-# that you have to modify something here, please edit Makefile.in,
-# *not* Makefile.
-#
-########################################################################
-
-prefix=@prefix@
-srcdir=@srcdir@
-VPATH=$(srcdir)
-
-TARGETS=@TARGETS@
-RUN_DIR=@MAKE_RUN_DIR@
-SPOOL_DIR=@MAKE_SPOOL_DIR@
-ETC_DIR=@MAKE_ETC_DIR@
-DATA_DIR=@MAKE_DATA_DIR@
-STATICDATA_DIR=@MAKE_STATICDATA_DIR@
-HELP_DIR=@MAKE_HELP_DIR@
-DOC_DIR=@MAKE_DOC_DIR@
-UTILBIN_DIR=@MAKE_UTILBIN_DIR@
-DEPEND_FLAG=@DEPEND_FLAG@
-all: buildinfo $(TARGETS)
-
-.SUFFIXES: .o .d .c
-
-EXEEXT=@EXEEXT@
-
-SERVER_TARGETS=citserver$(EXEEXT)
-
-include Make_modules
-
-UTIL_TARGETS=citmail$(EXEEXT) sendcommand$(EXEEXT)
-
-UTILBIN_TARGETS= setup$(EXEEXT) \
-       chkpw$(EXEEXT) chkpwd$(EXEEXT) \
-       ctdlmigrate$(EXEEXT)
-
-ACLOCAL=@ACLOCAL@
-AUTOCONF=@AUTOCONF@
-chkpwd_LIBS=@chkpwd_LIBS@
-CC=@CC@
-CFLAGS=@CFLAGS@ -I. -Wno-format-truncation -Wno-unused-result
-CPPFLAGS=@CPPFLAGS@ -I.
-DATABASE=@DATABASE@
-DEFS=@DEFS@ -DDIFF=\"@DIFF@\" -DPATCH=\"@PATCH@\"
-LDFLAGS=@LDFLAGS@ -rdynamic
-LIBS=@LIBS@
-LIBOBJS=@LIBOBJS@
-INSTALL=@INSTALL@
-INSTALL_DATA=@INSTALL_DATA@
-RESOLV=@RESOLV@
-SHELL=/bin/sh
-SERVER_LDFLAGS=@SERVER_LDFLAGS@ -rdynamic
-SERVER_LIBS=@SERVER_LIBS@
-SETUP_LIBS=@SETUP_LIBS@
-YACC=@YACC@
-DIFF=@DIFF@
-PATCH=@PATCH@
-LOCALEDIR=@LOCALEDIR@
-
-# End configuration section
-
-.SILENT:
-
-
-SOURCES=citmail.c setup.c chkpw.c \
-       sendcommand.c  ctdlmigrate.c chkpwd.c \
-       citadel_dirs.c \
-       citserver.c clientsocket.c config.c control.c $(DATABASE) \
-       domain.c serv_extensions.c genstamp.c \
-       housekeeping.c default_timezone.c internet_addressing.c \
-       locate_host.c auth.c msgbase.c parsedate.c \
-       room_ops.c euidindex.c server_main.c ldap.c \
-       support.c sysdep.c user_ops.c journaling.c threads.c \
-       context.c netconfig.c
-
-include Make_sources
-
-# for VPATH builds (invoked by configure)
-mkdir-init:
-       DIRS=`/bin/ls $(VPATH)/modules/`
-       echo $(DIRS)
-       @for d in `/bin/ls $(VPATH)/modules/`; do \
-               (mkdir -p modules/$$d ) ; \
-       done
-       DIRS=`/bin/ls $(VPATH)/user_modules/`
-       echo $(DIRS)
-       @for d in `/bin/ls $(VPATH)/user_modules/`; do \
-               (mkdir -p user_modules/$$d ) ; \
-       done
-       mkdir locale
-
-svn_revision.c: ${SOURCES}
-       $(srcdir)/scripts/mk_svn_revision.sh
-
-DEP_FILES=$(SOURCES:.c=.d) modules_init.d modules_upgrade.d
-
-noinst: $(NOINST_TARGETS)
-
-server: $(SERVER_TARGETS) $(SERV_MODULES)
-
-utils: $(UTIL_TARGETS) $(UTILBIN_TARGETS)
-
-.y.c:
-       $(YACC) $(YFLAGS) $<
-       mv -f y.tab.c $@
-
-parsedate.o: parsedate.c
-
-Make_sources: modules_init.c
-
-Make_modules: modules_init.c
-
-modules_upgrade.c: modules_init.c
-
-SERV_OBJS = server_main.o citadel_dirs.o \
-       user_ops.o citserver.o sysdep.o serv_extensions.o \
-       $(DATABASE:.c=.o) domain.o \
-       control.o config.o support.o room_ops.o \
-       msgbase.o euidindex.o \
-       locate_host.o housekeeping.o default_timezone.o \
-       internet_addressing.o journaling.o \
-       parsedate.o genstamp.o threads.o context.o \
-       clientsocket.o modules_init.o modules_upgrade.o $(SERV_MODULES) \
-       svn_revision.o ldap.o netconfig.o
-
-citserver$(EXEEXT): $(SERV_OBJS)
-       $(CC) $(SERV_OBJS) $(LDFLAGS) $(SERVER_LDFLAGS) $(LIBS) $(SERVER_LIBS) $(RESOLV) -o citserver$(EXEEXT)
-
-%.o: %.c ${HEADERS}
-       echo "CC $<"
-       $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $< -o $@
-
-citmail$(EXEEXT): citmail.o citadel_dirs.o
-       $(CC) citmail.o citadel_dirs.o \
-               $(LDFLAGS) -o citmail$(EXEEXT) $(LIBS)
-
-# setup does need LIBS defined, because it uses network functions which are in -lsocket -lnsl on Solaris.
-setup$(EXEEXT): setup.o citadel_dirs.o
-       $(CC) setup.o citadel_dirs.o \
-               $(LDFLAGS) -o setup$(EXEEXT) $(LIBS) $(SETUP_LIBS)
-
-ctdlmigrate$(EXEEXT): ctdlmigrate.o citadel_dirs.o
-       $(CC) ctdlmigrate.o citadel_dirs.o \
-               $(LDFLAGS) -lreadline -o ctdlmigrate$(EXEEXT) $(LIBS)
-
-chkpwd$(EXEEXT): chkpwd.o auth.o
-       $(CC) chkpwd.o auth.o $(LDFLAGS) -o chkpwd$(EXEEXT) $(chkpwd_LIBS)
-
-chkpw$(EXEEXT): chkpw.o auth.o citadel_dirs.o
-       $(CC) chkpw.o auth.o citadel_dirs.o \
-               $(LDFLAGS) -o chkpw$(EXEEXT) $(chkpwd_LIBS)
-
-sendcommand$(EXEEXT): sendcommand.o citadel_dirs.o $(LIBOBJS)
-       $(CC) sendcommand.o citadel_dirs.o \
-               $(LIBOBJS) $(LDFLAGS) -o sendcommand$(EXEEXT) $(LIBS)
-
-.PHONY: install-data install-doc install-exec clean cleaner distclean
-
-install-locale:
-       cd po/citadel-setup
-       $(MAKE)
-       for i in `find locale -type d | grep -v .svn` \
-               ; do \
-               test -d $(DESTDIR)$(LOCALEDIR)/$$i || mkdir -p $(DESTDIR)$(LOCALEDIR)/$$i; \
-       done
-       for i in `find locale -type f | grep -v .svn`; do \
-               $(INSTALL) $$i $(DESTDIR)$(LOCALEDIR)/$$i; \
-       done
-
-install: install-exec install-data install-doc install-locale
-       @echo 
-       @echo Installation is complete.
-       @echo Now go to your Citadel directory and run 'setup'.
-       @echo 
-
-install-new: install-exec-new install-data-new install-doc-new install-locale
-       @echo 
-       @echo Installation is complete.
-       @echo Now go to your Citadel directory and run 'setup'.
-       @echo 
-
-upgrade: install-exec install-doc
-       @echo
-       @echo Upgrade is complete.
-       @echo Now go to your Citadel directory and run 'setup'.
-       @echo
-
-install-data:
-       $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/messages
-       -@if test -d $(DESTDIR)/etc/pam.d; then \
-               echo $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
-               $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
-       fi
-
-install-data-new:
-       $(srcdir)/mkinstalldirs $(DESTDIR)$(ETC_DIR)/
-
-       $(srcdir)/mkinstalldirs $(DESTDIR)$(STATICDATA_DIR)/messages
-       @for i in  \
-                `find $(srcdir)/messages  -type f | grep -v .svn`; do \
-               echo $(INSTALL_DATA) $$i $(DESTDIR)$(STATICDATA_DIR)/$$i; \
-               $(INSTALL_DATA) $$i $(DESTDIR)$(STATICDATA_DIR)/$$i; \
-       done
-       -@if test -d $(DESTDIR)/etc/pam.d; then \
-               echo $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
-               $(INSTALL_DATA) $(srcdir)/citadel.pam $(DESTDIR)/etc/pam.d/citadel; \
-       fi
-       @for i in files; do \
-               $(srcdir)/mkinstalldirs $(DESTDIR)$(DATA_DIR)/$$i; \
-       done
-
-install-doc:
-       @$(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/docs
-       @for i in `find $(srcdir)/docs -type f | grep -v .svn`; do \
-               echo $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
-               $(INSTALL_DATA) $$i $(DESTDIR)$(prefix)/$$i; \
-       done
-       echo $(INSTALL_DATA) README.txt $(DESTDIR)$(prefix)/README.txt
-       $(INSTALL_DATA) README.txt $(DESTDIR)$(prefix)/README.txt
-
-install-doc-new:
-       @$(srcdir)/mkinstalldirs $(DESTDIR)$(DOC_DIR)/docs
-       @for i in `find $(srcdir)/docs -type f | grep -v .svn`; do \
-               echo $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
-               $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
-       done
-       @$(srcdir)/mkinstalldirs $(DESTDIR)$(DOC_DIR)/techdoc
-       @for i in `find $(srcdir)/techdoc -type f | grep -v .svn`; do \
-               echo $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
-               $(INSTALL_DATA) $$i $(DESTDIR)$(DOC_DIR)/$$i; \
-       done
-       $(INSTALL_DATA) README.txt $(DESTDIR)$(DOC_DIR)/README.txt
-
-install-exec: all
-       @for i in files; do \
-               $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/$$i; \
-       done
-       @for i in $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS); do \
-               if test -f $$i; then \
-                       echo $(INSTALL) $$i $(DESTDIR)$(prefix)/$$i; \
-                       $(INSTALL) $$i $(DESTDIR)$(prefix)/$$i; \
-               fi \
-       done
-       $(srcdir)/mkinstalldirs $(DESTDIR)$(prefix)/unstripped
-       cp $(SERVER_TARGETS) $(DESTDIR)$(prefix)/unstripped/
-
-       @for i in utilsmenu database_cleanup.sh ; do \
-               if test -f $(srcdir)/$$i; then \
-                       echo $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(prefix)/$$i; \
-                       $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(prefix)/$$i; \
-               fi \
-       done
-
-install-exec-new: all
-       $(srcdir)/mkinstalldirs $(DESTDIR)/usr/sbin; 
-       $(srcdir)/mkinstalldirs $(DESTDIR)/usr/bin; 
-       $(srcdir)/mkinstalldirs $(DESTDIR)/usr/bin; 
-       $(srcdir)/mkinstalldirs $(DESTDIR)$(UTILBIN_DIR); 
-       $(srcdir)/mkinstalldirs $(DESTDIR)$(DOC_DIR);
-       @for i in $(SERVER_TARGETS) $(UTIL_TARGETS); do \
-               if test -f $$i; then \
-                       echo $(INSTALL) $$i $(DESTDIR)/usr/sbin/$$i; \
-                       $(INSTALL) $$i $(DESTDIR)/usr/sbin/$$i; \
-               fi \
-       done
-       cp citserver $(DESTDIR)/$(UTILBIN_DIR)/citserver.unstripped
-       @for i in $(UTILBIN_TARGETS); do \
-               if test -f $$i; then \
-                       echo $(INSTALL) $$i $(DESTDIR)/$(UTILBIN_DIR)/$$i; \
-                       $(INSTALL) $$i $(DESTDIR)/$(UTILBIN_DIR)/$$i; \
-               fi \
-       done
-
-       $(INSTALL) citmail $(DESTDIR)/usr/sbin/sendmail;
-       @for i in utilsmenu database_cleanup.sh; do \
-               if test -f $(srcdir)/$$i; then \
-                       echo $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(DOC_DIR)/$$i; \
-                       $(INSTALL) $(srcdir)/$$i $(DESTDIR)$(DOC_DIR)/$$i; \
-               fi \
-       done
-
-clean:
-       rm -vfr locale/*
-       rm -vf *.o 
-       rm -vf *.o ;\
-       for i in $(srcdir)/modules/* ; do \
-               rm -vf $$i/*.o ;\
-       done
-       if test -d $(srcdir)/user_modules ; then \
-               for i in $(srcdir)/user_modules/* ; do \
-                       rm -vf $$i/*.o ;\
-               done \
-       fi
-       rm -vf $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS) $(NOINST_TARGETS)
-
-cleaner: clean
-       rm -vrf $(SERVER_TARGETS) $(UTIL_TARGETS) $(UTILBIN_TARGETS) $(NOINST_TARGETS) *.la
-       rm -vrf modules_upgrade.c modules_init.c modules_init.h Make_modules Make_sources
-
-distclean: cleaner
-       find . -name '*~' -o -name '.#*' | xargs rm -vf
-       rm -vf po/Makefile 
-       rm -vf Makefile configure sysdep.h config.cache config.log config.status *.d package-version.txt
-       for i in $(srcdir)/modules/* ; do \
-               rm -vf $$i/*.d ;\
-       done
-       if test -d $(srcdir)/user_modules ; then \
-               for i in $(srcdir)/user_modules/* ; do \
-                       rm -vf $$i/*.o ;\
-               done \
-       fi
-
-.c.d:
-       @echo Checking dependencies for $<
-       @$(CC) $(DEPEND_FLAG) $(CPPFLAGS) $< | sed -e 's!$*.o!$*.o $*/.o $@!' > $@
-       @test -s $@ || rm -f $@
-
-Makefile: $(srcdir)/Makefile.in config.status
-       CONFIG_FILES=Makefile CONFIG_HEADERS= $(SHELL) ./config.status
-
-config.status: $(srcdir)/configure
-       $(SHELL) ./config.status --recheck
-
-$(srcdir)/configure: $(srcdir)/configure.ac $(srcdir)/aclocal.m4
-       cd $(srcdir) && $(AUTOCONF)
-
-$(srcdir)/aclocal.m4: $(srcdir)/acinclude.m4
-       cd $(srcdir) && $(ACLOCAL)
-
-buildinfo:
-       echo
-       echo "Dependencies: $(CC) $(DEPEND_FLAG) $(CPPFLAGS) $< | sed -e 's!$*.o!$*.o $*/.o $@!' > $@"
-       echo "Compile: $(CC) $(CFLAGS) $(CPPFLAGS) $(DEFS) -c $< -o $@ "
-       echo "LDFLAGS: $(LDFLAGS)"
-       echo
-
--include $(DEP_FILES)
index 645249bd605221c9f2656945e0d80acf4b0a3d3b..d8b1a591efffb208473e2a485364bf42e9d71377 100644 (file)
@@ -6,7 +6,8 @@
    1. Create a user on your system under which to run Citadel
    2. Install supported versions of the required libraries
    3. ./configure && make && make install
-   4. Run the "setup" program
+   4. Start up the server
+   5. You can log in immediately or you can run setup
  
  * After installing Citadel, you'll probably want to install WebCit
    so that you can access the Citadel system using a web browser.
diff --git a/citadel/configure.ac b/citadel/configure.ac
deleted file mode 100644 (file)
index a6ec3f5..0000000
+++ /dev/null
@@ -1,994 +0,0 @@
-
-
-
-FAIL FAIL FAIL
-
-THIS IS THE OLD CONFIGURE SCRIPT
-
-KEEPING IT HERE FOR REFERENCE AS WE BUILD THE NEW ONE
-
-DONT RUN THIS
-
-
-
-
-
-dnl Process this file with autoconf to produce a configure script.
-AC_PREREQ(2.52)
-
-AC_INIT([Citadel],m4_esyscmd_s([grep REV_LEVEL citadel.h | sed 's/[^0-9]*//g']),[http://uncensored.citadel.org])
-
-AC_REVISION(m4_esyscmd_s([git log --pretty=%h | head -1]))
-
-AC_CONFIG_SRCDIR([citserver.c])
-AC_CONFIG_HEADER([sysdep.h])
-AC_CONFIG_MACRO_DIR([m4])
-AC_PREFIX_DEFAULT(/usr/local/citadel)
-if test "$prefix" = NONE; then
-       AC_DEFINE_UNQUOTED(CTDLDIR, "$ac_default_prefix", [define this to the Citadel home directory])
-       ssl_dir="$ac_default_prefix/keys"
-       localedir=$ac_default_prefix
-else
-       AC_DEFINE_UNQUOTED(CTDLDIR, "$prefix", [define this to the Citadel home directory])
-       ssl_dir="$prefix/keys"
-       localedir=$prefix
-fi
-
-dnl Make sure we see all GNU and Solaris extensions.
-AC_GNU_SOURCE
-
-
-dnl Checks for the Datadir
-AC_ARG_WITH(datadir, 
-                   [  --with-datadir          directory to store the databases under],
-                       [ if test "x$withval" != "xno" ; then
-                                             AC_DEFINE(HAVE_DATA_DIR,[],[use alternate database location?])
-                                             AC_DEFINE_UNQUOTED(DATA_DIR, "$withval",[define, if the user suplied a data-directory to use.])
-                                             MAKE_DATA_DIR=$withval
-                                             AC_SUBST(MAKE_DATA_DIR)
-                         fi
-                       ]
-)
-
-
-dnl Checks for the helpDatadir
-AC_ARG_WITH(helpdir, 
-                   [  --with-helpdir          directory to store the helpfiles under],
-                       [ if test "x$withval" != "xno" ; then
-                                             AC_DEFINE(HAVE_HELP_DIR,[],[use alternate database location?])
-                                             AC_DEFINE_UNQUOTED(HELP_DIR, "$withval",[define, if the user suplied a helpfile-directory to use.])
-                                             MAKE_HELP_DIR=$withval
-                                             AC_SUBST(MAKE_HELP_DIR)
-                         fi
-                       ]
-)
-
-dnl Checks for the Static Datadir
-AC_ARG_WITH(staticdatadir, 
-                   [  --with-staticdatadir    directory to store citadels system messages under],
-                       [ if test "x$withval" != "xno" ; then
-                                                 AC_DEFINE(HAVE_STATICDATA_DIR, [], [should we activate an alternate static text location?])
-                                                 AC_DEFINE_UNQUOTED(STATICDATA_DIR, "$withval", [where do we put our static text data?])
-                                                 MAKE_STATICDATA_DIR=$withval
-                                                 AC_SUBST(MAKE_STATICDATA_DIR)
-                         fi
-                       ]
-)
-
-
-dnl Checks for the SSLdir
-dnl this is a bit different than the rest, 
-dnl because of the citadel used to have a keys/ subdir.
-AC_ARG_WITH(ssldir, 
-                   [  --with-ssldir           directory to store the ssl certificates under],
-                       [ if test "x$withval" != "xno" ; then
-                                             
-                                                 ssl_dir="$withval"
-                         fi
-                       AC_SUBST(MAKE_SSL_DIR)
-                       ]
-)
-AC_DEFINE_UNQUOTED(SSL_DIR, "$ssl_dir", [were should we put our keys?])
-
-
-dnl Checks for the spooldir
-AC_ARG_WITH(spooldir, 
-                       [  --with-spooldir         directory to keep queues under],
-                       [ if test "x$withval" != "xno" ; then
-                                               AC_DEFINE(HAVE_SPOOL_DIR, [], [enable alternate spool dir?])
-                                               AC_DEFINE_UNQUOTED(SPOOL_DIR,"$withval", [where do we place our spool dirs?])
-                                               MAKE_SPOOL_DIR=$withval
-                                               AC_SUBST(MAKE_SPOOL_DIR)
-                          fi
-                       ]
-)
-
-
-dnl Checks for the Configdir
-AC_ARG_WITH(sysconfdir, 
-                       [  --with-sysconfdir       directory to store the configs under],
-                       [ if test "x$withval" != "xno" ; then
-                                           AC_DEFINE(HAVE_ETC_DIR, [], [should we search our system config in an alternate place?])
-                                               AC_DEFINE_UNQUOTED(ETC_DIR, "$withval", [where to search our config files])
-                                               MAKE_ETC_DIR=$withval
-                                               AC_SUBST(MAKE_ETC_DIR)
-                         fi
-                       ]
-)
-
-dnl Checks for the Configdir
-AC_ARG_WITH(autosysconfdir, 
-                       [  --with-autosysconfdir         directory to store the automaticaly maintained configs under],
-                       [ if test "x$withval" != "xno" ; then
-                                           AC_DEFINE(HAVE_AUTO_ETC_DIR, [], [should we search our automatic config in an alternate place?])
-                                               AC_DEFINE_UNQUOTED(AUTO_ETC_DIR, "$withval", [where to search our automatic config files])
-                                               MAKE_AUTO_ETC_DIR=$withval
-                                               AC_SUBST(MAKE_AUTO_ETC_DIR)
-                         fi
-                       ]
-)
-
-dnl Checks for where to put our utilities
-AC_ARG_WITH(utility-bindir, 
-                       [  --with-utility-bindir   directory where to find helper binaries],
-                       [ if test "x$withval" != "xno" ; then
-                                           AC_DEFINE(HAVE_UTILBIN_DIR,[],[should we put our helper binaries to another location?])
-                                               AC_DEFINE_UNQUOTED(UTILBIN_DIR, "$withval", [were to put our helper programs])
-                                               MAKE_UTILBIN_DIR=$withval
-                                               AC_SUBST(MAKE_UTILBIN_DIR)
-                         fi
-                       ]
-)
-
-
-dnl Checks for the run-dir for the sockets
-AC_ARG_WITH(rundir, 
-                       [  --with-rundir           directory to place runtime files (UDS) to?],
-                       [ if test "x$withval" != "xno" ; then
-                                           AC_DEFINE(HAVE_RUN_DIR, [], [should we put our non volatile files elsewhere?])
-                                               AC_DEFINE_UNQUOTED(RUN_DIR, "$withval", [define, where the config should go in unix style])
-                                               MAKE_RUN_DIR=$withval
-                                               AC_SUBST(MAKE_RUN_DIR)
-                         fi
-                       ]
-)
-
-
-AC_ARG_WITH(docdir,
-                       [  --with-docdir           where to install the documentation. default: /usr/local/citadel/],
-                       [ if test "x$withval" != "xno" ; then
-                                       MAKE_DOC_DIR=$withval
-                                       AC_SUBST(MAKE_DOC_DIR)
-                         fi
-                       ]
-)
-
-dnl where to put the locale files
-AC_ARG_WITH(localedir, 
-                   [  --with-localedir          directory to put the locale files to],
-                       [ if test "x$withval" != "xno" ; then
-                           localedir=$withval
-                         fi
-                       ]
-)
-AC_DEFINE_UNQUOTED(LOCALEDIR, "$localedir",[where to find our pot files])
-LOCALEDIR=$localedir
-AC_SUBST(LOCALEDIR)
-
-
-
-dnl Checks for the zlib compression library.
-saved_CFLAGS="$CFLAGS"
-CFLAGS="$CFLAGS $SERVER_LIBS"
-AC_CHECK_HEADER(zlib.h,
-       [AC_CHECK_LIB(z, zlibVersion,
-               [
-                       LIBS="-lz $LIBS $SERVER_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(zlib was not found or is not usable.  Please install zlib.)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(zlib.h was not found or is not usable.  Please install zlib.)
-       ]
-)
-CFLAGS="$saved_CFLAGS"
-
-dnl Checks for the crypt_r function
-saved_CFLAGS="$CFLAGS"
-CFLAGS="$CFLAGS $SERVER_LIBS"
-AC_CHECK_HEADER(crypt.h,
-       [AC_CHECK_LIB(crypt, crypt_r,
-               [
-                       SERVER_LIBS="-lcrypt $SERVER_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(crypt_r was not found or is not usable.)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(crypt.h was not found or is not usable.)
-       ]
-)
-CFLAGS="$saved_CFLAGS"
-
-dnl Here is the check for a libc integrated iconv
-AC_ARG_ENABLE(iconv,
-       [  --disable-iconv         do not use iconv charset conversion],
-       ok_iconv=no, ok_iconv=yes)
-
-AC_MSG_CHECKING(Checking to see if your system supports iconv)
-AC_TRY_RUN([
-       #include <iconv.h>
-       main() {
-               iconv_t ic = (iconv_t)(-1) ;
-               ic = iconv_open("UTF-8", "us-ascii");
-               iconv_close(ic);
-               exit(0);
-       }
- ],
-               [
-                 ok_iconv=yes
-                 AC_MSG_RESULT([yes])
-               ],
-               [ 
-                 ok_iconv=no
-                 AC_MSG_RESULT([no])
-               ]
-)
-
-dnl Check for iconv in external libiconv
-if test "$ok_iconv" = no; then
-       AC_MSG_CHECKING(Checking for an external libiconv)
-       OLD_LDFLAGS="$LDFLAGS"
-       LDFLAGS="$LDFLAGS -liconv"
-       AC_TRY_RUN([
-                       #include <iconv.h>
-                       main() {
-                               iconv_t ic = (iconv_t)(-1) ;
-                               ic = iconv_open("UTF-8", "us-ascii");
-                               iconv_close(ic);
-                       }
-               ],
-                       [
-                         ok_iconv=yes
-                         AC_MSG_RESULT([yes])
-                       ],
-                       [ 
-                         ok_iconv=no
-                         LDFLAGS="$OLD_LDFLAGS"
-                         AC_MSG_RESULT([no])
-                       ]
-               )
-fi
-
-if test "$ok_iconv" != "no"; then
-       AC_MSG_RESULT(Citadel will be built with character set conversion.)
-       AC_DEFINE(HAVE_ICONV,[],[whether we have iconv for charset conversion])
-else
-       AC_MSG_RESULT(Citadel will be built without character set conversion.)
-fi
-
-AC_CHECK_LIB(intl, libintl_bindtextdomain, [LDFLAGS="$LDFLAGS -lintl"])
-
-AC_ARG_ENABLE(pie, [  --enable-pie            build position-independent executables])
-
-AC_ARG_WITH(pam, [  --with-pam              use PAM if present (see PAM.txt before you try this)])
-AC_ARG_WITH(kthread, [  --with-kthread          use kernel threads (on FreeBSD) (not recommended yet)])
-AC_ARG_WITH(db, [  --with-db@<:@=DIR@:>@         use Berkeley DB 3.x @<:@DIR=/usr/local/BerkeleyDB.3.@<:@123@:>@@:>@])
-AC_ARG_WITH(ssl,
-       [  --with-ssl=PATH         Specify path to OpenSSL installation ],
-       [
-               if test "x$withval" != "xno" ; then
-                       tryssldir=$withval
-               fi
-       ]
-)
-
-if test "x$with_db" != xno -a "x$with_db" != xyes -a "$with_db"; then
-       db_dir="$with_db"
-       with_db=yes
-else
-       test -f /usr/local/lib/libdb.a -o -f /usr/local/lib/libdb.so \
-         && db_dir=/usr/local
-fi
-
-AC_CANONICAL_HOST
-PTHREAD_DEFS=-D_REENTRANT
-AC_MSG_CHECKING([how to compile with POSIX threads])
-case "$host" in
-       dnl BSDI 3.0 wants relocatable object modules instead of shared libs
-       dnl for dlopen(), and has a wrapper script to link with shared libs.
-       dnl Also has stupid non-reentrant gethostbyaddr() and friends.
-       *-*-bsdi[123]*)
-               test -z "$CC" -a -x /usr/bin/shlicc2 && CC=shlicc2
-               AC_DEFINE(HAVE_NONREENTRANT_NETDB,[], [define this if the OS has broken non-reentrant gethostby{name,addr}() ])
-               AC_MSG_RESULT([Old BSDI])
-       ;;
-       *-*-bsdi*)
-               AC_DEFINE(HAVE_NONREENTRANT_NETDB, [], [define this if the OS has broken non-reentrant gethostby{name,addr}() ])
-               AC_MSG_RESULT([BSD/OS])
-       ;;
-       dnl Curses support on Mac OS X is kind of screwed at the moment.
-       dnl TCP buffering isn't ideal under OS X. This define should also be
-       dnl checked in other cases of OS X-Linux differences.
-       *-*-darwin*)
-               AC_DEFINE(HAVE_DARWIN, [], [define if using OS X/Darwin])
-               AC_MSG_RESULT([Mac OS X])
-       ;;
-       dnl Digital Unix has an odd way to build for pthreads, and we can't
-       dnl build pthreads programs with gcc due to header problems.
-       alpha*-dec-osf*)
-               test -z "$CC" && CC=cc
-               LIBS="-lpthread -lexc $LIBS"
-               check_pthread=no
-               AC_MSG_RESULT([Tru64 or Digital UNIX])
-       ;;
-       dnl FreeBSD is similar to Digital UNIX with DEC C, which has a -pthread flag:
-       *-*-freebsd*)
-               if test "$with_kthread" = yes; then
-                       LIBS="-kthread $LIBS"
-               else
-                       LIBS="-pthread $LIBS"
-               fi
-               check_pthread=no
-               PTHREAD_DEFS=-D_THREAD_SAFE
-               AC_MSG_RESULT([FreeBSD])
-       ;;
-       *-*-openbsd*)
-               LIBS="-pthread $LIBS"
-               check_pthread=no
-               PTHREAD_DEFS=-pthread
-               AC_MSG_RESULT([OpenBSD])
-       ;;
-       *-*-linux*)
-               PTHREAD_DEFS="-D_REENTRANT -pthread"
-               AC_MSG_RESULT([Linux])
-       ;;
-       *-*-solaris*)
-               PTHREAD_DEFS="-D_REENTRANT -D_PTHREADS"
-               AC_MSG_RESULT([Solaris])
-       ;;
-       *-*-cygwin*)
-               SERVER_LDFLAGS="-Wl,-subsystem,windows"
-               AC_MSG_RESULT([Cygwin])
-       ;;
-       *)
-               AC_MSG_RESULT([default])
-       ;;
-esac
-dnl DEFS="$DEFS $PTHREAD_DEFS"
-
-
-dnl Checks for programs.
-AC_PROG_CC
-
-
-
-dnl Set up system-dependent compiler flags.
-if test "$GCC" = yes; then
-       if test "$CC" = icc; then
-               CFLAGS="$CFLAGS -w1"
-       else
-               case "$host" in
-                       *-*-solaris*|alpha*-dec-osf*)
-                               CFLAGS="$CFLAGS -Wall -Wcast-qual -Wcast-align -Wno-char-subscripts $PTHREAD_DEFS"
-                       ;;
-                       *)
-                       CFLAGS="$CFLAGS -Wall -Wcast-qual -Wcast-align -Wstrict-prototypes -Wno-strict-aliasing $PTHREAD_DEFS"
-                       ;;
-               esac
-       fi
-fi
-
-if test "x$enable_pie" = xyes; then
-       save_CFLAGS="$CFLAGS"
-       save_LDFLAGS="$LDFLAGS"
-       CFLAGS="$CFLAGS -fpie"
-       LDFLAGS="$LDFLAGS -pie -fpie"
-       AC_CACHE_CHECK([whether compiler accepts -pie -fpie], ac_cv_pie_fpie,
-       [AC_TRY_LINK([], [],
-       ac_cv_pie_fpie=yes, ac_cv_pie_fpie=no)])
-       if test $ac_cv_pie_fpie = no; then
-               CFLAGS="$save_CFLAGS"
-               LDFLAGS="$save_LDFLAGS"
-       fi
-fi
-
-AC_MSG_CHECKING([how to create dependancy checks])
-        if test -n "`$CC -V 2>&1 |grep Sun`"; then 
-               DEPEND_FLAG=-xM;
-        else 
-               DEPEND_FLAG=-M
-         fi
-AC_SUBST(DEPEND_FLAG)
-
-
-AC_PROG_INSTALL
-AC_PROG_YACC
-AC_PATH_PROG(DIFF,diff)
-AC_PATH_PROG(PATCH,patch)
-missing_dir=`cd $ac_aux_dir && pwd`
-AM_MISSING_PROG(AUTOCONF, autoconf, $missing_dir)
-AM_MISSING_PROG(ACLOCAL, aclocal, $missing_dir)
-
-dnl Checks for system services.
-
-dnl Check the size of various builtin types; see typesize.h (error)
-AC_CHECK_SIZEOF(char, 0)
-AC_CHECK_SIZEOF(short, 0)
-AC_CHECK_SIZEOF(int, 0)
-AC_CHECK_SIZEOF(long, 0)
-AC_CHECK_SIZEOF(size_t, 0)
-AC_CHECK_SIZEOF(loff_t, 0)
-dnl AC_CHECK_SIZEOF(long long, 0)
-
-dnl Checks for libraries.
-
-dnl We want to test for the following in libc before checking for their
-dnl respective libraries, because some systems (like Irix) have both, and the
-dnl non-libc versions may be broken.
-AC_CHECK_FUNCS(crypt gethostbyname connect getpwnam_r getpwuid_r getloadavg)
-
-AC_CHECK_FUNCS(strftime_l uselocale gettext)
-
-if test "$ok_nls" != "no"; then
-       AC_CHECK_PROG(ok_xgettext, xgettext, yes, no)
-       ok_nls=$ok_xgettext
-fi
-
-if test "$ok_nls" != "no"; then
-       AC_CHECK_PROG(ok_msgmerge, msgmerge, yes, no)
-       ok_nls=$ok_msgmerge
-fi
-
-if test "$ok_nls" != "no"; then
-       AC_CHECK_PROG(ok_msgfmt, msgfmt, yes, no)
-       ok_nls=$ok_msgfmt
-fi
-
-if test "$ok_nls" != "no"; then
-       AC_MSG_RESULT(citadel will be built with national language support.)
-       AC_DEFINE(ENABLE_NLS, [], [whether we have NLS support])
-       PROG_SUBDIRS="$PROG_SUBDIRS po/citadel-setup"
-else
-       AC_MSG_RESULT(citadel will be built without national language support.)
-fi
-
-dnl disable backtrace if we don't want it.
-AC_ARG_WITH(backtrace, 
-    [  --with-backtrace        enable backtrace dumps in the syslog],
-       [ if test "x$withval" != "xno" ; then
-            CFLAGS="$CFLAGS  -rdynamic "
-            LDFLAGS="$LDFLAGS  -rdynamic "
-            SERVER_LDFLAGS="$SERVER_LDFLAGS  -rdynamic "
-                           AC_CHECK_FUNCS(backtrace)
-         fi
-       ]
-)
-
-dnl disable backtrace if we don't want it.
-AC_ARG_WITH(gprof, 
-           [  --with-gprof            enable profiling],
-               [ if test "x$withval" != "xno" ; then
-                    CFLAGS="$CFLAGS  -pg "
-                    LDFLAGS="$LDFLAGS  -pg "
-                    SERVER_LDFLAGS="$SERVER_LDFLAGS  -pg "
-                 fi
-               ]
-)
-
-if test "$ac_cv_func_gethostbyname" = no; then
-       AC_CHECK_LIB(nsl, gethostbyname)
-fi
-
-if test "$ac_cv_func_connect" = no; then
-        AC_CHECK_LIB(socket, connect)
-fi
-
-dnl Check for Solaris realtime support
-AC_CHECK_LIB(rt, sched_yield)
-
-dnl Determine the system's authentication capabilities.
-dnl We currently support PAM, standard getpwnam(), and getspnam()
-dnl (Linux shadow passwords)
-
-save_LIBS=$LIBS
-AC_CHECK_LIB(pam, pam_start, [chkpwd_LIBS="-lpam $chkpwd_LIBS"
-       LIBS="-lpam $LIBS"])
-AC_CHECK_FUNCS(pam_start)
-test "$enable_chkpwd" != no && LIBS=$save_LIBS
-       if test "$ac_cv_func_pam_start" = no -o "$with_pam" != yes; then
-               save_LIBS=$LIBS
-               AC_SEARCH_LIBS(getspnam, shadow, [
-                       if test "$ac_cv_search_getspnam" = -lshadow; then
-                               chkpwd_LIBS="-lshadow $chkpwd_LIBS"
-                       fi])
-               test "$enable_chkpwd" != no && LIBS=$save_LIBS
-               if test "$ac_cv_func_crypt" = no; then
-                       AC_CHECK_LIB(crypt, crypt, [
-                               chkpwd_LIBS="-lcrypt $chkpwd_LIBS"
-                               test "$enable_chkpwd" = no && \
-                                       LIBS="-lcrypt $LIBS"])
-               fi
-       fi
-
-AC_CHECK_FUNCS(vw_printw wcolor_set resizeterm wresize)
-
-dnl Check for libpthread(s) if we're not using Digital UNIX or FreeBSD. (On
-dnl which the -pthread flag takes care of this.)
-if test "$check_pthread" != no; then
-       AC_CHECK_LIB(pthread, pthread_create)
-       AC_CHECK_LIB(pthreads, pthread_create)
-fi
-
-test -d /usr/kerberos/include && CPPFLAGS="$CPPFLAGS -I/usr/kerberos/include"
-
-dnl Checks for the libical iCalendar library.
-AC_CHECK_HEADER(libical/ical.h,
-       [AC_CHECK_LIB(ical, icaltimezone_set_tzid_prefix,
-               [
-                       SERVER_LIBS="-lical $SERVER_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(libical was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(libical/ical.h was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-       ]
-)
-
-
-saved_CFLAGS="$CFLAGS"
-CFLAGS="$CFLAGS $SERVER_LIBS"
-dnl Check for libcitadel
-AC_CHECK_HEADER(libcitadel.h,
-       [AC_CHECK_LIB(citadel, libcitadel_version_string,
-               [
-                       LIBS="-lcitadel $LIBS $SERVER_LIBS"
-                       chkpwd_LIBS="-lcitadel $chkpwd_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(libcitadel was not found or is not usable.  Please install libcitadel.)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(libcitadel.h was not found or is not usable.  Please install libcitadel.)
-       ]
-)
-CFLAGS="$saved_CFLAGS"
-
-
-# The big search for OpenSSL
-if test "$with_ssl" != "no"; then
-       saved_LIBS="$LIBS"
-       saved_LDFLAGS="$LDFLAGS"
-       saved_CFLAGS="$CFLAGS"
-       if test "x$prefix" != "xNONE"; then
-               tryssldir="$tryssldir $prefix"
-       fi
-       AC_CACHE_CHECK([for OpenSSL], ac_cv_openssldir, [
-               for ssldir in $tryssldir "" /usr /usr/local/openssl /usr/lib/openssl /usr/local/ssl /usr/lib/ssl /usr/local /usr/pkg /opt /opt/openssl ; do
-                       CFLAGS="$saved_CFLAGS"
-                       LDFLAGS="$saved_LDFLAGS"
-                       LIBS="$saved_LIBS -lssl -lcrypto"
-       
-                       # Skip directories if they don't exist
-                       if test ! -z "$ssldir" -a ! -d "$ssldir" ; then
-                               continue;
-                       fi
-                       if test ! -z "$ssldir" -a "x$ssldir" != "x/usr"; then
-                               # Try to use $ssldir/lib if it exists, otherwise
-                               # $ssldir
-                               if test -d "$ssldir/lib" ; then
-                                       LDFLAGS="-L$ssldir/lib $saved_LDFLAGS"
-                                       if test ! -z "$need_dash_r" ; then
-                                               LDFLAGS="-R$ssldir/lib $LDFLAGS"
-                                       fi
-                               else
-                                       LDFLAGS="-L$ssldir $saved_LDFLAGS"
-                                       if test ! -z "$need_dash_r" ; then
-                                               LDFLAGS="-R$ssldir $LDFLAGS"
-                                       fi
-                               fi
-                               # Try to use $ssldir/include if it exists, otherwise
-                               # $ssldir
-                               if test -d "$ssldir/include" ; then
-                                       CFLAGS="-I$ssldir/include $saved_CFLAGS"
-                               else
-                                       CFLAGS="-I$ssldir $saved_CFLAGS"
-                               fi
-                       fi
-       
-                       # Basic test to check for compatible version and correct linking
-                       # *does not* test for RSA - that comes later.
-                       AC_TRY_RUN(
-                               [
-       #include <string.h>
-       #include <openssl/rand.h>
-       int main(void)
-       {
-               char a[2048];
-               memset(a, 0, sizeof(a));
-               RAND_add(a, sizeof(a), sizeof(a));
-               return(RAND_status() <= 0);
-       }
-                               ],
-                               [
-                                       found_crypto=1
-                                       break;
-                               ], []
-                       )
-       
-                       if test ! -z "$found_crypto" ; then
-                               break;
-                       fi
-               done
-       
-               if test -z "$ssldir" ; then
-                       ssldir="(system)"
-               fi
-       
-               if test ! -z "$found_crypto" ; then
-                       ac_cv_openssldir=$ssldir
-               else
-                       ac_cv_openssldir="no"
-               fi
-       ])
-       LIBS="$saved_LIBS"
-       LDFLAGS="$saved_LDFLAGS"
-       CFLAGS="$saved_CFLAGS"
-       
-       if test "x$ac_cv_openssldir" != "xno" ; then
-               AC_DEFINE(HAVE_OPENSSL, [], [Define if you have OpenSSL.])
-               LIBS="-lssl -lcrypto $LIBS"
-               dnl Need to recover ssldir - test above runs in subshell
-               ssldir=$ac_cv_openssldir
-               if test ! -z "$ssldir" -a "x$ssldir" != "x/usr" -a "x$ssldir" != "x(system)"; then
-                       # Try to use $ssldir/lib if it exists, otherwise
-                       # $ssldir
-                       if test -d "$ssldir/lib" ; then
-                               LDFLAGS="-L$ssldir/lib $saved_LDFLAGS"
-                               if test ! -z "$need_dash_r" ; then
-                                       LDFLAGS="-R$ssldir/lib $LDFLAGS"
-                               fi
-                       else
-                               LDFLAGS="-L$ssldir $saved_LDFLAGS"
-                               if test ! -z "$need_dash_r" ; then
-                                       LDFLAGS="-R$ssldir $LDFLAGS"
-                               fi
-                       fi
-                       # Try to use $ssldir/include if it exists, otherwise
-                       # $ssldir
-                       if test -d "$ssldir/include" ; then
-                               CFLAGS="-I$ssldir/include $saved_CFLAGS"
-                       else
-                               CFLAGS="-I$ssldir $saved_CFLAGS"
-                       fi
-               fi
-       fi
-fi
-
-if test "x$with_db" != xno; then
-       test "$db_dir" && LDFLAGS="$LDFLAGS -L$db_dir/lib"
-
-       dblib=""
-
-       if test "$db_dir"; then
-               CPPFLAGS="$CPPFLAGS -I$db_dir/include"
-       fi
-
-
-       AC_CHECK_DB([db],
-                   [
-                    DATABASE=database.c
-                   ],
-                   AC_MSG_ERROR([[Can not locate a suitable Berkeley DB
-                                 library.  Use --with-db=PATH to specify
-                                 the path]]))
-
-fi
-
-
-dnl Checks for the OpenLDAP client library.
-AC_CHECK_HEADER(ldap.h,
-       [AC_CHECK_LIB(ldap, ldap_initialize,
-               [
-                       SERVER_LIBS="-lldap $SERVER_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(OpenLDAP development library was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(OpenLDAP development headers were not found and are required.  More info: http://www.citadel.org/doku.php/installation:start)
-       ]
-)
-
-
-dnl Checks for the Expat XML parser.
-AC_CHECK_HEADER(expat.h,
-       [AC_CHECK_LIB(expat, XML_ParserCreateNS,
-               [
-                       SERVER_LIBS="-lexpat $SERVER_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(The Expat XML parser was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(expat.h was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-       ]
-)
-
-
-dnl Checks for libcurl.
-AC_CHECK_HEADER(curl/curl.h,
-       [AC_CHECK_LIB(curl, curl_version,
-               [
-                       SERVER_LIBS="-lcurl $SERVER_LIBS"
-               ],
-               [
-                       AC_MSG_ERROR(libcurl was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-               ]
-       ,
-       )],
-       [
-               AC_MSG_ERROR(curl/curl.h was not found and is required.  More info: http://www.citadel.org/doku.php/installation:start)
-       ]
-)
-
-
-dnl Checks for header files.
-AC_HEADER_DIRENT
-AC_HEADER_STDC
-AC_HEADER_SYS_WAIT
-
-dnl
-dnl TODO: for the DB header checks, we should check whether the headers
-dnl define db_env_create, somehow
-dnl
-AC_CHECK_HEADERS(dl.h fcntl.h limits.h malloc.h termios.h sys/ioctl.h sys/select.h sys/stat.h sys/time.h sys/prctl.h syslog.h unistd.h utmp.h utmpx.h paths.h db.h pthread.h netinet/in.h arpa/nameser.h arpa/nameser_compat.h syscall.h sys/syscall.h)
-
-AC_CHECK_HEADER(resolv.h,AC_DEFINE(HAVE_RESOLV_H, [], [define this if you have the resolv.h header file.]),,
-[#ifdef HAVE_SYS_TYPES_H
-#include <sys/types.h>
-#endif
-#ifdef HAVE_NETINET_IN_H
-#include <netinet/in.h>
-#endif
-#ifdef HAVE_ARPA_NAMESER_H
-#include <arpa/nameser.h>
-#endif])
-
-
-dnl Checks for typedefs, structures, and compiler characteristics.
-AC_C_CONST
-AC_TYPE_PID_T
-AC_TYPE_SIZE_T
-AC_HEADER_TIME
-
-dnl defined in acinclude.m4:
-CIT_STRUCT_TM
-
-AC_CACHE_CHECK([for ut_type in struct utmp], ac_cv_struct_ut_type,
-[AC_TRY_COMPILE([#include <sys/types.h>
-#include <utmp.h>], [struct utmp ut; ut.ut_type;],
-ac_cv_struct_ut_type=yes, ac_cv_struct_ut_type=no)])
-if test $ac_cv_struct_ut_type = yes; then
-       AC_DEFINE(HAVE_UT_TYPE, [], [define this if struct utmp has an ut_type member])
-fi
-
-AC_CACHE_CHECK(
-       [for call semantics from getpwuid_r], 
-       ac_cv_call_getpwuid_r,
-       [AC_TRY_COMPILE([#include <sys/types.h>
-#include <pwd.h>], 
-                         [
-                               struct passwd pw, *pwp;
-                               char pwbuf[64];
-                               uid_t uid;
-
-                               getpwuid_r(uid, &pw, pwbuf, sizeof(pwbuf), &pwp);
-                       ],
-                       ac_cv_call_getpwuid_r=yes, 
-                       ac_cv_call_getpwuid_r=no)
-       ])
-
-if test $ac_cv_call_getpwuid_r = no; then
-       AC_DEFINE(SOLARIS_GETPWUID,[],[do we need to use solaris call syntax?])
-       AC_DEFINE(F_UID_T, "%ld", [whats the matching format string for uid_t?])
-       AC_DEFINE(F_PID_T, "%ld",  [whats the matching format string for pid_t?])
-       AC_DEFINE(F_XPID_T, "%lx",  [whats the matching format string for xpid_t?])
-else
-       AC_DEFINE(F_UID_T, "%d",  [whats the matching format string for uid_t?])
-       AC_DEFINE(F_PID_T, "%d",  [whats the matching format string for pid_t?])
-       AC_DEFINE(F_XPID_T, "%x",  [whats the matching format string for xpid_t?])
-fi
-
-
-dnl Our own happy little check for the resolver library.
-
-case "`uname -a`" in 
- OpenBSD*)
-       echo "we don't need to check for resolv on openbsd"  
-       ;;
- FreeBSD*)
-       echo "we don't need to check for resolv on freeBSD"  
-       ;;
- *)
-       test -f /usr/local/lib/libresolv.a && LDFLAGS="$LDFLAGS -L/usr/local/lib"
-       AC_CHECK_LIB(resolv, res_query,
-               RESOLV="$RESOLV -lresolv",
-               [dnl Have to include resolv.h as res_query is sometimes defined as a macro
-                       AC_MSG_CHECKING([for res_query in -lresolv (with resolv.h if present)])
-                       saved_libs="$LIBS"
-                       LIBS="-lresolv $LIBS"
-                       AC_TRY_LINK([
-                               #ifdef HAVE_RESOLV_H
-                               #include <resolv.h>
-                               #endif],
-                               [res_query(0,0,0,0,0)],
-                               [AC_MSG_RESULT(yes)
-                                               have_res_query=yes],
-                               [AC_MSG_RESULT(no)
-                                       AC_MSG_ERROR(libresolv was not found.  Citadel requires the resolver library.)
-                               ])
-         ]
-       )
-       ;;
-esac
-
-
-
-AC_CACHE_CHECK([for ut_host in struct utmp], ac_cv_struct_ut_host,
-[AC_TRY_COMPILE([#include <sys/types.h>
-#include <utmp.h>], [struct utmp ut; ut.ut_host;],
-ac_cv_struct_ut_host=yes, ac_cv_struct_ut_host=no)])
-if test $ac_cv_struct_ut_host = yes; then
-       AC_DEFINE(HAVE_UT_HOST, [], [define this if struct utmp has an ut_host member])
-fi
-
-dnl Checks for library functions.
-AC_FUNC_GETPGRP
-AC_PROG_GCC_TRADITIONAL
-AC_TYPE_SIGNAL
-AC_FUNC_VPRINTF
-AC_CHECK_FUNCS(getspnam getutxline mkdir mkfifo mktime rmdir select socket strerror strcasecmp strncasecmp)
-
-dnl Now check for pthreads
-
-dnl On some platforms, AC_CHECK_FUNC[S] doesn't work for pthreads programs;
-dnl we need to include pthread.h
-
-AC_CACHE_CHECK([for pthread_cancel], ac_cv_func_pthread_cancel,
-[AC_TRY_LINK([#include <pthread.h>],
-[      pthread_t thread;
-
-       /* The GNU C library defines this for functions which it implements
-          to always fail with ENOSYS.  Some functions are actually named
-          something starting with __ and the normal name is an alias.  */
-#if defined (__stub_pthread_cancel) || defined (__stub___pthread_cancel)
-       choke me
-#else
-       pthread_cancel(thread);
-#endif],
-ac_cv_func_pthread_cancel=yes, ac_cv_func_pthread_cancel=no)])
-if test "$ac_cv_func_pthread_cancel" = yes; then
-       AC_DEFINE(HAVE_PTHREAD_CANCEL, [], [define this if you have the pthread_cancel() function])
-fi
-
-AC_CACHE_CHECK([for pthread_create], ac_cv_func_pthread_create,
-[AC_TRY_LINK([#include <pthread.h>],
-[      /* The GNU C library defines this for functions which it implements
-          to always fail with ENOSYS.  Some functions are actually named
-          something starting with __ and the normal name is an alias.  */
-#if defined (__stub_pthread_cancel) || defined (__stub___pthread_cancel)
-       choke me
-#else
-       pthread_create(NULL, NULL, NULL, NULL);
-#endif],
-ac_cv_func_pthread_create=yes, ac_cv_func_pthread_create=no)])
-if test "$ac_cv_func_pthread_create" = yes; then
-       test "$DATABASE" && TARGETS="server utils"
-fi
-
-AC_CACHE_CHECK([the weather], ac_cv_weather, [
-       sleep 1
-       echo $ECHO_N "opening your window... $ECHO_C" >&6
-       sleep 2
-       month=`date | cut -f 2 -d ' '`
-       case $month in
-       Dec | Jan | Feb)
-               ac_cv_weather="it's cold!"
-               ;;
-       Mar | Apr)
-               ac_cv_weather="it's wet!"
-               ;;
-       Jul | Aug)
-               ac_cv_weather="it's hot!"
-               ;;
-       Oct | Nov)
-               ac_cv_weather="it's cool"
-               ;;
-       May | Jun | Sep | *)
-               ac_cv_weather="it's fine"
-               ;;
-       esac
-       ])
-
-
-AC_CACHE_CHECK([under the bed], ac_cv_under_the_bed, [
-       number=`date | cut -c 19`
-       case $number in
-       7)
-               ac_cv_under_the_bed="lunatics and monsters found"
-               ;;
-       *)
-               ac_cv_under_the_bed="dust bunnies found"
-               ;;
-       esac
-       ])
-
-
-STRUCT_UCRED
-
-dnl Done! Now write the Makefile and sysdep.h
-AC_SUBST(RESOLV)
-AC_SUBST(chkpwd_LIBS)
-AC_SUBST(TARGETS)
-AC_SUBST(DATABASE)
-AC_SUBST(SERVER_LDFLAGS)
-AC_SUBST(SERVER_LIBS)
-AC_SUBST(SETUP_LIBS)
-AC_SUBST(DIFF)
-AC_SUBST(PATCH)
-AC_CONFIG_FILES([Makefile])
-AC_OUTPUT(po/citadel-setup/Makefile)
-
-if test -z "$DATABASE"; then
-       AC_MSG_WARN([No database driver was found. Please install Berkeley DB.])
-fi
-
-abs_srcdir="`cd $srcdir && pwd`"
-abs_builddir="`pwd`"
-if test "$abs_srcdir" != "$abs_builddir"; then
-   ln -sf $abs_srcdir/include $abs_builddir
-   ln -sf $abs_srcdir/Make_sources $abs_builddir
-   ln -sf $abs_srcdir/Make_modules $abs_builddir
-   for i in $abs_srcdir/*.h ; do
-      if test "$abs_srcdir/sysdep.h" != "$i"; then
-         ln -sf $i $abs_builddir
-      fi
-   done
-   for d in `/bin/ls $abs_srcdir/modules/`; do 
-       (mkdir -p $abs_builddir/modules/$d) 
-   done
-   if test -d "$abs_srcdir/user_modules/"; then
-      for d in `/bin/ls $abs_srcdir/user_modules/`; do 
-       (mkdir -p $abs_builddir/user_modules/$d) 
-       done
-   fi
-   mkdir -p $abs_builddir/utils
-   mkdir -p $abs_builddir/utillib
-fi
-
-if test -n "$srcdir"; then 
-   export srcdir=.
-fi
-
-
-echo ------------------------------------------------------------------------
-echo 'Character set conversion support:' $ok_iconv
-echo 
-echo 'Note: if you are not using Linux, make sure you are using GNU make'
-echo '(gmake) to compile Citadel.'
-echo
diff --git a/citadel/license.txt b/citadel/license.txt
new file mode 100644 (file)
index 0000000..9192340
--- /dev/null
@@ -0,0 +1,675 @@
+
+Copyright: (C) 1987-2022 Citadel development team; GPL V3
+
+* As a special exception, it is officialy resolved that our
+  favorite type of software is called "open source" -- NOT "free
+  software" -- and that our favorite operating system is called
+  "Linux" -- NOT "GNU/Linux".
+
+* We reject and oppose Richard M. Stallman because he contributes
+  nothing but trouble to the open source community.
+
+* As a special exception, the copyright holders of the Citadel
+  system grant permission to link Citadel with non-GPL-compatible
+  libraries, including OpenSSL, in the sole case that such linking
+  is done to build the Citadel system itself.
+
+                       GENERAL PUBLIC LICENSE
+                       Version 3, 29 June 2007
+
+                            Preamble
+
+  The General Public License is an open source license for 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,
+the General Public License is intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains open
+source for all its users.  The Free Software Foundation uses the
+General Public License for most of its software; it applies also to
+any other work released this way by its authors.  You can apply it to
+your programs, too.
+
+  When we speak of free software, we are referring to freedom, not
+price.  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.
+
+  To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights.  Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
+
+  For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received.  You must make sure that they, too, receive
+or can get the source code.  And you must show them these terms so they
+know their rights.
+
+  Developers that use the GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+  For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this open source software.  For both users'
+and authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+  Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so.  This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software.  The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable.  Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products.  If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+  Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to an open source program
+could make it effectively proprietary.  To prevent this, the GPL assures
+that patents cannot be used to render the program closed-source.
+
+  The precise terms and conditions for copying, distribution and
+modification follow.
+
+                       TERMS AND CONDITIONS
+
+  0. Definitions.
+
+  "This License" refers to version 3 of the 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 open
+source 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. Use with the Affero General Public License.
+
+  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 Affero 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 special requirements of the Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+  14. Revised Versions of this License.
+
+  The Free Software Foundation may publish revised and/or new versions of
+the 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 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
+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 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
+
+
+
+
+
+CRC16 license:
+
+   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 Indigo Systems Corporation 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.
+
+MD5 license:
+
+   This code was written by Colin Plumb in 1993, no copyright is claimed.
+   This code is in the public domain; do with it what you wish.
+
+Copyright for CRC16: (C) 2002-2003 Indigo Systems Corporation; 
+         Artistic license + Non advertising clause
+
+Copyright for MD5 implementation: (C) 1993 Colin Plumb; Public Domain
+
diff --git a/citadel/mkinstalldirs b/citadel/mkinstalldirs
deleted file mode 100755 (executable)
index f945dbf..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-#! /bin/sh
-# mkinstalldirs --- make directory hierarchy
-# Author: Noah Friedman <friedman@prep.ai.mit.edu>
-# Created: 1993-05-16
-# Public domain
-
-errstatus=0
-
-for file
-do
-   set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'`
-   shift
-
-   pathcomp=
-   for d
-   do
-     pathcomp="$pathcomp$d"
-     case "$pathcomp" in
-       -* ) pathcomp=./$pathcomp ;;
-     esac
-
-     if test ! -d "$pathcomp"; then
-        echo "mkdir $pathcomp" 1>&2
-
-        mkdir "$pathcomp" || lasterr=$?
-
-        if test ! -d "$pathcomp"; then
-         errstatus=$lasterr
-        fi
-     fi
-
-     pathcomp="$pathcomp/"
-   done
-done
-
-exit $errstatus
-
-# mkinstalldirs ends here
index f4c2b6c6fb198476080b2b5930c8a9084335ba14..95cf32511e2894810088e2b34630039a1c040b70 100644 (file)
@@ -38,8 +38,8 @@
 #define file_pid_paniclog              "panic.log"
 #define file_crpt_file_key             "keys/citadel.key"
 #define file_crpt_file_cer             "keys/citadel.cer"
-#define file_chkpwd                    "chkpwd"
-#define file_guesstimezone             "guesstimezone.sh"
+#define file_chkpwd                    CTDLDIR "chkpwd"
+#define file_guesstimezone             CTDLDIR "guesstimezone.sh"
 
 
 // externs
diff --git a/citadel/server/modules/autocompletion/.gitignore b/citadel/server/modules/autocompletion/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/bio/.gitignore b/citadel/server/modules/bio/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
index cf3823210911fd2af59c242478815ca0b53f1cdb..6ccce90c1eddb0ebbb3b46d4a568cd664be3a055 100644 (file)
@@ -1,33 +1,23 @@
-/*
- * This module implements server commands related to the display and
- * manipulation of user "bio" files.
- *
- * Copyright (c) 1987-2022 by the citadel.org team
- *
- * This program is open source 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.
- */
-
-#include "../../ctdl_module.h"
-#include "../../config.h"
+// This module implements server commands related to the display and
+// manipulation of user profiles (also known as "bio" files).
+//
+// Copyright (c) 1987-2022 by the citadel.org team
+//
+// This program is open source software.  Use, duplication, or disclosure
+// is subject to the terms of the GNU General Public License, version 3.
+// The program is distributed without any warranty, expressed or implied.
 
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <dirent.h>
 
+#include "../../ctdl_module.h"
+#include "../../config.h"
+
 
-/*
- * Command to enter user bio (profile) in plain text.
- * This is deprecated , or at least it will be when its replacement is written  :)
- * I want commands to get/set bio in full MIME wonderfulness.
- */
+// Command to enter user bio (profile) in plain text.
+// This is deprecated , or at least it will be when its replacement is written  :)
+// I want commands to get/set bio in full MIME wonderfulness.
 void cmd_ebio(char *cmdbuf) {
        char buf[SIZ];
 
@@ -46,7 +36,7 @@ void cmd_ebio(char *cmdbuf) {
                StrBufAppendBufPlain(NewProfile, HKEY("\n"), 0);
        }
 
-       /* we have read the new profile from the user , now save it */
+       // we have read the new profile from the user , now save it
        long old_msgnum = CC->user.msgnum_bio;
        char userconfigroomname[ROOMNAMELEN];
        CtdlMailboxName(userconfigroomname, sizeof userconfigroomname, &CC->user, USERCONFIGROOM);
@@ -62,13 +52,10 @@ void cmd_ebio(char *cmdbuf) {
 }
 
 
-/*
- * Command to read user bio (profile) in plain text.
- * This is deprecated , or at least it will be when its replacement is written  :)
- * I want commands to get/set bio in full MIME wonderfulness.
- */
-void cmd_rbio(char *cmdbuf)
-{
+// Command to read user bio (profile) in plain text.
+// This is deprecated , or at least it will be when its replacement is written  :)
+// I want commands to get/set bio in full MIME wonderfulness.
+void cmd_rbio(char *cmdbuf) {
        struct ctdluser ruser;
        char buf[SIZ];
 
@@ -91,11 +78,8 @@ void cmd_rbio(char *cmdbuf)
 }
 
 
-/*
- * Import function called by import_old_bio_files() for a single user
- */
-void import_one_bio_file(char *username, long usernum, char *path)
-{
+// Import function called by import_old_bio_files() for a single user
+void import_one_bio_file(char *username, long usernum, char *path) {
        syslog(LOG_DEBUG, "Import legacy bio for %s, usernum=%ld, filename=%s", username, usernum, path);
 
        FILE *fp = fopen(path, "r");
@@ -139,11 +123,8 @@ void import_one_bio_file(char *username, long usernum, char *path)
 }
 
 
-/*
- * Look for old-format "bio" files and import them into the message base
- */
-void import_old_bio_files(void)
-{
+// Look for old-format "bio" files and import them into the message base
+void import_old_bio_files(void) {
        DIR *filedir = NULL;
        struct dirent *filedir_entry;
        size_t d_namelen;
@@ -153,14 +134,12 @@ void import_old_bio_files(void)
        struct stat s;
        char path[PATH_MAX];
 
-
        syslog(LOG_DEBUG, "Importing old style bio files into the message base");
        filedir = opendir("bio");
        if (filedir == NULL) {
                return;
        }
-       while ( (filedir_entry = readdir(filedir)) , (filedir_entry != NULL))
-       {
+       while ( (filedir_entry = readdir(filedir)) , (filedir_entry != NULL)) {
 #ifdef _DIRENT_HAVE_D_NAMLEN
                d_namelen = filedir_entry->d_namlen;
 
@@ -222,6 +201,6 @@ char *ctdl_module_init_bio(void) {
                CtdlRegisterProtoHook(cmd_ebio, "EBIO", "Enter your bio");
                CtdlRegisterProtoHook(cmd_rbio, "RBIO", "Read a user's bio");
        }
-       /* return our module name for the log */
+       // return our module name for the log
         return "bio";
 }
diff --git a/citadel/server/modules/calendar/.gitignore b/citadel/server/modules/calendar/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/checkpoint/.gitignore b/citadel/server/modules/checkpoint/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/clamav/.gitignore b/citadel/server/modules/clamav/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/crypto/.gitignore b/citadel/server/modules/crypto/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/expire/.gitignore b/citadel/server/modules/expire/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/fulltext/.gitignore b/citadel/server/modules/fulltext/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/imap/.gitignore b/citadel/server/modules/imap/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/inboxrules/.gitignore b/citadel/server/modules/inboxrules/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/inetcfg/.gitignore b/citadel/server/modules/inetcfg/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/instmsg/.gitignore b/citadel/server/modules/instmsg/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/listsub/.gitignore b/citadel/server/modules/listsub/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/migrate/.gitignore b/citadel/server/modules/migrate/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/newuser/.gitignore b/citadel/server/modules/newuser/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/notes/.gitignore b/citadel/server/modules/notes/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/openid/.gitignore b/citadel/server/modules/openid/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/pop3/.gitignore b/citadel/server/modules/pop3/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/pop3client/.gitignore b/citadel/server/modules/pop3client/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/roomchat/.gitignore b/citadel/server/modules/roomchat/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/rssclient/.gitignore b/citadel/server/modules/rssclient/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/rwho/.gitignore b/citadel/server/modules/rwho/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/smtp/.gitignore b/citadel/server/modules/smtp/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/spam/.gitignore b/citadel/server/modules/spam/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/test/.gitignore b/citadel/server/modules/test/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/upgrade/.gitignore b/citadel/server/modules/upgrade/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/vcard/.gitignore b/citadel/server/modules/vcard/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/wiki/.gitignore b/citadel/server/modules/wiki/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
diff --git a/citadel/server/modules/xmpp/.gitignore b/citadel/server/modules/xmpp/.gitignore
deleted file mode 100644 (file)
index 5761abc..0000000
+++ /dev/null
@@ -1 +0,0 @@
-*.o
index 966c769fc75c5b0adc89e6596143d0431f146d49..9fdb98c59becb4780d13dd7d646e270abc86f4ca 100644 (file)
@@ -26,50 +26,50 @@ int threading = 0;
 
 void initialize_modules(int is_threading) {
        threading = is_threading;
-       syslog(LOG_DEBUG, "modules: begin initializing modules (threading=%d)", threading);
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_control());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_euidindex());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_msgbase());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_database());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_autocompletion());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_bio());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_blog());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_calendar());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_checkpoint());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_virus());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_file_ops());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_ctdl_message());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_rooms());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_serv_session());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_syscmd());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_serv_user());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_expire());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_fulltext());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_image());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_imap());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_sieve());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_inetcfg());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_instmsg());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_listdeliver());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_listsub());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_migrate());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_newuser());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_nntp());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_notes());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_openid_rp());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_pop3());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_pop3client());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_roomchat());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_rssclient());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_rwho());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_smtp());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_smtpclient());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_spam());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_test());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_upgrade());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_vcard());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_wiki());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_xmpp());
-       syslog(LOG_DEBUG, "modules: init %s", ctdl_module_init_netconfig());
-       syslog(LOG_DEBUG, "modules: finished initializing modules (threading=%d)", threading);
+       syslog(LOG_DEBUG, "extensions: begin initializing modules (threading=%d)", threading);
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_control());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_euidindex());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_msgbase());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_database());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_autocompletion());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_bio());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_blog());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_calendar());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_checkpoint());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_virus());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_file_ops());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_ctdl_message());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_rooms());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_serv_session());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_syscmd());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_serv_user());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_expire());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_fulltext());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_image());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_imap());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_sieve());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_inetcfg());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_instmsg());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_listdeliver());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_listsub());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_migrate());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_newuser());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_nntp());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_notes());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_openid_rp());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_pop3());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_pop3client());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_roomchat());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_rssclient());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_rwho());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_smtp());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_smtpclient());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_spam());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_test());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_upgrade());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_vcard());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_wiki());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_xmpp());
+       syslog(LOG_DEBUG, "extensions: init %s", ctdl_module_init_netconfig());
+       syslog(LOG_DEBUG, "extensions: finished initializing modules (threading=%d)", threading);
 }
old mode 100644 (file)
new mode 100755 (executable)