commit
60733179a9
@ -0,0 +1,4 @@
|
|||||||
|
Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
Michael Rasmussen (mir@datanom.net)
|
||||||
|
Emmanuel Blindauer (e.blindauer@gmail.com)
|
||||||
|
|
@ -0,0 +1,674 @@
|
|||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 3, 29 June 2007
|
||||||
|
|
||||||
|
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The GNU General Public License is a free, copyleft license for
|
||||||
|
software and other kinds of works.
|
||||||
|
|
||||||
|
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 GNU General Public License is intended to guarantee your freedom to
|
||||||
|
share and change all versions of a program--to make sure it remains free
|
||||||
|
software for all its users. We, the Free Software Foundation, use the
|
||||||
|
GNU General Public License for most of our 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. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
them if you wish), that you receive source code or can get it if you
|
||||||
|
want it, that you can change the software or use pieces of it in new
|
||||||
|
free programs, and that you know you can do these things.
|
||||||
|
|
||||||
|
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 GNU 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 free 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 a free program could
|
||||||
|
make it effectively proprietary. To prevent this, the GPL assures that
|
||||||
|
patents cannot be used to render the program non-free.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
0. Definitions.
|
||||||
|
|
||||||
|
"This License" refers to version 3 of the GNU General Public License.
|
||||||
|
|
||||||
|
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||||
|
works, such as semiconductor masks.
|
||||||
|
|
||||||
|
"The Program" refers to any copyrightable work licensed under this
|
||||||
|
License. Each licensee is addressed as "you". "Licensees" and
|
||||||
|
"recipients" may be individuals or organizations.
|
||||||
|
|
||||||
|
To "modify" a work means to copy from or adapt all or part of the work
|
||||||
|
in a fashion requiring copyright permission, other than the making of an
|
||||||
|
exact copy. The resulting work is called a "modified version" of the
|
||||||
|
earlier work or a work "based on" the earlier work.
|
||||||
|
|
||||||
|
A "covered work" means either the unmodified Program or a work based
|
||||||
|
on the Program.
|
||||||
|
|
||||||
|
To "propagate" a work means to do anything with it that, without
|
||||||
|
permission, would make you directly or secondarily liable for
|
||||||
|
infringement under applicable copyright law, except executing it on a
|
||||||
|
computer or modifying a private copy. Propagation includes copying,
|
||||||
|
distribution (with or without modification), making available to the
|
||||||
|
public, and in some countries other activities as well.
|
||||||
|
|
||||||
|
To "convey" a work means any kind of propagation that enables other
|
||||||
|
parties to make or receive copies. Mere interaction with a user through
|
||||||
|
a computer network, with no transfer of a copy, is not conveying.
|
||||||
|
|
||||||
|
An interactive user interface displays "Appropriate Legal Notices"
|
||||||
|
to the extent that it includes a convenient and prominently visible
|
||||||
|
feature that (1) displays an appropriate copyright notice, and (2)
|
||||||
|
tells the user that there is no warranty for the work (except to the
|
||||||
|
extent that warranties are provided), that licensees may convey the
|
||||||
|
work under this License, and how to view a copy of this License. If
|
||||||
|
the interface presents a list of user commands or options, such as a
|
||||||
|
menu, a prominent item in the list meets this criterion.
|
||||||
|
|
||||||
|
1. Source Code.
|
||||||
|
|
||||||
|
The "source code" for a work means the preferred form of the work
|
||||||
|
for making modifications to it. "Object code" means any non-source
|
||||||
|
form of a work.
|
||||||
|
|
||||||
|
A "Standard Interface" means an interface that either is an official
|
||||||
|
standard defined by a recognized standards body, or, in the case of
|
||||||
|
interfaces specified for a particular programming language, one that
|
||||||
|
is widely used among developers working in that language.
|
||||||
|
|
||||||
|
The "System Libraries" of an executable work include anything, other
|
||||||
|
than the work as a whole, that (a) is included in the normal form of
|
||||||
|
packaging a Major Component, but which is not part of that Major
|
||||||
|
Component, and (b) serves only to enable use of the work with that
|
||||||
|
Major Component, or to implement a Standard Interface for which an
|
||||||
|
implementation is available to the public in source code form. A
|
||||||
|
"Major Component", in this context, means a major essential component
|
||||||
|
(kernel, window system, and so on) of the specific operating system
|
||||||
|
(if any) on which the executable work runs, or a compiler used to
|
||||||
|
produce the work, or an object code interpreter used to run it.
|
||||||
|
|
||||||
|
The "Corresponding Source" for a work in object code form means all
|
||||||
|
the source code needed to generate, install, and (for an executable
|
||||||
|
work) run the object code and to modify the work, including scripts to
|
||||||
|
control those activities. However, it does not include the work's
|
||||||
|
System Libraries, or general-purpose tools or generally available free
|
||||||
|
programs which are used unmodified in performing those activities but
|
||||||
|
which are not part of the work. For example, Corresponding Source
|
||||||
|
includes interface definition files associated with source files for
|
||||||
|
the work, and the source code for shared libraries and dynamically
|
||||||
|
linked subprograms that the work is specifically designed to require,
|
||||||
|
such as by intimate data communication or control flow between those
|
||||||
|
subprograms and other parts of the work.
|
||||||
|
|
||||||
|
The Corresponding Source need not include anything that users
|
||||||
|
can regenerate automatically from other parts of the Corresponding
|
||||||
|
Source.
|
||||||
|
|
||||||
|
The Corresponding Source for a work in source code form is that
|
||||||
|
same work.
|
||||||
|
|
||||||
|
2. Basic Permissions.
|
||||||
|
|
||||||
|
All rights granted under this License are granted for the term of
|
||||||
|
copyright on the Program, and are irrevocable provided the stated
|
||||||
|
conditions are met. This License explicitly affirms your unlimited
|
||||||
|
permission to run the unmodified Program. The output from running a
|
||||||
|
covered work is covered by this License only if the output, given its
|
||||||
|
content, constitutes a covered work. This License acknowledges your
|
||||||
|
rights of fair use or other equivalent, as provided by copyright law.
|
||||||
|
|
||||||
|
You may make, run and propagate covered works that you do not
|
||||||
|
convey, without conditions so long as your license otherwise remains
|
||||||
|
in force. You may convey covered works to others for the sole purpose
|
||||||
|
of having them make modifications exclusively for you, or provide you
|
||||||
|
with facilities for running those works, provided that you comply with
|
||||||
|
the terms of this License in conveying all material for which you do
|
||||||
|
not control copyright. Those thus making or running the covered works
|
||||||
|
for you must do so exclusively on your behalf, under your direction
|
||||||
|
and control, on terms that prohibit them from making any copies of
|
||||||
|
your copyrighted material outside their relationship with you.
|
||||||
|
|
||||||
|
Conveying under any other circumstances is permitted solely under
|
||||||
|
the conditions stated below. Sublicensing is not allowed; section 10
|
||||||
|
makes it unnecessary.
|
||||||
|
|
||||||
|
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||||
|
|
||||||
|
No covered work shall be deemed part of an effective technological
|
||||||
|
measure under any applicable law fulfilling obligations under article
|
||||||
|
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||||
|
similar laws prohibiting or restricting circumvention of such
|
||||||
|
measures.
|
||||||
|
|
||||||
|
When you convey a covered work, you waive any legal power to forbid
|
||||||
|
circumvention of technological measures to the extent such circumvention
|
||||||
|
is effected by exercising rights under this License with respect to
|
||||||
|
the covered work, and you disclaim any intention to limit operation or
|
||||||
|
modification of the work as a means of enforcing, against the work's
|
||||||
|
users, your or third parties' legal rights to forbid circumvention of
|
||||||
|
technological measures.
|
||||||
|
|
||||||
|
4. Conveying Verbatim Copies.
|
||||||
|
|
||||||
|
You may convey verbatim copies of the Program's source code as you
|
||||||
|
receive it, in any medium, provided that you conspicuously and
|
||||||
|
appropriately publish on each copy an appropriate copyright notice;
|
||||||
|
keep intact all notices stating that this License and any
|
||||||
|
non-permissive terms added in accord with section 7 apply to the code;
|
||||||
|
keep intact all notices of the absence of any warranty; and give all
|
||||||
|
recipients a copy of this License along with the Program.
|
||||||
|
|
||||||
|
You may charge any price or no price for each copy that you convey,
|
||||||
|
and you may offer support or warranty protection for a fee.
|
||||||
|
|
||||||
|
5. Conveying Modified Source Versions.
|
||||||
|
|
||||||
|
You may convey a work based on the Program, or the modifications to
|
||||||
|
produce it from the Program, in the form of source code under the
|
||||||
|
terms of section 4, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) The work must carry prominent notices stating that you modified
|
||||||
|
it, and giving a relevant date.
|
||||||
|
|
||||||
|
b) The work must carry prominent notices stating that it is
|
||||||
|
released under this License and any conditions added under section
|
||||||
|
7. This requirement modifies the requirement in section 4 to
|
||||||
|
"keep intact all notices".
|
||||||
|
|
||||||
|
c) You must license the entire work, as a whole, under this
|
||||||
|
License to anyone who comes into possession of a copy. This
|
||||||
|
License will therefore apply, along with any applicable section 7
|
||||||
|
additional terms, to the whole of the work, and all its parts,
|
||||||
|
regardless of how they are packaged. This License gives no
|
||||||
|
permission to license the work in any other way, but it does not
|
||||||
|
invalidate such permission if you have separately received it.
|
||||||
|
|
||||||
|
d) If the work has interactive user interfaces, each must display
|
||||||
|
Appropriate Legal Notices; however, if the Program has interactive
|
||||||
|
interfaces that do not display Appropriate Legal Notices, your
|
||||||
|
work need not make them do so.
|
||||||
|
|
||||||
|
A compilation of a covered work with other separate and independent
|
||||||
|
works, which are not by their nature extensions of the covered work,
|
||||||
|
and which are not combined with it such as to form a larger program,
|
||||||
|
in or on a volume of a storage or distribution medium, is called an
|
||||||
|
"aggregate" if the compilation and its resulting copyright are not
|
||||||
|
used to limit the access or legal rights of the compilation's users
|
||||||
|
beyond what the individual works permit. Inclusion of a covered work
|
||||||
|
in an aggregate does not cause this License to apply to the other
|
||||||
|
parts of the aggregate.
|
||||||
|
|
||||||
|
6. Conveying Non-Source Forms.
|
||||||
|
|
||||||
|
You may convey a covered work in object code form under the terms
|
||||||
|
of sections 4 and 5, provided that you also convey the
|
||||||
|
machine-readable Corresponding Source under the terms of this License,
|
||||||
|
in one of these ways:
|
||||||
|
|
||||||
|
a) Convey the object code in, or embodied in, a physical product
|
||||||
|
(including a physical distribution medium), accompanied by the
|
||||||
|
Corresponding Source fixed on a durable physical medium
|
||||||
|
customarily used for software interchange.
|
||||||
|
|
||||||
|
b) Convey the object code in, or embodied in, a physical product
|
||||||
|
(including a physical distribution medium), accompanied by a
|
||||||
|
written offer, valid for at least three years and valid for as
|
||||||
|
long as you offer spare parts or customer support for that product
|
||||||
|
model, to give anyone who possesses the object code either (1) a
|
||||||
|
copy of the Corresponding Source for all the software in the
|
||||||
|
product that is covered by this License, on a durable physical
|
||||||
|
medium customarily used for software interchange, for a price no
|
||||||
|
more than your reasonable cost of physically performing this
|
||||||
|
conveying of source, or (2) access to copy the
|
||||||
|
Corresponding Source from a network server at no charge.
|
||||||
|
|
||||||
|
c) Convey individual copies of the object code with a copy of the
|
||||||
|
written offer to provide the Corresponding Source. This
|
||||||
|
alternative is allowed only occasionally and noncommercially, and
|
||||||
|
only if you received the object code with such an offer, in accord
|
||||||
|
with subsection 6b.
|
||||||
|
|
||||||
|
d) Convey the object code by offering access from a designated
|
||||||
|
place (gratis or for a charge), and offer equivalent access to the
|
||||||
|
Corresponding Source in the same way through the same place at no
|
||||||
|
further charge. You need not require recipients to copy the
|
||||||
|
Corresponding Source along with the object code. If the place to
|
||||||
|
copy the object code is a network server, the Corresponding Source
|
||||||
|
may be on a different server (operated by you or a third party)
|
||||||
|
that supports equivalent copying facilities, provided you maintain
|
||||||
|
clear directions next to the object code saying where to find the
|
||||||
|
Corresponding Source. Regardless of what server hosts the
|
||||||
|
Corresponding Source, you remain obligated to ensure that it is
|
||||||
|
available for as long as needed to satisfy these requirements.
|
||||||
|
|
||||||
|
e) Convey the object code using peer-to-peer transmission, provided
|
||||||
|
you inform other peers where the object code and Corresponding
|
||||||
|
Source of the work are being offered to the general public at no
|
||||||
|
charge under subsection 6d.
|
||||||
|
|
||||||
|
A separable portion of the object code, whose source code is excluded
|
||||||
|
from the Corresponding Source as a System Library, need not be
|
||||||
|
included in conveying the object code work.
|
||||||
|
|
||||||
|
A "User Product" is either (1) a "consumer product", which means any
|
||||||
|
tangible personal property which is normally used for personal, family,
|
||||||
|
or household purposes, or (2) anything designed or sold for incorporation
|
||||||
|
into a dwelling. In determining whether a product is a consumer product,
|
||||||
|
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||||
|
product received by a particular user, "normally used" refers to a
|
||||||
|
typical or common use of that class of product, regardless of the status
|
||||||
|
of the particular user or of the way in which the particular user
|
||||||
|
actually uses, or expects or is expected to use, the product. A product
|
||||||
|
is a consumer product regardless of whether the product has substantial
|
||||||
|
commercial, industrial or non-consumer uses, unless such uses represent
|
||||||
|
the only significant mode of use of the product.
|
||||||
|
|
||||||
|
"Installation Information" for a User Product means any methods,
|
||||||
|
procedures, authorization keys, or other information required to install
|
||||||
|
and execute modified versions of a covered work in that User Product from
|
||||||
|
a modified version of its Corresponding Source. The information must
|
||||||
|
suffice to ensure that the continued functioning of the modified object
|
||||||
|
code is in no case prevented or interfered with solely because
|
||||||
|
modification has been made.
|
||||||
|
|
||||||
|
If you convey an object code work under this section in, or with, or
|
||||||
|
specifically for use in, a User Product, and the conveying occurs as
|
||||||
|
part of a transaction in which the right of possession and use of the
|
||||||
|
User Product is transferred to the recipient in perpetuity or for a
|
||||||
|
fixed term (regardless of how the transaction is characterized), the
|
||||||
|
Corresponding Source conveyed under this section must be accompanied
|
||||||
|
by the Installation Information. But this requirement does not apply
|
||||||
|
if neither you nor any third party retains the ability to install
|
||||||
|
modified object code on the User Product (for example, the work has
|
||||||
|
been installed in ROM).
|
||||||
|
|
||||||
|
The requirement to provide Installation Information does not include a
|
||||||
|
requirement to continue to provide support service, warranty, or updates
|
||||||
|
for a work that has been modified or installed by the recipient, or for
|
||||||
|
the User Product in which it has been modified or installed. Access to a
|
||||||
|
network may be denied when the modification itself materially and
|
||||||
|
adversely affects the operation of the network or violates the rules and
|
||||||
|
protocols for communication across the network.
|
||||||
|
|
||||||
|
Corresponding Source conveyed, and Installation Information provided,
|
||||||
|
in accord with this section must be in a format that is publicly
|
||||||
|
documented (and with an implementation available to the public in
|
||||||
|
source code form), and must require no special password or key for
|
||||||
|
unpacking, reading or copying.
|
||||||
|
|
||||||
|
7. Additional Terms.
|
||||||
|
|
||||||
|
"Additional permissions" are terms that supplement the terms of this
|
||||||
|
License by making exceptions from one or more of its conditions.
|
||||||
|
Additional permissions that are applicable to the entire Program shall
|
||||||
|
be treated as though they were included in this License, to the extent
|
||||||
|
that they are valid under applicable law. If additional permissions
|
||||||
|
apply only to part of the Program, that part may be used separately
|
||||||
|
under those permissions, but the entire Program remains governed by
|
||||||
|
this License without regard to the additional permissions.
|
||||||
|
|
||||||
|
When you convey a copy of a covered work, you may at your option
|
||||||
|
remove any additional permissions from that copy, or from any part of
|
||||||
|
it. (Additional permissions may be written to require their own
|
||||||
|
removal in certain cases when you modify the work.) You may place
|
||||||
|
additional permissions on material, added by you to a covered work,
|
||||||
|
for which you have or can give appropriate copyright permission.
|
||||||
|
|
||||||
|
Notwithstanding any other provision of this License, for material you
|
||||||
|
add to a covered work, you may (if authorized by the copyright holders of
|
||||||
|
that material) supplement the terms of this License with terms:
|
||||||
|
|
||||||
|
a) Disclaiming warranty or limiting liability differently from the
|
||||||
|
terms of sections 15 and 16 of this License; or
|
||||||
|
|
||||||
|
b) Requiring preservation of specified reasonable legal notices or
|
||||||
|
author attributions in that material or in the Appropriate Legal
|
||||||
|
Notices displayed by works containing it; or
|
||||||
|
|
||||||
|
c) Prohibiting misrepresentation of the origin of that material, or
|
||||||
|
requiring that modified versions of such material be marked in
|
||||||
|
reasonable ways as different from the original version; or
|
||||||
|
|
||||||
|
d) Limiting the use for publicity purposes of names of licensors or
|
||||||
|
authors of the material; or
|
||||||
|
|
||||||
|
e) Declining to grant rights under trademark law for use of some
|
||||||
|
trade names, trademarks, or service marks; or
|
||||||
|
|
||||||
|
f) Requiring indemnification of licensors and authors of that
|
||||||
|
material by anyone who conveys the material (or modified versions of
|
||||||
|
it) with contractual assumptions of liability to the recipient, for
|
||||||
|
any liability that these contractual assumptions directly impose on
|
||||||
|
those licensors and authors.
|
||||||
|
|
||||||
|
All other non-permissive additional terms are considered "further
|
||||||
|
restrictions" within the meaning of section 10. If the Program as you
|
||||||
|
received it, or any part of it, contains a notice stating that it is
|
||||||
|
governed by this License along with a term that is a further
|
||||||
|
restriction, you may remove that term. If a license document contains
|
||||||
|
a further restriction but permits relicensing or conveying under this
|
||||||
|
License, you may add to a covered work material governed by the terms
|
||||||
|
of that license document, provided that the further restriction does
|
||||||
|
not survive such relicensing or conveying.
|
||||||
|
|
||||||
|
If you add terms to a covered work in accord with this section, you
|
||||||
|
must place, in the relevant source files, a statement of the
|
||||||
|
additional terms that apply to those files, or a notice indicating
|
||||||
|
where to find the applicable terms.
|
||||||
|
|
||||||
|
Additional terms, permissive or non-permissive, may be stated in the
|
||||||
|
form of a separately written license, or stated as exceptions;
|
||||||
|
the above requirements apply either way.
|
||||||
|
|
||||||
|
8. Termination.
|
||||||
|
|
||||||
|
You may not propagate or modify a covered work except as expressly
|
||||||
|
provided under this License. Any attempt otherwise to propagate or
|
||||||
|
modify it is void, and will automatically terminate your rights under
|
||||||
|
this License (including any patent licenses granted under the third
|
||||||
|
paragraph of section 11).
|
||||||
|
|
||||||
|
However, if you cease all violation of this License, then your
|
||||||
|
license from a particular copyright holder is reinstated (a)
|
||||||
|
provisionally, unless and until the copyright holder explicitly and
|
||||||
|
finally terminates your license, and (b) permanently, if the copyright
|
||||||
|
holder fails to notify you of the violation by some reasonable means
|
||||||
|
prior to 60 days after the cessation.
|
||||||
|
|
||||||
|
Moreover, your license from a particular copyright holder is
|
||||||
|
reinstated permanently if the copyright holder notifies you of the
|
||||||
|
violation by some reasonable means, this is the first time you have
|
||||||
|
received notice of violation of this License (for any work) from that
|
||||||
|
copyright holder, and you cure the violation prior to 30 days after
|
||||||
|
your receipt of the notice.
|
||||||
|
|
||||||
|
Termination of your rights under this section does not terminate the
|
||||||
|
licenses of parties who have received copies or rights from you under
|
||||||
|
this License. If your rights have been terminated and not permanently
|
||||||
|
reinstated, you do not qualify to receive new licenses for the same
|
||||||
|
material under section 10.
|
||||||
|
|
||||||
|
9. Acceptance Not Required for Having Copies.
|
||||||
|
|
||||||
|
You are not required to accept this License in order to receive or
|
||||||
|
run a copy of the Program. Ancillary propagation of a covered work
|
||||||
|
occurring solely as a consequence of using peer-to-peer transmission
|
||||||
|
to receive a copy likewise does not require acceptance. However,
|
||||||
|
nothing other than this License grants you permission to propagate or
|
||||||
|
modify any covered work. These actions infringe copyright if you do
|
||||||
|
not accept this License. Therefore, by modifying or propagating a
|
||||||
|
covered work, you indicate your acceptance of this License to do so.
|
||||||
|
|
||||||
|
10. Automatic Licensing of Downstream Recipients.
|
||||||
|
|
||||||
|
Each time you convey a covered work, the recipient automatically
|
||||||
|
receives a license from the original licensors, to run, modify and
|
||||||
|
propagate that work, subject to this License. You are not responsible
|
||||||
|
for enforcing compliance by third parties with this License.
|
||||||
|
|
||||||
|
An "entity transaction" is a transaction transferring control of an
|
||||||
|
organization, or substantially all assets of one, or subdividing an
|
||||||
|
organization, or merging organizations. If propagation of a covered
|
||||||
|
work results from an entity transaction, each party to that
|
||||||
|
transaction who receives a copy of the work also receives whatever
|
||||||
|
licenses to the work the party's predecessor in interest had or could
|
||||||
|
give under the previous paragraph, plus a right to possession of the
|
||||||
|
Corresponding Source of the work from the predecessor in interest, if
|
||||||
|
the predecessor has it or can get it with reasonable efforts.
|
||||||
|
|
||||||
|
You may not impose any further restrictions on the exercise of the
|
||||||
|
rights granted or affirmed under this License. For example, you may
|
||||||
|
not impose a license fee, royalty, or other charge for exercise of
|
||||||
|
rights granted under this License, and you may not initiate litigation
|
||||||
|
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||||
|
any patent claim is infringed by making, using, selling, offering for
|
||||||
|
sale, or importing the Program or any portion of it.
|
||||||
|
|
||||||
|
11. Patents.
|
||||||
|
|
||||||
|
A "contributor" is a copyright holder who authorizes use under this
|
||||||
|
License of the Program or a work on which the Program is based. The
|
||||||
|
work thus licensed is called the contributor's "contributor version".
|
||||||
|
|
||||||
|
A contributor's "essential patent claims" are all patent claims
|
||||||
|
owned or controlled by the contributor, whether already acquired or
|
||||||
|
hereafter acquired, that would be infringed by some manner, permitted
|
||||||
|
by this License, of making, using, or selling its contributor version,
|
||||||
|
but do not include claims that would be infringed only as a
|
||||||
|
consequence of further modification of the contributor version. For
|
||||||
|
purposes of this definition, "control" includes the right to grant
|
||||||
|
patent sublicenses in a manner consistent with the requirements of
|
||||||
|
this License.
|
||||||
|
|
||||||
|
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||||
|
patent license under the contributor's essential patent claims, to
|
||||||
|
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||||
|
propagate the contents of its contributor version.
|
||||||
|
|
||||||
|
In the following three paragraphs, a "patent license" is any express
|
||||||
|
agreement or commitment, however denominated, not to enforce a patent
|
||||||
|
(such as an express permission to practice a patent or covenant not to
|
||||||
|
sue for patent infringement). To "grant" such a patent license to a
|
||||||
|
party means to make such an agreement or commitment not to enforce a
|
||||||
|
patent against the party.
|
||||||
|
|
||||||
|
If you convey a covered work, knowingly relying on a patent license,
|
||||||
|
and the Corresponding Source of the work is not available for anyone
|
||||||
|
to copy, free of charge and under the terms of this License, through a
|
||||||
|
publicly available network server or other readily accessible means,
|
||||||
|
then you must either (1) cause the Corresponding Source to be so
|
||||||
|
available, or (2) arrange to deprive yourself of the benefit of the
|
||||||
|
patent license for this particular work, or (3) arrange, in a manner
|
||||||
|
consistent with the requirements of this License, to extend the patent
|
||||||
|
license to downstream recipients. "Knowingly relying" means you have
|
||||||
|
actual knowledge that, but for the patent license, your conveying the
|
||||||
|
covered work in a country, or your recipient's use of the covered work
|
||||||
|
in a country, would infringe one or more identifiable patents in that
|
||||||
|
country that you have reason to believe are valid.
|
||||||
|
|
||||||
|
If, pursuant to or in connection with a single transaction or
|
||||||
|
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||||
|
covered work, and grant a patent license to some of the parties
|
||||||
|
receiving the covered work authorizing them to use, propagate, modify
|
||||||
|
or convey a specific copy of the covered work, then the patent license
|
||||||
|
you grant is automatically extended to all recipients of the covered
|
||||||
|
work and works based on it.
|
||||||
|
|
||||||
|
A patent license is "discriminatory" if it does not include within
|
||||||
|
the scope of its coverage, prohibits the exercise of, or is
|
||||||
|
conditioned on the non-exercise of one or more of the rights that are
|
||||||
|
specifically granted under this License. You may not convey a covered
|
||||||
|
work if you are a party to an arrangement with a third party that is
|
||||||
|
in the business of distributing software, under which you make payment
|
||||||
|
to the third party based on the extent of your activity of conveying
|
||||||
|
the work, and under which the third party grants, to any of the
|
||||||
|
parties who would receive the covered work from you, a discriminatory
|
||||||
|
patent license (a) in connection with copies of the covered work
|
||||||
|
conveyed by you (or copies made from those copies), or (b) primarily
|
||||||
|
for and in connection with specific products or compilations that
|
||||||
|
contain the covered work, unless you entered into that arrangement,
|
||||||
|
or that patent license was granted, prior to 28 March 2007.
|
||||||
|
|
||||||
|
Nothing in this License shall be construed as excluding or limiting
|
||||||
|
any implied license or other defenses to infringement that may
|
||||||
|
otherwise be available to you under applicable patent law.
|
||||||
|
|
||||||
|
12. No Surrender of Others' Freedom.
|
||||||
|
|
||||||
|
If conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot convey a
|
||||||
|
covered work so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you may
|
||||||
|
not convey it at all. For example, if you agree to terms that obligate you
|
||||||
|
to collect a royalty for further conveying from those to whom you convey
|
||||||
|
the Program, the only way you could satisfy both those terms and this
|
||||||
|
License would be to refrain entirely from conveying the Program.
|
||||||
|
|
||||||
|
13. Use with the GNU 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 GNU 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 GNU 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 GNU General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the
|
||||||
|
Program specifies that a certain numbered version of the GNU General
|
||||||
|
Public License "or any later version" applies to it, you have the
|
||||||
|
option of following the terms and conditions either of that numbered
|
||||||
|
version or of any later version published by the Free Software
|
||||||
|
Foundation. If the Program does not specify a version number of the
|
||||||
|
GNU General Public License, you may choose any version ever published
|
||||||
|
by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Program specifies that a proxy can decide which future
|
||||||
|
versions of the GNU General Public License can be used, that proxy's
|
||||||
|
public statement of acceptance of a version permanently authorizes you
|
||||||
|
to choose that version for the Program.
|
||||||
|
|
||||||
|
Later license versions may give you additional or different
|
||||||
|
permissions. However, no additional obligations are imposed on any
|
||||||
|
author or copyright holder as a result of your choosing to follow a
|
||||||
|
later version.
|
||||||
|
|
||||||
|
15. Disclaimer of Warranty.
|
||||||
|
|
||||||
|
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||||
|
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
||||||
|
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
||||||
|
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
||||||
|
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
||||||
|
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
16. Limitation of Liability.
|
||||||
|
|
||||||
|
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||||
|
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
||||||
|
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
||||||
|
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
||||||
|
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
||||||
|
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
||||||
|
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
||||||
|
SUCH DAMAGES.
|
||||||
|
|
||||||
|
17. Interpretation of Sections 15 and 16.
|
||||||
|
|
||||||
|
If the disclaimer of warranty and limitation of liability provided
|
||||||
|
above cannot be given local legal effect according to their terms,
|
||||||
|
reviewing courts shall apply local law that most closely approximates
|
||||||
|
an absolute waiver of all civil liability in connection with the
|
||||||
|
Program, unless a warranty or assumption of liability accompanies a
|
||||||
|
copy of the Program in return for a fee.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
state the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program does terminal interaction, make it output a short
|
||||||
|
notice like this when it starts in an interactive mode:
|
||||||
|
|
||||||
|
<program> Copyright (C) <year> <name of author>
|
||||||
|
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||||
|
parts of the General Public License. Of course, your program's commands
|
||||||
|
might be different; for a GUI interface, you would use an "about box".
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or school,
|
||||||
|
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||||
|
For more information on this, and how to apply and follow the GNU GPL, see
|
||||||
|
<http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
The GNU General Public License does not permit incorporating your program
|
||||||
|
into proprietary programs. If your program is a subroutine library, you
|
||||||
|
may consider it more useful to permit linking proprietary applications with
|
||||||
|
the library. If this is what you want to do, use the GNU Lesser General
|
||||||
|
Public License instead of this License. But first, please read
|
||||||
|
<http://www.gnu.org/philosophy/why-not-lgpl.html>.
|
@ -0,0 +1,124 @@
|
|||||||
|
libcarddav (0.6.1)
|
||||||
|
* Fix redirection bug to fully support Zimbra server. Patch
|
||||||
|
provided by Timothy Pearson
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Tue, 25 May 2010 22:51:03 +0100
|
||||||
|
|
||||||
|
libcarddav (0.6.0)
|
||||||
|
* Refactored to properly handle URL schema. Also fixes bug 2985320
|
||||||
|
* More accurate error message in case of unresolable host or unable
|
||||||
|
to get a connection. fixes feature request 2985321
|
||||||
|
* Added support for FREEBUSY search
|
||||||
|
* Fix bug 3003201. Solution provided by Dmitry Savenko
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Mon, 12 Apr 2010 12:15:03 +0100
|
||||||
|
|
||||||
|
libcarddav (0.5.2)
|
||||||
|
* Added a unit like testing framework
|
||||||
|
* Make the use of locking configurable
|
||||||
|
* Extend testing framework to test for this
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Thu, 8 Apr 2010 12:15:03 +0100
|
||||||
|
|
||||||
|
libcarddav (0.5.1)
|
||||||
|
* Honor request 2981083. Implement a response_free function
|
||||||
|
* Honor request 2981100. Implement a runtime_info creation function
|
||||||
|
* Fix bug 2981096. A number of memory leaks
|
||||||
|
* Complete refactoring. Implement basic setup of curl instance in a
|
||||||
|
function which all other function uses to ease maintainability and
|
||||||
|
simplicity and to reduce the number of repeated code lines.
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Sat, 3 Apr 2010 03:29:03 +0100
|
||||||
|
|
||||||
|
libcarddav (0.5.0)
|
||||||
|
* Make library thread-safe. Close bug 2971102.
|
||||||
|
* Changed test application accordingly.
|
||||||
|
* Fix a number of memory leaks.
|
||||||
|
* Fix a number of double frees.
|
||||||
|
* fix regression introduced in revision 9 which broke locking
|
||||||
|
in delete and modify.
|
||||||
|
* Enhanced the error reporting for lock requests.
|
||||||
|
* Fix some potential memory leaks.
|
||||||
|
* Fix bug in parsing URL for username and password.
|
||||||
|
* Fix pedantic behaviour from Google which chokes on URL's
|
||||||
|
containing //
|
||||||
|
* Fix bug so that get_etag also is able to handle namespace
|
||||||
|
prefix for finding etags
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Sat, 27 Mar 2010 03:27:03 +0100
|
||||||
|
|
||||||
|
libcarddav (0.4.2)
|
||||||
|
* Fix bug so that SSL specific settings are actually used.
|
||||||
|
Close bug 2971096.
|
||||||
|
* Fix bug so is-carddav and options are handled correct
|
||||||
|
* Applied help for new SSL settings to test application
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Sat, 27 Mar 2010 03:27:03 +0100
|
||||||
|
|
||||||
|
libcarddav (0.4.1)
|
||||||
|
* Fix bug so that SSL specific errors are handled properly.
|
||||||
|
Close bug 2963143.
|
||||||
|
* Add option to build script to disable/enable building of
|
||||||
|
API documentation. Default is disabled.
|
||||||
|
* More cleaning up of the build system.
|
||||||
|
* Fix compile time warnings caused by gcc4.4 and minor change in
|
||||||
|
libcurl API.
|
||||||
|
* Add option to disable verification of peer's certificate
|
||||||
|
* Add option to specify custom CA cert file
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Sat, 7 Mar 2010 09:06:24 +0100
|
||||||
|
|
||||||
|
libcarddav (0.4.0)
|
||||||
|
* Extend test client to be able to use both http and https
|
||||||
|
* Clean up some build instructions
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Sat, 27 Feb 2010 12:06:24 +0100
|
||||||
|
|
||||||
|
libcarddav (0.3.1)
|
||||||
|
* Add https support
|
||||||
|
* make the useragent a configurable string, as some server doesn't like
|
||||||
|
'curl'
|
||||||
|
|
||||||
|
-- Emmanuel Blindauer <e.blindauer@gmail.com> Fri Feb 26 20:49:16 CET 2010
|
||||||
|
|
||||||
|
|
||||||
|
libcarddav (0.3.0)
|
||||||
|
* This version implements locking if the server supports this. Locking
|
||||||
|
will be done every time a request for modify or delete is sent to the
|
||||||
|
server
|
||||||
|
* 1) In ICalendar all plain text is wrapped inside DTD CDATA elements
|
||||||
|
* 2) ICalendar does not support collations for text-match in which case
|
||||||
|
collations has been removed from request - default is i;ascii-casemap anyhow
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Thu, 08 Apr 2008 00:06:24 +0100
|
||||||
|
|
||||||
|
libcarddav (0.2.0)
|
||||||
|
|
||||||
|
* This version is a maintenance release due to important bugs.
|
||||||
|
* 1) Bugs found in XML which produced incorrect requests corrected
|
||||||
|
* 2) Added an option to configure to request dynamic or static library
|
||||||
|
* 3) Build system clean up
|
||||||
|
* 4) Discovered possible null pointers in error messages which is now
|
||||||
|
eliminated
|
||||||
|
* 5) Resolve bug in get_response_header which caused function to
|
||||||
|
change contents of variable in calling function
|
||||||
|
* 6) Added extra variable to get_response_header to decide whether returned
|
||||||
|
string should be all lower or not
|
||||||
|
7) Function get_tag can now also handle namespace prefix in tags
|
||||||
|
8) Added function carddav_getoptions to have a list of supported options
|
||||||
|
by the server returned.
|
||||||
|
* 9) Compatibily tests run against Chandler and Apple's ICalendar
|
||||||
|
- Chandler: calendar-query not working due to bugs in Chandler's
|
||||||
|
implementation of calendar-query which is not conforming to RFC4791
|
||||||
|
- ICalendar: After adding namespace prefix awareness all test ran as
|
||||||
|
expected.
|
||||||
|
* 10) The CLI test application upgraded to use new features.
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Thu, 03 Apr 2008 10:10:00 +0100
|
||||||
|
|
||||||
|
libcarddav (0.1.0)
|
||||||
|
|
||||||
|
* first public release
|
||||||
|
|
||||||
|
-- Michael Rasmussen <mir@datanom.net> Tue, 25 Mar 2008 13:20:21 +0100
|
||||||
|
|
@ -0,0 +1,365 @@
|
|||||||
|
Installation Instructions
|
||||||
|
*************************
|
||||||
|
|
||||||
|
Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002, 2004, 2005,
|
||||||
|
2006, 2007, 2008, 2009 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
Copying and distribution of this file, with or without modification,
|
||||||
|
are permitted in any medium without royalty provided the copyright
|
||||||
|
notice and this notice are preserved. This file is offered as-is,
|
||||||
|
without warranty of any kind.
|
||||||
|
|
||||||
|
Basic Installation
|
||||||
|
==================
|
||||||
|
|
||||||
|
Briefly, the shell commands `./configure; make; make install' should
|
||||||
|
configure, build, and install this package. The following
|
||||||
|
more-detailed instructions are generic; see the `README' file for
|
||||||
|
instructions specific to this package. Some packages provide this
|
||||||
|
`INSTALL' file but do not implement all of the features documented
|
||||||
|
below. The lack of an optional feature in a given package is not
|
||||||
|
necessarily a bug. More recommendations for GNU packages can be found
|
||||||
|
in *note Makefile Conventions: (standards)Makefile Conventions.
|
||||||
|
|
||||||
|
The `configure' shell script attempts to guess correct values for
|
||||||
|
various system-dependent variables used during compilation. It uses
|
||||||
|
those values to create a `Makefile' in each directory of the package.
|
||||||
|
It may also create one or more `.h' files containing system-dependent
|
||||||
|
definitions. Finally, it creates a shell script `config.status' that
|
||||||
|
you can run in the future to recreate the current configuration, and a
|
||||||
|
file `config.log' containing compiler output (useful mainly for
|
||||||
|
debugging `configure').
|
||||||
|
|
||||||
|
It can also use an optional file (typically called `config.cache'
|
||||||
|
and enabled with `--cache-file=config.cache' or simply `-C') that saves
|
||||||
|
the results of its tests to speed up reconfiguring. Caching is
|
||||||
|
disabled by default to prevent problems with accidental use of stale
|
||||||
|
cache files.
|
||||||
|
|
||||||
|
If you need to do unusual things to compile the package, please try
|
||||||
|
to figure out how `configure' could check whether to do them, and mail
|
||||||
|
diffs or instructions to the address given in the `README' so they can
|
||||||
|
be considered for the next release. If you are using the cache, and at
|
||||||
|
some point `config.cache' contains results you don't want to keep, you
|
||||||
|
may remove or edit it.
|
||||||
|
|
||||||
|
The file `configure.ac' (or `configure.in') is used to create
|
||||||
|
`configure' by a program called `autoconf'. You need `configure.ac' if
|
||||||
|
you want to change it or regenerate `configure' using a newer version
|
||||||
|
of `autoconf'.
|
||||||
|
|
||||||
|
The simplest way to compile this package is:
|
||||||
|
|
||||||
|
1. `cd' to the directory containing the package's source code and type
|
||||||
|
`./configure' to configure the package for your system.
|
||||||
|
|
||||||
|
Running `configure' might take a while. While running, it prints
|
||||||
|
some messages telling which features it is checking for.
|
||||||
|
|
||||||
|
2. Type `make' to compile the package.
|
||||||
|
|
||||||
|
3. Optionally, type `make check' to run any self-tests that come with
|
||||||
|
the package, generally using the just-built uninstalled binaries.
|
||||||
|
|
||||||
|
4. Type `make install' to install the programs and any data files and
|
||||||
|
documentation. When installing into a prefix owned by root, it is
|
||||||
|
recommended that the package be configured and built as a regular
|
||||||
|
user, and only the `make install' phase executed with root
|
||||||
|
privileges.
|
||||||
|
|
||||||
|
5. Optionally, type `make installcheck' to repeat any self-tests, but
|
||||||
|
this time using the binaries in their final installed location.
|
||||||
|
This target does not install anything. Running this target as a
|
||||||
|
regular user, particularly if the prior `make install' required
|
||||||
|
root privileges, verifies that the installation completed
|
||||||
|
correctly.
|
||||||
|
|
||||||
|
6. You can remove the program binaries and object files from the
|
||||||
|
source code directory by typing `make clean'. To also remove the
|
||||||
|
files that `configure' created (so you can compile the package for
|
||||||
|
a different kind of computer), type `make distclean'. There is
|
||||||
|
also a `make maintainer-clean' target, but that is intended mainly
|
||||||
|
for the package's developers. If you use it, you may have to get
|
||||||
|
all sorts of other programs in order to regenerate files that came
|
||||||
|
with the distribution.
|
||||||
|
|
||||||
|
7. Often, you can also type `make uninstall' to remove the installed
|
||||||
|
files again. In practice, not all packages have tested that
|
||||||
|
uninstallation works correctly, even though it is required by the
|
||||||
|
GNU Coding Standards.
|
||||||
|
|
||||||
|
8. Some packages, particularly those that use Automake, provide `make
|
||||||
|
distcheck', which can by used by developers to test that all other
|
||||||
|
targets like `make install' and `make uninstall' work correctly.
|
||||||
|
This target is generally not run by end users.
|
||||||
|
|
||||||
|
Compilers and Options
|
||||||
|
=====================
|
||||||
|
|
||||||
|
Some systems require unusual options for compilation or linking that
|
||||||
|
the `configure' script does not know about. Run `./configure --help'
|
||||||
|
for details on some of the pertinent environment variables.
|
||||||
|
|
||||||
|
You can give `configure' initial values for configuration parameters
|
||||||
|
by setting variables in the command line or in the environment. Here
|
||||||
|
is an example:
|
||||||
|
|
||||||
|
./configure CC=c99 CFLAGS=-g LIBS=-lposix
|
||||||
|
|
||||||
|
*Note Defining Variables::, for more details.
|
||||||
|
|
||||||
|
Compiling For Multiple Architectures
|
||||||
|
====================================
|
||||||
|
|
||||||
|
You can compile the package for more than one kind of computer at the
|
||||||
|
same time, by placing the object files for each architecture in their
|
||||||
|
own directory. To do this, you can use GNU `make'. `cd' to the
|
||||||
|
directory where you want the object files and executables to go and run
|
||||||
|
the `configure' script. `configure' automatically checks for the
|
||||||
|
source code in the directory that `configure' is in and in `..'. This
|
||||||
|
is known as a "VPATH" build.
|
||||||
|
|
||||||
|
With a non-GNU `make', it is safer to compile the package for one
|
||||||
|
architecture at a time in the source code directory. After you have
|
||||||
|
installed the package for one architecture, use `make distclean' before
|
||||||
|
reconfiguring for another architecture.
|
||||||
|
|
||||||
|
On MacOS X 10.5 and later systems, you can create libraries and
|
||||||
|
executables that work on multiple system types--known as "fat" or
|
||||||
|
"universal" binaries--by specifying multiple `-arch' options to the
|
||||||
|
compiler but only a single `-arch' option to the preprocessor. Like
|
||||||
|
this:
|
||||||
|
|
||||||
|
./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
|
||||||
|
CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
|
||||||
|
CPP="gcc -E" CXXCPP="g++ -E"
|
||||||
|
|
||||||
|
This is not guaranteed to produce working output in all cases, you
|
||||||
|
may have to build one architecture at a time and combine the results
|
||||||
|
using the `lipo' tool if you have problems.
|
||||||
|
|
||||||
|
Installation Names
|
||||||
|
==================
|
||||||
|
|
||||||
|
By default, `make install' installs the package's commands under
|
||||||
|
`/usr/local/bin', include files under `/usr/local/include', etc. You
|
||||||
|
can specify an installation prefix other than `/usr/local' by giving
|
||||||
|
`configure' the option `--prefix=PREFIX', where PREFIX must be an
|
||||||
|
absolute file name.
|
||||||
|
|
||||||
|
You can specify separate installation prefixes for
|
||||||
|
architecture-specific files and architecture-independent files. If you
|
||||||
|
pass the option `--exec-prefix=PREFIX' to `configure', the package uses
|
||||||
|
PREFIX as the prefix for installing programs and libraries.
|
||||||
|
Documentation and other data files still use the regular prefix.
|
||||||
|
|
||||||
|
In addition, if you use an unusual directory layout you can give
|
||||||
|
options like `--bindir=DIR' to specify different values for particular
|
||||||
|
kinds of files. Run `configure --help' for a list of the directories
|
||||||
|
you can set and what kinds of files go in them. In general, the
|
||||||
|
default for these options is expressed in terms of `${prefix}', so that
|
||||||
|
specifying just `--prefix' will affect all of the other directory
|
||||||
|
specifications that were not explicitly provided.
|
||||||
|
|
||||||
|
The most portable way to affect installation locations is to pass the
|
||||||
|
correct locations to `configure'; however, many packages provide one or
|
||||||
|
both of the following shortcuts of passing variable assignments to the
|
||||||
|
`make install' command line to change installation locations without
|
||||||
|
having to reconfigure or recompile.
|
||||||
|
|
||||||
|
The first method involves providing an override variable for each
|
||||||
|
affected directory. For example, `make install
|
||||||
|
prefix=/alternate/directory' will choose an alternate location for all
|
||||||
|
directory configuration variables that were expressed in terms of
|
||||||
|
`${prefix}'. Any directories that were specified during `configure',
|
||||||
|
but not in terms of `${prefix}', must each be overridden at install
|
||||||
|
time for the entire installation to be relocated. The approach of
|
||||||
|
makefile variable overrides for each directory variable is required by
|
||||||
|
the GNU Coding Standards, and ideally causes no recompilation.
|
||||||
|
However, some platforms have known limitations with the semantics of
|
||||||
|
shared libraries that end up requiring recompilation when using this
|
||||||
|
method, particularly noticeable in packages that use GNU Libtool.
|
||||||
|
|
||||||
|
The second method involves providing the `DESTDIR' variable. For
|
||||||
|
example, `make install DESTDIR=/alternate/directory' will prepend
|
||||||
|
`/alternate/directory' before all installation names. The approach of
|
||||||
|
`DESTDIR' overrides is not required by the GNU Coding Standards, and
|
||||||
|
does not work on platforms that have drive letters. On the other hand,
|
||||||
|
it does better at avoiding recompilation issues, and works well even
|
||||||
|
when some directory options were not specified in terms of `${prefix}'
|
||||||
|
at `configure' time.
|
||||||
|
|
||||||
|
Optional Features
|
||||||
|
=================
|
||||||
|
|
||||||
|
If the package supports it, you can cause programs to be installed
|
||||||
|
with an extra prefix or suffix on their names by giving `configure' the
|
||||||
|
option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
|
||||||
|
|
||||||
|
Some packages pay attention to `--enable-FEATURE' options to
|
||||||
|
`configure', where FEATURE indicates an optional part of the package.
|
||||||
|
They may also pay attention to `--with-PACKAGE' options, where PACKAGE
|
||||||
|
is something like `gnu-as' or `x' (for the X Window System). The
|
||||||
|
`README' should mention any `--enable-' and `--with-' options that the
|
||||||
|
package recognizes.
|
||||||
|
|
||||||
|
For packages that use the X Window System, `configure' can usually
|
||||||
|
find the X include and library files automatically, but if it doesn't,
|
||||||
|
you can use the `configure' options `--x-includes=DIR' and
|
||||||
|
`--x-libraries=DIR' to specify their locations.
|
||||||
|
|
||||||
|
Some packages offer the ability to configure how verbose the
|
||||||
|
execution of `make' will be. For these packages, running `./configure
|
||||||
|
--enable-silent-rules' sets the default to minimal output, which can be
|
||||||
|
overridden with `make V=1'; while running `./configure
|
||||||
|
--disable-silent-rules' sets the default to verbose, which can be
|
||||||
|
overridden with `make V=0'.
|
||||||
|
|
||||||
|
Particular systems
|
||||||
|
==================
|
||||||
|
|
||||||
|
On HP-UX, the default C compiler is not ANSI C compatible. If GNU
|
||||||
|
CC is not installed, it is recommended to use the following options in
|
||||||
|
order to use an ANSI C compiler:
|
||||||
|
|
||||||
|
./configure CC="cc -Ae -D_XOPEN_SOURCE=500"
|
||||||
|
|
||||||
|
and if that doesn't work, install pre-built binaries of GCC for HP-UX.
|
||||||
|
|
||||||
|
On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot
|
||||||
|
parse its `<wchar.h>' header file. The option `-nodtk' can be used as
|
||||||
|
a workaround. If GNU CC is not installed, it is therefore recommended
|
||||||
|
to try
|
||||||
|
|
||||||
|
./configure CC="cc"
|
||||||
|
|
||||||
|
and if that doesn't work, try
|
||||||
|
|
||||||
|
./configure CC="cc -nodtk"
|
||||||
|
|
||||||
|
On Solaris, don't put `/usr/ucb' early in your `PATH'. This
|
||||||
|
directory contains several dysfunctional programs; working variants of
|
||||||
|
these programs are available in `/usr/bin'. So, if you need `/usr/ucb'
|
||||||
|
in your `PATH', put it _after_ `/usr/bin'.
|
||||||
|
|
||||||
|
On Haiku, software installed for all users goes in `/boot/common',
|
||||||
|
not `/usr/local'. It is recommended to use the following options:
|
||||||
|
|
||||||
|
./configure --prefix=/boot/common
|
||||||
|
|
||||||
|
Specifying the System Type
|
||||||
|
==========================
|
||||||
|
|
||||||
|
There may be some features `configure' cannot figure out
|
||||||
|
automatically, but needs to determine by the type of machine the package
|
||||||
|
will run on. Usually, assuming the package is built to be run on the
|
||||||
|
_same_ architectures, `configure' can figure that out, but if it prints
|
||||||
|
a message saying it cannot guess the machine type, give it the
|
||||||
|
`--build=TYPE' option. TYPE can either be a short name for the system
|
||||||
|
type, such as `sun4', or a canonical name which has the form:
|
||||||
|
|
||||||
|
CPU-COMPANY-SYSTEM
|
||||||
|
|
||||||
|
where SYSTEM can have one of these forms:
|
||||||
|
|
||||||
|
OS
|
||||||
|
KERNEL-OS
|
||||||
|
|
||||||
|
See the file `config.sub' for the possible values of each field. If
|
||||||
|
`config.sub' isn't included in this package, then this package doesn't
|
||||||
|
need to know the machine type.
|
||||||
|
|
||||||
|
If you are _building_ compiler tools for cross-compiling, you should
|
||||||
|
use the option `--target=TYPE' to select the type of system they will
|
||||||
|
produce code for.
|
||||||
|
|
||||||
|
If you want to _use_ a cross compiler, that generates code for a
|
||||||
|
platform different from the build platform, you should specify the
|
||||||
|
"host" platform (i.e., that on which the generated programs will
|
||||||
|
eventually be run) with `--host=TYPE'.
|
||||||
|
|
||||||
|
Sharing Defaults
|
||||||
|
================
|
||||||
|
|
||||||
|
If you want to set default values for `configure' scripts to share,
|
||||||
|
you can create a site shell script called `config.site' that gives
|
||||||
|
default values for variables like `CC', `cache_file', and `prefix'.
|
||||||
|
`configure' looks for `PREFIX/share/config.site' if it exists, then
|
||||||
|
`PREFIX/etc/config.site' if it exists. Or, you can set the
|
||||||
|
`CONFIG_SITE' environment variable to the location of the site script.
|
||||||
|
A warning: not all `configure' scripts look for a site script.
|
||||||
|
|
||||||
|
Defining Variables
|
||||||
|
==================
|
||||||
|
|
||||||
|
Variables not defined in a site shell script can be set in the
|
||||||
|
environment passed to `configure'. However, some packages may run
|
||||||
|
configure again during the build, and the customized values of these
|
||||||
|
variables may be lost. In order to avoid this problem, you should set
|
||||||
|
them in the `configure' command line, using `VAR=value'. For example:
|
||||||
|
|
||||||
|
./configure CC=/usr/local2/bin/gcc
|
||||||
|
|
||||||
|
causes the specified `gcc' to be used as the C compiler (unless it is
|
||||||
|
overridden in the site shell script).
|
||||||
|
|
||||||
|
Unfortunately, this technique does not work for `CONFIG_SHELL' due to
|
||||||
|
an Autoconf bug. Until the bug is fixed you can use this workaround:
|
||||||
|
|
||||||
|
CONFIG_SHELL=/bin/bash /bin/bash ./configure CONFIG_SHELL=/bin/bash
|
||||||
|
|
||||||
|
`configure' Invocation
|
||||||
|
======================
|
||||||
|
|
||||||
|
`configure' recognizes the following options to control how it
|
||||||
|
operates.
|
||||||
|
|
||||||
|
`--help'
|
||||||
|
`-h'
|
||||||
|
Print a summary of all of the options to `configure', and exit.
|
||||||
|
|
||||||
|
`--help=short'
|
||||||
|
`--help=recursive'
|
||||||
|
Print a summary of the options unique to this package's
|
||||||
|
`configure', and exit. The `short' variant lists options used
|
||||||
|
only in the top level, while the `recursive' variant lists options
|
||||||
|
also present in any nested packages.
|
||||||
|
|
||||||
|
`--version'
|
||||||
|
`-V'
|
||||||
|
Print the version of Autoconf used to generate the `configure'
|
||||||
|
script, and exit.
|
||||||
|
|
||||||
|
`--cache-file=FILE'
|
||||||
|
Enable the cache: use and save the results of the tests in FILE,
|
||||||
|
traditionally `config.cache'. FILE defaults to `/dev/null' to
|
||||||
|
disable caching.
|
||||||
|
|
||||||
|
`--config-cache'
|
||||||
|
`-C'
|
||||||
|
Alias for `--cache-file=config.cache'.
|
||||||
|
|
||||||
|
`--quiet'
|
||||||
|
`--silent'
|
||||||
|
`-q'
|
||||||
|
Do not print messages saying which checks are being made. To
|
||||||
|
suppress all normal output, redirect it to `/dev/null' (any error
|
||||||
|
messages will still be shown).
|
||||||
|
|
||||||
|
`--srcdir=DIR'
|
||||||
|
Look for the package's source code in directory DIR. Usually
|
||||||
|
`configure' can determine that directory automatically.
|
||||||
|
|
||||||
|
`--prefix=DIR'
|
||||||
|
Use DIR as the installation prefix. *note Installation Names::
|
||||||
|
for more details, including other options available for fine-tuning
|
||||||
|
the installation locations.
|
||||||
|
|
||||||
|
`--no-create'
|
||||||
|
`-n'
|
||||||
|
Run the configure checks, but stop before creating any output
|
||||||
|
files.
|
||||||
|
|
||||||
|
`configure' also accepts some other, not widely useful, options. Run
|
||||||
|
`configure --help' for more details.
|
||||||
|
|
@ -0,0 +1,39 @@
|
|||||||
|
AUTOMAKE_OPTIONS = gnu
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -I m4
|
||||||
|
|
||||||
|
SUBDIRS = src
|
||||||
|
|
||||||
|
if BUILD_DOC
|
||||||
|
include aminclude.am
|
||||||
|
|
||||||
|
MOSTLYCLEANFILES = \
|
||||||
|
$(DX_CLEANFILES) \
|
||||||
|
doc
|
||||||
|
|
||||||
|
doxydir = @DX_DOCDIR@
|
||||||
|
dist_man3_MANS = $(doxydir)/man/man3/carddav.h.3
|
||||||
|
$(dist_man3_MANS): doxygen-doc
|
||||||
|
|
||||||
|
libcarddav_apidoc_filedir = $(docdir)
|
||||||
|
libcarddav_apidoc_file_DATA = \
|
||||||
|
doc/libcarddav.pdf
|
||||||
|
endif
|
||||||
|
|
||||||
|
libcarddav_configdir = $(libdir)/pkgconfig
|
||||||
|
libcarddav_config_DATA = libcarddav.pc
|
||||||
|
|
||||||
|
EXTRA_DIST = \
|
||||||
|
README \
|
||||||
|
COPYING \
|
||||||
|
AUTHORS \
|
||||||
|
ChangeLog \
|
||||||
|
INSTALL \
|
||||||
|
NEWS \
|
||||||
|
TODO \
|
||||||
|
rfc4791.pdf \
|
||||||
|
version.sh \
|
||||||
|
$(dx_config) \
|
||||||
|
doxygen-api.cfg \
|
||||||
|
libcarddav.pc \
|
||||||
|
autogen.sh
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,4 @@
|
|||||||
|
2008-03-29 (Michael Rasmussen)
|
||||||
|
As this is the first public version of the library there is not
|
||||||
|
so much news appart from the fact, that the library is now publicly
|
||||||
|
available for download.
|
@ -0,0 +1,20 @@
|
|||||||
|
libcarddav Version 0.1.0
|
||||||
|
|
||||||
|
These are the feature so far
|
||||||
|
- Support for VEVENT
|
||||||
|
- Add. Add a new event to the collection
|
||||||
|
- Get. Get one or more events from the collection
|
||||||
|
- Getall. Get all events from the collection
|
||||||
|
- Modify. Modify an event
|
||||||
|
- Delete. Delete an event
|
||||||
|
- GetCardName. Get the display name from the collection
|
||||||
|
- IsCardDAV. Test whether a given URL represents a CardDAV collection
|
||||||
|
|
||||||
|
See INSTALL for further information.
|
||||||
|
|
||||||
|
For an overview of the current status and future feature implementation
|
||||||
|
study the TODO file.
|
||||||
|
|
||||||
|
Happy Hacking
|
||||||
|
Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
Michael Rasmussen (mir@datanom.net)
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,186 @@
|
|||||||
|
# Copyright (C) 2004 Oren Ben-Kiki
|
||||||
|
# This file is distributed under the same terms as the Automake macro files.
|
||||||
|
|
||||||
|
# Generate automatic documentation using Doxygen. Goals and variables values
|
||||||
|
# are controlled by the various DX_COND_??? conditionals set by autoconf.
|
||||||
|
#
|
||||||
|
# The provided goals are:
|
||||||
|
# doxygen-doc: Generate all doxygen documentation.
|
||||||
|
# doxygen-run: Run doxygen, which will generate some of the documentation
|
||||||
|
# (HTML, CHM, CHI, MAN, RTF, XML) but will not do the post
|
||||||
|
# processing required for the rest of it (PS, PDF, and some MAN).
|
||||||
|
# doxygen-man: Rename some doxygen generated man pages.
|
||||||
|
# doxygen-ps: Generate doxygen PostScript documentation.
|
||||||
|
# doxygen-pdf: Generate doxygen PDF documentation.
|
||||||
|
#
|
||||||
|
# Note that by default these are not integrated into the automake goals. If
|
||||||
|
# doxygen is used to generate man pages, you can achieve this integration by
|
||||||
|
# setting man3_MANS to the list of man pages generated and then adding the
|
||||||
|
# dependency:
|
||||||
|
#
|
||||||
|
# $(man3_MANS): doxygen-doc
|
||||||
|
#
|
||||||
|
# This will cause make to run doxygen and generate all the documentation.
|
||||||
|
#
|
||||||
|
# The following variable is intended for use in Makefile.am:
|
||||||
|
#
|
||||||
|
# DX_CLEANFILES = everything to clean.
|
||||||
|
#
|
||||||
|
# This is usually added to MOSTLYCLEANFILES.
|
||||||
|
|
||||||
|
## --------------------------------- ##
|
||||||
|
## Format-independent Doxygen rules. ##
|
||||||
|
## --------------------------------- ##
|
||||||
|
|
||||||
|
if DX_COND_doc
|
||||||
|
|
||||||
|
## ------------------------------- ##
|
||||||
|
## Rules specific for HTML output. ##
|
||||||
|
## ------------------------------- ##
|
||||||
|
|
||||||
|
if DX_COND_html
|
||||||
|
|
||||||
|
DX_CLEAN_HTML = @DX_DOCDIR@/html
|
||||||
|
|
||||||
|
endif DX_COND_html
|
||||||
|
|
||||||
|
## ------------------------------ ##
|
||||||
|
## Rules specific for CHM output. ##
|
||||||
|
## ------------------------------ ##
|
||||||
|
|
||||||
|
if DX_COND_chm
|
||||||
|
|
||||||
|
DX_CLEAN_CHM = @DX_DOCDIR@/chm
|
||||||
|
|
||||||
|
if DX_COND_chi
|
||||||
|
|
||||||
|
DX_CLEAN_CHI = @DX_DOCDIR@/@PACKAGE@.chi
|
||||||
|
|
||||||
|
endif DX_COND_chi
|
||||||
|
|
||||||
|
endif DX_COND_chm
|
||||||
|
|
||||||
|
## ------------------------------ ##
|
||||||
|
## Rules specific for MAN output. ##
|
||||||
|
## ------------------------------ ##
|
||||||
|
|
||||||
|
if DX_COND_man
|
||||||
|
|
||||||
|
DX_CLEAN_MAN = @DX_DOCDIR@/man
|
||||||
|
|
||||||
|
endif DX_COND_man
|
||||||
|
|
||||||
|
## ------------------------------ ##
|
||||||
|
## Rules specific for RTF output. ##
|
||||||
|
## ------------------------------ ##
|
||||||
|
|
||||||
|
if DX_COND_rtf
|
||||||
|
|
||||||
|
DX_CLEAN_RTF = @DX_DOCDIR@/rtf
|
||||||
|
|
||||||
|
endif DX_COND_rtf
|
||||||
|
|
||||||
|
## ------------------------------ ##
|
||||||
|
## Rules specific for XML output. ##
|
||||||
|
## ------------------------------ ##
|
||||||
|
|
||||||
|
if DX_COND_xml
|
||||||
|
|
||||||
|
DX_CLEAN_XML = @DX_DOCDIR@/xml
|
||||||
|
|
||||||
|
endif DX_COND_xml
|
||||||
|
|
||||||
|
## ----------------------------- ##
|
||||||
|
## Rules specific for PS output. ##
|
||||||
|
## ----------------------------- ##
|
||||||
|
|
||||||
|
if DX_COND_ps
|
||||||
|
|
||||||
|
DX_CLEAN_PS = @DX_DOCDIR@/@PACKAGE@.ps
|
||||||
|
|
||||||
|
DX_PS_GOAL = doxygen-ps
|
||||||
|
|
||||||
|
doxygen-ps: @DX_DOCDIR@/@PACKAGE@.ps
|
||||||
|
|
||||||
|
@DX_DOCDIR@/@PACKAGE@.ps: @DX_DOCDIR@/@PACKAGE@.tag
|
||||||
|
cd @DX_DOCDIR@/latex; \
|
||||||
|
rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \
|
||||||
|
$(DX_LATEX) refman.tex; \
|
||||||
|
$(MAKEINDEX_PATH) refman.idx; \
|
||||||
|
$(DX_LATEX) refman.tex; \
|
||||||
|
countdown=5; \
|
||||||
|
while $(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \
|
||||||
|
refman.log > /dev/null 2>&1 \
|
||||||
|
&& test $$countdown -gt 0; do \
|
||||||
|
$(DX_LATEX) refman.tex; \
|
||||||
|
countdown=`expr $$countdown - 1`; \
|
||||||
|
done; \
|
||||||
|
$(DX_DVIPS) -o ../@PACKAGE@.ps refman.dvi
|
||||||
|
|
||||||
|
endif DX_COND_ps
|
||||||
|
|
||||||
|
## ------------------------------ ##
|
||||||
|
## Rules specific for PDF output. ##
|
||||||
|
## ------------------------------ ##
|
||||||
|
|
||||||
|
if DX_COND_pdf
|
||||||
|
|
||||||
|
DX_CLEAN_PDF = @DX_DOCDIR@/@PACKAGE@.pdf
|
||||||
|
|
||||||
|
DX_PDF_GOAL = doxygen-pdf
|
||||||
|
|
||||||
|
doxygen-pdf: @DX_DOCDIR@/@PACKAGE@.pdf
|
||||||
|
|
||||||
|
@DX_DOCDIR@/@PACKAGE@.pdf: @DX_DOCDIR@/@PACKAGE@.tag
|
||||||
|
cd @DX_DOCDIR@/latex; \
|
||||||
|
rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \
|
||||||
|
$(DX_PDFLATEX) refman.tex; \
|
||||||
|
$(DX_MAKEINDEX) refman.idx; \
|
||||||
|
$(DX_PDFLATEX) refman.tex; \
|
||||||
|
countdown=5; \
|
||||||
|
while $(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \
|
||||||
|
refman.log > /dev/null 2>&1 \
|
||||||
|
&& test $$countdown -gt 0; do \
|
||||||
|
$(DX_PDFLATEX) refman.tex; \
|
||||||
|
countdown=`expr $$countdown - 1`; \
|
||||||
|
done; \
|
||||||
|
mv refman.pdf ../@PACKAGE@.pdf
|
||||||
|
|
||||||
|
endif DX_COND_pdf
|
||||||
|
|
||||||
|
## ------------------------------------------------- ##
|
||||||
|
## Rules specific for LaTeX (shared for PS and PDF). ##
|
||||||
|
## ------------------------------------------------- ##
|
||||||
|
|
||||||
|
if DX_COND_latex
|
||||||
|
|
||||||
|
DX_CLEAN_LATEX = @DX_DOCDIR@/latex
|
||||||
|
|
||||||
|
endif DX_COND_latex
|
||||||
|
|
||||||
|
.PHONY: doxygen-run doxygen-doc $(DX_PS_GOAL) $(DX_PDF_GOAL)
|
||||||
|
|
||||||
|
.INTERMEDIATE: doxygen-run $(DX_PS_GOAL) $(DX_PDF_GOAL)
|
||||||
|
|
||||||
|
doxygen-run: @DX_DOCDIR@/@PACKAGE@.tag
|
||||||
|
|
||||||
|
doxygen-doc: doxygen-run $(DX_PS_GOAL) $(DX_PDF_GOAL)
|
||||||
|
|
||||||
|
@DX_DOCDIR@/@PACKAGE@.tag: $(DX_CONFIG) $(pkginclude_HEADERS)
|
||||||
|
rm -rf @DX_DOCDIR@
|
||||||
|
$(DX_ENV) $(DX_DOXYGEN) $(srcdir)/$(DX_CONFIG)
|
||||||
|
|
||||||
|
DX_CLEANFILES = \
|
||||||
|
@DX_DOCDIR@/@PACKAGE@.tag \
|
||||||
|
-r \
|
||||||
|
$(DX_CLEAN_HTML) \
|
||||||
|
$(DX_CLEAN_CHM) \
|
||||||
|
$(DX_CLEAN_CHI) \
|
||||||
|
$(DX_CLEAN_MAN) \
|
||||||
|
$(DX_CLEAN_RTF) \
|
||||||
|
$(DX_CLEAN_XML) \
|
||||||
|
$(DX_CLEAN_PS) \
|
||||||
|
$(DX_CLEAN_PDF) \
|
||||||
|
$(DX_CLEAN_LATEX)
|
||||||
|
|
||||||
|
endif DX_COND_doc
|
@ -0,0 +1,32 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
echo "Rebuilding build system......"
|
||||||
|
|
||||||
|
autoreconf --version 2>&1 > /dev/null 2>&1
|
||||||
|
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
AUTORECONF=autoreconf
|
||||||
|
else
|
||||||
|
AUTORECONF=
|
||||||
|
fi
|
||||||
|
|
||||||
|
error() {
|
||||||
|
echo "Missing tool: $1"
|
||||||
|
echo "Cannot proceed until the missing tool is available"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ ! -z ${AUTORECONF} ]; then
|
||||||
|
echo "Using autoreconf to rebuild build system"
|
||||||
|
autoreconf --force --install --symlink
|
||||||
|
else
|
||||||
|
echo "No autoreconf found. Using plain old tools to rebuild build system"
|
||||||
|
libtoolize --automake --force || error libtoolize
|
||||||
|
aclocal -I m4|| error aclocal
|
||||||
|
autoheader --force || error autoheader
|
||||||
|
automake --add-missing --force-missing --gnu || error automake
|
||||||
|
autoconf --force || error autoconf
|
||||||
|
fi
|
||||||
|
./configure $*
|
||||||
|
|
||||||
|
exit 0
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,68 @@
|
|||||||
|
/* config.h.in. Generated from configure.ac by autoheader. */
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <dlfcn.h> header file. */
|
||||||
|
#undef HAVE_DLFCN_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <inttypes.h> header file. */
|
||||||
|
#undef HAVE_INTTYPES_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <memory.h> header file. */
|
||||||
|
#undef HAVE_MEMORY_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <stdint.h> header file. */
|
||||||
|
#undef HAVE_STDINT_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <stdlib.h> header file. */
|
||||||
|
#undef HAVE_STDLIB_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <strings.h> header file. */
|
||||||
|
#undef HAVE_STRINGS_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <string.h> header file. */
|
||||||
|
#undef HAVE_STRING_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <sys/stat.h> header file. */
|
||||||
|
#undef HAVE_SYS_STAT_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <sys/types.h> header file. */
|
||||||
|
#undef HAVE_SYS_TYPES_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <unistd.h> header file. */
|
||||||
|
#undef HAVE_UNISTD_H
|
||||||
|
|
||||||
|
/* Define to the sub-directory in which libtool stores uninstalled libraries.
|
||||||
|
*/
|
||||||
|
#undef LT_OBJDIR
|
||||||
|
|
||||||
|
/* Name of package */
|
||||||
|
#undef PACKAGE
|
||||||
|
|
||||||
|
/* Define to the address where bug reports for this package should be sent. */
|
||||||
|
#undef PACKAGE_BUGREPORT
|
||||||
|
|
||||||
|
/* Define to the full name of this package. */
|
||||||
|
#undef PACKAGE_NAME
|
||||||
|
|
||||||
|
/* Define to the full name and version of this package. */
|
||||||
|
#undef PACKAGE_STRING
|
||||||
|
|
||||||
|
/* Define to the one symbol short name of this package. */
|
||||||
|
#undef PACKAGE_TARNAME
|
||||||
|
|
||||||
|
/* Define to the version of this package. */
|
||||||
|
#undef PACKAGE_VERSION
|
||||||
|
|
||||||
|
/* Define to 1 if you have the ANSI C header files. */
|
||||||
|
#undef STDC_HEADERS
|
||||||
|
|
||||||
|
/* Define to 1 if your <sys/time.h> declares `struct tm'. */
|
||||||
|
#undef TM_IN_SYS_TIME
|
||||||
|
|
||||||
|
/* Version number of package */
|
||||||
|
#undef VERSION
|
||||||
|
|
||||||
|
/* Define to empty if `const' does not conform to ANSI C. */
|
||||||
|
#undef const
|
||||||
|
|
||||||
|
/* Define to `unsigned int' if <sys/types.h> does not define. */
|
||||||
|
#undef size_t
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,120 @@
|
|||||||
|
# -*- Autoconf -*-
|
||||||
|
# Process this file with autoconf to produce a configure script.
|
||||||
|
|
||||||
|
AC_PREREQ(2.61)
|
||||||
|
|
||||||
|
AC_INIT([libcarddav], m4_esyscmd([sh ./version.sh | tr -d '\n']), [mir@datanom.net])
|
||||||
|
AC_CONFIG_MACRO_DIR([m4])
|
||||||
|
|
||||||
|
LIBVERSION=m4_esyscmd([sh ./version.sh LIBTOOL | tr -d '\n'])
|
||||||
|
AC_SUBST(LIBVERSION)
|
||||||
|
|
||||||
|
AC_CANONICAL_SYSTEM
|
||||||
|
|
||||||
|
# Generate documentation
|
||||||
|
# API
|
||||||
|
DX_HTML_FEATURE(OFF)
|
||||||
|
DX_CHM_FEATURE(OFF)
|
||||||
|
DX_CHI_FEATURE(OFF)
|
||||||
|
DX_MAN_FEATURE(ON)
|
||||||
|
DX_RTF_FEATURE(OFF)
|
||||||
|
DX_XML_FEATURE(OFF)
|
||||||
|
DX_PDF_FEATURE(ON)
|
||||||
|
DX_PS_FEATURE(OFF)
|
||||||
|
DX_INIT_DOXYGEN(libcarddav, doxygen-api.cfg, doc)
|
||||||
|
|
||||||
|
AM_INIT_AUTOMAKE([dist-bzip2 1.9.6])
|
||||||
|
AM_MAINTAINER_MODE
|
||||||
|
AC_CONFIG_HEADER([config.h])
|
||||||
|
AM_MAINTAINER_MODE
|
||||||
|
|
||||||
|
if test $USE_MAINTAINER_MODE = yes; then
|
||||||
|
CFLAGS="-g -Wall -D_REENTRANT"
|
||||||
|
STATIC=1
|
||||||
|
DYNAMIC=0
|
||||||
|
BUILD_TEST=true
|
||||||
|
else
|
||||||
|
#CFLAGS="-g -Wall"
|
||||||
|
CFLAGS="$CFLAGS -O2 -Wall -D_REENTRANT"
|
||||||
|
STATIC=0
|
||||||
|
DYNAMIC=1
|
||||||
|
BUILD_TEST=false
|
||||||
|
fi
|
||||||
|
AM_CONDITIONAL([STATIC_LINK], [test $STATIC -eq 1])
|
||||||
|
AM_CONDITIONAL([DYNAMIC_LINK], [test $DYNAMIC -eq 1])
|
||||||
|
|
||||||
|
# Checks for programs.
|
||||||
|
AC_PROG_CC
|
||||||
|
AC_LANG_C
|
||||||
|
AC_ISC_POSIX
|
||||||
|
AC_PROG_INSTALL
|
||||||
|
AC_PROG_LN_S
|
||||||
|
AC_PROG_MAKE_SET
|
||||||
|
AC_HEADER_STDC
|
||||||
|
AC_PROG_CPP
|
||||||
|
AM_PROG_LIBTOOL
|
||||||
|
AC_PROG_INSTALL
|
||||||
|
|
||||||
|
# Checks for libraries.
|
||||||
|
PKG_CHECK_MODULES(CURL, [libcurl >= 7.15.5])
|
||||||
|
AC_SUBST(CURL_CFLAGS)
|
||||||
|
AC_SUBST(CURL_LIBS)
|
||||||
|
|
||||||
|
PKG_CHECK_MODULES(GLIB, [glib-2.0 >= 2.6 gthread-2.0])
|
||||||
|
AC_SUBST(GLIB_CFLAGS)
|
||||||
|
AC_SUBST(GLIB_LIBS)
|
||||||
|
|
||||||
|
#PKG_CHECK_MODULES(OPENSSL, [openssl >= 0.9.8])
|
||||||
|
#AC_SUBST(OPENSSL_CFLAGS)
|
||||||
|
#AC_SUBST(OPENSSL_LIBS)
|
||||||
|
|
||||||
|
# Checks for header files.
|
||||||
|
AC_HEADER_STDC
|
||||||
|
|
||||||
|
# Checks for typedefs, structures, and compiler characteristics.
|
||||||
|
AC_C_CONST
|
||||||
|
AC_TYPE_SIZE_T
|
||||||
|
AC_STRUCT_TM
|
||||||
|
|
||||||
|
# Checks for library functions.
|
||||||
|
|
||||||
|
# Build API documentation
|
||||||
|
AC_ARG_ENABLE([doc],
|
||||||
|
[AC_HELP_STRING(--enable-doc, Build API documentation (default=no))],
|
||||||
|
[case "${enableval}" in
|
||||||
|
yes) doc=true ;;
|
||||||
|
no) doc=false ;;
|
||||||
|
*) AC_MSG_ERROR([bad value "${enableval}" for --enable-doc]) ;;
|
||||||
|
esac], [doc=false])
|
||||||
|
AM_CONDITIONAL([BUILD_DOC], [test x$doc = xtrue])
|
||||||
|
|
||||||
|
AC_CONFIG_COMMANDS(
|
||||||
|
summary,
|
||||||
|
[echo ""
|
||||||
|
echo "libcarddav will be compiled with these settings:"
|
||||||
|
echo ""
|
||||||
|
echo -e "\tCFLAGS:\t\t\t\t$cflags"
|
||||||
|
echo -e "\tBuild API documentation:\t$doc"
|
||||||
|
echo -e "\tLibrary is linked:\t\t$link"
|
||||||
|
echo ""
|
||||||
|
echo -e "Now run make to build the library"
|
||||||
|
echo ""
|
||||||
|
echo -e "Please send bugs or feature requests to the maintainer(s)."
|
||||||
|
echo -e "Email addresses can be found in the AUTHORS file."
|
||||||
|
echo ""],
|
||||||
|
[carddav=${carddav}
|
||||||
|
unittest=${unittest}
|
||||||
|
doc=${doc}
|
||||||
|
cflags="${CFLAGS}"
|
||||||
|
if test $DYNAMIC -eq 1; then
|
||||||
|
link="Dynamic"
|
||||||
|
else
|
||||||
|
link="Static"
|
||||||
|
fi]
|
||||||
|
)
|
||||||
|
|
||||||
|
AC_OUTPUT([
|
||||||
|
Makefile
|
||||||
|
libcarddav.pc
|
||||||
|
src/Makefile
|
||||||
|
])
|
@ -0,0 +1,630 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
# depcomp - compile a program generating dependencies as side-effects
|
||||||
|
|
||||||
|
scriptversion=2009-04-28.21; # UTC
|
||||||
|
|
||||||
|
# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006, 2007, 2009 Free
|
||||||
|
# Software Foundation, Inc.
|
||||||
|
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
# any later version.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
# As a special exception to the GNU General Public License, if you
|
||||||
|
# distribute this file as part of a program that contains a
|
||||||
|
# configuration script generated by Autoconf, you may include it under
|
||||||
|
# the same distribution terms that you use for the rest of that program.
|
||||||
|
|
||||||
|
# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
'')
|
||||||
|
echo "$0: No command. Try \`$0 --help' for more information." 1>&2
|
||||||
|
exit 1;
|
||||||
|
;;
|
||||||
|
-h | --h*)
|
||||||
|
cat <<\EOF
|
||||||
|
Usage: depcomp [--help] [--version] PROGRAM [ARGS]
|
||||||
|
|
||||||
|
Run PROGRAMS ARGS to compile a file, generating dependencies
|
||||||
|
as side-effects.
|
||||||
|
|
||||||
|
Environment variables:
|
||||||
|
depmode Dependency tracking mode.
|
||||||
|
source Source file read by `PROGRAMS ARGS'.
|
||||||
|
object Object file output by `PROGRAMS ARGS'.
|
||||||
|
DEPDIR directory where to store dependencies.
|
||||||
|
depfile Dependency file to output.
|
||||||
|
tmpdepfile Temporary file to use when outputing dependencies.
|
||||||
|
libtool Whether libtool is used (yes/no).
|
||||||
|
|
||||||
|
Report bugs to <bug-automake@gnu.org>.
|
||||||
|
EOF
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
-v | --v*)
|
||||||
|
echo "depcomp $scriptversion"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
||||||
|
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
|
||||||
|
depfile=${depfile-`echo "$object" |
|
||||||
|
sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
|
||||||
|
tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
||||||
|
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
|
||||||
|
# Some modes work just like other modes, but use different flags. We
|
||||||
|
# parameterize here, but still list the modes in the big case below,
|
||||||
|
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
||||||
|
# here, because this file can only contain one case statement.
|
||||||
|
if test "$depmode" = hp; then
|
||||||
|
# HP compiler uses -M and no extra arg.
|
||||||
|
gccflag=-M
|
||||||
|
depmode=gcc
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$depmode" = dashXmstdout; then
|
||||||
|
# This is just like dashmstdout with a different argument.
|
||||||
|
dashmflag=-xM
|
||||||
|
depmode=dashmstdout
|
||||||
|
fi
|
||||||
|
|
||||||
|
cygpath_u="cygpath -u -f -"
|
||||||
|
if test "$depmode" = msvcmsys; then
|
||||||
|
# This is just like msvisualcpp but w/o cygpath translation.
|
||||||
|
# Just convert the backslash-escaped backslashes to single forward
|
||||||
|
# slashes to satisfy depend.m4
|
||||||
|
cygpath_u="sed s,\\\\\\\\,/,g"
|
||||||
|
depmode=msvisualcpp
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$depmode" in
|
||||||
|
gcc3)
|
||||||
|
## gcc 3 implements dependency tracking that does exactly what
|
||||||
|
## we want. Yay! Note: for some reason libtool 1.4 doesn't like
|
||||||
|
## it if -MD -MP comes after the -MF stuff. Hmm.
|
||||||
|
## Unfortunately, FreeBSD c89 acceptance of flags depends upon
|
||||||
|
## the command line argument order; so add the flags where they
|
||||||
|
## appear in depend2.am. Note that the slowdown incurred here
|
||||||
|
## affects only configure: in makefiles, %FASTDEP% shortcuts this.
|
||||||
|
for arg
|
||||||
|
do
|
||||||
|
case $arg in
|
||||||
|
-c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;;
|
||||||
|
*) set fnord "$@" "$arg" ;;
|
||||||
|
esac
|
||||||
|
shift # fnord
|
||||||
|
shift # $arg
|
||||||
|
done
|
||||||
|
"$@"
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
mv "$tmpdepfile" "$depfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
gcc)
|
||||||
|
## There are various ways to get dependency output from gcc. Here's
|
||||||
|
## why we pick this rather obscure method:
|
||||||
|
## - Don't want to use -MD because we'd like the dependencies to end
|
||||||
|
## up in a subdir. Having to rename by hand is ugly.
|
||||||
|
## (We might end up doing this anyway to support other compilers.)
|
||||||
|
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
||||||
|
## -MM, not -M (despite what the docs say).
|
||||||
|
## - Using -M directly means running the compiler twice (even worse
|
||||||
|
## than renaming).
|
||||||
|
if test -z "$gccflag"; then
|
||||||
|
gccflag=-MD,
|
||||||
|
fi
|
||||||
|
"$@" -Wp,"$gccflag$tmpdepfile"
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
rm -f "$depfile"
|
||||||
|
echo "$object : \\" > "$depfile"
|
||||||
|
alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
|
||||||
|
## The second -e expression handles DOS-style file names with drive letters.
|
||||||
|
sed -e 's/^[^:]*: / /' \
|
||||||
|
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
||||||
|
## This next piece of magic avoids the `deleted header file' problem.
|
||||||
|
## The problem is that when a header file which appears in a .P file
|
||||||
|
## is deleted, the dependency causes make to die (because there is
|
||||||
|
## typically no way to rebuild the header). We avoid this by adding
|
||||||
|
## dummy dependencies for each header file. Too bad gcc doesn't do
|
||||||
|
## this for us directly.
|
||||||
|
tr ' ' '
|
||||||
|
' < "$tmpdepfile" |
|
||||||
|
## Some versions of gcc put a space before the `:'. On the theory
|
||||||
|
## that the space means something, we add a space to the output as
|
||||||
|
## well.
|
||||||
|
## Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
|
## correctly. Breaking it into two sed invocations is a workaround.
|
||||||
|
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
hp)
|
||||||
|
# This case exists only to let depend.m4 do its work. It works by
|
||||||
|
# looking at the text of this script. This case will never be run,
|
||||||
|
# since it is checked for above.
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
|
sgi)
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
"$@" "-Wp,-MDupdate,$tmpdepfile"
|
||||||
|
else
|
||||||
|
"$@" -MDupdate "$tmpdepfile"
|
||||||
|
fi
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
rm -f "$depfile"
|
||||||
|
|
||||||
|
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
||||||
|
echo "$object : \\" > "$depfile"
|
||||||
|
|
||||||
|
# Clip off the initial element (the dependent). Don't try to be
|
||||||
|
# clever and replace this with sed code, as IRIX sed won't handle
|
||||||
|
# lines with more than a fixed number of characters (4096 in
|
||||||
|
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
||||||
|
# the IRIX cc adds comments like `#:fec' to the end of the
|
||||||
|
# dependency line.
|
||||||
|
tr ' ' '
|
||||||
|
' < "$tmpdepfile" \
|
||||||
|
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
|
||||||
|
tr '
|
||||||
|
' ' ' >> "$depfile"
|
||||||
|
echo >> "$depfile"
|
||||||
|
|
||||||
|
# The second pass generates a dummy entry for each header file.
|
||||||
|
tr ' ' '
|
||||||
|
' < "$tmpdepfile" \
|
||||||
|
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
||||||
|
>> "$depfile"
|
||||||
|
else
|
||||||
|
# The sourcefile does not contain any dependencies, so just
|
||||||
|
# store a dummy comment line, to avoid errors with the Makefile
|
||||||
|
# "include basename.Plo" scheme.
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
fi
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
aix)
|
||||||
|
# The C for AIX Compiler uses -M and outputs the dependencies
|
||||||
|
# in a .u file. In older versions, this file always lives in the
|
||||||
|
# current directory. Also, the AIX compiler puts `$object:' at the
|
||||||
|
# start of each line; $object doesn't have directory information.
|
||||||
|
# Version 6 uses the directory in both cases.
|
||||||
|
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
||||||
|
test "x$dir" = "x$object" && dir=
|
||||||
|
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
tmpdepfile1=$dir$base.u
|
||||||
|
tmpdepfile2=$base.u
|
||||||
|
tmpdepfile3=$dir.libs/$base.u
|
||||||
|
"$@" -Wc,-M
|
||||||
|
else
|
||||||
|
tmpdepfile1=$dir$base.u
|
||||||
|
tmpdepfile2=$dir$base.u
|
||||||
|
tmpdepfile3=$dir$base.u
|
||||||
|
"$@" -M
|
||||||
|
fi
|
||||||
|
stat=$?
|
||||||
|
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
|
||||||
|
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
|
do
|
||||||
|
test -f "$tmpdepfile" && break
|
||||||
|
done
|
||||||
|
if test -f "$tmpdepfile"; then
|
||||||
|
# Each line is of the form `foo.o: dependent.h'.
|
||||||
|
# Do two passes, one to just change these to
|
||||||
|
# `$object: dependent.h' and one to simply `dependent.h:'.
|
||||||
|
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
||||||
|
# That's a tab and a space in the [].
|
||||||
|
sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
||||||
|
else
|
||||||
|
# The sourcefile does not contain any dependencies, so just
|
||||||
|
# store a dummy comment line, to avoid errors with the Makefile
|
||||||
|
# "include basename.Plo" scheme.
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
fi
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
icc)
|
||||||
|
# Intel's C compiler understands `-MD -MF file'. However on
|
||||||
|
# icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
|
||||||
|
# ICC 7.0 will fill foo.d with something like
|
||||||
|
# foo.o: sub/foo.c
|
||||||
|
# foo.o: sub/foo.h
|
||||||
|
# which is wrong. We want:
|
||||||
|
# sub/foo.o: sub/foo.c
|
||||||
|
# sub/foo.o: sub/foo.h
|
||||||
|
# sub/foo.c:
|
||||||
|
# sub/foo.h:
|
||||||
|
# ICC 7.1 will output
|
||||||
|
# foo.o: sub/foo.c sub/foo.h
|
||||||
|
# and will wrap long lines using \ :
|
||||||
|
# foo.o: sub/foo.c ... \
|
||||||
|
# sub/foo.h ... \
|
||||||
|
# ...
|
||||||
|
|
||||||
|
"$@" -MD -MF "$tmpdepfile"
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
rm -f "$depfile"
|
||||||
|
# Each line is of the form `foo.o: dependent.h',
|
||||||
|
# or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
|
||||||
|
# Do two passes, one to just change these to
|
||||||
|
# `$object: dependent.h' and one to simply `dependent.h:'.
|
||||||
|
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
||||||
|
# Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
|
# correctly. Breaking it into two sed invocations is a workaround.
|
||||||
|
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" |
|
||||||
|
sed -e 's/$/ :/' >> "$depfile"
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
hp2)
|
||||||
|
# The "hp" stanza above does not work with aCC (C++) and HP's ia64
|
||||||
|
# compilers, which have integrated preprocessors. The correct option
|
||||||
|
# to use with these is +Maked; it writes dependencies to a file named
|
||||||
|
# 'foo.d', which lands next to the object file, wherever that
|
||||||
|
# happens to be.
|
||||||
|
# Much of this is similar to the tru64 case; see comments there.
|
||||||
|
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
||||||
|
test "x$dir" = "x$object" && dir=
|
||||||
|
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
tmpdepfile1=$dir$base.d
|
||||||
|
tmpdepfile2=$dir.libs/$base.d
|
||||||
|
"$@" -Wc,+Maked
|
||||||
|
else
|
||||||
|
tmpdepfile1=$dir$base.d
|
||||||
|
tmpdepfile2=$dir$base.d
|
||||||
|
"$@" +Maked
|
||||||
|
fi
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile1" "$tmpdepfile2"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
|
||||||
|
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2"
|
||||||
|
do
|
||||||
|
test -f "$tmpdepfile" && break
|
||||||
|
done
|
||||||
|
if test -f "$tmpdepfile"; then
|
||||||
|
sed -e "s,^.*\.[a-z]*:,$object:," "$tmpdepfile" > "$depfile"
|
||||||
|
# Add `dependent.h:' lines.
|
||||||
|
sed -ne '2,${
|
||||||
|
s/^ *//
|
||||||
|
s/ \\*$//
|
||||||
|
s/$/:/
|
||||||
|
p
|
||||||
|
}' "$tmpdepfile" >> "$depfile"
|
||||||
|
else
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
fi
|
||||||
|
rm -f "$tmpdepfile" "$tmpdepfile2"
|
||||||
|
;;
|
||||||
|
|
||||||
|
tru64)
|
||||||
|
# The Tru64 compiler uses -MD to generate dependencies as a side
|
||||||
|
# effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
|
||||||
|
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
||||||
|
# dependencies in `foo.d' instead, so we check for that too.
|
||||||
|
# Subdirectories are respected.
|
||||||
|
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
||||||
|
test "x$dir" = "x$object" && dir=
|
||||||
|
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
||||||
|
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
# With Tru64 cc, shared objects can also be used to make a
|
||||||
|
# static library. This mechanism is used in libtool 1.4 series to
|
||||||
|
# handle both shared and static libraries in a single compilation.
|
||||||
|
# With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d.
|
||||||
|
#
|
||||||
|
# With libtool 1.5 this exception was removed, and libtool now
|
||||||
|
# generates 2 separate objects for the 2 libraries. These two
|
||||||
|
# compilations output dependencies in $dir.libs/$base.o.d and
|
||||||
|
# in $dir$base.o.d. We have to check for both files, because
|
||||||
|
# one of the two compilations can be disabled. We should prefer
|
||||||
|
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
||||||
|
# automatically cleaned when .libs/ is deleted, while ignoring
|
||||||
|
# the former would cause a distcleancheck panic.
|
||||||
|
tmpdepfile1=$dir.libs/$base.lo.d # libtool 1.4
|
||||||
|
tmpdepfile2=$dir$base.o.d # libtool 1.5
|
||||||
|
tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5
|
||||||
|
tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504
|
||||||
|
"$@" -Wc,-MD
|
||||||
|
else
|
||||||
|
tmpdepfile1=$dir$base.o.d
|
||||||
|
tmpdepfile2=$dir$base.d
|
||||||
|
tmpdepfile3=$dir$base.d
|
||||||
|
tmpdepfile4=$dir$base.d
|
||||||
|
"$@" -MD
|
||||||
|
fi
|
||||||
|
|
||||||
|
stat=$?
|
||||||
|
if test $stat -eq 0; then :
|
||||||
|
else
|
||||||
|
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
|
||||||
|
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
||||||
|
do
|
||||||
|
test -f "$tmpdepfile" && break
|
||||||
|
done
|
||||||
|
if test -f "$tmpdepfile"; then
|
||||||
|
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
||||||
|
# That's a tab and a space in the [].
|
||||||
|
sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
||||||
|
else
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
fi
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
#nosideeffect)
|
||||||
|
# This comment above is used by automake to tell side-effect
|
||||||
|
# dependency tracking mechanisms from slower ones.
|
||||||
|
|
||||||
|
dashmstdout)
|
||||||
|
# Important note: in order to support this mode, a compiler *must*
|
||||||
|
# always write the preprocessed file to stdout, regardless of -o.
|
||||||
|
"$@" || exit $?
|
||||||
|
|
||||||
|
# Remove the call to Libtool.
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
while test "X$1" != 'X--mode=compile'; do
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove `-o $object'.
|
||||||
|
IFS=" "
|
||||||
|
for arg
|
||||||
|
do
|
||||||
|
case $arg in
|
||||||
|
-o)
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
$object)
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
set fnord "$@" "$arg"
|
||||||
|
shift # fnord
|
||||||
|
shift # $arg
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
test -z "$dashmflag" && dashmflag=-M
|
||||||
|
# Require at least two characters before searching for `:'
|
||||||
|
# in the target name. This is to cope with DOS-style filenames:
|
||||||
|
# a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
|
||||||
|
"$@" $dashmflag |
|
||||||
|
sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile"
|
||||||
|
rm -f "$depfile"
|
||||||
|
cat < "$tmpdepfile" > "$depfile"
|
||||||
|
tr ' ' '
|
||||||
|
' < "$tmpdepfile" | \
|
||||||
|
## Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
|
## correctly. Breaking it into two sed invocations is a workaround.
|
||||||
|
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
dashXmstdout)
|
||||||
|
# This case only exists to satisfy depend.m4. It is never actually
|
||||||
|
# run, as this mode is specially recognized in the preamble.
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
|
makedepend)
|
||||||
|
"$@" || exit $?
|
||||||
|
# Remove any Libtool call
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
while test "X$1" != 'X--mode=compile'; do
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
# X makedepend
|
||||||
|
shift
|
||||||
|
cleared=no eat=no
|
||||||
|
for arg
|
||||||
|
do
|
||||||
|
case $cleared in
|
||||||
|
no)
|
||||||
|
set ""; shift
|
||||||
|
cleared=yes ;;
|
||||||
|
esac
|
||||||
|
if test $eat = yes; then
|
||||||
|
eat=no
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
case "$arg" in
|
||||||
|
-D*|-I*)
|
||||||
|
set fnord "$@" "$arg"; shift ;;
|
||||||
|
# Strip any option that makedepend may not understand. Remove
|
||||||
|
# the object too, otherwise makedepend will parse it as a source file.
|
||||||
|
-arch)
|
||||||
|
eat=yes ;;
|
||||||
|
-*|$object)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
set fnord "$@" "$arg"; shift ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
obj_suffix=`echo "$object" | sed 's/^.*\././'`
|
||||||
|
touch "$tmpdepfile"
|
||||||
|
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
||||||
|
rm -f "$depfile"
|
||||||
|
cat < "$tmpdepfile" > "$depfile"
|
||||||
|
sed '1,2d' "$tmpdepfile" | tr ' ' '
|
||||||
|
' | \
|
||||||
|
## Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
|
## correctly. Breaking it into two sed invocations is a workaround.
|
||||||
|
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
||||||
|
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
||||||
|
;;
|
||||||
|
|
||||||
|
cpp)
|
||||||
|
# Important note: in order to support this mode, a compiler *must*
|
||||||
|
# always write the preprocessed file to stdout.
|
||||||
|
"$@" || exit $?
|
||||||
|
|
||||||
|
# Remove the call to Libtool.
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
while test "X$1" != 'X--mode=compile'; do
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove `-o $object'.
|
||||||
|
IFS=" "
|
||||||
|
for arg
|
||||||
|
do
|
||||||
|
case $arg in
|
||||||
|
-o)
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
$object)
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
set fnord "$@" "$arg"
|
||||||
|
shift # fnord
|
||||||
|
shift # $arg
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
"$@" -E |
|
||||||
|
sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
||||||
|
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
|
||||||
|
sed '$ s: \\$::' > "$tmpdepfile"
|
||||||
|
rm -f "$depfile"
|
||||||
|
echo "$object : \\" > "$depfile"
|
||||||
|
cat < "$tmpdepfile" >> "$depfile"
|
||||||
|
sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
msvisualcpp)
|
||||||
|
# Important note: in order to support this mode, a compiler *must*
|
||||||
|
# always write the preprocessed file to stdout.
|
||||||
|
"$@" || exit $?
|
||||||
|
|
||||||
|
# Remove the call to Libtool.
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
while test "X$1" != 'X--mode=compile'; do
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
|
||||||
|
IFS=" "
|
||||||
|
for arg
|
||||||
|
do
|
||||||
|
case "$arg" in
|
||||||
|
-o)
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
$object)
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
"-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
|
||||||
|
set fnord "$@"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
set fnord "$@" "$arg"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
"$@" -E 2>/dev/null |
|
||||||
|
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile"
|
||||||
|
rm -f "$depfile"
|
||||||
|
echo "$object : \\" > "$depfile"
|
||||||
|
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile"
|
||||||
|
echo " " >> "$depfile"
|
||||||
|
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
msvcmsys)
|
||||||
|
# This case exists only to let depend.m4 do its work. It works by
|
||||||
|
# looking at the text of this script. This case will never be run,
|
||||||
|
# since it is checked for above.
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
|
none)
|
||||||
|
exec "$@"
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "Unknown depmode $depmode" 1>&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
# Local Variables:
|
||||||
|
# mode: shell-script
|
||||||
|
# sh-indentation: 2
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "scriptversion="
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||||
|
# time-stamp-time-zone: "UTC"
|
||||||
|
# time-stamp-end: "; # UTC"
|
||||||
|
# End:
|
@ -0,0 +1,250 @@
|
|||||||
|
# Doxyfile 1.5.5
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Project related configuration options
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
DOXYFILE_ENCODING = UTF-8
|
||||||
|
PROJECT_NAME = $(PROJECT)-$(VERSION)
|
||||||
|
PROJECT_NUMBER =
|
||||||
|
OUTPUT_DIRECTORY = $(DOCDIR)
|
||||||
|
CREATE_SUBDIRS = NO
|
||||||
|
OUTPUT_LANGUAGE = English
|
||||||
|
BRIEF_MEMBER_DESC = YES
|
||||||
|
REPEAT_BRIEF = YES
|
||||||
|
ABBREVIATE_BRIEF = "The $name class" \
|
||||||
|
"The $name widget" \
|
||||||
|
"The $name file" \
|
||||||
|
is \
|
||||||
|
provides \
|
||||||
|
specifies \
|
||||||
|
contains \
|
||||||
|
represents \
|
||||||
|
a \
|
||||||
|
an \
|
||||||
|
the
|
||||||
|
ALWAYS_DETAILED_SEC = NO
|
||||||
|
INLINE_INHERITED_MEMB = NO
|
||||||
|
FULL_PATH_NAMES = NO
|
||||||
|
STRIP_FROM_PATH = $(SRCDIR)/src
|
||||||
|
STRIP_FROM_INC_PATH = $(SRCDIR)/src
|
||||||
|
SHORT_NAMES = NO
|
||||||
|
JAVADOC_AUTOBRIEF = YES
|
||||||
|
QT_AUTOBRIEF = NO
|
||||||
|
MULTILINE_CPP_IS_BRIEF = NO
|
||||||
|
DETAILS_AT_TOP = NO
|
||||||
|
INHERIT_DOCS = YES
|
||||||
|
SEPARATE_MEMBER_PAGES = NO
|
||||||
|
TAB_SIZE = 8
|
||||||
|
ALIASES =
|
||||||
|
OPTIMIZE_OUTPUT_FOR_C = YES
|
||||||
|
OPTIMIZE_OUTPUT_JAVA = NO
|
||||||
|
OPTIMIZE_FOR_FORTRAN = NO
|
||||||
|
OPTIMIZE_OUTPUT_VHDL = NO
|
||||||
|
BUILTIN_STL_SUPPORT = NO
|
||||||
|
CPP_CLI_SUPPORT = NO
|
||||||
|
SIP_SUPPORT = NO
|
||||||
|
DISTRIBUTE_GROUP_DOC = NO
|
||||||
|
SUBGROUPING = YES
|
||||||
|
TYPEDEF_HIDES_STRUCT = NO
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Build related configuration options
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
EXTRACT_ALL = NO
|
||||||
|
EXTRACT_PRIVATE = NO
|
||||||
|
EXTRACT_STATIC = YES
|
||||||
|
EXTRACT_LOCAL_CLASSES = YES
|
||||||
|
EXTRACT_LOCAL_METHODS = NO
|
||||||
|
EXTRACT_ANON_NSPACES = NO
|
||||||
|
HIDE_UNDOC_MEMBERS = NO
|
||||||
|
HIDE_UNDOC_CLASSES = NO
|
||||||
|
HIDE_FRIEND_COMPOUNDS = NO
|
||||||
|
HIDE_IN_BODY_DOCS = NO
|
||||||
|
INTERNAL_DOCS = NO
|
||||||
|
CASE_SENSE_NAMES = YES
|
||||||
|
HIDE_SCOPE_NAMES = NO
|
||||||
|
SHOW_INCLUDE_FILES = YES
|
||||||
|
INLINE_INFO = YES
|
||||||
|
SORT_MEMBER_DOCS = YES
|
||||||
|
SORT_BRIEF_DOCS = NO
|
||||||
|
SORT_GROUP_NAMES = NO
|
||||||
|
SORT_BY_SCOPE_NAME = NO
|
||||||
|
GENERATE_TODOLIST = YES
|
||||||
|
GENERATE_TESTLIST = YES
|
||||||
|
GENERATE_BUGLIST = YES
|
||||||
|
GENERATE_DEPRECATEDLIST= YES
|
||||||
|
ENABLED_SECTIONS =
|
||||||
|
MAX_INITIALIZER_LINES = 30
|
||||||
|
SHOW_USED_FILES = YES
|
||||||
|
SHOW_DIRECTORIES = NO
|
||||||
|
FILE_VERSION_FILTER =
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to warning and progress messages
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
QUIET = YES
|
||||||
|
WARNINGS = NO
|
||||||
|
WARN_IF_UNDOCUMENTED = NO
|
||||||
|
WARN_IF_DOC_ERROR = YES
|
||||||
|
WARN_NO_PARAMDOC = NO
|
||||||
|
WARN_FORMAT = "$file:$line: $text"
|
||||||
|
WARN_LOGFILE =
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the input files
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
INPUT = $(SRCDIR)/src
|
||||||
|
INPUT_ENCODING = UTF-8
|
||||||
|
FILE_PATTERNS = *.c \
|
||||||
|
*.h
|
||||||
|
RECURSIVE = YES
|
||||||
|
EXCLUDE =
|
||||||
|
EXCLUDE_SYMLINKS = NO
|
||||||
|
EXCLUDE_PATTERNS =
|
||||||
|
EXCLUDE_SYMBOLS =
|
||||||
|
EXAMPLE_PATH = $(SRCDIR)/src
|
||||||
|
EXAMPLE_PATTERNS = *
|
||||||
|
EXAMPLE_RECURSIVE = NO
|
||||||
|
IMAGE_PATH =
|
||||||
|
INPUT_FILTER =
|
||||||
|
FILTER_PATTERNS =
|
||||||
|
FILTER_SOURCE_FILES = NO
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to source browsing
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
SOURCE_BROWSER = NO
|
||||||
|
INLINE_SOURCES = NO
|
||||||
|
STRIP_CODE_COMMENTS = YES
|
||||||
|
REFERENCED_BY_RELATION = NO
|
||||||
|
REFERENCES_RELATION = NO
|
||||||
|
REFERENCES_LINK_SOURCE = YES
|
||||||
|
USE_HTAGS = NO
|
||||||
|
VERBATIM_HEADERS = NO
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the alphabetical class index
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
ALPHABETICAL_INDEX = YES
|
||||||
|
COLS_IN_ALPHA_INDEX = 5
|
||||||
|
IGNORE_PREFIX =
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the HTML output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_HTML = $(GENERATE_HTML)
|
||||||
|
HTML_OUTPUT = html
|
||||||
|
HTML_FILE_EXTENSION = .html
|
||||||
|
HTML_HEADER =
|
||||||
|
HTML_FOOTER =
|
||||||
|
HTML_STYLESHEET =
|
||||||
|
HTML_ALIGN_MEMBERS = YES
|
||||||
|
GENERATE_HTMLHELP = NO
|
||||||
|
GENERATE_DOCSET = NO
|
||||||
|
DOCSET_FEEDNAME = "Doxygen generated docs"
|
||||||
|
DOCSET_BUNDLE_ID = org.doxygen.Project
|
||||||
|
HTML_DYNAMIC_SECTIONS = NO
|
||||||
|
CHM_FILE = ../$(PROJECT).chm
|
||||||
|
HHC_LOCATION = $(HHC_PATH)
|
||||||
|
GENERATE_CHI = $(GENERATE_CHM)
|
||||||
|
BINARY_TOC = NO
|
||||||
|
TOC_EXPAND = NO
|
||||||
|
DISABLE_INDEX = NO
|
||||||
|
ENUM_VALUES_PER_LINE = 4
|
||||||
|
GENERATE_TREEVIEW = YES
|
||||||
|
TREEVIEW_WIDTH = 250
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the LaTeX output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_LATEX = $(GENERATE_LATEX)
|
||||||
|
LATEX_OUTPUT = latex
|
||||||
|
LATEX_CMD_NAME = latex
|
||||||
|
MAKEINDEX_CMD_NAME = makeindex
|
||||||
|
COMPACT_LATEX = NO
|
||||||
|
PAPER_TYPE = $(PAPER_SIZE)
|
||||||
|
EXTRA_PACKAGES =
|
||||||
|
LATEX_HEADER =
|
||||||
|
PDF_HYPERLINKS = YES
|
||||||
|
USE_PDFLATEX = YES
|
||||||
|
LATEX_BATCHMODE = NO
|
||||||
|
LATEX_HIDE_INDICES = NO
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the RTF output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_RTF = $(GENERATE_RTF)
|
||||||
|
RTF_OUTPUT = rtf
|
||||||
|
COMPACT_RTF = NO
|
||||||
|
RTF_HYPERLINKS = NO
|
||||||
|
RTF_STYLESHEET_FILE =
|
||||||
|
RTF_EXTENSIONS_FILE =
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the man page output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_MAN = $(GENERATE_MAN)
|
||||||
|
MAN_OUTPUT = man
|
||||||
|
MAN_EXTENSION = .3
|
||||||
|
MAN_LINKS = NO
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the XML output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_XML = $(GENERATE_XML)
|
||||||
|
XML_OUTPUT = xml
|
||||||
|
XML_SCHEMA =
|
||||||
|
XML_DTD =
|
||||||
|
XML_PROGRAMLISTING = YES
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options for the AutoGen Definitions output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_AUTOGEN_DEF = NO
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# configuration options related to the Perl module output
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
GENERATE_PERLMOD = NO
|
||||||
|
PERLMOD_LATEX = NO
|
||||||
|
PERLMOD_PRETTY = YES
|
||||||
|
PERLMOD_MAKEVAR_PREFIX =
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration options related to the preprocessor
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
ENABLE_PREPROCESSING = YES
|
||||||
|
MACRO_EXPANSION = NO
|
||||||
|
EXPAND_ONLY_PREDEF = NO
|
||||||
|
SEARCH_INCLUDES = YES
|
||||||
|
INCLUDE_PATH =
|
||||||
|
INCLUDE_FILE_PATTERNS =
|
||||||
|
PREDEFINED =
|
||||||
|
EXPAND_AS_DEFINED =
|
||||||
|
SKIP_FUNCTION_MACROS = YES
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration::additions related to external references
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
TAGFILES =
|
||||||
|
GENERATE_TAGFILE = $(DOCDIR)/$(PROJECT).tag
|
||||||
|
ALLEXTERNALS = NO
|
||||||
|
EXTERNAL_GROUPS = YES
|
||||||
|
PERL_PATH = $(PERL_PATH)
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration options related to the dot tool
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
CLASS_DIAGRAMS = NO
|
||||||
|
MSCGEN_PATH =
|
||||||
|
HIDE_UNDOC_RELATIONS = YES
|
||||||
|
HAVE_DOT = $(HAVE_DOT)
|
||||||
|
CLASS_GRAPH = YES
|
||||||
|
COLLABORATION_GRAPH = YES
|
||||||
|
GROUP_GRAPHS = YES
|
||||||
|
UML_LOOK = NO
|
||||||
|
TEMPLATE_RELATIONS = NO
|
||||||
|
INCLUDE_GRAPH = YES
|
||||||
|
INCLUDED_BY_GRAPH = YES
|
||||||
|
CALL_GRAPH = NO
|
||||||
|
CALLER_GRAPH = NO
|
||||||
|
GRAPHICAL_HIERARCHY = YES
|
||||||
|
DIRECTORY_GRAPH = YES
|
||||||
|
DOT_IMAGE_FORMAT = png
|
||||||
|
DOT_PATH = $(DOT_PATH)
|
||||||
|
DOTFILE_DIRS =
|
||||||
|
DOT_GRAPH_MAX_NODES = 50
|
||||||
|
MAX_DOT_GRAPH_DEPTH = 1000
|
||||||
|
DOT_TRANSPARENT = YES
|
||||||
|
DOT_MULTI_TARGETS = NO
|
||||||
|
GENERATE_LEGEND = YES
|
||||||
|
DOT_CLEANUP = YES
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
# Configuration::additions related to the search engine
|
||||||
|
#---------------------------------------------------------------------------
|
||||||
|
SEARCHENGINE = NO
|
@ -0,0 +1,520 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# install - install a program, script, or datafile
|
||||||
|
|
||||||
|
scriptversion=2009-04-28.21; # UTC
|
||||||
|
|
||||||
|
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
||||||
|
# later released in X11R6 (xc/config/util/install.sh) with the
|
||||||
|
# following copyright and license.
|
||||||
|
#
|
||||||
|
# Copyright (C) 1994 X Consortium
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
# of this software and associated documentation files (the "Software"), to
|
||||||
|
# deal in the Software without restriction, including without limitation the
|
||||||
|
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
||||||
|
# sell copies of the Software, and to permit persons to whom the Software is
|
||||||
|
# furnished to do so, subject to the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be included in
|
||||||
|
# all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
||||||
|
# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
|
||||||
|
# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
#
|
||||||
|
# Except as contained in this notice, the name of the X Consortium shall not
|
||||||
|
# be used in advertising or otherwise to promote the sale, use or other deal-
|
||||||
|
# ings in this Software without prior written authorization from the X Consor-
|
||||||
|
# tium.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# FSF changes to this file are in the public domain.
|
||||||
|
#
|
||||||
|
# Calling this script install-sh is preferred over install.sh, to prevent
|
||||||
|
# `make' implicit rules from creating a file called install from it
|
||||||
|
# when there is no Makefile.
|
||||||
|
#
|
||||||
|
# This script is compatible with the BSD install script, but was written
|
||||||
|
# from scratch.
|
||||||
|
|
||||||
|
nl='
|
||||||
|
'
|
||||||
|
IFS=" "" $nl"
|
||||||
|
|
||||||
|
# set DOITPROG to echo to test this script
|
||||||
|
|
||||||
|
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
||||||
|
doit=${DOITPROG-}
|
||||||
|
if test -z "$doit"; then
|
||||||
|
doit_exec=exec
|
||||||
|
else
|
||||||
|
doit_exec=$doit
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Put in absolute file names if you don't have them in your path;
|
||||||
|
# or use environment vars.
|
||||||
|
|
||||||
|
chgrpprog=${CHGRPPROG-chgrp}
|
||||||
|
chmodprog=${CHMODPROG-chmod}
|
||||||
|
chownprog=${CHOWNPROG-chown}
|
||||||
|
cmpprog=${CMPPROG-cmp}
|
||||||
|
cpprog=${CPPROG-cp}
|
||||||
|
mkdirprog=${MKDIRPROG-mkdir}
|
||||||
|
mvprog=${MVPROG-mv}
|
||||||
|
rmprog=${RMPROG-rm}
|
||||||
|
stripprog=${STRIPPROG-strip}
|
||||||
|
|
||||||
|
posix_glob='?'
|
||||||
|
initialize_posix_glob='
|
||||||
|
test "$posix_glob" != "?" || {
|
||||||
|
if (set -f) 2>/dev/null; then
|
||||||
|
posix_glob=
|
||||||
|
else
|
||||||
|
posix_glob=:
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
'
|
||||||
|
|
||||||
|
posix_mkdir=
|
||||||
|
|
||||||
|
# Desired mode of installed file.
|
||||||
|
mode=0755
|
||||||
|
|
||||||
|
chgrpcmd=
|
||||||
|
chmodcmd=$chmodprog
|
||||||
|
chowncmd=
|
||||||
|
mvcmd=$mvprog
|
||||||
|
rmcmd="$rmprog -f"
|
||||||
|
stripcmd=
|
||||||
|
|
||||||
|
src=
|
||||||
|
dst=
|
||||||
|
dir_arg=
|
||||||
|
dst_arg=
|
||||||
|
|
||||||
|
copy_on_change=false
|
||||||
|
no_target_directory=
|
||||||
|
|
||||||
|
usage="\
|
||||||
|
Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
|
||||||
|
or: $0 [OPTION]... SRCFILES... DIRECTORY
|
||||||
|
or: $0 [OPTION]... -t DIRECTORY SRCFILES...
|
||||||
|
or: $0 [OPTION]... -d DIRECTORIES...
|
||||||
|
|
||||||
|
In the 1st form, copy SRCFILE to DSTFILE.
|
||||||
|
In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
|
||||||
|
In the 4th, create DIRECTORIES.
|
||||||
|
|
||||||
|
Options:
|
||||||
|
--help display this help and exit.
|
||||||
|
--version display version info and exit.
|
||||||
|
|
||||||
|
-c (ignored)
|
||||||
|
-C install only if different (preserve the last data modification time)
|
||||||
|
-d create directories instead of installing files.
|
||||||
|
-g GROUP $chgrpprog installed files to GROUP.
|
||||||
|
-m MODE $chmodprog installed files to MODE.
|
||||||
|
-o USER $chownprog installed files to USER.
|
||||||
|
-s $stripprog installed files.
|
||||||
|
-t DIRECTORY install into DIRECTORY.
|
||||||
|
-T report an error if DSTFILE is a directory.
|
||||||
|
|
||||||
|
Environment variables override the default commands:
|
||||||
|
CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG
|
||||||
|
RMPROG STRIPPROG
|
||||||
|
"
|
||||||
|
|
||||||
|
while test $# -ne 0; do
|
||||||
|
case $1 in
|
||||||
|
-c) ;;
|
||||||
|
|
||||||
|
-C) copy_on_change=true;;
|
||||||
|
|
||||||
|
-d) dir_arg=true;;
|
||||||
|
|
||||||
|
-g) chgrpcmd="$chgrpprog $2"
|
||||||
|
shift;;
|
||||||
|
|
||||||
|
--help) echo "$usage"; exit $?;;
|
||||||
|
|
||||||
|
-m) mode=$2
|
||||||
|
case $mode in
|
||||||
|
*' '* | *' '* | *'
|
||||||
|
'* | *'*'* | *'?'* | *'['*)
|
||||||
|
echo "$0: invalid mode: $mode" >&2
|
||||||
|
exit 1;;
|
||||||
|
esac
|
||||||
|
shift;;
|
||||||
|
|
||||||
|
-o) chowncmd="$chownprog $2"
|
||||||
|
shift;;
|
||||||
|
|
||||||
|
-s) stripcmd=$stripprog;;
|
||||||
|
|
||||||
|
-t) dst_arg=$2
|
||||||
|
shift;;
|
||||||
|
|
||||||
|
-T) no_target_directory=true;;
|
||||||
|
|
||||||
|
--version) echo "$0 $scriptversion"; exit $?;;
|
||||||
|
|
||||||
|
--) shift
|
||||||
|
break;;
|
||||||
|
|
||||||
|
-*) echo "$0: invalid option: $1" >&2
|
||||||
|
exit 1;;
|
||||||
|
|
||||||
|
*) break;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
|
||||||
|
# When -d is used, all remaining arguments are directories to create.
|
||||||
|
# When -t is used, the destination is already specified.
|
||||||
|
# Otherwise, the last argument is the destination. Remove it from $@.
|
||||||
|
for arg
|
||||||
|
do
|
||||||
|
if test -n "$dst_arg"; then
|
||||||
|
# $@ is not empty: it contains at least $arg.
|
||||||
|
set fnord "$@" "$dst_arg"
|
||||||
|
shift # fnord
|
||||||
|
fi
|
||||||
|
shift # arg
|
||||||
|
dst_arg=$arg
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test $# -eq 0; then
|
||||||
|
if test -z "$dir_arg"; then
|
||||||
|
echo "$0: no input file specified." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
# It's OK to call `install-sh -d' without argument.
|
||||||
|
# This can happen when creating conditional directories.
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z "$dir_arg"; then
|
||||||
|
trap '(exit $?); exit' 1 2 13 15
|
||||||
|
|
||||||
|
# Set umask so as not to create temps with too-generous modes.
|
||||||
|
# However, 'strip' requires both read and write access to temps.
|
||||||
|
case $mode in
|
||||||
|
# Optimize common cases.
|
||||||
|
*644) cp_umask=133;;
|
||||||
|
*755) cp_umask=22;;
|
||||||
|
|
||||||
|
*[0-7])
|
||||||
|
if test -z "$stripcmd"; then
|
||||||
|
u_plus_rw=
|
||||||
|
else
|
||||||
|
u_plus_rw='% 200'
|
||||||
|
fi
|
||||||
|
cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
|
||||||
|
*)
|
||||||
|
if test -z "$stripcmd"; then
|
||||||
|
u_plus_rw=
|
||||||
|
else
|
||||||
|
u_plus_rw=,u+rw
|
||||||
|
fi
|
||||||
|
cp_umask=$mode$u_plus_rw;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
for src
|
||||||
|
do
|
||||||
|
# Protect names starting with `-'.
|
||||||
|
case $src in
|
||||||
|
-*) src=./$src;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if test -n "$dir_arg"; then
|
||||||
|
dst=$src
|
||||||
|
dstdir=$dst
|
||||||
|
test -d "$dstdir"
|
||||||
|
dstdir_status=$?
|
||||||
|
else
|
||||||
|
|
||||||
|
# Waiting for this to be detected by the "$cpprog $src $dsttmp" command
|
||||||
|
# might cause directories to be created, which would be especially bad
|
||||||
|
# if $src (and thus $dsttmp) contains '*'.
|
||||||
|
if test ! -f "$src" && test ! -d "$src"; then
|
||||||
|
echo "$0: $src does not exist." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z "$dst_arg"; then
|
||||||
|
echo "$0: no destination specified." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
dst=$dst_arg
|
||||||
|
# Protect names starting with `-'.
|
||||||
|
case $dst in
|
||||||
|
-*) dst=./$dst;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# If destination is a directory, append the input filename; won't work
|
||||||
|
# if double slashes aren't ignored.
|
||||||
|
if test -d "$dst"; then
|
||||||
|
if test -n "$no_target_directory"; then
|
||||||
|
echo "$0: $dst_arg: Is a directory" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
dstdir=$dst
|
||||||
|
dst=$dstdir/`basename "$src"`
|
||||||
|
dstdir_status=0
|
||||||
|
else
|
||||||
|
# Prefer dirname, but fall back on a substitute if dirname fails.
|
||||||
|
dstdir=`
|
||||||
|
(dirname "$dst") 2>/dev/null ||
|
||||||
|
expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
||||||
|
X"$dst" : 'X\(//\)[^/]' \| \
|
||||||
|
X"$dst" : 'X\(//\)$' \| \
|
||||||
|
X"$dst" : 'X\(/\)' \| . 2>/dev/null ||
|
||||||
|
echo X"$dst" |
|
||||||
|
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
||||||
|
s//\1/
|
||||||
|
q
|
||||||
|
}
|
||||||
|
/^X\(\/\/\)[^/].*/{
|
||||||
|
s//\1/
|
||||||
|
q
|
||||||
|
}
|
||||||
|
/^X\(\/\/\)$/{
|
||||||
|
s//\1/
|
||||||
|
q
|
||||||
|
}
|
||||||
|
/^X\(\/\).*/{
|
||||||
|
s//\1/
|
||||||
|
q
|
||||||
|
}
|
||||||
|
s/.*/./; q'
|
||||||
|
`
|
||||||
|
|
||||||
|
test -d "$dstdir"
|
||||||
|
dstdir_status=$?
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
obsolete_mkdir_used=false
|
||||||
|
|
||||||
|
if test $dstdir_status != 0; then
|
||||||
|
case $posix_mkdir in
|
||||||
|
'')
|
||||||
|
# Create intermediate dirs using mode 755 as modified by the umask.
|
||||||
|
# This is like FreeBSD 'install' as of 1997-10-28.
|
||||||
|
umask=`umask`
|
||||||
|
case $stripcmd.$umask in
|
||||||
|
# Optimize common cases.
|
||||||
|
*[2367][2367]) mkdir_umask=$umask;;
|
||||||
|
.*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
|
||||||
|
|
||||||
|
*[0-7])
|
||||||
|
mkdir_umask=`expr $umask + 22 \
|
||||||
|
- $umask % 100 % 40 + $umask % 20 \
|
||||||
|
- $umask % 10 % 4 + $umask % 2
|
||||||
|
`;;
|
||||||
|
*) mkdir_umask=$umask,go-w;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# With -d, create the new directory with the user-specified mode.
|
||||||
|
# Otherwise, rely on $mkdir_umask.
|
||||||
|
if test -n "$dir_arg"; then
|
||||||
|
mkdir_mode=-m$mode
|
||||||
|
else
|
||||||
|
mkdir_mode=
|
||||||
|
fi
|
||||||
|
|
||||||
|
posix_mkdir=false
|
||||||
|
case $umask in
|
||||||
|
*[123567][0-7][0-7])
|
||||||
|
# POSIX mkdir -p sets u+wx bits regardless of umask, which
|
||||||
|
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
|
||||||
|
trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
|
||||||
|
|
||||||
|
if (umask $mkdir_umask &&
|
||||||
|
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
|
||||||
|
then
|
||||||
|
if test -z "$dir_arg" || {
|
||||||
|
# Check for POSIX incompatibilities with -m.
|
||||||
|
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
|
||||||
|
# other-writeable bit of parent directory when it shouldn't.
|
||||||
|
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
|
||||||
|
ls_ld_tmpdir=`ls -ld "$tmpdir"`
|
||||||
|
case $ls_ld_tmpdir in
|
||||||
|
d????-?r-*) different_mode=700;;
|
||||||
|
d????-?--*) different_mode=755;;
|
||||||
|
*) false;;
|
||||||
|
esac &&
|
||||||
|
$mkdirprog -m$different_mode -p -- "$tmpdir" && {
|
||||||
|
ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
|
||||||
|
test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
then posix_mkdir=:
|
||||||
|
fi
|
||||||
|
rmdir "$tmpdir/d" "$tmpdir"
|
||||||
|
else
|
||||||
|
# Remove any dirs left behind by ancient mkdir implementations.
|
||||||
|
rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
|
||||||
|
fi
|
||||||
|
trap '' 0;;
|
||||||
|
esac;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if
|
||||||
|
$posix_mkdir && (
|
||||||
|
umask $mkdir_umask &&
|
||||||
|
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
|
||||||
|
)
|
||||||
|
then :
|
||||||
|
else
|
||||||
|
|
||||||
|
# The umask is ridiculous, or mkdir does not conform to POSIX,
|
||||||
|
# or it failed possibly due to a race condition. Create the
|
||||||
|
# directory the slow way, step by step, checking for races as we go.
|
||||||
|
|
||||||
|
case $dstdir in
|
||||||
|
/*) prefix='/';;
|
||||||
|
-*) prefix='./';;
|
||||||
|
*) prefix='';;
|
||||||
|
esac
|
||||||
|
|
||||||
|
eval "$initialize_posix_glob"
|
||||||
|
|
||||||
|
oIFS=$IFS
|
||||||
|
IFS=/
|
||||||
|
$posix_glob set -f
|
||||||
|
set fnord $dstdir
|
||||||
|
shift
|
||||||
|
$posix_glob set +f
|
||||||
|
IFS=$oIFS
|
||||||
|
|
||||||
|
prefixes=
|
||||||
|
|
||||||
|
for d
|
||||||
|
do
|
||||||
|
test -z "$d" && continue
|
||||||
|
|
||||||
|
prefix=$prefix$d
|
||||||
|
if test -d "$prefix"; then
|
||||||
|
prefixes=
|
||||||
|
else
|
||||||
|
if $posix_mkdir; then
|
||||||
|
(umask=$mkdir_umask &&
|
||||||
|
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
|
||||||
|
# Don't fail if two instances are running concurrently.
|
||||||
|
test -d "$prefix" || exit 1
|
||||||
|
else
|
||||||
|
case $prefix in
|
||||||
|
*\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
|
||||||
|
*) qprefix=$prefix;;
|
||||||
|
esac
|
||||||
|
prefixes="$prefixes '$qprefix'"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
prefix=$prefix/
|
||||||
|
done
|
||||||
|
|
||||||
|
if test -n "$prefixes"; then
|
||||||
|
# Don't fail if two instances are running concurrently.
|
||||||
|
(umask $mkdir_umask &&
|
||||||
|
eval "\$doit_exec \$mkdirprog $prefixes") ||
|
||||||
|
test -d "$dstdir" || exit 1
|
||||||
|
obsolete_mkdir_used=true
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -n "$dir_arg"; then
|
||||||
|
{ test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
|
||||||
|
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
|
||||||
|
{ test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
|
||||||
|
test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
|
||||||
|
else
|
||||||
|
|
||||||
|
# Make a couple of temp file names in the proper directory.
|
||||||
|
dsttmp=$dstdir/_inst.$$_
|
||||||
|
rmtmp=$dstdir/_rm.$$_
|
||||||
|
|
||||||
|
# Trap to clean up those temp files at exit.
|
||||||
|
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
||||||
|
|
||||||
|
# Copy the file name to the temp name.
|
||||||
|
(umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") &&
|
||||||
|
|
||||||
|
# and set any options; do chmod last to preserve setuid bits.
|
||||||
|
#
|
||||||
|
# If any of these fail, we abort the whole thing. If we want to
|
||||||
|
# ignore errors from any of these, just make sure not to ignore
|
||||||
|
# errors from the above "$doit $cpprog $src $dsttmp" command.
|
||||||
|
#
|
||||||
|
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } &&
|
||||||
|
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } &&
|
||||||
|
{ test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } &&
|
||||||
|
{ test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
|
||||||
|
|
||||||
|
# If -C, don't bother to copy if it wouldn't change the file.
|
||||||
|
if $copy_on_change &&
|
||||||
|
old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` &&
|
||||||
|
new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` &&
|
||||||
|
|
||||||
|
eval "$initialize_posix_glob" &&
|
||||||
|
$posix_glob set -f &&
|
||||||
|
set X $old && old=:$2:$4:$5:$6 &&
|
||||||
|
set X $new && new=:$2:$4:$5:$6 &&
|
||||||
|
$posix_glob set +f &&
|
||||||
|
|
||||||
|
test "$old" = "$new" &&
|
||||||
|
$cmpprog "$dst" "$dsttmp" >/dev/null 2>&1
|
||||||
|
then
|
||||||
|
rm -f "$dsttmp"
|
||||||
|
else
|
||||||
|
# Rename the file to the real destination.
|
||||||
|
$doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null ||
|
||||||
|
|
||||||
|
# The rename failed, perhaps because mv can't rename something else
|
||||||
|
# to itself, or perhaps because mv is so ancient that it does not
|
||||||
|
# support -f.
|
||||||
|
{
|
||||||
|
# Now remove or move aside any old file at destination location.
|
||||||
|
# We try this two ways since rm can't unlink itself on some
|
||||||
|
# systems and the destination file might be busy for other
|
||||||
|
# reasons. In this case, the final cleanup might fail but the new
|
||||||
|
# file should still install successfully.
|
||||||
|
{
|
||||||
|
test ! -f "$dst" ||
|
||||||
|
$doit $rmcmd -f "$dst" 2>/dev/null ||
|
||||||
|
{ $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null &&
|
||||||
|
{ $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }
|
||||||
|
} ||
|
||||||
|
{ echo "$0: cannot unlink or rename $dst" >&2
|
||||||
|
(exit 1); exit 1
|
||||||
|
}
|
||||||
|
} &&
|
||||||
|
|
||||||
|
# Now rename the file to the real destination.
|
||||||
|
$doit $mvcmd "$dsttmp" "$dst"
|
||||||
|
}
|
||||||
|
fi || exit 1
|
||||||
|
|
||||||
|
trap '' 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "scriptversion="
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||||
|
# time-stamp-time-zone: "UTC"
|
||||||
|
# time-stamp-end: "; # UTC"
|
||||||
|
# End:
|
@ -0,0 +1,14 @@
|
|||||||
|
prefix=@prefix@
|
||||||
|
exec_prefix=@exec_prefix@
|
||||||
|
libdir=@libdir@
|
||||||
|
includedir=@includedir@
|
||||||
|
|
||||||
|
pkglibdir=${libdir}/@PACKAGE@
|
||||||
|
pkgincludedir=${includedir}/@PACKAGE@
|
||||||
|
|
||||||
|
Name: libcarddav
|
||||||
|
Description: libcarddav is a client library for CardDAV
|
||||||
|
Version: @VERSION@
|
||||||
|
|
||||||
|
Cflags: @GLIB_CFLAGS@ @CURL_CFLAGS@
|
||||||
|
Libs: @GLIB_LIBS@ @CURL_LIBS@
|
@ -0,0 +1,533 @@
|
|||||||
|
# ===========================================================================
|
||||||
|
# http://www.nongnu.org/autoconf-archive/ax_prog_doxygen.html
|
||||||
|
# ===========================================================================
|
||||||
|
#
|
||||||
|
# SYNOPSIS
|
||||||
|
#
|
||||||
|
# DX_INIT_DOXYGEN(PROJECT-NAME, DOXYFILE-PATH, [OUTPUT-DIR])
|
||||||
|
# DX_DOXYGEN_FEATURE(ON|OFF)
|
||||||
|
# DX_DOT_FEATURE(ON|OFF)
|
||||||
|
# DX_HTML_FEATURE(ON|OFF)
|
||||||
|
# DX_CHM_FEATURE(ON|OFF)
|
||||||
|
# DX_CHI_FEATURE(ON|OFF)
|
||||||
|
# DX_MAN_FEATURE(ON|OFF)
|
||||||
|
# DX_RTF_FEATURE(ON|OFF)
|
||||||
|
# DX_XML_FEATURE(ON|OFF)
|
||||||
|
# DX_PDF_FEATURE(ON|OFF)
|
||||||
|
# DX_PS_FEATURE(ON|OFF)
|
||||||
|
#
|
||||||
|
# DESCRIPTION
|
||||||
|
#
|
||||||
|
# The DX_*_FEATURE macros control the default setting for the given
|
||||||
|
# Doxygen feature. Supported features are 'DOXYGEN' itself, 'DOT' for
|
||||||
|
# generating graphics, 'HTML' for plain HTML, 'CHM' for compressed HTML
|
||||||
|
# help (for MS users), 'CHI' for generating a seperate .chi file by the
|
||||||
|
# .chm file, and 'MAN', 'RTF', 'XML', 'PDF' and 'PS' for the appropriate
|
||||||
|
# output formats. The environment variable DOXYGEN_PAPER_SIZE may be
|
||||||
|
# specified to override the default 'a4wide' paper size.
|
||||||
|
#
|
||||||
|
# By default, HTML, PDF and PS documentation is generated as this seems to
|
||||||
|
# be the most popular and portable combination. MAN pages created by
|
||||||
|
# Doxygen are usually problematic, though by picking an appropriate subset
|
||||||
|
# and doing some massaging they might be better than nothing. CHM and RTF
|
||||||
|
# are specific for MS (note that you can't generate both HTML and CHM at
|
||||||
|
# the same time). The XML is rather useless unless you apply specialized
|
||||||
|
# post-processing to it.
|
||||||
|
#
|
||||||
|
# The macros mainly control the default state of the feature. The use can
|
||||||
|
# override the default by specifying --enable or --disable. The macros
|
||||||
|
# ensure that contradictory flags are not given (e.g.,
|
||||||
|
# --enable-doxygen-html and --enable-doxygen-chm,
|
||||||
|
# --enable-doxygen-anything with --disable-doxygen, etc.) Finally, each
|
||||||
|
# feature will be automatically disabled (with a warning) if the required
|
||||||
|
# programs are missing.
|
||||||
|
#
|
||||||
|
# Once all the feature defaults have been specified, call DX_INIT_DOXYGEN
|
||||||
|
# with the following parameters: a one-word name for the project for use
|
||||||
|
# as a filename base etc., an optional configuration file name (the
|
||||||
|
# default is 'Doxyfile', the same as Doxygen's default), and an optional
|
||||||
|
# output directory name (the default is 'doxygen-doc').
|
||||||
|
#
|
||||||
|
# Automake Support
|
||||||
|
#
|
||||||
|
# The following is a template aminclude.am file for use with Automake.
|
||||||
|
# Make targets and variables values are controlled by the various
|
||||||
|
# DX_COND_* conditionals set by autoconf.
|
||||||
|
#
|
||||||
|
# The provided targets are:
|
||||||
|
#
|
||||||
|
# doxygen-doc: Generate all doxygen documentation.
|
||||||
|
#
|
||||||
|
# doxygen-run: Run doxygen, which will generate some of the
|
||||||
|
# documentation (HTML, CHM, CHI, MAN, RTF, XML)
|
||||||
|
# but will not do the post processing required
|
||||||
|
# for the rest of it (PS, PDF, and some MAN).
|
||||||
|
#
|
||||||
|
# doxygen-man: Rename some doxygen generated man pages.
|
||||||
|
#
|
||||||
|
# doxygen-ps: Generate doxygen PostScript documentation.
|
||||||
|
#
|
||||||
|
# doxygen-pdf: Generate doxygen PDF documentation.
|
||||||
|
#
|
||||||
|
# Note that by default these are not integrated into the automake targets.
|
||||||
|
# If doxygen is used to generate man pages, you can achieve this
|
||||||
|
# integration by setting man3_MANS to the list of man pages generated and
|
||||||
|
# then adding the dependency:
|
||||||
|
#
|
||||||
|
# $(man3_MANS): doxygen-doc
|
||||||
|
#
|
||||||
|
# This will cause make to run doxygen and generate all the documentation.
|
||||||
|
#
|
||||||
|
# The following variable is intended for use in Makefile.am:
|
||||||
|
#
|
||||||
|
# DX_CLEANFILES = everything to clean.
|
||||||
|
#
|
||||||
|
# Then add this variable to MOSTLYCLEANFILES.
|
||||||
|
#
|
||||||
|
# ----- begin aminclude.am -------------------------------------
|
||||||
|
#
|
||||||
|
# ## --------------------------------- ##
|
||||||
|
# ## Format-independent Doxygen rules. ##
|
||||||
|
# ## --------------------------------- ##
|
||||||
|
#
|
||||||
|
# if DX_COND_doc
|
||||||
|
#
|
||||||
|
# ## ------------------------------- ##
|
||||||
|
# ## Rules specific for HTML output. ##
|
||||||
|
# ## ------------------------------- ##
|
||||||
|
#
|
||||||
|
# if DX_COND_html
|
||||||
|
#
|
||||||
|
# DX_CLEAN_HTML = @DX_DOCDIR@/html
|
||||||
|
#
|
||||||
|
# endif DX_COND_html
|
||||||
|
#
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
# ## Rules specific for CHM output. ##
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
#
|
||||||
|
# if DX_COND_chm
|
||||||
|
#
|
||||||
|
# DX_CLEAN_CHM = @DX_DOCDIR@/chm
|
||||||
|
#
|
||||||
|
# if DX_COND_chi
|
||||||
|
#
|
||||||
|
# DX_CLEAN_CHI = @DX_DOCDIR@/@PACKAGE@.chi
|
||||||
|
#
|
||||||
|
# endif DX_COND_chi
|
||||||
|
#
|
||||||
|
# endif DX_COND_chm
|
||||||
|
#
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
# ## Rules specific for MAN output. ##
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
#
|
||||||
|
# if DX_COND_man
|
||||||
|
#
|
||||||
|
# DX_CLEAN_MAN = @DX_DOCDIR@/man
|
||||||
|
#
|
||||||
|
# endif DX_COND_man
|
||||||
|
#
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
# ## Rules specific for RTF output. ##
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
#
|
||||||
|
# if DX_COND_rtf
|
||||||
|
#
|
||||||
|
# DX_CLEAN_RTF = @DX_DOCDIR@/rtf
|
||||||
|
#
|
||||||
|
# endif DX_COND_rtf
|
||||||
|
#
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
# ## Rules specific for XML output. ##
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
#
|
||||||
|
# if DX_COND_xml
|
||||||
|
#
|
||||||
|
# DX_CLEAN_XML = @DX_DOCDIR@/xml
|
||||||
|
#
|
||||||
|
# endif DX_COND_xml
|
||||||
|
#
|
||||||
|
# ## ----------------------------- ##
|
||||||
|
# ## Rules specific for PS output. ##
|
||||||
|
# ## ----------------------------- ##
|
||||||
|
#
|
||||||
|
# if DX_COND_ps
|
||||||
|
#
|
||||||
|
# DX_CLEAN_PS = @DX_DOCDIR@/@PACKAGE@.ps
|
||||||
|
#
|
||||||
|
# DX_PS_GOAL = doxygen-ps
|
||||||
|
#
|
||||||
|
# doxygen-ps: @DX_DOCDIR@/@PACKAGE@.ps
|
||||||
|
#
|
||||||
|
# @DX_DOCDIR@/@PACKAGE@.ps: @DX_DOCDIR@/@PACKAGE@.tag
|
||||||
|
# cd @DX_DOCDIR@/latex; \
|
||||||
|
# rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \
|
||||||
|
# $(DX_LATEX) refman.tex; \
|
||||||
|
# $(MAKEINDEX_PATH) refman.idx; \
|
||||||
|
# $(DX_LATEX) refman.tex; \
|
||||||
|
# countdown=5; \
|
||||||
|
# while $(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \
|
||||||
|
# refman.log > /dev/null 2>&1 \
|
||||||
|
# && test $$countdown -gt 0; do \
|
||||||
|
# $(DX_LATEX) refman.tex; \
|
||||||
|
# countdown=`expr $$countdown - 1`; \
|
||||||
|
# done; \
|
||||||
|
# $(DX_DVIPS) -o ../@PACKAGE@.ps refman.dvi
|
||||||
|
#
|
||||||
|
# endif DX_COND_ps
|
||||||
|
#
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
# ## Rules specific for PDF output. ##
|
||||||
|
# ## ------------------------------ ##
|
||||||
|
#
|
||||||
|
# if DX_COND_pdf
|
||||||
|
#
|
||||||
|
# DX_CLEAN_PDF = @DX_DOCDIR@/@PACKAGE@.pdf
|
||||||
|
#
|
||||||
|
# DX_PDF_GOAL = doxygen-pdf
|
||||||
|
#
|
||||||
|
# doxygen-pdf: @DX_DOCDIR@/@PACKAGE@.pdf
|
||||||
|
#
|
||||||
|
# @DX_DOCDIR@/@PACKAGE@.pdf: @DX_DOCDIR@/@PACKAGE@.tag
|
||||||
|
# cd @DX_DOCDIR@/latex; \
|
||||||
|
# rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \
|
||||||
|
# $(DX_PDFLATEX) refman.tex; \
|
||||||
|
# $(DX_MAKEINDEX) refman.idx; \
|
||||||
|
# $(DX_PDFLATEX) refman.tex; \
|
||||||
|
# countdown=5; \
|
||||||
|
# while $(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \
|
||||||
|
# refman.log > /dev/null 2>&1 \
|
||||||
|
# && test $$countdown -gt 0; do \
|
||||||
|
# $(DX_PDFLATEX) refman.tex; \
|
||||||
|
# countdown=`expr $$countdown - 1`; \
|
||||||
|
# done; \
|
||||||
|
# mv refman.pdf ../@PACKAGE@.pdf
|
||||||
|
#
|
||||||
|
# endif DX_COND_pdf
|
||||||
|
#
|
||||||
|
# ## ------------------------------------------------- ##
|
||||||
|
# ## Rules specific for LaTeX (shared for PS and PDF). ##
|
||||||
|
# ## ------------------------------------------------- ##
|
||||||
|
#
|
||||||
|
# if DX_COND_latex
|
||||||
|
#
|
||||||
|
# DX_CLEAN_LATEX = @DX_DOCDIR@/latex
|
||||||
|
#
|
||||||
|
# endif DX_COND_latex
|
||||||
|
#
|
||||||
|
# .PHONY: doxygen-run doxygen-doc $(DX_PS_GOAL) $(DX_PDF_GOAL)
|
||||||
|
#
|
||||||
|
# .INTERMEDIATE: doxygen-run $(DX_PS_GOAL) $(DX_PDF_GOAL)
|
||||||
|
#
|
||||||
|
# doxygen-run: @DX_DOCDIR@/@PACKAGE@.tag
|
||||||
|
#
|
||||||
|
# doxygen-doc: doxygen-run $(DX_PS_GOAL) $(DX_PDF_GOAL)
|
||||||
|
#
|
||||||
|
# @DX_DOCDIR@/@PACKAGE@.tag: $(DX_CONFIG) $(pkginclude_HEADERS)
|
||||||
|
# rm -rf @DX_DOCDIR@
|
||||||
|
# $(DX_ENV) $(DX_DOXYGEN) $(srcdir)/$(DX_CONFIG)
|
||||||
|
#
|
||||||
|
# DX_CLEANFILES = \
|
||||||
|
# @DX_DOCDIR@/@PACKAGE@.tag \
|
||||||
|
# -r \
|
||||||
|
# $(DX_CLEAN_HTML) \
|
||||||
|
# $(DX_CLEAN_CHM) \
|
||||||
|
# $(DX_CLEAN_CHI) \
|
||||||
|
# $(DX_CLEAN_MAN) \
|
||||||
|
# $(DX_CLEAN_RTF) \
|
||||||
|
# $(DX_CLEAN_XML) \
|
||||||
|
# $(DX_CLEAN_PS) \
|
||||||
|
# $(DX_CLEAN_PDF) \
|
||||||
|
# $(DX_CLEAN_LATEX)
|
||||||
|
#
|
||||||
|
# endif DX_COND_doc
|
||||||
|
#
|
||||||
|
# ----- end aminclude.am ---------------------------------------
|
||||||
|
#
|
||||||
|
# LICENSE
|
||||||
|
#
|
||||||
|
# Copyright (c) 2009 Oren Ben-Kiki <oren@ben-kiki.org>
|
||||||
|
#
|
||||||
|
# Copying and distribution of this file, with or without modification, are
|
||||||
|
# permitted in any medium without royalty provided the copyright notice
|
||||||
|
# and this notice are preserved. This file is offered as-is, without any
|
||||||
|
# warranty.
|
||||||
|
|
||||||
|
#serial 9
|
||||||
|
|
||||||
|
## ----------##
|
||||||
|
## Defaults. ##
|
||||||
|
## ----------##
|
||||||
|
|
||||||
|
DX_ENV=""
|
||||||
|
AC_DEFUN([DX_FEATURE_doc], ON)
|
||||||
|
AC_DEFUN([DX_FEATURE_dot], ON)
|
||||||
|
AC_DEFUN([DX_FEATURE_man], OFF)
|
||||||
|
AC_DEFUN([DX_FEATURE_html], ON)
|
||||||
|
AC_DEFUN([DX_FEATURE_chm], OFF)
|
||||||
|
AC_DEFUN([DX_FEATURE_chi], OFF)
|
||||||
|
AC_DEFUN([DX_FEATURE_rtf], OFF)
|
||||||
|
AC_DEFUN([DX_FEATURE_xml], OFF)
|
||||||
|
AC_DEFUN([DX_FEATURE_pdf], ON)
|
||||||
|
AC_DEFUN([DX_FEATURE_ps], ON)
|
||||||
|
|
||||||
|
## --------------- ##
|
||||||
|
## Private macros. ##
|
||||||
|
## --------------- ##
|
||||||
|
|
||||||
|
# DX_ENV_APPEND(VARIABLE, VALUE)
|
||||||
|
# ------------------------------
|
||||||
|
# Append VARIABLE="VALUE" to DX_ENV for invoking doxygen.
|
||||||
|
AC_DEFUN([DX_ENV_APPEND], [AC_SUBST([DX_ENV], ["$DX_ENV $1='$2'"])])
|
||||||
|
|
||||||
|
# DX_DIRNAME_EXPR
|
||||||
|
# ---------------
|
||||||
|
# Expand into a shell expression prints the directory part of a path.
|
||||||
|
AC_DEFUN([DX_DIRNAME_EXPR],
|
||||||
|
[[expr ".$1" : '\(\.\)[^/]*$' \| "x$1" : 'x\(.*\)/[^/]*$']])
|
||||||
|
|
||||||
|
# DX_IF_FEATURE(FEATURE, IF-ON, IF-OFF)
|
||||||
|
# -------------------------------------
|
||||||
|
# Expands according to the M4 (static) status of the feature.
|
||||||
|
AC_DEFUN([DX_IF_FEATURE], [ifelse(DX_FEATURE_$1, ON, [$2], [$3])])
|
||||||
|
|
||||||
|
# DX_REQUIRE_PROG(VARIABLE, PROGRAM)
|
||||||
|
# ----------------------------------
|
||||||
|
# Require the specified program to be found for the DX_CURRENT_FEATURE to work.
|
||||||
|
AC_DEFUN([DX_REQUIRE_PROG], [
|
||||||
|
AC_PATH_TOOL([$1], [$2])
|
||||||
|
if test "$DX_FLAG_[]DX_CURRENT_FEATURE$$1" = 1; then
|
||||||
|
AC_MSG_WARN([$2 not found - will not DX_CURRENT_DESCRIPTION])
|
||||||
|
AC_SUBST(DX_FLAG_[]DX_CURRENT_FEATURE, 0)
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
# DX_TEST_FEATURE(FEATURE)
|
||||||
|
# ------------------------
|
||||||
|
# Expand to a shell expression testing whether the feature is active.
|
||||||
|
AC_DEFUN([DX_TEST_FEATURE], [test "$DX_FLAG_$1" = 1])
|
||||||
|
|
||||||
|
# DX_CHECK_DEPEND(REQUIRED_FEATURE, REQUIRED_STATE)
|
||||||
|
# -------------------------------------------------
|
||||||
|
# Verify that a required features has the right state before trying to turn on
|
||||||
|
# the DX_CURRENT_FEATURE.
|
||||||
|
AC_DEFUN([DX_CHECK_DEPEND], [
|
||||||
|
test "$DX_FLAG_$1" = "$2" \
|
||||||
|
|| AC_MSG_ERROR([doxygen-DX_CURRENT_FEATURE ifelse([$2], 1,
|
||||||
|
requires, contradicts) doxygen-DX_CURRENT_FEATURE])
|
||||||
|
])
|
||||||
|
|
||||||
|
# DX_CLEAR_DEPEND(FEATURE, REQUIRED_FEATURE, REQUIRED_STATE)
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# Turn off the DX_CURRENT_FEATURE if the required feature is off.
|
||||||
|
AC_DEFUN([DX_CLEAR_DEPEND], [
|
||||||
|
test "$DX_FLAG_$1" = "$2" || AC_SUBST(DX_FLAG_[]DX_CURRENT_FEATURE, 0)
|
||||||
|
])
|
||||||
|
|
||||||
|
# DX_FEATURE_ARG(FEATURE, DESCRIPTION,
|
||||||
|
# CHECK_DEPEND, CLEAR_DEPEND,
|
||||||
|
# REQUIRE, DO-IF-ON, DO-IF-OFF)
|
||||||
|
# --------------------------------------------
|
||||||
|
# Parse the command-line option controlling a feature. CHECK_DEPEND is called
|
||||||
|
# if the user explicitly turns the feature on (and invokes DX_CHECK_DEPEND),
|
||||||
|
# otherwise CLEAR_DEPEND is called to turn off the default state if a required
|
||||||
|
# feature is disabled (using DX_CLEAR_DEPEND). REQUIRE performs additional
|
||||||
|
# requirement tests (DX_REQUIRE_PROG). Finally, an automake flag is set and
|
||||||
|
# DO-IF-ON or DO-IF-OFF are called according to the final state of the feature.
|
||||||
|
AC_DEFUN([DX_ARG_ABLE], [
|
||||||
|
AC_DEFUN([DX_CURRENT_FEATURE], [$1])
|
||||||
|
AC_DEFUN([DX_CURRENT_DESCRIPTION], [$2])
|
||||||
|
AC_ARG_ENABLE(doxygen-$1,
|
||||||
|
[AS_HELP_STRING(DX_IF_FEATURE([$1], [--disable-doxygen-$1],
|
||||||
|
[--enable-doxygen-$1]),
|
||||||
|
DX_IF_FEATURE([$1], [don't $2], [$2]))],
|
||||||
|
[
|
||||||
|
case "$enableval" in
|
||||||
|
#(
|
||||||
|
y|Y|yes|Yes|YES)
|
||||||
|
AC_SUBST([DX_FLAG_$1], 1)
|
||||||
|
$3
|
||||||
|
;; #(
|
||||||
|
n|N|no|No|NO)
|
||||||
|
AC_SUBST([DX_FLAG_$1], 0)
|
||||||
|
;; #(
|
||||||
|
*)
|
||||||
|
AC_MSG_ERROR([invalid value '$enableval' given to doxygen-$1])
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
], [
|
||||||
|
AC_SUBST([DX_FLAG_$1], [DX_IF_FEATURE([$1], 1, 0)])
|
||||||
|
$4
|
||||||
|
])
|
||||||
|
if DX_TEST_FEATURE([$1]); then
|
||||||
|
$5
|
||||||
|
:
|
||||||
|
fi
|
||||||
|
if DX_TEST_FEATURE([$1]); then
|
||||||
|
AM_CONDITIONAL(DX_COND_$1, :)
|
||||||
|
$6
|
||||||
|
:
|
||||||
|
else
|
||||||
|
AM_CONDITIONAL(DX_COND_$1, false)
|
||||||
|
$7
|
||||||
|
:
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
## -------------- ##
|
||||||
|
## Public macros. ##
|
||||||
|
## -------------- ##
|
||||||
|
|
||||||
|
# DX_XXX_FEATURE(DEFAULT_STATE)
|
||||||
|
# -----------------------------
|
||||||
|
AC_DEFUN([DX_DOXYGEN_FEATURE], [AC_DEFUN([DX_FEATURE_doc], [$1])])
|
||||||
|
AC_DEFUN([DX_MAN_FEATURE], [AC_DEFUN([DX_FEATURE_man], [$1])])
|
||||||
|
AC_DEFUN([DX_HTML_FEATURE], [AC_DEFUN([DX_FEATURE_html], [$1])])
|
||||||
|
AC_DEFUN([DX_CHM_FEATURE], [AC_DEFUN([DX_FEATURE_chm], [$1])])
|
||||||
|
AC_DEFUN([DX_CHI_FEATURE], [AC_DEFUN([DX_FEATURE_chi], [$1])])
|
||||||
|
AC_DEFUN([DX_RTF_FEATURE], [AC_DEFUN([DX_FEATURE_rtf], [$1])])
|
||||||
|
AC_DEFUN([DX_XML_FEATURE], [AC_DEFUN([DX_FEATURE_xml], [$1])])
|
||||||
|
AC_DEFUN([DX_XML_FEATURE], [AC_DEFUN([DX_FEATURE_xml], [$1])])
|
||||||
|
AC_DEFUN([DX_PDF_FEATURE], [AC_DEFUN([DX_FEATURE_pdf], [$1])])
|
||||||
|
AC_DEFUN([DX_PS_FEATURE], [AC_DEFUN([DX_FEATURE_ps], [$1])])
|
||||||
|
|
||||||
|
# DX_INIT_DOXYGEN(PROJECT, [CONFIG-FILE], [OUTPUT-DOC-DIR])
|
||||||
|
# ---------------------------------------------------------
|
||||||
|
# PROJECT also serves as the base name for the documentation files.
|
||||||
|
# The default CONFIG-FILE is "Doxyfile" and OUTPUT-DOC-DIR is "doxygen-doc".
|
||||||
|
AC_DEFUN([DX_INIT_DOXYGEN], [
|
||||||
|
|
||||||
|
# Files:
|
||||||
|
AC_SUBST([DX_PROJECT], [$1])
|
||||||
|
AC_SUBST([DX_CONFIG], [ifelse([$2], [], Doxyfile, [$2])])
|
||||||
|
AC_SUBST([DX_DOCDIR], [ifelse([$3], [], doxygen-doc, [$3])])
|
||||||
|
|
||||||
|
# Environment variables used inside doxygen.cfg:
|
||||||
|
DX_ENV_APPEND(SRCDIR, $srcdir)
|
||||||
|
DX_ENV_APPEND(PROJECT, $DX_PROJECT)
|
||||||
|
DX_ENV_APPEND(DOCDIR, $DX_DOCDIR)
|
||||||
|
DX_ENV_APPEND(VERSION, $PACKAGE_VERSION)
|
||||||
|
|
||||||
|
# Doxygen itself:
|
||||||
|
DX_ARG_ABLE(doc, [generate any doxygen documentation],
|
||||||
|
[],
|
||||||
|
[],
|
||||||
|
[DX_REQUIRE_PROG([DX_DOXYGEN], doxygen)
|
||||||
|
DX_REQUIRE_PROG([DX_PERL], perl)],
|
||||||
|
[DX_ENV_APPEND(PERL_PATH, $DX_PERL)])
|
||||||
|
|
||||||
|
# Dot for graphics:
|
||||||
|
DX_ARG_ABLE(dot, [generate graphics for doxygen documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[DX_REQUIRE_PROG([DX_DOT], dot)],
|
||||||
|
[DX_ENV_APPEND(HAVE_DOT, YES)
|
||||||
|
DX_ENV_APPEND(DOT_PATH, [`DX_DIRNAME_EXPR($DX_DOT)`])],
|
||||||
|
[DX_ENV_APPEND(HAVE_DOT, NO)])
|
||||||
|
|
||||||
|
# Man pages generation:
|
||||||
|
DX_ARG_ABLE(man, [generate doxygen manual pages],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[],
|
||||||
|
[DX_ENV_APPEND(GENERATE_MAN, YES)],
|
||||||
|
[DX_ENV_APPEND(GENERATE_MAN, NO)])
|
||||||
|
|
||||||
|
# RTF file generation:
|
||||||
|
DX_ARG_ABLE(rtf, [generate doxygen RTF documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[],
|
||||||
|
[DX_ENV_APPEND(GENERATE_RTF, YES)],
|
||||||
|
[DX_ENV_APPEND(GENERATE_RTF, NO)])
|
||||||
|
|
||||||
|
# XML file generation:
|
||||||
|
DX_ARG_ABLE(xml, [generate doxygen XML documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[],
|
||||||
|
[DX_ENV_APPEND(GENERATE_XML, YES)],
|
||||||
|
[DX_ENV_APPEND(GENERATE_XML, NO)])
|
||||||
|
|
||||||
|
# (Compressed) HTML help generation:
|
||||||
|
DX_ARG_ABLE(chm, [generate doxygen compressed HTML help documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[DX_REQUIRE_PROG([DX_HHC], hhc)],
|
||||||
|
[DX_ENV_APPEND(HHC_PATH, $DX_HHC)
|
||||||
|
DX_ENV_APPEND(GENERATE_HTML, YES)
|
||||||
|
DX_ENV_APPEND(GENERATE_HTMLHELP, YES)],
|
||||||
|
[DX_ENV_APPEND(GENERATE_HTMLHELP, NO)])
|
||||||
|
|
||||||
|
# Seperate CHI file generation.
|
||||||
|
DX_ARG_ABLE(chi, [generate doxygen seperate compressed HTML help index file],
|
||||||
|
[DX_CHECK_DEPEND(chm, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(chm, 1)],
|
||||||
|
[],
|
||||||
|
[DX_ENV_APPEND(GENERATE_CHI, YES)],
|
||||||
|
[DX_ENV_APPEND(GENERATE_CHI, NO)])
|
||||||
|
|
||||||
|
# Plain HTML pages generation:
|
||||||
|
DX_ARG_ABLE(html, [generate doxygen plain HTML documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1) DX_CHECK_DEPEND(chm, 0)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1) DX_CLEAR_DEPEND(chm, 0)],
|
||||||
|
[],
|
||||||
|
[DX_ENV_APPEND(GENERATE_HTML, YES)],
|
||||||
|
[DX_TEST_FEATURE(chm) || DX_ENV_APPEND(GENERATE_HTML, NO)])
|
||||||
|
|
||||||
|
# PostScript file generation:
|
||||||
|
DX_ARG_ABLE(ps, [generate doxygen PostScript documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[DX_REQUIRE_PROG([DX_LATEX], latex)
|
||||||
|
DX_REQUIRE_PROG([DX_MAKEINDEX], makeindex)
|
||||||
|
DX_REQUIRE_PROG([DX_DVIPS], dvips)
|
||||||
|
DX_REQUIRE_PROG([DX_EGREP], egrep)])
|
||||||
|
|
||||||
|
# PDF file generation:
|
||||||
|
DX_ARG_ABLE(pdf, [generate doxygen PDF documentation],
|
||||||
|
[DX_CHECK_DEPEND(doc, 1)],
|
||||||
|
[DX_CLEAR_DEPEND(doc, 1)],
|
||||||
|
[DX_REQUIRE_PROG([DX_PDFLATEX], pdflatex)
|
||||||
|
DX_REQUIRE_PROG([DX_MAKEINDEX], makeindex)
|
||||||
|
DX_REQUIRE_PROG([DX_EGREP], egrep)])
|
||||||
|
|
||||||
|
# LaTeX generation for PS and/or PDF:
|
||||||
|
if DX_TEST_FEATURE(ps) || DX_TEST_FEATURE(pdf); then
|
||||||
|
AM_CONDITIONAL(DX_COND_latex, :)
|
||||||
|
DX_ENV_APPEND(GENERATE_LATEX, YES)
|
||||||
|
else
|
||||||
|
AM_CONDITIONAL(DX_COND_latex, false)
|
||||||
|
DX_ENV_APPEND(GENERATE_LATEX, NO)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Paper size for PS and/or PDF:
|
||||||
|
AC_ARG_VAR(DOXYGEN_PAPER_SIZE,
|
||||||
|
[a4wide (default), a4, letter, legal or executive])
|
||||||
|
case "$DOXYGEN_PAPER_SIZE" in
|
||||||
|
#(
|
||||||
|
"")
|
||||||
|
AC_SUBST(DOXYGEN_PAPER_SIZE, "")
|
||||||
|
;; #(
|
||||||
|
a4wide|a4|letter|legal|executive)
|
||||||
|
DX_ENV_APPEND(PAPER_SIZE, $DOXYGEN_PAPER_SIZE)
|
||||||
|
;; #(
|
||||||
|
*)
|
||||||
|
AC_MSG_ERROR([unknown DOXYGEN_PAPER_SIZE='$DOXYGEN_PAPER_SIZE'])
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
#For debugging:
|
||||||
|
#echo DX_FLAG_doc=$DX_FLAG_doc
|
||||||
|
#echo DX_FLAG_dot=$DX_FLAG_dot
|
||||||
|
#echo DX_FLAG_man=$DX_FLAG_man
|
||||||
|
#echo DX_FLAG_html=$DX_FLAG_html
|
||||||
|
#echo DX_FLAG_chm=$DX_FLAG_chm
|
||||||
|
#echo DX_FLAG_chi=$DX_FLAG_chi
|
||||||
|
#echo DX_FLAG_rtf=$DX_FLAG_rtf
|
||||||
|
#echo DX_FLAG_xml=$DX_FLAG_xml
|
||||||
|
#echo DX_FLAG_pdf=$DX_FLAG_pdf
|
||||||
|
#echo DX_FLAG_ps=$DX_FLAG_ps
|
||||||
|
#echo DX_ENV=$DX_ENV
|
||||||
|
])
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,368 @@
|
|||||||
|
# Helper functions for option handling. -*- Autoconf -*-
|
||||||
|
#
|
||||||
|
# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
|
||||||
|
# Written by Gary V. Vaughan, 2004
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation gives
|
||||||
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 6 ltoptions.m4
|
||||||
|
|
||||||
|
# This is to help aclocal find these macros, as it can't see m4_define.
|
||||||
|
AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME)
|
||||||
|
# ------------------------------------------
|
||||||
|
m4_define([_LT_MANGLE_OPTION],
|
||||||
|
[[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_SET_OPTION(MACRO-NAME, OPTION-NAME)
|
||||||
|
# ---------------------------------------
|
||||||
|
# Set option OPTION-NAME for macro MACRO-NAME, and if there is a
|
||||||
|
# matching handler defined, dispatch to it. Other OPTION-NAMEs are
|
||||||
|
# saved as a flag.
|
||||||
|
m4_define([_LT_SET_OPTION],
|
||||||
|
[m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl
|
||||||
|
m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]),
|
||||||
|
_LT_MANGLE_DEFUN([$1], [$2]),
|
||||||
|
[m4_warning([Unknown $1 option `$2'])])[]dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET])
|
||||||
|
# ------------------------------------------------------------
|
||||||
|
# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
|
||||||
|
m4_define([_LT_IF_OPTION],
|
||||||
|
[m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET)
|
||||||
|
# -------------------------------------------------------
|
||||||
|
# Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME
|
||||||
|
# are set.
|
||||||
|
m4_define([_LT_UNLESS_OPTIONS],
|
||||||
|
[m4_foreach([_LT_Option], m4_split(m4_normalize([$2])),
|
||||||
|
[m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option),
|
||||||
|
[m4_define([$0_found])])])[]dnl
|
||||||
|
m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3
|
||||||
|
])[]dnl
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST)
|
||||||
|
# ----------------------------------------
|
||||||
|
# OPTION-LIST is a space-separated list of Libtool options associated
|
||||||
|
# with MACRO-NAME. If any OPTION has a matching handler declared with
|
||||||
|
# LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about
|
||||||
|
# the unknown option and exit.
|
||||||
|
m4_defun([_LT_SET_OPTIONS],
|
||||||
|
[# Set options
|
||||||
|
m4_foreach([_LT_Option], m4_split(m4_normalize([$2])),
|
||||||
|
[_LT_SET_OPTION([$1], _LT_Option)])
|
||||||
|
|
||||||
|
m4_if([$1],[LT_INIT],[
|
||||||
|
dnl
|
||||||
|
dnl Simply set some default values (i.e off) if boolean options were not
|
||||||
|
dnl specified:
|
||||||
|
_LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no
|
||||||
|
])
|
||||||
|
_LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no
|
||||||
|
])
|
||||||
|
dnl
|
||||||
|
dnl If no reference was made to various pairs of opposing options, then
|
||||||
|
dnl we run the default mode handler for the pair. For example, if neither
|
||||||
|
dnl `shared' nor `disable-shared' was passed, we enable building of shared
|
||||||
|
dnl archives by default:
|
||||||
|
_LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED])
|
||||||
|
_LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC])
|
||||||
|
_LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC])
|
||||||
|
_LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install],
|
||||||
|
[_LT_ENABLE_FAST_INSTALL])
|
||||||
|
])
|
||||||
|
])# _LT_SET_OPTIONS
|
||||||
|
|
||||||
|
|
||||||
|
## --------------------------------- ##
|
||||||
|
## Macros to handle LT_INIT options. ##
|
||||||
|
## --------------------------------- ##
|
||||||
|
|
||||||
|
# _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME)
|
||||||
|
# -----------------------------------------
|
||||||
|
m4_define([_LT_MANGLE_DEFUN],
|
||||||
|
[[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])])
|
||||||
|
|
||||||
|
|
||||||
|
# LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE)
|
||||||
|
# -----------------------------------------------
|
||||||
|
m4_define([LT_OPTION_DEFINE],
|
||||||
|
[m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl
|
||||||
|
])# LT_OPTION_DEFINE
|
||||||
|
|
||||||
|
|
||||||
|
# dlopen
|
||||||
|
# ------
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes
|
||||||
|
])
|
||||||
|
|
||||||
|
AU_DEFUN([AC_LIBTOOL_DLOPEN],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], [dlopen])
|
||||||
|
AC_DIAGNOSE([obsolete],
|
||||||
|
[$0: Remove this warning and the call to _LT_SET_OPTION when you
|
||||||
|
put the `dlopen' option into LT_INIT's first parameter.])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl aclocal-1.4 backwards compatibility:
|
||||||
|
dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], [])
|
||||||
|
|
||||||
|
|
||||||
|
# win32-dll
|
||||||
|
# ---------
|
||||||
|
# Declare package support for building win32 dll's.
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [win32-dll],
|
||||||
|
[enable_win32_dll=yes
|
||||||
|
|
||||||
|
case $host in
|
||||||
|
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-cegcc*)
|
||||||
|
AC_CHECK_TOOL(AS, as, false)
|
||||||
|
AC_CHECK_TOOL(DLLTOOL, dlltool, false)
|
||||||
|
AC_CHECK_TOOL(OBJDUMP, objdump, false)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
test -z "$AS" && AS=as
|
||||||
|
_LT_DECL([], [AS], [0], [Assembler program])dnl
|
||||||
|
|
||||||
|
test -z "$DLLTOOL" && DLLTOOL=dlltool
|
||||||
|
_LT_DECL([], [DLLTOOL], [0], [DLL creation program])dnl
|
||||||
|
|
||||||
|
test -z "$OBJDUMP" && OBJDUMP=objdump
|
||||||
|
_LT_DECL([], [OBJDUMP], [0], [Object dumper program])dnl
|
||||||
|
])# win32-dll
|
||||||
|
|
||||||
|
AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
|
||||||
|
[AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
||||||
|
_LT_SET_OPTION([LT_INIT], [win32-dll])
|
||||||
|
AC_DIAGNOSE([obsolete],
|
||||||
|
[$0: Remove this warning and the call to _LT_SET_OPTION when you
|
||||||
|
put the `win32-dll' option into LT_INIT's first parameter.])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl aclocal-1.4 backwards compatibility:
|
||||||
|
dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], [])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_ENABLE_SHARED([DEFAULT])
|
||||||
|
# ----------------------------
|
||||||
|
# implement the --enable-shared flag, and supports the `shared' and
|
||||||
|
# `disable-shared' LT_INIT options.
|
||||||
|
# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
|
||||||
|
m4_define([_LT_ENABLE_SHARED],
|
||||||
|
[m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl
|
||||||
|
AC_ARG_ENABLE([shared],
|
||||||
|
[AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@],
|
||||||
|
[build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])],
|
||||||
|
[p=${PACKAGE-default}
|
||||||
|
case $enableval in
|
||||||
|
yes) enable_shared=yes ;;
|
||||||
|
no) enable_shared=no ;;
|
||||||
|
*)
|
||||||
|
enable_shared=no
|
||||||
|
# Look at the argument we got. We use all the common list separators.
|
||||||
|
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
||||||
|
for pkg in $enableval; do
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
if test "X$pkg" = "X$p"; then
|
||||||
|
enable_shared=yes
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
;;
|
||||||
|
esac],
|
||||||
|
[enable_shared=]_LT_ENABLE_SHARED_DEFAULT)
|
||||||
|
|
||||||
|
_LT_DECL([build_libtool_libs], [enable_shared], [0],
|
||||||
|
[Whether or not to build shared libraries])
|
||||||
|
])# _LT_ENABLE_SHARED
|
||||||
|
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])])
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])])
|
||||||
|
|
||||||
|
# Old names:
|
||||||
|
AC_DEFUN([AC_ENABLE_SHARED],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared])
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN([AC_DISABLE_SHARED],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], [disable-shared])
|
||||||
|
])
|
||||||
|
|
||||||
|
AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)])
|
||||||
|
AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)])
|
||||||
|
|
||||||
|
dnl aclocal-1.4 backwards compatibility:
|
||||||
|
dnl AC_DEFUN([AM_ENABLE_SHARED], [])
|
||||||
|
dnl AC_DEFUN([AM_DISABLE_SHARED], [])
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_ENABLE_STATIC([DEFAULT])
|
||||||
|
# ----------------------------
|
||||||
|
# implement the --enable-static flag, and support the `static' and
|
||||||
|
# `disable-static' LT_INIT options.
|
||||||
|
# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
|
||||||
|
m4_define([_LT_ENABLE_STATIC],
|
||||||
|
[m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl
|
||||||
|
AC_ARG_ENABLE([static],
|
||||||
|
[AS_HELP_STRING([--enable-static@<:@=PKGS@:>@],
|
||||||
|
[build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])],
|
||||||
|
[p=${PACKAGE-default}
|
||||||
|
case $enableval in
|
||||||
|
yes) enable_static=yes ;;
|
||||||
|
no) enable_static=no ;;
|
||||||
|
*)
|
||||||
|
enable_static=no
|
||||||
|
# Look at the argument we got. We use all the common list separators.
|
||||||
|
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
||||||
|
for pkg in $enableval; do
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
if test "X$pkg" = "X$p"; then
|
||||||
|
enable_static=yes
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
;;
|
||||||
|
esac],
|
||||||
|
[enable_static=]_LT_ENABLE_STATIC_DEFAULT)
|
||||||
|
|
||||||
|
_LT_DECL([build_old_libs], [enable_static], [0],
|
||||||
|
[Whether or not to build static libraries])
|
||||||
|
])# _LT_ENABLE_STATIC
|
||||||
|
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])])
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])])
|
||||||
|
|
||||||
|
# Old names:
|
||||||
|
AC_DEFUN([AC_ENABLE_STATIC],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static])
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN([AC_DISABLE_STATIC],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], [disable-static])
|
||||||
|
])
|
||||||
|
|
||||||
|
AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)])
|
||||||
|
AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)])
|
||||||
|
|
||||||
|
dnl aclocal-1.4 backwards compatibility:
|
||||||
|
dnl AC_DEFUN([AM_ENABLE_STATIC], [])
|
||||||
|
dnl AC_DEFUN([AM_DISABLE_STATIC], [])
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_ENABLE_FAST_INSTALL([DEFAULT])
|
||||||
|
# ----------------------------------
|
||||||
|
# implement the --enable-fast-install flag, and support the `fast-install'
|
||||||
|
# and `disable-fast-install' LT_INIT options.
|
||||||
|
# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
|
||||||
|
m4_define([_LT_ENABLE_FAST_INSTALL],
|
||||||
|
[m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl
|
||||||
|
AC_ARG_ENABLE([fast-install],
|
||||||
|
[AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@],
|
||||||
|
[optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])],
|
||||||
|
[p=${PACKAGE-default}
|
||||||
|
case $enableval in
|
||||||
|
yes) enable_fast_install=yes ;;
|
||||||
|
no) enable_fast_install=no ;;
|
||||||
|
*)
|
||||||
|
enable_fast_install=no
|
||||||
|
# Look at the argument we got. We use all the common list separators.
|
||||||
|
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
||||||
|
for pkg in $enableval; do
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
if test "X$pkg" = "X$p"; then
|
||||||
|
enable_fast_install=yes
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
;;
|
||||||
|
esac],
|
||||||
|
[enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT)
|
||||||
|
|
||||||
|
_LT_DECL([fast_install], [enable_fast_install], [0],
|
||||||
|
[Whether or not to optimize for fast installation])dnl
|
||||||
|
])# _LT_ENABLE_FAST_INSTALL
|
||||||
|
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])])
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])])
|
||||||
|
|
||||||
|
# Old names:
|
||||||
|
AU_DEFUN([AC_ENABLE_FAST_INSTALL],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install])
|
||||||
|
AC_DIAGNOSE([obsolete],
|
||||||
|
[$0: Remove this warning and the call to _LT_SET_OPTION when you put
|
||||||
|
the `fast-install' option into LT_INIT's first parameter.])
|
||||||
|
])
|
||||||
|
|
||||||
|
AU_DEFUN([AC_DISABLE_FAST_INSTALL],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], [disable-fast-install])
|
||||||
|
AC_DIAGNOSE([obsolete],
|
||||||
|
[$0: Remove this warning and the call to _LT_SET_OPTION when you put
|
||||||
|
the `disable-fast-install' option into LT_INIT's first parameter.])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl aclocal-1.4 backwards compatibility:
|
||||||
|
dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], [])
|
||||||
|
dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], [])
|
||||||
|
|
||||||
|
|
||||||
|
# _LT_WITH_PIC([MODE])
|
||||||
|
# --------------------
|
||||||
|
# implement the --with-pic flag, and support the `pic-only' and `no-pic'
|
||||||
|
# LT_INIT options.
|
||||||
|
# MODE is either `yes' or `no'. If omitted, it defaults to `both'.
|
||||||
|
m4_define([_LT_WITH_PIC],
|
||||||
|
[AC_ARG_WITH([pic],
|
||||||
|
[AS_HELP_STRING([--with-pic],
|
||||||
|
[try to use only PIC/non-PIC objects @<:@default=use both@:>@])],
|
||||||
|
[pic_mode="$withval"],
|
||||||
|
[pic_mode=default])
|
||||||
|
|
||||||
|
test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
|
||||||
|
|
||||||
|
_LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl
|
||||||
|
])# _LT_WITH_PIC
|
||||||
|
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])])
|
||||||
|
LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])])
|
||||||
|
|
||||||
|
# Old name:
|
||||||
|
AU_DEFUN([AC_LIBTOOL_PICMODE],
|
||||||
|
[_LT_SET_OPTION([LT_INIT], [pic-only])
|
||||||
|
AC_DIAGNOSE([obsolete],
|
||||||
|
[$0: Remove this warning and the call to _LT_SET_OPTION when you
|
||||||
|
put the `pic-only' option into LT_INIT's first parameter.])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl aclocal-1.4 backwards compatibility:
|
||||||
|
dnl AC_DEFUN([AC_LIBTOOL_PICMODE], [])
|
||||||
|
|
||||||
|
## ----------------- ##
|
||||||
|
## LTDL_INIT Options ##
|
||||||
|
## ----------------- ##
|
||||||
|
|
||||||
|
m4_define([_LTDL_MODE], [])
|
||||||
|
LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive],
|
||||||
|
[m4_define([_LTDL_MODE], [nonrecursive])])
|
||||||
|
LT_OPTION_DEFINE([LTDL_INIT], [recursive],
|
||||||
|
[m4_define([_LTDL_MODE], [recursive])])
|
||||||
|
LT_OPTION_DEFINE([LTDL_INIT], [subproject],
|
||||||
|
[m4_define([_LTDL_MODE], [subproject])])
|
||||||
|
|
||||||
|
m4_define([_LTDL_TYPE], [])
|
||||||
|
LT_OPTION_DEFINE([LTDL_INIT], [installable],
|
||||||
|
[m4_define([_LTDL_TYPE], [installable])])
|
||||||
|
LT_OPTION_DEFINE([LTDL_INIT], [convenience],
|
||||||
|
[m4_define([_LTDL_TYPE], [convenience])])
|
@ -0,0 +1,123 @@
|
|||||||
|
# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*-
|
||||||
|
#
|
||||||
|
# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
|
||||||
|
# Written by Gary V. Vaughan, 2004
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation gives
|
||||||
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 6 ltsugar.m4
|
||||||
|
|
||||||
|
# This is to help aclocal find these macros, as it can't see m4_define.
|
||||||
|
AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_join(SEP, ARG1, [ARG2...])
|
||||||
|
# -----------------------------
|
||||||
|
# Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their
|
||||||
|
# associated separator.
|
||||||
|
# Needed until we can rely on m4_join from Autoconf 2.62, since all earlier
|
||||||
|
# versions in m4sugar had bugs.
|
||||||
|
m4_define([lt_join],
|
||||||
|
[m4_if([$#], [1], [],
|
||||||
|
[$#], [2], [[$2]],
|
||||||
|
[m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])])
|
||||||
|
m4_define([_lt_join],
|
||||||
|
[m4_if([$#$2], [2], [],
|
||||||
|
[m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_car(LIST)
|
||||||
|
# lt_cdr(LIST)
|
||||||
|
# ------------
|
||||||
|
# Manipulate m4 lists.
|
||||||
|
# These macros are necessary as long as will still need to support
|
||||||
|
# Autoconf-2.59 which quotes differently.
|
||||||
|
m4_define([lt_car], [[$1]])
|
||||||
|
m4_define([lt_cdr],
|
||||||
|
[m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])],
|
||||||
|
[$#], 1, [],
|
||||||
|
[m4_dquote(m4_shift($@))])])
|
||||||
|
m4_define([lt_unquote], $1)
|
||||||
|
|
||||||
|
|
||||||
|
# lt_append(MACRO-NAME, STRING, [SEPARATOR])
|
||||||
|
# ------------------------------------------
|
||||||
|
# Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'.
|
||||||
|
# Note that neither SEPARATOR nor STRING are expanded; they are appended
|
||||||
|
# to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked).
|
||||||
|
# No SEPARATOR is output if MACRO-NAME was previously undefined (different
|
||||||
|
# than defined and empty).
|
||||||
|
#
|
||||||
|
# This macro is needed until we can rely on Autoconf 2.62, since earlier
|
||||||
|
# versions of m4sugar mistakenly expanded SEPARATOR but not STRING.
|
||||||
|
m4_define([lt_append],
|
||||||
|
[m4_define([$1],
|
||||||
|
m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])])
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...])
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# Produce a SEP delimited list of all paired combinations of elements of
|
||||||
|
# PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list
|
||||||
|
# has the form PREFIXmINFIXSUFFIXn.
|
||||||
|
# Needed until we can rely on m4_combine added in Autoconf 2.62.
|
||||||
|
m4_define([lt_combine],
|
||||||
|
[m4_if(m4_eval([$# > 3]), [1],
|
||||||
|
[m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl
|
||||||
|
[[m4_foreach([_Lt_prefix], [$2],
|
||||||
|
[m4_foreach([_Lt_suffix],
|
||||||
|
]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[,
|
||||||
|
[_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ])
|
||||||
|
# -----------------------------------------------------------------------
|
||||||
|
# Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited
|
||||||
|
# by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ.
|
||||||
|
m4_define([lt_if_append_uniq],
|
||||||
|
[m4_ifdef([$1],
|
||||||
|
[m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1],
|
||||||
|
[lt_append([$1], [$2], [$3])$4],
|
||||||
|
[$5])],
|
||||||
|
[lt_append([$1], [$2], [$3])$4])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_dict_add(DICT, KEY, VALUE)
|
||||||
|
# -----------------------------
|
||||||
|
m4_define([lt_dict_add],
|
||||||
|
[m4_define([$1($2)], [$3])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE)
|
||||||
|
# --------------------------------------------
|
||||||
|
m4_define([lt_dict_add_subkey],
|
||||||
|
[m4_define([$1($2:$3)], [$4])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_dict_fetch(DICT, KEY, [SUBKEY])
|
||||||
|
# ----------------------------------
|
||||||
|
m4_define([lt_dict_fetch],
|
||||||
|
[m4_ifval([$3],
|
||||||
|
m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]),
|
||||||
|
m4_ifdef([$1($2)], [m4_defn([$1($2)])]))])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE])
|
||||||
|
# -----------------------------------------------------------------
|
||||||
|
m4_define([lt_if_dict_fetch],
|
||||||
|
[m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4],
|
||||||
|
[$5],
|
||||||
|
[$6])])
|
||||||
|
|
||||||
|
|
||||||
|
# lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...])
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
m4_define([lt_dict_filter],
|
||||||
|
[m4_if([$5], [], [],
|
||||||
|
[lt_join(m4_quote(m4_default([$4], [[, ]])),
|
||||||
|
lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]),
|
||||||
|
[lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl
|
||||||
|
])
|
@ -0,0 +1,23 @@
|
|||||||
|
# ltversion.m4 -- version numbers -*- Autoconf -*-
|
||||||
|
#
|
||||||
|
# Copyright (C) 2004 Free Software Foundation, Inc.
|
||||||
|
# Written by Scott James Remnant, 2004
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation gives
|
||||||
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Generated from ltversion.in.
|
||||||
|
|
||||||
|
# serial 3017 ltversion.m4
|
||||||
|
# This file is part of GNU Libtool
|
||||||
|
|
||||||
|
m4_define([LT_PACKAGE_VERSION], [2.2.6b])
|
||||||
|
m4_define([LT_PACKAGE_REVISION], [1.3017])
|
||||||
|
|
||||||
|
AC_DEFUN([LTVERSION_VERSION],
|
||||||
|
[macro_version='2.2.6b'
|
||||||
|
macro_revision='1.3017'
|
||||||
|
_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
|
||||||
|
_LT_DECL(, macro_revision, 0)
|
||||||
|
])
|
@ -0,0 +1,92 @@
|
|||||||
|
# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*-
|
||||||
|
#
|
||||||
|
# Copyright (C) 2004, 2005, 2007 Free Software Foundation, Inc.
|
||||||
|
# Written by Scott James Remnant, 2004.
|
||||||
|
#
|
||||||
|
# This file is free software; the Free Software Foundation gives
|
||||||
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# serial 4 lt~obsolete.m4
|
||||||
|
|
||||||
|
# These exist entirely to fool aclocal when bootstrapping libtool.
|
||||||
|
#
|
||||||
|
# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN)
|
||||||
|
# which have later been changed to m4_define as they aren't part of the
|
||||||
|
# exported API, or moved to Autoconf or Automake where they belong.
|
||||||
|
#
|
||||||
|
# The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN
|
||||||
|
# in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us
|
||||||
|
# using a macro with the same name in our local m4/libtool.m4 it'll
|
||||||
|
# pull the old libtool.m4 in (it doesn't see our shiny new m4_define
|
||||||
|
# and doesn't know about Autoconf macros at all.)
|
||||||
|
#
|
||||||
|
# So we provide this file, which has a silly filename so it's always
|
||||||
|
# included after everything else. This provides aclocal with the
|
||||||
|
# AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything
|
||||||
|
# because those macros already exist, or will be overwritten later.
|
||||||
|
# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6.
|
||||||
|
#
|
||||||
|
# Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here.
|
||||||
|
# Yes, that means every name once taken will need to remain here until
|
||||||
|
# we give up compatibility with versions before 1.7, at which point
|
||||||
|
# we need to keep only those names which we still refer to.
|
||||||
|
|
||||||
|
# This is to help aclocal find these macros, as it can't see m4_define.
|
||||||
|
AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])])
|
||||||
|
|
||||||
|
m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])])
|
||||||
|
m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])])
|
||||||
|
m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])])
|
||||||
|
m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])])
|
||||||
|
m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])])
|
||||||
|
m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])])
|
||||||
|
m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])])
|
||||||
|
m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])])
|
||||||
|
m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])])
|
||||||
|
m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])])
|
||||||
|
m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])])
|
||||||
|
m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])])
|
||||||
|
m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])])
|
||||||
|
m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])])
|
||||||
|
m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])])
|
||||||
|
m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])])
|
||||||
|
m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])])
|
||||||
|
m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])])
|
||||||
|
m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])])
|
||||||
|
m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])])
|
||||||
|
m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])])
|
||||||
|
m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])])
|
||||||
|
m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])])
|
||||||
|
m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])])
|
||||||
|
m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])])
|
||||||
|
m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_RC], [AC_DEFUN([AC_LIBTOOL_RC])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])])
|
||||||
|
m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])])
|
||||||
|
m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])])
|
||||||
|
m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])])
|
@ -0,0 +1,376 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
# Common stub for a few missing GNU programs while installing.
|
||||||
|
|
||||||
|
scriptversion=2009-04-28.21; # UTC
|
||||||
|
|
||||||
|
# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006,
|
||||||
|
# 2008, 2009 Free Software Foundation, Inc.
|
||||||
|
# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
||||||
|
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
# any later version.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
# As a special exception to the GNU General Public License, if you
|
||||||
|
# distribute this file as part of a program that contains a
|
||||||
|
# configuration script generated by Autoconf, you may include it under
|
||||||
|
# the same distribution terms that you use for the rest of that program.
|
||||||
|
|
||||||
|
if test $# -eq 0; then
|
||||||
|
echo 1>&2 "Try \`$0 --help' for more information"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
run=:
|
||||||
|
sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p'
|
||||||
|
sed_minuso='s/.* -o \([^ ]*\).*/\1/p'
|
||||||
|
|
||||||
|
# In the cases where this matters, `missing' is being run in the
|
||||||
|
# srcdir already.
|
||||||
|
if test -f configure.ac; then
|
||||||
|
configure_ac=configure.ac
|
||||||
|
else
|
||||||
|
configure_ac=configure.in
|
||||||
|
fi
|
||||||
|
|
||||||
|
msg="missing on your system"
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
--run)
|
||||||
|
# Try to run requested program, and just exit if it succeeds.
|
||||||
|
run=
|
||||||
|
shift
|
||||||
|
"$@" && exit 0
|
||||||
|
# Exit code 63 means version mismatch. This often happens
|
||||||
|
# when the user try to use an ancient version of a tool on
|
||||||
|
# a file that requires a minimum version. In this case we
|
||||||
|
# we should proceed has if the program had been absent, or
|
||||||
|
# if --run hadn't been passed.
|
||||||
|
if test $? = 63; then
|
||||||
|
run=:
|
||||||
|
msg="probably too old"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
-h|--h|--he|--hel|--help)
|
||||||
|
echo "\
|
||||||
|
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
||||||
|
|
||||||
|
Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
|
||||||
|
error status if there is no known handling for PROGRAM.
|
||||||
|
|
||||||
|
Options:
|
||||||
|
-h, --help display this help and exit
|
||||||
|
-v, --version output version information and exit
|
||||||
|
--run try to run the given command, and emulate it if it fails
|
||||||
|
|
||||||
|
Supported PROGRAM values:
|
||||||
|
aclocal touch file \`aclocal.m4'
|
||||||
|
autoconf touch file \`configure'
|
||||||
|
autoheader touch file \`config.h.in'
|
||||||
|
autom4te touch the output file, or create a stub one
|
||||||
|
automake touch all \`Makefile.in' files
|
||||||
|
bison create \`y.tab.[ch]', if possible, from existing .[ch]
|
||||||
|
flex create \`lex.yy.c', if possible, from existing .c
|
||||||
|
help2man touch the output file
|
||||||
|
lex create \`lex.yy.c', if possible, from existing .c
|
||||||
|
makeinfo touch the output file
|
||||||
|
tar try tar, gnutar, gtar, then tar without non-portable flags
|
||||||
|
yacc create \`y.tab.[ch]', if possible, from existing .[ch]
|
||||||
|
|
||||||
|
Version suffixes to PROGRAM as well as the prefixes \`gnu-', \`gnu', and
|
||||||
|
\`g' are ignored when checking the name.
|
||||||
|
|
||||||
|
Send bug reports to <bug-automake@gnu.org>."
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
|
||||||
|
-v|--v|--ve|--ver|--vers|--versi|--versio|--version)
|
||||||
|
echo "missing $scriptversion (GNU Automake)"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
|
||||||
|
-*)
|
||||||
|
echo 1>&2 "$0: Unknown \`$1' option"
|
||||||
|
echo 1>&2 "Try \`$0 --help' for more information"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
|
||||||
|
# normalize program name to check for.
|
||||||
|
program=`echo "$1" | sed '
|
||||||
|
s/^gnu-//; t
|
||||||
|
s/^gnu//; t
|
||||||
|
s/^g//; t'`
|
||||||
|
|
||||||
|
# Now exit if we have it, but it failed. Also exit now if we
|
||||||
|
# don't have it and --version was passed (most likely to detect
|
||||||
|
# the program). This is about non-GNU programs, so use $1 not
|
||||||
|
# $program.
|
||||||
|
case $1 in
|
||||||
|
lex*|yacc*)
|
||||||
|
# Not GNU programs, they don't have --version.
|
||||||
|
;;
|
||||||
|
|
||||||
|
tar*)
|
||||||
|
if test -n "$run"; then
|
||||||
|
echo 1>&2 "ERROR: \`tar' requires --run"
|
||||||
|
exit 1
|
||||||
|
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
|
||||||
|
# We have it, but it failed.
|
||||||
|
exit 1
|
||||||
|
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
||||||
|
# Could not run --version or --help. This is probably someone
|
||||||
|
# running `$TOOL --version' or `$TOOL --help' to check whether
|
||||||
|
# $TOOL exists and not knowing $TOOL uses missing.
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# If it does not exist, or fails to run (possibly an outdated version),
|
||||||
|
# try to emulate it.
|
||||||
|
case $program in
|
||||||
|
aclocal*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`acinclude.m4' or \`${configure_ac}'. You might want
|
||||||
|
to install the \`Automake' and \`Perl' packages. Grab them from
|
||||||
|
any GNU archive site."
|
||||||
|
touch aclocal.m4
|
||||||
|
;;
|
||||||
|
|
||||||
|
autoconf*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`${configure_ac}'. You might want to install the
|
||||||
|
\`Autoconf' and \`GNU m4' packages. Grab them from any GNU
|
||||||
|
archive site."
|
||||||
|
touch configure
|
||||||
|
;;
|
||||||
|
|
||||||
|
autoheader*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`acconfig.h' or \`${configure_ac}'. You might want
|
||||||
|
to install the \`Autoconf' and \`GNU m4' packages. Grab them
|
||||||
|
from any GNU archive site."
|
||||||
|
files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
|
||||||
|
test -z "$files" && files="config.h"
|
||||||
|
touch_files=
|
||||||
|
for f in $files; do
|
||||||
|
case $f in
|
||||||
|
*:*) touch_files="$touch_files "`echo "$f" |
|
||||||
|
sed -e 's/^[^:]*://' -e 's/:.*//'`;;
|
||||||
|
*) touch_files="$touch_files $f.in";;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
touch $touch_files
|
||||||
|
;;
|
||||||
|
|
||||||
|
automake*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
|
||||||
|
You might want to install the \`Automake' and \`Perl' packages.
|
||||||
|
Grab them from any GNU archive site."
|
||||||
|
find . -type f -name Makefile.am -print |
|
||||||
|
sed 's/\.am$/.in/' |
|
||||||
|
while read f; do touch "$f"; done
|
||||||
|
;;
|
||||||
|
|
||||||
|
autom4te*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is needed, but is $msg.
|
||||||
|
You might have modified some files without having the
|
||||||
|
proper tools for further handling them.
|
||||||
|
You can get \`$1' as part of \`Autoconf' from any GNU
|
||||||
|
archive site."
|
||||||
|
|
||||||
|
file=`echo "$*" | sed -n "$sed_output"`
|
||||||
|
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
||||||
|
if test -f "$file"; then
|
||||||
|
touch $file
|
||||||
|
else
|
||||||
|
test -z "$file" || exec >$file
|
||||||
|
echo "#! /bin/sh"
|
||||||
|
echo "# Created by GNU Automake missing as a replacement of"
|
||||||
|
echo "# $ $@"
|
||||||
|
echo "exit 0"
|
||||||
|
chmod +x $file
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
bison*|yacc*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' $msg. You should only need it if
|
||||||
|
you modified a \`.y' file. You may need the \`Bison' package
|
||||||
|
in order for those modifications to take effect. You can get
|
||||||
|
\`Bison' from any GNU archive site."
|
||||||
|
rm -f y.tab.c y.tab.h
|
||||||
|
if test $# -ne 1; then
|
||||||
|
eval LASTARG="\${$#}"
|
||||||
|
case $LASTARG in
|
||||||
|
*.y)
|
||||||
|
SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
|
||||||
|
if test -f "$SRCFILE"; then
|
||||||
|
cp "$SRCFILE" y.tab.c
|
||||||
|
fi
|
||||||
|
SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
|
||||||
|
if test -f "$SRCFILE"; then
|
||||||
|
cp "$SRCFILE" y.tab.h
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
if test ! -f y.tab.h; then
|
||||||
|
echo >y.tab.h
|
||||||
|
fi
|
||||||
|
if test ! -f y.tab.c; then
|
||||||
|
echo 'main() { return 0; }' >y.tab.c
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
lex*|flex*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified a \`.l' file. You may need the \`Flex' package
|
||||||
|
in order for those modifications to take effect. You can get
|
||||||
|
\`Flex' from any GNU archive site."
|
||||||
|
rm -f lex.yy.c
|
||||||
|
if test $# -ne 1; then
|
||||||
|
eval LASTARG="\${$#}"
|
||||||
|
case $LASTARG in
|
||||||
|
*.l)
|
||||||
|
SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
|
||||||
|
if test -f "$SRCFILE"; then
|
||||||
|
cp "$SRCFILE" lex.yy.c
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
if test ! -f lex.yy.c; then
|
||||||
|
echo 'main() { return 0; }' >lex.yy.c
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
help2man*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified a dependency of a manual page. You may need the
|
||||||
|
\`Help2man' package in order for those modifications to take
|
||||||
|
effect. You can get \`Help2man' from any GNU archive site."
|
||||||
|
|
||||||
|
file=`echo "$*" | sed -n "$sed_output"`
|
||||||
|
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
||||||
|
if test -f "$file"; then
|
||||||
|
touch $file
|
||||||
|
else
|
||||||
|
test -z "$file" || exec >$file
|
||||||
|
echo ".ab help2man is required to generate this page"
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
makeinfo*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is $msg. You should only need it if
|
||||||
|
you modified a \`.texi' or \`.texinfo' file, or any other file
|
||||||
|
indirectly affecting the aspect of the manual. The spurious
|
||||||
|
call might also be the consequence of using a buggy \`make' (AIX,
|
||||||
|
DU, IRIX). You might want to install the \`Texinfo' package or
|
||||||
|
the \`GNU make' package. Grab either from any GNU archive site."
|
||||||
|
# The file to touch is that specified with -o ...
|
||||||
|
file=`echo "$*" | sed -n "$sed_output"`
|
||||||
|
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
||||||
|
if test -z "$file"; then
|
||||||
|
# ... or it is the one specified with @setfilename ...
|
||||||
|
infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
|
||||||
|
file=`sed -n '
|
||||||
|
/^@setfilename/{
|
||||||
|
s/.* \([^ ]*\) *$/\1/
|
||||||
|
p
|
||||||
|
q
|
||||||
|
}' $infile`
|
||||||
|
# ... or it is derived from the source name (dir/f.texi becomes f.info)
|
||||||
|
test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info
|
||||||
|
fi
|
||||||
|
# If the file does not exist, the user really needs makeinfo;
|
||||||
|
# let's fail without touching anything.
|
||||||
|
test -f $file || exit 1
|
||||||
|
touch $file
|
||||||
|
;;
|
||||||
|
|
||||||
|
tar*)
|
||||||
|
shift
|
||||||
|
|
||||||
|
# We have already tried tar in the generic part.
|
||||||
|
# Look for gnutar/gtar before invocation to avoid ugly error
|
||||||
|
# messages.
|
||||||
|
if (gnutar --version > /dev/null 2>&1); then
|
||||||
|
gnutar "$@" && exit 0
|
||||||
|
fi
|
||||||
|
if (gtar --version > /dev/null 2>&1); then
|
||||||
|
gtar "$@" && exit 0
|
||||||
|
fi
|
||||||
|
firstarg="$1"
|
||||||
|
if shift; then
|
||||||
|
case $firstarg in
|
||||||
|
*o*)
|
||||||
|
firstarg=`echo "$firstarg" | sed s/o//`
|
||||||
|
tar "$firstarg" "$@" && exit 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
case $firstarg in
|
||||||
|
*h*)
|
||||||
|
firstarg=`echo "$firstarg" | sed s/h//`
|
||||||
|
tar "$firstarg" "$@" && exit 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: I can't seem to be able to run \`tar' with the given arguments.
|
||||||
|
You may want to install GNU tar or Free paxutils, or check the
|
||||||
|
command line arguments."
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo 1>&2 "\
|
||||||
|
WARNING: \`$1' is needed, and is $msg.
|
||||||
|
You might have modified some files without having the
|
||||||
|
proper tools for further handling them. Check the \`README' file,
|
||||||
|
it often tells you about the needed prerequisites for installing
|
||||||
|
this package. You may also peek at any GNU archive site, in case
|
||||||
|
some other package would contain this missing \`$1' program."
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
# time-stamp-start: "scriptversion="
|
||||||
|
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||||
|
# time-stamp-time-zone: "UTC"
|
||||||
|
# time-stamp-end: "; # UTC"
|
||||||
|
# End:
|
File diff suppressed because one or more lines are too long
@ -0,0 +1,51 @@
|
|||||||
|
AUTOMAKE_OPTIONS = gnu
|
||||||
|
|
||||||
|
INCLUDES = @CURL_CFLAGS@ @GLIB_CFLAGS@ \
|
||||||
|
-I$(top_srcdir) -I$(top_builddir)
|
||||||
|
|
||||||
|
if STATIC_LINK
|
||||||
|
noinst_LTLIBRARIES = libcarddav.la
|
||||||
|
endif
|
||||||
|
|
||||||
|
if DYNAMIC_LINK
|
||||||
|
lib_LTLIBRARIES = libcarddav.la
|
||||||
|
endif
|
||||||
|
|
||||||
|
libcarddav_la_LDFLAGS = -version-info @LIBVERSION@
|
||||||
|
|
||||||
|
libcarddav_la_SOURCES = \
|
||||||
|
carddav.h \
|
||||||
|
carddav.c \
|
||||||
|
add-carddav-object.c \
|
||||||
|
add-carddav-object.h \
|
||||||
|
delete-carddav-object.c \
|
||||||
|
delete-carddav-object.h \
|
||||||
|
modify-carddav-object.c \
|
||||||
|
modify-carddav-object.h \
|
||||||
|
get-carddav-report.c \
|
||||||
|
get-carddav-report.h \
|
||||||
|
get-display-name.c \
|
||||||
|
get-display-name.h \
|
||||||
|
carddav-utils.c \
|
||||||
|
carddav-utils.h \
|
||||||
|
md5.c \
|
||||||
|
md5.h \
|
||||||
|
options-carddav-server.c \
|
||||||
|
options-carddav-server.h \
|
||||||
|
lock-carddav-object.c \
|
||||||
|
lock-carddav-object.h
|
||||||
|
|
||||||
|
libcarddav_includedir=$(includedir)/libcarddav-@VERSION@
|
||||||
|
libcarddav_include_HEADERS = carddav.h
|
||||||
|
|
||||||
|
noinst_HEADERS = \
|
||||||
|
add-carddav-object.h \
|
||||||
|
delete-carddav-object.h \
|
||||||
|
modify-carddav-object.h \
|
||||||
|
get-carddav-report.h \
|
||||||
|
carddav-utils.h
|
||||||
|
|
||||||
|
libcarddav_la_LIBADD = \
|
||||||
|
@CURL_LIBS@ \
|
||||||
|
@GLIB_LIBS@
|
||||||
|
|
@ -0,0 +1,642 @@
|
|||||||
|
# Makefile.in generated by automake 1.11 from Makefile.am.
|
||||||
|
# @configure_input@
|
||||||
|
|
||||||
|
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
||||||
|
# 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation,
|
||||||
|
# Inc.
|
||||||
|
# This Makefile.in is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
||||||
|
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||||
|
# PARTICULAR PURPOSE.
|
||||||
|
|
||||||
|
@SET_MAKE@
|
||||||
|
|
||||||
|
|
||||||
|
VPATH = @srcdir@
|
||||||
|
pkgdatadir = $(datadir)/@PACKAGE@
|
||||||
|
pkgincludedir = $(includedir)/@PACKAGE@
|
||||||
|
pkglibdir = $(libdir)/@PACKAGE@
|
||||||
|
pkglibexecdir = $(libexecdir)/@PACKAGE@
|
||||||
|
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
||||||
|
install_sh_DATA = $(install_sh) -c -m 644
|
||||||
|
install_sh_PROGRAM = $(install_sh) -c
|
||||||
|
install_sh_SCRIPT = $(install_sh) -c
|
||||||
|
INSTALL_HEADER = $(INSTALL_DATA)
|
||||||
|
transform = $(program_transform_name)
|
||||||
|
NORMAL_INSTALL = :
|
||||||
|
PRE_INSTALL = :
|
||||||
|
POST_INSTALL = :
|
||||||
|
NORMAL_UNINSTALL = :
|
||||||
|
PRE_UNINSTALL = :
|
||||||
|
POST_UNINSTALL = :
|
||||||
|
build_triplet = @build@
|
||||||
|
host_triplet = @host@
|
||||||
|
target_triplet = @target@
|
||||||
|
subdir = src
|
||||||
|
DIST_COMMON = $(libcarddav_include_HEADERS) $(noinst_HEADERS) \
|
||||||
|
$(srcdir)/Makefile.am $(srcdir)/Makefile.in
|
||||||
|
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
||||||
|
am__aclocal_m4_deps = $(top_srcdir)/m4/ax_prog_doxygen.m4 \
|
||||||
|
$(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
|
||||||
|
$(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
|
||||||
|
$(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
|
||||||
|
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
||||||
|
$(ACLOCAL_M4)
|
||||||
|
mkinstalldirs = $(install_sh) -d
|
||||||
|
CONFIG_HEADER = $(top_builddir)/config.h
|
||||||
|
CONFIG_CLEAN_FILES =
|
||||||
|
CONFIG_CLEAN_VPATH_FILES =
|
||||||
|
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
||||||
|
am__vpath_adj = case $$p in \
|
||||||
|
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
||||||
|
*) f=$$p;; \
|
||||||
|
esac;
|
||||||
|
am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
|
||||||
|
am__install_max = 40
|
||||||
|
am__nobase_strip_setup = \
|
||||||
|
srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
|
||||||
|
am__nobase_strip = \
|
||||||
|
for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
|
||||||
|
am__nobase_list = $(am__nobase_strip_setup); \
|
||||||
|
for p in $$list; do echo "$$p $$p"; done | \
|
||||||
|
sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
|
||||||
|
$(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
|
||||||
|
if (++n[$$2] == $(am__install_max)) \
|
||||||
|
{ print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
|
||||||
|
END { for (dir in files) print dir, files[dir] }'
|
||||||
|
am__base_list = \
|
||||||
|
sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
|
||||||
|
sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
|
||||||
|
am__installdirs = "$(DESTDIR)$(libdir)" \
|
||||||
|
"$(DESTDIR)$(libcarddav_includedir)"
|
||||||
|
LTLIBRARIES = $(lib_LTLIBRARIES) $(noinst_LTLIBRARIES)
|
||||||
|
libcarddav_la_DEPENDENCIES =
|
||||||
|
am_libcarddav_la_OBJECTS = carddav.lo add-carddav-object.lo \
|
||||||
|
delete-carddav-object.lo modify-carddav-object.lo \
|
||||||
|
get-carddav-report.lo get-display-name.lo carddav-utils.lo \
|
||||||
|
md5.lo options-carddav-server.lo lock-carddav-object.lo
|
||||||
|
libcarddav_la_OBJECTS = $(am_libcarddav_la_OBJECTS)
|
||||||
|
libcarddav_la_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \
|
||||||
|
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
|
||||||
|
$(libcarddav_la_LDFLAGS) $(LDFLAGS) -o $@
|
||||||
|
@DYNAMIC_LINK_TRUE@am_libcarddav_la_rpath = -rpath $(libdir)
|
||||||
|
@STATIC_LINK_TRUE@am_libcarddav_la_rpath =
|
||||||
|
DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
|
||||||
|
depcomp = $(SHELL) $(top_srcdir)/depcomp
|
||||||
|
am__depfiles_maybe = depfiles
|
||||||
|
am__mv = mv -f
|
||||||
|
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
|
||||||
|
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
||||||
|
LTCOMPILE = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
|
||||||
|
--mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \
|
||||||
|
$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
||||||
|
CCLD = $(CC)
|
||||||
|
LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \
|
||||||
|
--mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) \
|
||||||
|
$(LDFLAGS) -o $@
|
||||||
|
SOURCES = $(libcarddav_la_SOURCES)
|
||||||
|
DIST_SOURCES = $(libcarddav_la_SOURCES)
|
||||||
|
HEADERS = $(libcarddav_include_HEADERS) $(noinst_HEADERS)
|
||||||
|
ETAGS = etags
|
||||||
|
CTAGS = ctags
|
||||||
|
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
|
ACLOCAL = @ACLOCAL@
|
||||||
|
AMTAR = @AMTAR@
|
||||||
|
AR = @AR@
|
||||||
|
AUTOCONF = @AUTOCONF@
|
||||||
|
AUTOHEADER = @AUTOHEADER@
|
||||||
|
AUTOMAKE = @AUTOMAKE@
|
||||||
|
AWK = @AWK@
|
||||||
|
CC = @CC@
|
||||||
|
CCDEPMODE = @CCDEPMODE@
|
||||||
|
CFLAGS = @CFLAGS@
|
||||||
|
CPP = @CPP@
|
||||||
|
CPPFLAGS = @CPPFLAGS@
|
||||||
|
CURL_CFLAGS = @CURL_CFLAGS@
|
||||||
|
CURL_LIBS = @CURL_LIBS@
|
||||||
|
CYGPATH_W = @CYGPATH_W@
|
||||||
|
DEFS = @DEFS@
|
||||||
|
DEPDIR = @DEPDIR@
|
||||||
|
DOXYGEN_PAPER_SIZE = @DOXYGEN_PAPER_SIZE@
|
||||||
|
DSYMUTIL = @DSYMUTIL@
|
||||||
|
DUMPBIN = @DUMPBIN@
|
||||||
|
DX_CONFIG = @DX_CONFIG@
|
||||||
|
DX_DOCDIR = @DX_DOCDIR@
|
||||||
|
DX_DOT = @DX_DOT@
|
||||||
|
DX_DOXYGEN = @DX_DOXYGEN@
|
||||||
|
DX_DVIPS = @DX_DVIPS@
|
||||||
|
DX_EGREP = @DX_EGREP@
|
||||||
|
DX_ENV = @DX_ENV@
|
||||||
|
DX_FLAG_chi = @DX_FLAG_chi@
|
||||||
|
DX_FLAG_chm = @DX_FLAG_chm@
|
||||||
|
DX_FLAG_doc = @DX_FLAG_doc@
|
||||||
|
DX_FLAG_dot = @DX_FLAG_dot@
|
||||||
|
DX_FLAG_html = @DX_FLAG_html@
|
||||||
|
DX_FLAG_man = @DX_FLAG_man@
|
||||||
|
DX_FLAG_pdf = @DX_FLAG_pdf@
|
||||||
|
DX_FLAG_ps = @DX_FLAG_ps@
|
||||||
|
DX_FLAG_rtf = @DX_FLAG_rtf@
|
||||||
|
DX_FLAG_xml = @DX_FLAG_xml@
|
||||||
|
DX_HHC = @DX_HHC@
|
||||||
|
DX_LATEX = @DX_LATEX@
|
||||||
|
DX_MAKEINDEX = @DX_MAKEINDEX@
|
||||||
|
DX_PDFLATEX = @DX_PDFLATEX@
|
||||||
|
DX_PERL = @DX_PERL@
|
||||||
|
DX_PROJECT = @DX_PROJECT@
|
||||||
|
ECHO_C = @ECHO_C@
|
||||||
|
ECHO_N = @ECHO_N@
|
||||||
|
ECHO_T = @ECHO_T@
|
||||||
|
EGREP = @EGREP@
|
||||||
|
EXEEXT = @EXEEXT@
|
||||||
|
FGREP = @FGREP@
|
||||||
|
GLIB_CFLAGS = @GLIB_CFLAGS@
|
||||||
|
GLIB_LIBS = @GLIB_LIBS@
|
||||||
|
GREP = @GREP@
|
||||||
|
INSTALL = @INSTALL@
|
||||||
|
INSTALL_DATA = @INSTALL_DATA@
|
||||||
|
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
||||||
|
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||||
|
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
||||||
|
LD = @LD@
|
||||||
|
LDFLAGS = @LDFLAGS@
|
||||||
|
LIBOBJS = @LIBOBJS@
|
||||||
|
LIBS = @LIBS@
|
||||||
|
LIBTOOL = @LIBTOOL@
|
||||||
|
LIBVERSION = @LIBVERSION@
|
||||||
|
LIPO = @LIPO@
|
||||||
|
LN_S = @LN_S@
|
||||||
|
LTLIBOBJS = @LTLIBOBJS@
|
||||||
|
MAINT = @MAINT@
|
||||||
|
MAKEINFO = @MAKEINFO@
|
||||||
|
MKDIR_P = @MKDIR_P@
|
||||||
|
NM = @NM@
|
||||||
|
NMEDIT = @NMEDIT@
|
||||||
|
OBJDUMP = @OBJDUMP@
|
||||||
|
OBJEXT = @OBJEXT@
|
||||||
|
OTOOL = @OTOOL@
|
||||||
|
OTOOL64 = @OTOOL64@
|
||||||
|
PACKAGE = @PACKAGE@
|
||||||
|
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
||||||
|
PACKAGE_NAME = @PACKAGE_NAME@
|
||||||
|
PACKAGE_STRING = @PACKAGE_STRING@
|
||||||
|
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
||||||
|
PACKAGE_VERSION = @PACKAGE_VERSION@
|
||||||
|
PATH_SEPARATOR = @PATH_SEPARATOR@
|
||||||
|
PKG_CONFIG = @PKG_CONFIG@
|
||||||
|
RANLIB = @RANLIB@
|
||||||
|
SED = @SED@
|
||||||
|
SET_MAKE = @SET_MAKE@
|
||||||
|
SHELL = @SHELL@
|
||||||
|
STRIP = @STRIP@
|
||||||
|
VERSION = @VERSION@
|
||||||
|
abs_builddir = @abs_builddir@
|
||||||
|
abs_srcdir = @abs_srcdir@
|
||||||
|
abs_top_builddir = @abs_top_builddir@
|
||||||
|
abs_top_srcdir = @abs_top_srcdir@
|
||||||
|
ac_ct_CC = @ac_ct_CC@
|
||||||
|
ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
|
||||||
|
am__include = @am__include@
|
||||||
|
am__leading_dot = @am__leading_dot@
|
||||||
|
am__quote = @am__quote@
|
||||||
|
am__tar = @am__tar@
|
||||||
|
am__untar = @am__untar@
|
||||||
|
bindir = @bindir@
|
||||||
|
build = @build@
|
||||||
|
build_alias = @build_alias@
|
||||||
|
build_cpu = @build_cpu@
|
||||||
|
build_os = @build_os@
|
||||||
|
build_vendor = @build_vendor@
|
||||||
|
builddir = @builddir@
|
||||||
|
datadir = @datadir@
|
||||||
|
datarootdir = @datarootdir@
|
||||||
|
docdir = @docdir@
|
||||||
|
dvidir = @dvidir@
|
||||||
|
exec_prefix = @exec_prefix@
|
||||||
|
host = @host@
|
||||||
|
host_alias = @host_alias@
|
||||||
|
host_cpu = @host_cpu@
|
||||||
|
host_os = @host_os@
|
||||||
|
host_vendor = @host_vendor@
|
||||||
|
htmldir = @htmldir@
|
||||||
|
includedir = @includedir@
|
||||||
|
infodir = @infodir@
|
||||||
|
install_sh = @install_sh@
|
||||||
|
libdir = @libdir@
|
||||||
|
libexecdir = @libexecdir@
|
||||||
|
localedir = @localedir@
|
||||||
|
localstatedir = @localstatedir@
|
||||||
|
lt_ECHO = @lt_ECHO@
|
||||||
|
mandir = @mandir@
|
||||||
|
mkdir_p = @mkdir_p@
|
||||||
|
oldincludedir = @oldincludedir@
|
||||||
|
pdfdir = @pdfdir@
|
||||||
|
prefix = @prefix@
|
||||||
|
program_transform_name = @program_transform_name@
|
||||||
|
psdir = @psdir@
|
||||||
|
sbindir = @sbindir@
|
||||||
|
sharedstatedir = @sharedstatedir@
|
||||||
|
srcdir = @srcdir@
|
||||||
|
sysconfdir = @sysconfdir@
|
||||||
|
target = @target@
|
||||||
|
target_alias = @target_alias@
|
||||||
|
target_cpu = @target_cpu@
|
||||||
|
target_os = @target_os@
|
||||||
|
target_vendor = @target_vendor@
|
||||||
|
top_build_prefix = @top_build_prefix@
|
||||||
|
top_builddir = @top_builddir@
|
||||||
|
top_srcdir = @top_srcdir@
|
||||||
|
AUTOMAKE_OPTIONS = gnu
|
||||||
|
INCLUDES = @CURL_CFLAGS@ @GLIB_CFLAGS@ \
|
||||||
|
-I$(top_srcdir) -I$(top_builddir)
|
||||||
|
|
||||||
|
@STATIC_LINK_TRUE@noinst_LTLIBRARIES = libcarddav.la
|
||||||
|
@DYNAMIC_LINK_TRUE@lib_LTLIBRARIES = libcarddav.la
|
||||||
|
libcarddav_la_LDFLAGS = -version-info @LIBVERSION@
|
||||||
|
libcarddav_la_SOURCES = \
|
||||||
|
carddav.h \
|
||||||
|
carddav.c \
|
||||||
|
add-carddav-object.c \
|
||||||
|
add-carddav-object.h \
|
||||||
|
delete-carddav-object.c \
|
||||||
|
delete-carddav-object.h \
|
||||||
|
modify-carddav-object.c \
|
||||||
|
modify-carddav-object.h \
|
||||||
|
get-carddav-report.c \
|
||||||
|
get-carddav-report.h \
|
||||||
|
get-display-name.c \
|
||||||
|
get-display-name.h \
|
||||||
|
carddav-utils.c \
|
||||||
|
carddav-utils.h \
|
||||||
|
md5.c \
|
||||||
|
md5.h \
|
||||||
|
options-carddav-server.c \
|
||||||
|
options-carddav-server.h \
|
||||||
|
lock-carddav-object.c \
|
||||||
|
lock-carddav-object.h
|
||||||
|
|
||||||
|
libcarddav_includedir = $(includedir)/libcarddav-@VERSION@
|
||||||
|
libcarddav_include_HEADERS = carddav.h
|
||||||
|
noinst_HEADERS = \
|
||||||
|
add-carddav-object.h \
|
||||||
|
delete-carddav-object.h \
|
||||||
|
modify-carddav-object.h \
|
||||||
|
get-carddav-report.h \
|
||||||
|
carddav-utils.h
|
||||||
|
|
||||||
|
libcarddav_la_LIBADD = \
|
||||||
|
@CURL_LIBS@ \
|
||||||
|
@GLIB_LIBS@
|
||||||
|
|
||||||
|
all: all-am
|
||||||
|
|
||||||
|
.SUFFIXES:
|
||||||
|
.SUFFIXES: .c .lo .o .obj
|
||||||
|
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
|
||||||
|
@for dep in $?; do \
|
||||||
|
case '$(am__configure_deps)' in \
|
||||||
|
*$$dep*) \
|
||||||
|
( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
|
||||||
|
&& { if test -f $@; then exit 0; else break; fi; }; \
|
||||||
|
exit 1;; \
|
||||||
|
esac; \
|
||||||
|
done; \
|
||||||
|
echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu src/Makefile'; \
|
||||||
|
$(am__cd) $(top_srcdir) && \
|
||||||
|
$(AUTOMAKE) --gnu src/Makefile
|
||||||
|
.PRECIOUS: Makefile
|
||||||
|
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||||
|
@case '$?' in \
|
||||||
|
*config.status*) \
|
||||||
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
|
||||||
|
*) \
|
||||||
|
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
|
||||||
|
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
|
||||||
|
esac;
|
||||||
|
|
||||||
|
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||||
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||||
|
|
||||||
|
$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
|
||||||
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||||
|
$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
|
||||||
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||||
|
$(am__aclocal_m4_deps):
|
||||||
|
install-libLTLIBRARIES: $(lib_LTLIBRARIES)
|
||||||
|
@$(NORMAL_INSTALL)
|
||||||
|
test -z "$(libdir)" || $(MKDIR_P) "$(DESTDIR)$(libdir)"
|
||||||
|
@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
|
||||||
|
list2=; for p in $$list; do \
|
||||||
|
if test -f $$p; then \
|
||||||
|
list2="$$list2 $$p"; \
|
||||||
|
else :; fi; \
|
||||||
|
done; \
|
||||||
|
test -z "$$list2" || { \
|
||||||
|
echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \
|
||||||
|
$(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \
|
||||||
|
}
|
||||||
|
|
||||||
|
uninstall-libLTLIBRARIES:
|
||||||
|
@$(NORMAL_UNINSTALL)
|
||||||
|
@list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
|
||||||
|
for p in $$list; do \
|
||||||
|
$(am__strip_dir) \
|
||||||
|
echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \
|
||||||
|
$(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \
|
||||||
|
done
|
||||||
|
|
||||||
|
clean-libLTLIBRARIES:
|
||||||
|
-test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
|
||||||
|
@list='$(lib_LTLIBRARIES)'; for p in $$list; do \
|
||||||
|
dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \
|
||||||
|
test "$$dir" != "$$p" || dir=.; \
|
||||||
|
echo "rm -f \"$${dir}/so_locations\""; \
|
||||||
|
rm -f "$${dir}/so_locations"; \
|
||||||
|
done
|
||||||
|
|
||||||
|
clean-noinstLTLIBRARIES:
|
||||||
|
-test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES)
|
||||||
|
@list='$(noinst_LTLIBRARIES)'; for p in $$list; do \
|
||||||
|
dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \
|
||||||
|
test "$$dir" != "$$p" || dir=.; \
|
||||||
|
echo "rm -f \"$${dir}/so_locations\""; \
|
||||||
|
rm -f "$${dir}/so_locations"; \
|
||||||
|
done
|
||||||
|
libcarddav.la: $(libcarddav_la_OBJECTS) $(libcarddav_la_DEPENDENCIES)
|
||||||
|
$(libcarddav_la_LINK) $(am_libcarddav_la_rpath) $(libcarddav_la_OBJECTS) $(libcarddav_la_LIBADD) $(LIBS)
|
||||||
|
|
||||||
|
mostlyclean-compile:
|
||||||
|
-rm -f *.$(OBJEXT)
|
||||||
|
|
||||||
|
distclean-compile:
|
||||||
|
-rm -f *.tab.c
|
||||||
|
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/add-carddav-object.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/carddav-utils.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/carddav.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/delete-carddav-object.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/get-carddav-report.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/get-display-name.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lock-carddav-object.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/md5.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/modify-carddav-object.Plo@am__quote@
|
||||||
|
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/options-carddav-server.Plo@am__quote@
|
||||||
|
|
||||||
|
.c.o:
|
||||||
|
@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
||||||
|
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
|
||||||
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
||||||
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||||
|
@am__fastdepCC_FALSE@ $(COMPILE) -c $<
|
||||||
|
|
||||||
|
.c.obj:
|
||||||
|
@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'`
|
||||||
|
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po
|
||||||
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
||||||
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||||
|
@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'`
|
||||||
|
|
||||||
|
.c.lo:
|
||||||
|
@am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
|
||||||
|
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
|
||||||
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
|
||||||
|
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||||
|
@am__fastdepCC_FALSE@ $(LTCOMPILE) -c -o $@ $<
|
||||||
|
|
||||||
|
mostlyclean-libtool:
|
||||||
|
-rm -f *.lo
|
||||||
|
|
||||||
|
clean-libtool:
|
||||||
|
-rm -rf .libs _libs
|
||||||
|
install-libcarddav_includeHEADERS: $(libcarddav_include_HEADERS)
|
||||||
|
@$(NORMAL_INSTALL)
|
||||||
|
test -z "$(libcarddav_includedir)" || $(MKDIR_P) "$(DESTDIR)$(libcarddav_includedir)"
|
||||||
|
@list='$(libcarddav_include_HEADERS)'; test -n "$(libcarddav_includedir)" || list=; \
|
||||||
|
for p in $$list; do \
|
||||||
|
if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
|
||||||
|
echo "$$d$$p"; \
|
||||||
|
done | $(am__base_list) | \
|
||||||
|
while read files; do \
|
||||||
|
echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(libcarddav_includedir)'"; \
|
||||||
|
$(INSTALL_HEADER) $$files "$(DESTDIR)$(libcarddav_includedir)" || exit $$?; \
|
||||||
|
done
|
||||||
|
|
||||||
|
uninstall-libcarddav_includeHEADERS:
|
||||||
|
@$(NORMAL_UNINSTALL)
|
||||||
|
@list='$(libcarddav_include_HEADERS)'; test -n "$(libcarddav_includedir)" || list=; \
|
||||||
|
files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
|
||||||
|
test -n "$$files" || exit 0; \
|
||||||
|
echo " ( cd '$(DESTDIR)$(libcarddav_includedir)' && rm -f" $$files ")"; \
|
||||||
|
cd "$(DESTDIR)$(libcarddav_includedir)" && rm -f $$files
|
||||||
|
|
||||||
|
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
|
mkid -fID $$unique
|
||||||
|
tags: TAGS
|
||||||
|
|
||||||
|
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
|
$(TAGS_FILES) $(LISP)
|
||||||
|
set x; \
|
||||||
|
here=`pwd`; \
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
|
shift; \
|
||||||
|
if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
|
||||||
|
test -n "$$unique" || unique=$$empty_fix; \
|
||||||
|
if test $$# -gt 0; then \
|
||||||
|
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
"$$@" $$unique; \
|
||||||
|
else \
|
||||||
|
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
$$unique; \
|
||||||
|
fi; \
|
||||||
|
fi
|
||||||
|
ctags: CTAGS
|
||||||
|
CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
|
$(TAGS_FILES) $(LISP)
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
||||||
|
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
||||||
|
test -z "$(CTAGS_ARGS)$$unique" \
|
||||||
|
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
||||||
|
$$unique
|
||||||
|
|
||||||
|
GTAGS:
|
||||||
|
here=`$(am__cd) $(top_builddir) && pwd` \
|
||||||
|
&& $(am__cd) $(top_srcdir) \
|
||||||
|
&& gtags -i $(GTAGS_ARGS) "$$here"
|
||||||
|
|
||||||
|
distclean-tags:
|
||||||
|
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
||||||
|
|
||||||
|
distdir: $(DISTFILES)
|
||||||
|
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||||
|
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||||
|
list='$(DISTFILES)'; \
|
||||||
|
dist_files=`for file in $$list; do echo $$file; done | \
|
||||||
|
sed -e "s|^$$srcdirstrip/||;t" \
|
||||||
|
-e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
|
||||||
|
case $$dist_files in \
|
||||||
|
*/*) $(MKDIR_P) `echo "$$dist_files" | \
|
||||||
|
sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
|
||||||
|
sort -u` ;; \
|
||||||
|
esac; \
|
||||||
|
for file in $$dist_files; do \
|
||||||
|
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
||||||
|
if test -d $$d/$$file; then \
|
||||||
|
dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
|
||||||
|
if test -d "$(distdir)/$$file"; then \
|
||||||
|
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
||||||
|
fi; \
|
||||||
|
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
||||||
|
cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
|
||||||
|
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
||||||
|
fi; \
|
||||||
|
cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
|
||||||
|
else \
|
||||||
|
test -f "$(distdir)/$$file" \
|
||||||
|
|| cp -p $$d/$$file "$(distdir)/$$file" \
|
||||||
|
|| exit 1; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
check-am: all-am
|
||||||
|
check: check-am
|
||||||
|
all-am: Makefile $(LTLIBRARIES) $(HEADERS)
|
||||||
|
installdirs:
|
||||||
|
for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(libcarddav_includedir)"; do \
|
||||||
|
test -z "$$dir" || $(MKDIR_P) "$$dir"; \
|
||||||
|
done
|
||||||
|
install: install-am
|
||||||
|
install-exec: install-exec-am
|
||||||
|
install-data: install-data-am
|
||||||
|
uninstall: uninstall-am
|
||||||
|
|
||||||
|
install-am: all-am
|
||||||
|
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
||||||
|
|
||||||
|
installcheck: installcheck-am
|
||||||
|
install-strip:
|
||||||
|
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||||
|
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||||
|
`test -z '$(STRIP)' || \
|
||||||
|
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
||||||
|
mostlyclean-generic:
|
||||||
|
|
||||||
|
clean-generic:
|
||||||
|
|
||||||
|
distclean-generic:
|
||||||
|
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
||||||
|
-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
|
||||||
|
|
||||||
|
maintainer-clean-generic:
|
||||||
|
@echo "This command is intended for maintainers to use"
|
||||||
|
@echo "it deletes files that may require special tools to rebuild."
|
||||||
|
clean: clean-am
|
||||||
|
|
||||||
|
clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \
|
||||||
|
clean-noinstLTLIBRARIES mostlyclean-am
|
||||||
|
|
||||||
|
distclean: distclean-am
|
||||||
|
-rm -rf ./$(DEPDIR)
|
||||||
|
-rm -f Makefile
|
||||||
|
distclean-am: clean-am distclean-compile distclean-generic \
|
||||||
|
distclean-tags
|
||||||
|
|
||||||
|
dvi: dvi-am
|
||||||
|
|
||||||
|
dvi-am:
|
||||||
|
|
||||||
|
html: html-am
|
||||||
|
|
||||||
|
html-am:
|
||||||
|
|
||||||
|
info: info-am
|
||||||
|
|
||||||
|
info-am:
|
||||||
|
|
||||||
|
install-data-am: install-libcarddav_includeHEADERS
|
||||||
|
|
||||||
|
install-dvi: install-dvi-am
|
||||||
|
|
||||||
|
install-dvi-am:
|
||||||
|
|
||||||
|
install-exec-am: install-libLTLIBRARIES
|
||||||
|
|
||||||
|
install-html: install-html-am
|
||||||
|
|
||||||
|
install-html-am:
|
||||||
|
|
||||||
|
install-info: install-info-am
|
||||||
|
|
||||||
|
install-info-am:
|
||||||
|
|
||||||
|
install-man:
|
||||||
|
|
||||||
|
install-pdf: install-pdf-am
|
||||||
|
|
||||||
|
install-pdf-am:
|
||||||
|
|
||||||
|
install-ps: install-ps-am
|
||||||
|
|
||||||
|
install-ps-am:
|
||||||
|
|
||||||
|
installcheck-am:
|
||||||
|
|
||||||
|
maintainer-clean: maintainer-clean-am
|
||||||
|
-rm -rf ./$(DEPDIR)
|
||||||
|
-rm -f Makefile
|
||||||
|
maintainer-clean-am: distclean-am maintainer-clean-generic
|
||||||
|
|
||||||
|
mostlyclean: mostlyclean-am
|
||||||
|
|
||||||
|
mostlyclean-am: mostlyclean-compile mostlyclean-generic \
|
||||||
|
mostlyclean-libtool
|
||||||
|
|
||||||
|
pdf: pdf-am
|
||||||
|
|
||||||
|
pdf-am:
|
||||||
|
|
||||||
|
ps: ps-am
|
||||||
|
|
||||||
|
ps-am:
|
||||||
|
|
||||||
|
uninstall-am: uninstall-libLTLIBRARIES \
|
||||||
|
uninstall-libcarddav_includeHEADERS
|
||||||
|
|
||||||
|
.MAKE: install-am install-strip
|
||||||
|
|
||||||
|
.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \
|
||||||
|
clean-libLTLIBRARIES clean-libtool clean-noinstLTLIBRARIES \
|
||||||
|
ctags distclean distclean-compile distclean-generic \
|
||||||
|
distclean-libtool distclean-tags distdir dvi dvi-am html \
|
||||||
|
html-am info info-am install install-am install-data \
|
||||||
|
install-data-am install-dvi install-dvi-am install-exec \
|
||||||
|
install-exec-am install-html install-html-am install-info \
|
||||||
|
install-info-am install-libLTLIBRARIES \
|
||||||
|
install-libcarddav_includeHEADERS install-man install-pdf \
|
||||||
|
install-pdf-am install-ps install-ps-am install-strip \
|
||||||
|
installcheck installcheck-am installdirs maintainer-clean \
|
||||||
|
maintainer-clean-generic mostlyclean mostlyclean-compile \
|
||||||
|
mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
|
||||||
|
tags uninstall uninstall-am uninstall-libLTLIBRARIES \
|
||||||
|
uninstall-libcarddav_includeHEADERS
|
||||||
|
|
||||||
|
|
||||||
|
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
||||||
|
# Otherwise a system limit (for SysV at least) may be exceeded.
|
||||||
|
.NOEXPORT:
|
@ -0,0 +1,133 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "add-carddav-object.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for adding a new event.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_add(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
gchar* url;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: text/directory; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "If-None-Match: *");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
gchar* tmp = random_file_name(settings->file);
|
||||||
|
gchar* s = rebuild_url(settings, NULL);
|
||||||
|
if (g_str_has_suffix(s, "/")) {
|
||||||
|
url = g_strdup_printf("%slibcarddav-%s.vcf", s, tmp);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
url = g_strdup_printf("%s/libcarddav-%s.vcf", s, tmp);
|
||||||
|
}
|
||||||
|
g_free(s);
|
||||||
|
g_free(tmp);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
|
tmp = g_strdup(settings->file);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = verify_uid(tmp);
|
||||||
|
g_free(tmp);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, settings->file);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(settings->file));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PUT");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 201) {
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
error->code = code;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,36 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ADD_CARDDAV_OBJECT_H__
|
||||||
|
#define __ADD_CARDDAV_OBJECT_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "carddav.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for adding a new card.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_add(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,735 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "md5.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param text
|
||||||
|
* @param stream
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @param nohex
|
||||||
|
*/
|
||||||
|
void dump(const char* text, FILE* stream, char* ptr, size_t size, char nohex) {
|
||||||
|
size_t i;
|
||||||
|
size_t c;
|
||||||
|
|
||||||
|
unsigned int width=0x10;
|
||||||
|
|
||||||
|
if(nohex)
|
||||||
|
/* without the hex output, we can fit more on screen */
|
||||||
|
width = 0x40;
|
||||||
|
fprintf(stream, "%s, %zd bytes (0x%zx)\n", text, size, size);
|
||||||
|
for(i=0; i<size; i+= width) {
|
||||||
|
fprintf(stream, "%04zx: ", i);
|
||||||
|
if(!nohex) {
|
||||||
|
/* hex not disabled, show it */
|
||||||
|
for(c = 0; c < width; c++) {
|
||||||
|
if(i+c < size)
|
||||||
|
fprintf(stream, "%02x ", ptr[i+c]);
|
||||||
|
else
|
||||||
|
fputs(" ", stream);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for(c = 0; (c < width) && (i+c < size); c++) {
|
||||||
|
/* check for 0D0A; if found, skip past and start a new line of output */
|
||||||
|
if (nohex && (i+c+1 < size) && ptr[i+c]==0x0D && ptr[i+c+1]==0x0A) {
|
||||||
|
i+=(c+2-width);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
fprintf(stream, "%c",(ptr[i+c]>=0x20) && (ptr[i+c]<0x80)?ptr[i+c]:'.');
|
||||||
|
/* check again for 0D0A, to avoid an extra \n if it's at width */
|
||||||
|
if (nohex && (i+c+2 < size) && ptr[i+c+1]==0x0D && ptr[i+c+2]==0x0A) {
|
||||||
|
i+=(c+3-width);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fputc('\n', stream); /* newline */
|
||||||
|
}
|
||||||
|
fflush(stream);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param handle
|
||||||
|
* @param type
|
||||||
|
* @param data
|
||||||
|
* @param size
|
||||||
|
* @param userp
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
int my_trace(CURL* handle, curl_infotype type, char* data, size_t size, void* userp) {
|
||||||
|
struct config_data* config = (struct config_data *)userp;
|
||||||
|
const char* text;
|
||||||
|
(void)handle; /* prevent compiler warning */
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case CURLINFO_TEXT:
|
||||||
|
fprintf(stderr, "== Info: %s", data);
|
||||||
|
default: /* in case a new one is introduced to shock us */
|
||||||
|
return 0;
|
||||||
|
case CURLINFO_HEADER_OUT:
|
||||||
|
text = "=> Send header";
|
||||||
|
break;
|
||||||
|
case CURLINFO_DATA_OUT:
|
||||||
|
text = "=> Send data";
|
||||||
|
break;
|
||||||
|
case CURLINFO_SSL_DATA_OUT:
|
||||||
|
text = "=> Send SSL data";
|
||||||
|
break;
|
||||||
|
case CURLINFO_HEADER_IN:
|
||||||
|
text = "<= Recv header";
|
||||||
|
break;
|
||||||
|
case CURLINFO_DATA_IN:
|
||||||
|
text = "<= Recv data";
|
||||||
|
break;
|
||||||
|
case CURLINFO_SSL_DATA_IN:
|
||||||
|
text = "<= Recv SSL data";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
dump(text, stderr, data, size, config->trace_ascii);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @return void* to memory region
|
||||||
|
*/
|
||||||
|
static void* myrealloc(void* ptr, size_t size) {
|
||||||
|
/* There might be a realloc() out there that doesn't like reallocing
|
||||||
|
* NULL pointers, so we take care of it here
|
||||||
|
* */
|
||||||
|
if(ptr)
|
||||||
|
return realloc(ptr, size);
|
||||||
|
else
|
||||||
|
return malloc(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @param nmemb
|
||||||
|
* @param data
|
||||||
|
* @return number of written bytes
|
||||||
|
*/
|
||||||
|
size_t WriteMemoryCallback(void* ptr, size_t size, size_t nmemb, void* data) {
|
||||||
|
size_t realsize = size * nmemb;
|
||||||
|
struct MemoryStruct* mem = (struct MemoryStruct *)data;
|
||||||
|
mem->memory = (char *)myrealloc(mem->memory, mem->size + realsize + 1);
|
||||||
|
|
||||||
|
if (mem->memory) {
|
||||||
|
memcpy(&(mem->memory[mem->size]), ptr, realsize);
|
||||||
|
mem->size += realsize;
|
||||||
|
mem->memory[mem->size] = 0;
|
||||||
|
}
|
||||||
|
return realsize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @param nmemb
|
||||||
|
* @param data
|
||||||
|
* @return number of written bytes
|
||||||
|
*/
|
||||||
|
size_t WriteHeaderCallback(void* ptr, size_t size, size_t nmemb, void* data) {
|
||||||
|
size_t realsize = size * nmemb;
|
||||||
|
struct MemoryStruct* mem = (struct MemoryStruct *)data;
|
||||||
|
mem->memory = (char *)myrealloc(mem->memory, mem->size + realsize + 1);
|
||||||
|
|
||||||
|
if (mem->memory) {
|
||||||
|
memcpy(&(mem->memory[mem->size]), ptr, realsize);
|
||||||
|
mem->size += realsize;
|
||||||
|
mem->memory[mem->size] = 0;
|
||||||
|
}
|
||||||
|
return realsize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
size_t ReadMemoryCallback(void* ptr, size_t size, size_t nmemb, void* data){
|
||||||
|
struct MemoryStruct* mem = (struct MemoryStruct *)data;
|
||||||
|
|
||||||
|
memcpy(ptr, mem->memory, mem->size);
|
||||||
|
return mem->size;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize carddav settings structure.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
*/
|
||||||
|
void init_carddav_settings(carddav_settings* settings) {
|
||||||
|
settings->username = NULL;
|
||||||
|
settings->password = NULL;
|
||||||
|
settings->url = NULL;
|
||||||
|
settings->file = NULL;
|
||||||
|
settings->usehttps = FALSE;
|
||||||
|
settings->custom_cacert = NULL;
|
||||||
|
settings->verify_ssl_certificate = TRUE;
|
||||||
|
settings->debug = FALSE;
|
||||||
|
settings->trace_ascii = TRUE;
|
||||||
|
settings->ACTION = UNKNOWN;
|
||||||
|
settings->start = 0;
|
||||||
|
settings->end = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Free memory assigned to carddav settings structure.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
*/
|
||||||
|
void free_carddav_settings(carddav_settings* settings) {
|
||||||
|
if (settings->username) {
|
||||||
|
g_free(settings->username);
|
||||||
|
settings->username = NULL;
|
||||||
|
}
|
||||||
|
if (settings->password) {
|
||||||
|
g_free(settings->password);
|
||||||
|
settings->password = NULL;
|
||||||
|
}
|
||||||
|
if (settings->url) {
|
||||||
|
g_free(settings->url);
|
||||||
|
settings->url = NULL;
|
||||||
|
}
|
||||||
|
if (settings->file) {
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
if (settings->custom_cacert) {
|
||||||
|
g_free(settings->custom_cacert);
|
||||||
|
settings->custom_cacert = NULL;
|
||||||
|
}
|
||||||
|
settings->verify_ssl_certificate = TRUE;
|
||||||
|
settings->usehttps = FALSE;
|
||||||
|
settings->debug = FALSE;
|
||||||
|
settings->trace_ascii = TRUE;
|
||||||
|
settings->ACTION = UNKNOWN;
|
||||||
|
settings->start = 0;
|
||||||
|
settings->end = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gchar* place_after_hostname(const gchar* start, const gchar* stop) {
|
||||||
|
gchar* newpos = NULL;
|
||||||
|
gchar* pos = (gchar *) stop;
|
||||||
|
gboolean digit = TRUE;
|
||||||
|
|
||||||
|
if (pos && stop && strcmp(start, pos) != 0) {
|
||||||
|
while (*pos != ':' && strcmp(start, pos) != 0)
|
||||||
|
--pos;
|
||||||
|
if (pos > start) {
|
||||||
|
gchar* tmp = (gchar *) pos + 1;
|
||||||
|
/* is pos++ a port number */
|
||||||
|
while (*tmp != '/' && digit) {
|
||||||
|
if (isdigit(*tmp) != 0) {
|
||||||
|
digit = TRUE;
|
||||||
|
tmp++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
digit = FALSE;
|
||||||
|
}
|
||||||
|
if (digit) {
|
||||||
|
/* pos was a port number */
|
||||||
|
while (*pos != '@' && strcmp(start, pos) != 0)
|
||||||
|
--pos;
|
||||||
|
if (strcmp(start, pos) != 0)
|
||||||
|
newpos = pos;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
while (*pos != '@' && pos != stop)
|
||||||
|
pos++;
|
||||||
|
if (pos != stop)
|
||||||
|
newpos = pos;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* is a username present */
|
||||||
|
gchar* tmp = NULL;
|
||||||
|
while (*pos != '/' && pos != stop) {
|
||||||
|
if (*pos == '@')
|
||||||
|
tmp = pos;
|
||||||
|
pos++;
|
||||||
|
}
|
||||||
|
if (tmp && pos != stop)
|
||||||
|
newpos = tmp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return newpos;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse URL
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param url String containing URL to collection
|
||||||
|
*/
|
||||||
|
void parse_url(carddav_settings* settings, const char* url) {
|
||||||
|
char* start;
|
||||||
|
char* pos;
|
||||||
|
char* end;
|
||||||
|
char* login;
|
||||||
|
|
||||||
|
login = pos = end = start = NULL;
|
||||||
|
if (!url)
|
||||||
|
return;
|
||||||
|
if ((pos = strstr(url, "//")) != NULL) {
|
||||||
|
/* Does the URL use https ?*/
|
||||||
|
if (!g_ascii_strncasecmp(url,"https",5) && settings->usehttps == FALSE) {
|
||||||
|
settings->usehttps=TRUE;
|
||||||
|
}
|
||||||
|
start = g_strdup(&(*(pos + 2)));
|
||||||
|
if ((pos = place_after_hostname(start, strrchr(start, '\0') - 1)) != NULL) {
|
||||||
|
/* username and/or password present */
|
||||||
|
login = g_strndup(start, pos - start);
|
||||||
|
end = pos;
|
||||||
|
if ((pos = strrchr(login, ':')) != NULL) {
|
||||||
|
/* both username and password is present */
|
||||||
|
settings->username = g_strndup(login, pos - login);
|
||||||
|
settings->password = g_strdup(++pos);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* only username present */
|
||||||
|
settings->username = g_strdup(login);
|
||||||
|
settings->password = NULL;
|
||||||
|
}
|
||||||
|
g_free(login);
|
||||||
|
settings->url = g_strdup(++end);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* no username or password present */
|
||||||
|
settings->url = g_strdup(start);
|
||||||
|
settings->username = NULL;
|
||||||
|
settings->password = NULL;
|
||||||
|
}
|
||||||
|
g_free(start);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find a specific HTTP header from last request
|
||||||
|
* @param header HTTP header to search for
|
||||||
|
* @param headers String of HTTP headers from last request
|
||||||
|
* @param lowcase Should string be returned in all lower case.
|
||||||
|
* @return The header found or NULL
|
||||||
|
*/
|
||||||
|
#define MAX_TOKENS 2
|
||||||
|
gchar* get_response_header(
|
||||||
|
const char* header, gchar* headers, gboolean lowcase) {
|
||||||
|
gchar* line;
|
||||||
|
gchar* head = NULL;
|
||||||
|
gchar* oldhead = NULL;
|
||||||
|
gchar** buf;
|
||||||
|
gchar* header_list;
|
||||||
|
gchar* saveptr;
|
||||||
|
|
||||||
|
header_list = g_strdup(headers);
|
||||||
|
line = strtok_r(header_list, "\r\n", &saveptr);
|
||||||
|
if (line != NULL) {
|
||||||
|
do {
|
||||||
|
buf = g_strsplit(line, ":", MAX_TOKENS);
|
||||||
|
if (buf[1] != NULL) {
|
||||||
|
if (g_ascii_strcasecmp(buf[0], header) == 0) {
|
||||||
|
if (head) {
|
||||||
|
oldhead = head;
|
||||||
|
head = g_strconcat(head, buf[1], NULL);
|
||||||
|
g_free(oldhead);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
head = g_strdup(buf[1]);
|
||||||
|
if (head)
|
||||||
|
g_strstrip(head);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_strfreev(buf);
|
||||||
|
} while ((line = strtok_r(NULL, "\r\n", &saveptr)) != NULL);
|
||||||
|
}
|
||||||
|
g_free(header_list);
|
||||||
|
if (head)
|
||||||
|
return (lowcase) ? g_ascii_strdown(head, -1) : head;
|
||||||
|
else
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// static const char* VCAL_HEAD =
|
||||||
|
// "BEGIN:VCALENDAR\r\n"
|
||||||
|
// "PRODID:-//CardDAV Calendar//NONSGML libcarddav//EN\r\n"
|
||||||
|
// "VERSION:2.0\r\n";
|
||||||
|
// static const char* VCAL_FOOT = "END:VCALENDAR";
|
||||||
|
|
||||||
|
static const char* VCAL_HEAD = "";
|
||||||
|
static const char* VCAL_FOOT = "";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse response from CardDAV server. Internal function.
|
||||||
|
* @param report Response from server
|
||||||
|
* @param element XML element to find
|
||||||
|
* @param type VCalendar element to find
|
||||||
|
* @param wrap Is this the final parsing or just a part
|
||||||
|
* @param recursive Stop after first match or not
|
||||||
|
* @return the parsed result
|
||||||
|
*/
|
||||||
|
static gchar* parse_carddav_report_wrap(
|
||||||
|
char* report, const char* element, const char* type,
|
||||||
|
gboolean wrap, gboolean recursive) {
|
||||||
|
char* pos;
|
||||||
|
char* start;
|
||||||
|
char* object;
|
||||||
|
char* tmp_report;
|
||||||
|
char* tmp;
|
||||||
|
gchar* response;
|
||||||
|
gchar* begin_type;
|
||||||
|
gchar* end_type;
|
||||||
|
gboolean keep_going = TRUE;
|
||||||
|
|
||||||
|
begin_type = g_strdup_printf("BEGIN:%s", type);
|
||||||
|
end_type = g_strdup_printf("END:%s", type);
|
||||||
|
pos = start = object = response = NULL;
|
||||||
|
tmp_report = g_strdup(report);
|
||||||
|
while ((pos = strstr(tmp_report, element)) != NULL && keep_going) {
|
||||||
|
gchar* url = NULL;
|
||||||
|
url = get_url(tmp_report);
|
||||||
|
if (!url) {
|
||||||
|
url = g_strdup_printf("none");
|
||||||
|
}
|
||||||
|
pos = strchr(pos, '>');
|
||||||
|
if (!pos) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pos = &(*(pos + 1));
|
||||||
|
pos = strstr(pos, begin_type);
|
||||||
|
if (!pos) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
object = &(*(pos + strlen(begin_type)));
|
||||||
|
object = g_strchug(object);
|
||||||
|
start = g_strdup(object);
|
||||||
|
if ((pos = strstr(start, end_type)) == NULL) {
|
||||||
|
g_free(start);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
object = g_strndup(start, strlen(start) - strlen(pos));
|
||||||
|
if (response) {
|
||||||
|
tmp = g_strdup(response);
|
||||||
|
g_free(response);
|
||||||
|
response = g_strdup_printf("%s%s\r\n%sURI:%s\r\n%s\r\n",
|
||||||
|
tmp, begin_type, object, url, end_type);
|
||||||
|
g_free(tmp);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (wrap)
|
||||||
|
response = g_strdup_printf("%s%s\r\n%sURI:%s\r\n%s\r\n",
|
||||||
|
VCAL_HEAD, begin_type, object, url, end_type);
|
||||||
|
else
|
||||||
|
response = g_strdup_printf("%s\r\n%sURI:%s\r\n%s\r\n",
|
||||||
|
begin_type, object, url, end_type);
|
||||||
|
}
|
||||||
|
if (url) {
|
||||||
|
g_free(url);
|
||||||
|
}
|
||||||
|
if (recursive) {
|
||||||
|
pos = strchr(pos, '>');
|
||||||
|
g_free(tmp_report);
|
||||||
|
tmp_report = g_strdup(&(*(pos + 1)));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
keep_going = FALSE;
|
||||||
|
}
|
||||||
|
g_free(start);
|
||||||
|
g_free(object);
|
||||||
|
}
|
||||||
|
g_free(tmp_report);
|
||||||
|
g_free(begin_type);
|
||||||
|
g_free(end_type);
|
||||||
|
if (wrap)
|
||||||
|
if (response) {
|
||||||
|
object = g_strdup(response);
|
||||||
|
g_free(response);
|
||||||
|
response = g_strdup_printf("%s%s", object, VCAL_FOOT);
|
||||||
|
g_free(object);
|
||||||
|
}
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse response from CardDAV server
|
||||||
|
* @param report Response from server
|
||||||
|
* @param element XML element to find
|
||||||
|
* @param type VCalendar element to find
|
||||||
|
* @return the parsed result
|
||||||
|
*/
|
||||||
|
gchar* parse_carddav_report(char* report, const char* element, const char* type) {
|
||||||
|
gchar* response = NULL;
|
||||||
|
gchar* timezone = NULL;
|
||||||
|
gchar* temp = NULL;
|
||||||
|
|
||||||
|
if (!report || !element || !type)
|
||||||
|
return NULL;
|
||||||
|
/* test for VTIMEZONE.
|
||||||
|
* Only the first found will be used and this will then
|
||||||
|
* be the time zone for the entire report
|
||||||
|
*/
|
||||||
|
timezone = parse_carddav_report_wrap(
|
||||||
|
report, element, "VTIMEZONE", FALSE, FALSE);
|
||||||
|
if (timezone) {
|
||||||
|
response = g_strdup_printf("%s%s", VCAL_HEAD, timezone);
|
||||||
|
g_free(timezone);
|
||||||
|
temp = parse_carddav_report_wrap(report, element, type, FALSE, TRUE);
|
||||||
|
if (temp) {
|
||||||
|
gchar* tmp = g_strdup(response);
|
||||||
|
g_free(response);
|
||||||
|
response = g_strdup_printf("%s%s%s", tmp, temp, VCAL_FOOT);
|
||||||
|
g_free(tmp);
|
||||||
|
g_free(temp);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(response);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
temp = parse_carddav_report_wrap(report, element, type, FALSE, TRUE);
|
||||||
|
if (temp) {
|
||||||
|
g_free(response);
|
||||||
|
response = g_strdup_printf("%s%s%s", VCAL_HEAD, temp, VCAL_FOOT);
|
||||||
|
g_free(temp);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(response);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert a time_t variable to CardDAV DateTime
|
||||||
|
* @param time a specific date and time
|
||||||
|
* @return the CardDAV DateTime
|
||||||
|
*/
|
||||||
|
gchar* get_carddav_datetime(time_t* time) {
|
||||||
|
struct tm *current;
|
||||||
|
gchar* datetime;
|
||||||
|
|
||||||
|
current = localtime(time);
|
||||||
|
datetime = g_strdup_printf("%d%.2d%.2dT%.2d%.2d%.2dZ",
|
||||||
|
current->tm_year + 1900, current->tm_mon + 1, current->tm_mday,
|
||||||
|
current->tm_hour, current->tm_min, current->tm_sec);
|
||||||
|
return datetime;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a random text string, using MD5. @see carddav_md5_hex_digest()
|
||||||
|
* @param text some text to randomize
|
||||||
|
* @return MD5 hash of text
|
||||||
|
*/
|
||||||
|
gchar* random_file_name(gchar* text) {
|
||||||
|
unsigned char* name;
|
||||||
|
gchar md5sum[33];
|
||||||
|
|
||||||
|
name = (unsigned char *) g_strdup(text);
|
||||||
|
carddav_md5_hex_digest(md5sum, name);
|
||||||
|
g_free(name);
|
||||||
|
return g_strdup(md5sum);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Does the event contain a UID element or not. If not add it.
|
||||||
|
* @param object A specific event
|
||||||
|
* @return event, eventually added UID
|
||||||
|
*/
|
||||||
|
gchar* verify_uid(gchar* object) {
|
||||||
|
gchar* uid;
|
||||||
|
gchar* newobj;
|
||||||
|
gchar* pos;
|
||||||
|
|
||||||
|
newobj = g_strdup(object);
|
||||||
|
uid = get_response_header("uid", object, TRUE);
|
||||||
|
if (!uid) {
|
||||||
|
object = g_strdup(newobj);
|
||||||
|
g_free(newobj);
|
||||||
|
pos = strstr(object, "END:VEVENT");
|
||||||
|
newobj = g_strndup(object, strlen(object) - strlen(pos));
|
||||||
|
newobj = g_strchomp(newobj);
|
||||||
|
uid = random_file_name(object);
|
||||||
|
gchar*tmp = g_strdup(newobj);
|
||||||
|
g_free(newobj);
|
||||||
|
newobj = g_strdup_printf("%s\r\nUID:libcarddav-%s@tempuri.org\r\n%s",
|
||||||
|
tmp, uid, pos);
|
||||||
|
g_free(uid);
|
||||||
|
g_free(tmp);
|
||||||
|
g_free(object);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
g_free(uid);
|
||||||
|
/*uid = g_strdup(newobj);
|
||||||
|
g_free(newobj);*/
|
||||||
|
g_strchomp(newobj);
|
||||||
|
/*g_free(uid);*/
|
||||||
|
return newobj;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch a URL from a XML element
|
||||||
|
* @param text String
|
||||||
|
* @return URL
|
||||||
|
*/
|
||||||
|
#define ELEM_HREF "href>"
|
||||||
|
gchar* get_url(gchar* text) {
|
||||||
|
gchar* pos;
|
||||||
|
gchar* url = NULL;
|
||||||
|
|
||||||
|
if ((pos = strstr(text, ELEM_HREF)) == NULL)
|
||||||
|
return url;
|
||||||
|
pos = &(*(pos + strlen(ELEM_HREF)));
|
||||||
|
url = g_strndup(pos, strlen(pos) - strlen(strchr(pos, '<')));
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch any element from XML
|
||||||
|
* @param text String
|
||||||
|
* @param tag The element to look for
|
||||||
|
* @return element
|
||||||
|
*/
|
||||||
|
gchar* get_tag(const gchar* tag, gchar* text) {
|
||||||
|
gchar *pos;
|
||||||
|
gchar* res = NULL;
|
||||||
|
gchar* the_tag = NULL;
|
||||||
|
|
||||||
|
/*printf("%s\n", text);*/
|
||||||
|
the_tag = g_strdup_printf("<%s>", tag);
|
||||||
|
if ((pos = strstr(text, the_tag)) == NULL) {
|
||||||
|
g_free(the_tag);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
pos = &(*(pos + strlen(the_tag)));
|
||||||
|
res = g_strndup(pos, strlen(pos) - strlen(strchr(pos, '<')));
|
||||||
|
g_free(the_tag);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch the etag element from XML
|
||||||
|
* @param text String
|
||||||
|
* @return etag
|
||||||
|
*/
|
||||||
|
#define ELEM_ETAG "getetag"
|
||||||
|
gchar* get_etag(gchar* text) {
|
||||||
|
gchar* etag = NULL;
|
||||||
|
|
||||||
|
etag = get_tag(ELEM_ETAG, text);
|
||||||
|
/* Maybe namespace prefixed */
|
||||||
|
if (!etag) {
|
||||||
|
etag = get_tag("D:getetag", text);
|
||||||
|
}
|
||||||
|
return etag;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch host from URL
|
||||||
|
* @param url URL
|
||||||
|
* @return host
|
||||||
|
*/
|
||||||
|
gchar* get_host(gchar* url) {
|
||||||
|
gchar** buf;
|
||||||
|
gchar* result = NULL;
|
||||||
|
|
||||||
|
buf = g_strsplit(url, "/", 2);
|
||||||
|
if (buf[0]) {
|
||||||
|
result = g_strdup(buf[0]);
|
||||||
|
}
|
||||||
|
g_strfreev(buf);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* rebuild a raw URL with https if needed from the settings
|
||||||
|
* @param settings carddav_settings
|
||||||
|
* @param uri URI to use instead of base
|
||||||
|
* @return URL
|
||||||
|
*/
|
||||||
|
|
||||||
|
gchar* rebuild_url(carddav_settings* settings, gchar* uri){
|
||||||
|
gchar* url = NULL;
|
||||||
|
gchar* mystr = NULL;
|
||||||
|
if (settings->usehttps) {
|
||||||
|
mystr = "https://";
|
||||||
|
} else {
|
||||||
|
mystr = "http://";
|
||||||
|
}
|
||||||
|
if (uri)
|
||||||
|
url = g_strdup_printf("%s%s", mystr, uri);
|
||||||
|
else
|
||||||
|
url = g_strdup_printf("%s%s", mystr,settings->url);
|
||||||
|
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prepare a curl connection
|
||||||
|
* @param settings carddav_settings
|
||||||
|
* @return CURL
|
||||||
|
*/
|
||||||
|
CURL* get_curl(carddav_settings* setting) {
|
||||||
|
CURL* curl;
|
||||||
|
gchar* userpwd = NULL;
|
||||||
|
gchar* url = NULL;
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if (curl) {
|
||||||
|
if (setting->username) {
|
||||||
|
if (setting->password)
|
||||||
|
userpwd = g_strdup_printf("%s:%s",
|
||||||
|
setting->username, setting->password);
|
||||||
|
else
|
||||||
|
userpwd = g_strdup_printf("%s", setting->username);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_USERPWD, userpwd);
|
||||||
|
g_free(userpwd);
|
||||||
|
}
|
||||||
|
if (setting->verify_ssl_certificate)
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 2);
|
||||||
|
else {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0);
|
||||||
|
}
|
||||||
|
if (setting->custom_cacert)
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CAINFO, setting->custom_cacert);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_USERAGENT, __CARDDAV_USERAGENT);
|
||||||
|
url = rebuild_url(setting, NULL);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
|
g_free(url);
|
||||||
|
}
|
||||||
|
return (curl) ? curl : NULL;
|
||||||
|
}
|
@ -0,0 +1,223 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __CARDDAV_UTILS_H__
|
||||||
|
#define __CARDDAV_UTILS_H__
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include "carddav.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef struct _CARDDAV_SETTINGS carddav_settings
|
||||||
|
* A pointer to a struct _CARDDAV_SETTINGS
|
||||||
|
*/
|
||||||
|
typedef struct _CARDDAV_SETTINGS carddav_settings;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @struct _CARDDAV_SETTINGS
|
||||||
|
* A struct used to exchange all user input between various parts
|
||||||
|
* of the library
|
||||||
|
*/
|
||||||
|
struct _CARDDAV_SETTINGS {
|
||||||
|
gchar* username;
|
||||||
|
gchar* password;
|
||||||
|
gchar* url;
|
||||||
|
gchar* file;
|
||||||
|
gboolean usehttps;
|
||||||
|
gboolean verify_ssl_certificate;
|
||||||
|
gchar* custom_cacert;
|
||||||
|
gboolean debug;
|
||||||
|
gboolean use_locking;
|
||||||
|
char trace_ascii;
|
||||||
|
CARDDAV_ACTION ACTION;
|
||||||
|
time_t start;
|
||||||
|
time_t end;
|
||||||
|
char use_uri;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef struct MemoryStruct memory_ptr
|
||||||
|
* A pointer to a struct MemoryStruct
|
||||||
|
*/
|
||||||
|
typedef struct MemoryStruct memory_ptr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @struct MemoryStruct
|
||||||
|
* Used to hold messages between the CardDAV server and the library
|
||||||
|
*/
|
||||||
|
struct MemoryStruct {
|
||||||
|
char *memory;
|
||||||
|
size_t size;
|
||||||
|
};
|
||||||
|
|
||||||
|
/** @struct config_data
|
||||||
|
* Used to exchange user options to the library
|
||||||
|
*/
|
||||||
|
struct config_data {
|
||||||
|
char trace_ascii;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param text
|
||||||
|
* @param stream
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @param nohex
|
||||||
|
*/
|
||||||
|
void dump(const char* text, FILE* stream, char* ptr, size_t size, char nohex);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param handle
|
||||||
|
* @param type
|
||||||
|
* @param data
|
||||||
|
* @param size
|
||||||
|
* @param userp
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
int my_trace(CURL* handle, curl_infotype type, char* data, size_t size, void* userp);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @return void* to memory region
|
||||||
|
*/
|
||||||
|
size_t WriteMemoryCallback(void* ptr, size_t size, size_t nmemb, void* data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is burrowed from the libcurl documentation
|
||||||
|
* @param ptr
|
||||||
|
* @param size
|
||||||
|
* @param nmemb
|
||||||
|
* @param data
|
||||||
|
* @return number of written bytes
|
||||||
|
*/
|
||||||
|
size_t WriteHeaderCallback(void* ptr, size_t size, size_t nmemb, void* data);
|
||||||
|
|
||||||
|
/*size_t ReadMemoryCallback(void* ptr, size_t size, size_t nmemb, void* data);*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize carddav settings structure.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
*/
|
||||||
|
void init_carddav_settings(carddav_settings* settings);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Free momory assigned to carddav settings structure.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
*/
|
||||||
|
void free_carddav_settings(carddav_settings* settings);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse URL
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param url String containing URL to collection
|
||||||
|
*/
|
||||||
|
void parse_url(carddav_settings* settings, const char* url);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find a specific HTTP header from last request
|
||||||
|
* @param header HTTP header to search for
|
||||||
|
* @param headers String of HTTP headers from last request
|
||||||
|
* @param lowcase Should string be returned in all lower case.
|
||||||
|
* @return The header found or NULL
|
||||||
|
*/
|
||||||
|
gchar* get_response_header(
|
||||||
|
const char* header, gchar* headers, gboolean lowcase);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse response from CardDAV server
|
||||||
|
* @param report Response from server
|
||||||
|
* @param element XML element to find
|
||||||
|
* @param type VCalendar element to find
|
||||||
|
* @return the parsed result
|
||||||
|
*/
|
||||||
|
gchar* parse_carddav_report(char* report, const char* element, const char* type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert a time_t variable to CardDAV DateTime
|
||||||
|
* @param time a specific date and time
|
||||||
|
* @return the CardDAV DateTime
|
||||||
|
*/
|
||||||
|
gchar* get_carddav_datetime(time_t* time);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a random text string, using MD5. @see carddav_md5_hex_digest()
|
||||||
|
* @param text some text to randomize
|
||||||
|
* @return MD5 hash of text
|
||||||
|
*/
|
||||||
|
gchar* random_file_name(gchar* text);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Does the card contain a UID element or not. If not add it.
|
||||||
|
* @param object A specific card
|
||||||
|
* @return card, eventually added UID
|
||||||
|
*/
|
||||||
|
gchar* verify_uid(gchar* object);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch a URL from a XML element
|
||||||
|
* @param text String
|
||||||
|
* @return URL
|
||||||
|
*/
|
||||||
|
gchar* get_url(gchar* text);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch host from URL
|
||||||
|
* @param url URL
|
||||||
|
* @return host
|
||||||
|
*/
|
||||||
|
gchar* get_host(gchar* url);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch the etag element from XML
|
||||||
|
* @param text String
|
||||||
|
* @return etag
|
||||||
|
*/
|
||||||
|
gchar* get_etag(gchar* text);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch any element from XML
|
||||||
|
* @param text String
|
||||||
|
* @return element
|
||||||
|
*/
|
||||||
|
gchar* get_tag(const gchar* tag, gchar* text);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* rebuild a raw URL with https if needed from the settings
|
||||||
|
* @param settings carddav_settings
|
||||||
|
* @return URL
|
||||||
|
*/
|
||||||
|
gchar* rebuild_url(carddav_settings* setting, gchar* uri);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prepare a curl connection
|
||||||
|
* @param settings carddav_settings
|
||||||
|
* @return CURL
|
||||||
|
*/
|
||||||
|
CURL* get_curl(carddav_settings* setting);
|
||||||
|
|
||||||
|
#endif
|
@ -0,0 +1,868 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "carddav.h"
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "get-carddav-report.h"
|
||||||
|
#include "add-carddav-object.h"
|
||||||
|
#include "delete-carddav-object.h"
|
||||||
|
#include "modify-carddav-object.h"
|
||||||
|
#include "get-display-name.h"
|
||||||
|
#include "options-carddav-server.h"
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <glib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
static void init_runtime(runtime_info* info) {
|
||||||
|
if (! info)
|
||||||
|
return;
|
||||||
|
if (! info->error)
|
||||||
|
info->error = g_new0(carddav_error, 1);
|
||||||
|
if (! info->options) {
|
||||||
|
info->options = g_new0(debug_curl, 1);
|
||||||
|
info->options->trace_ascii = 1;
|
||||||
|
info->options->debug = 0;
|
||||||
|
info->options->verify_ssl_certificate = TRUE;
|
||||||
|
info->options->use_locking = TRUE;
|
||||||
|
info->options->custom_cacert = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param curl An instance of libcurl.
|
||||||
|
* @param settings Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. URL is part of the structure. [http://][username:password@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return FALSE (zero) mens URL does not reference a CardDAV calendar
|
||||||
|
* resource. TRUE if the URL does reference a CardDAV calendar resource.
|
||||||
|
*/
|
||||||
|
static gboolean test_carddav_enabled(CURL* curl,
|
||||||
|
carddav_settings* settings,
|
||||||
|
carddav_error* error) {
|
||||||
|
return carddav_getoptions(curl, settings, NULL, error, TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @param settings An instance of carddav_settings. @see carddav_settings
|
||||||
|
* @return TRUE if there was an error. Error can be in libcurl, in libcarddav,
|
||||||
|
* or an error related to the CardDAV protocol.
|
||||||
|
*/
|
||||||
|
static gboolean make_carddav_call(carddav_settings* settings,
|
||||||
|
runtime_info* info) {
|
||||||
|
CURL* curl;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
info->error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
if (!test_carddav_enabled(curl, settings, info->error)) {
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
if (settings->use_uri == 0) {
|
||||||
|
switch (settings->ACTION) {
|
||||||
|
case GETALL: result = carddav_getall(settings, info->error); break;
|
||||||
|
case ADD: result = carddav_add(settings, info->error); break;
|
||||||
|
case DELETE: result = carddav_delete(settings, info->error); break;
|
||||||
|
case MODIFY: result = carddav_modify(settings, info->error); break;
|
||||||
|
case GETCALNAME: result = carddav_getname(settings, info->error); break;
|
||||||
|
default: break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
switch (settings->ACTION) {
|
||||||
|
case GETALL: result = carddav_getall_by_uri(settings, info->error); break;
|
||||||
|
case ADD: result = carddav_add(settings, info->error); break;
|
||||||
|
case DELETE: result = carddav_delete_by_uri(settings, info->error); break;
|
||||||
|
case MODIFY: result = carddav_modify_by_uri(settings, info->error); break;
|
||||||
|
case GETCALNAME: result = carddav_getname(settings, info->error); break;
|
||||||
|
default: break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for adding a new event.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_add_object(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.file = g_strdup(object);
|
||||||
|
settings.ACTION = ADD;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting an event.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_delete_object(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.file = g_strdup(object);
|
||||||
|
settings.ACTION = DELETE;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
settings.use_uri = 0;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting an event by URI.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_delete_object_by_uri(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.file = g_strdup(object);
|
||||||
|
settings.ACTION = DELETE;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
settings.use_uri = 1;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying an event.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_modify_object(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.file = g_strdup(object);
|
||||||
|
settings.ACTION = MODIFY;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
settings.use_uri = 0;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying an event by URI.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_modify_object_by_uri(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.file = g_strdup(object);
|
||||||
|
settings.ACTION = MODIFY;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
settings.use_uri = 1;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting a collection of events determined by time range.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param start time_t variable specifying start and end for range. Both
|
||||||
|
* are included in range.
|
||||||
|
* @param end time_t variable specifying start and end for range. Both
|
||||||
|
* are included in range.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_get_object(response *result,
|
||||||
|
time_t start,
|
||||||
|
time_t end,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
if (!result) {
|
||||||
|
result = malloc(sizeof(response *));
|
||||||
|
memset(result, '\0', sizeof(response *));
|
||||||
|
}
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.ACTION = GET;
|
||||||
|
settings.start = start;
|
||||||
|
settings.end = end;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
result->msg = NULL;
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
result->msg = g_strdup(settings.file);
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all events from the collection.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_getall_object(response* result,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
if (!result) {
|
||||||
|
result = malloc(sizeof(response *));
|
||||||
|
memset(result, '\0', sizeof(response *));
|
||||||
|
}
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.ACTION = GETALL;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
settings.use_uri = 0;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
result->msg = NULL;
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
result->msg = g_strdup(settings.file);
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all events from the collection.
|
||||||
|
* This version stores the URI as a VCARD parameter.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_getall_object_by_uri(response* result,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
if (!result) {
|
||||||
|
result = malloc(sizeof(response *));
|
||||||
|
memset(result, '\0', sizeof(response *));
|
||||||
|
}
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.ACTION = GETALL;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
settings.use_uri = 1;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
result->msg = NULL;
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
result->msg = g_strdup(settings.file);
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting the stored display name for the collection.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_get_displayname(response* result,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info) {
|
||||||
|
carddav_settings settings;
|
||||||
|
CARDDAV_RESPONSE carddav_response;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
if (!result) {
|
||||||
|
result = malloc(sizeof(response *));
|
||||||
|
memset(result, '\0', sizeof(response *));
|
||||||
|
}
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
settings.ACTION = GETCALNAME;
|
||||||
|
if (info->options->debug)
|
||||||
|
settings.debug = TRUE;
|
||||||
|
else
|
||||||
|
settings.debug = FALSE;
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
settings.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
settings.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
gboolean res = make_carddav_call(&settings, info);
|
||||||
|
if (res) {
|
||||||
|
result->msg = NULL;
|
||||||
|
if (info->error->code > 0) {
|
||||||
|
switch (info->error->code) {
|
||||||
|
case 403: carddav_response = FORBIDDEN; break;
|
||||||
|
case 409: carddav_response = CONFLICT; break;
|
||||||
|
case 423: carddav_response = LOCKED; break;
|
||||||
|
case 501: carddav_response = NOTIMPLEMENTED; break;
|
||||||
|
default: carddav_response = CONFLICT; break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* fall-back to conflicting state */
|
||||||
|
carddav_response = CONFLICT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
result->msg = g_strdup(settings.file);
|
||||||
|
carddav_response = OK;
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
return carddav_response;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to test wether a calendar resource is CardDAV enabled or not.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for
|
||||||
|
* freeing the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @result 0 (zero) means no CardDAV support, otherwise CardDAV support
|
||||||
|
* detechted.
|
||||||
|
*/
|
||||||
|
int carddav_enabled_resource(const char* URL, runtime_info* info) {
|
||||||
|
CURL* curl;
|
||||||
|
carddav_settings settings;
|
||||||
|
struct config_data data;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, TRUE);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
curl = get_curl(&settings);
|
||||||
|
if (!curl) {
|
||||||
|
info->error->code = -1;
|
||||||
|
info->error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
settings.file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (info->options->trace_ascii)
|
||||||
|
data.trace_ascii = 1;
|
||||||
|
else
|
||||||
|
data.trace_ascii = 0;
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
|
||||||
|
if (info->options->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
gboolean res = test_carddav_enabled(curl, &settings, info->error);
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return (res && (info->error->code == 0 || info->error->code == 200)) ? 1 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function which supports sending various options inside the library.
|
||||||
|
* @param curl_options A struct debug_curl. See debug_curl.
|
||||||
|
*/
|
||||||
|
void carddav_set_options(debug_curl curl_options) {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Function to call in case of errors.
|
||||||
|
* Caller provides a pointer to a local carddav_error structure.
|
||||||
|
* Carddav_get_error will initialize pointer if NULL.
|
||||||
|
* Caller is responsible for freeing returned memory.
|
||||||
|
* After the first call the internal error buffer is reset.
|
||||||
|
* @param lib_error A pointer to a struct _carddav_error. @see _carddav_error
|
||||||
|
* @return An initialized carddav_error pointer to memory where error
|
||||||
|
* messages can be found from the last call to the library.
|
||||||
|
*/
|
||||||
|
carddav_error* carddav_get_error(carddav_error* lib_error) {
|
||||||
|
if (!lib_error) {
|
||||||
|
lib_error = g_new0(carddav_error, 1);
|
||||||
|
}
|
||||||
|
return lib_error;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for freeing memory for a previous initialization of a
|
||||||
|
* carddav_error. @see carddav_get_error()
|
||||||
|
* Caller provides a pointer to a local carddav_error structure.
|
||||||
|
* @param lib_error A pointer to a struct _carddav_error. @see _carddav_error
|
||||||
|
*/
|
||||||
|
void carddav_free_error(carddav_error* lib_error) {
|
||||||
|
if (lib_error->str)
|
||||||
|
g_free(lib_error->str);
|
||||||
|
g_free(lib_error);
|
||||||
|
lib_error = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to call to get a list of supported CardDAV options for a server
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for
|
||||||
|
* freeing the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @result A list of available options or NULL in case of any error.
|
||||||
|
*/
|
||||||
|
char** carddav_get_server_options(const char* URL, runtime_info* info) {
|
||||||
|
CURL* curl;
|
||||||
|
carddav_settings settings;
|
||||||
|
response server_options;
|
||||||
|
gchar** option_list = NULL;
|
||||||
|
gchar** tmp;
|
||||||
|
gboolean res = FALSE;
|
||||||
|
|
||||||
|
g_return_val_if_fail(info != NULL, NULL);
|
||||||
|
|
||||||
|
init_runtime(info);
|
||||||
|
tmp = option_list = NULL;
|
||||||
|
init_carddav_settings(&settings);
|
||||||
|
|
||||||
|
parse_url(&settings, URL);
|
||||||
|
curl = get_curl(&settings);
|
||||||
|
if (!curl) {
|
||||||
|
info->error->code = -1;
|
||||||
|
info->error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
settings.file = NULL;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
if (info->options->use_locking)
|
||||||
|
settings.use_locking = 1;
|
||||||
|
else
|
||||||
|
settings.use_locking = 0;
|
||||||
|
|
||||||
|
res = carddav_getoptions(curl, &settings, &server_options, info->error, FALSE);
|
||||||
|
if (res) {
|
||||||
|
if (server_options.msg) {
|
||||||
|
option_list = g_strsplit(server_options.msg, ", ", 0);
|
||||||
|
tmp = &(*(option_list));
|
||||||
|
while (*tmp) {
|
||||||
|
g_strstrip(*tmp++);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free_carddav_settings(&settings);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return (option_list) ? option_list : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting an initialized runtime_info structure
|
||||||
|
* @return runtime_info. @see runtime_info
|
||||||
|
*/
|
||||||
|
runtime_info* carddav_get_runtime_info() {
|
||||||
|
runtime_info* rt_info;
|
||||||
|
|
||||||
|
rt_info = g_new0(runtime_info, 1);
|
||||||
|
rt_info->error = g_new0(carddav_error, 1);
|
||||||
|
rt_info->options = g_new0(debug_curl, 1);
|
||||||
|
|
||||||
|
return rt_info;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for freeing memory for a previous initialization of an info
|
||||||
|
* structure
|
||||||
|
* @param info Address to a pointer to a runtime_info structure. @see
|
||||||
|
* runtime_info
|
||||||
|
*/
|
||||||
|
void carddav_free_runtime_info(runtime_info** info) {
|
||||||
|
runtime_info* ri;
|
||||||
|
|
||||||
|
if (*info) {
|
||||||
|
ri = *info;
|
||||||
|
if (ri->error) {
|
||||||
|
if (ri->error->str)
|
||||||
|
g_free(ri->error->str);
|
||||||
|
g_free(ri->error);
|
||||||
|
ri->error = NULL;
|
||||||
|
}
|
||||||
|
if (ri->options) {
|
||||||
|
if (ri->options->custom_cacert)
|
||||||
|
g_free(ri->options->custom_cacert);
|
||||||
|
g_free(ri->options);
|
||||||
|
ri->options = NULL;
|
||||||
|
}
|
||||||
|
g_free(ri);
|
||||||
|
*info = ri = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting an initialized response structure
|
||||||
|
* @return response. @see _response
|
||||||
|
*/
|
||||||
|
response* carddav_get_response() {
|
||||||
|
response* r;
|
||||||
|
|
||||||
|
r = g_new0(response, 1);
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for freeing memory for a previous initialization of an response
|
||||||
|
* structure
|
||||||
|
* @param info Address to a pointer to a response structure. @see
|
||||||
|
* _response
|
||||||
|
*/
|
||||||
|
void carddav_free_response(response** resp) {
|
||||||
|
response* r;
|
||||||
|
|
||||||
|
if (*resp) {
|
||||||
|
r = *resp;
|
||||||
|
if (r->msg)
|
||||||
|
g_free(r->msg);
|
||||||
|
g_free(r);
|
||||||
|
*resp = r = NULL;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,387 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file carddav.h
|
||||||
|
* @brief interface to the carddav library.
|
||||||
|
* The library conforms to IETF carddav draft specification daboo-10. For further information follow this
|
||||||
|
* link http://tools.ietf.org/html/draft-ietf-vcarddav-carddav-10
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @mainpage
|
||||||
|
* This document is the documentation for the public interface to libcarddav.
|
||||||
|
* If you want to study the implementation look for the developers API.
|
||||||
|
*
|
||||||
|
* The libray and documentation is Copyright (c) 2010 Timothy Pearson
|
||||||
|
* (kb9vqf@pearsoncomputing.net) and the original caldav implementation is
|
||||||
|
* copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* License for the source code.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*
|
||||||
|
* License for the documentation.
|
||||||
|
*
|
||||||
|
* Permission is granted to copy, distribute and/or modify this document
|
||||||
|
* under the terms of the GNU Free Documentation License, Version 1.2
|
||||||
|
* or any later version published by the Free Software Foundation;
|
||||||
|
* with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
|
||||||
|
* Texts.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __CARDDAV_H__
|
||||||
|
#define __CARDDAV_H__
|
||||||
|
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
/* For debug purposes */
|
||||||
|
/**
|
||||||
|
* @typedef struct debug_curl
|
||||||
|
* A struct used to set internal options in the library
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
int trace_ascii; /** @var int trace_ascii
|
||||||
|
* 0 or 1
|
||||||
|
*/
|
||||||
|
int debug; /** @var int debug
|
||||||
|
* 0 or 1
|
||||||
|
*/
|
||||||
|
int verify_ssl_certificate;
|
||||||
|
int use_locking;
|
||||||
|
char* custom_cacert;
|
||||||
|
} debug_curl;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef struct _carddav_error carddav_error
|
||||||
|
* Pointer to a carddav_error structure
|
||||||
|
*/
|
||||||
|
typedef struct _carddav_error carddav_error;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @struct _carddav_error
|
||||||
|
* A struct for storing error codes and messages
|
||||||
|
*/
|
||||||
|
struct _carddav_error {
|
||||||
|
long code; /**
|
||||||
|
* @var long code
|
||||||
|
* if < 0 internal error > 0 CardDAV protocol error.
|
||||||
|
*/
|
||||||
|
char* str; /** @var char* str
|
||||||
|
* For storing human readable error message
|
||||||
|
*/
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef struct runtime_info
|
||||||
|
* Pointer to a runtime structure holding debug and error information
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
carddav_error* error;
|
||||||
|
debug_curl* options;
|
||||||
|
} runtime_info;
|
||||||
|
|
||||||
|
/* CardDAV is defined in RFC4791 */
|
||||||
|
|
||||||
|
/* Buffer to hold response */
|
||||||
|
/**
|
||||||
|
* @typedef struct _response response
|
||||||
|
* Pointer to a _response structure
|
||||||
|
*/
|
||||||
|
typedef struct _response response;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @struct _response
|
||||||
|
* A struct used for returning messages from the library to users
|
||||||
|
*/
|
||||||
|
struct _response {
|
||||||
|
char* msg; /** @var char* msg
|
||||||
|
* String for storing response
|
||||||
|
*/
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @enum CARDDAV_ACTION specifies supported CardDAV actions.
|
||||||
|
* UNKNOWN. An unknown action.
|
||||||
|
* ADD. Add a CardDAV calendar object.
|
||||||
|
* DELETE. Delete a CardDAV calendar object.
|
||||||
|
* MODIFY. Modify a CardDAV calendar object.
|
||||||
|
* GET. Get one or more CardDAV calendar object(s).
|
||||||
|
* GETALL. Get all CardDAV calendar objects.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
UNKNOWN,
|
||||||
|
ADD,
|
||||||
|
DELETE,
|
||||||
|
FREEBUSY,
|
||||||
|
MODIFY,
|
||||||
|
GET,
|
||||||
|
GETALL,
|
||||||
|
GETCALNAME,
|
||||||
|
ISCARDDAV,
|
||||||
|
OPTIONS
|
||||||
|
} CARDDAV_ACTION;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @enum CARDDAV_RESPONSE specifies CardDAV error states.
|
||||||
|
* OK (HTTP 200). Request was satisfied.
|
||||||
|
* FORBIDDEN (HTTP 403). Access not allowed. Dont repeat request.
|
||||||
|
* CONFLICT (HTTP 409). Conflict between current state of CardDAV collection
|
||||||
|
* and request. Client must solve the conflict and then resend request.
|
||||||
|
* LOCKED (HTTP 423). Locking failed.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
OK,
|
||||||
|
FORBIDDEN,
|
||||||
|
CONFLICT,
|
||||||
|
LOCKED,
|
||||||
|
NOTIMPLEMENTED
|
||||||
|
} CARDDAV_RESPONSE;
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __CARDDAV_USERAGENT
|
||||||
|
#define __CARDDAV_USERAGENT "libcurl-agent/0.1"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for adding a new card.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_add_object(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting a card.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_delete_object(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting a card by URI.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_delete_object_by_uri(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying a card.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_modify_object(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying a card by URI.
|
||||||
|
* @param object Appointment following ICal format (RFC2445). Receiver is
|
||||||
|
* responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_modify_object_by_uri(const char* object,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting a collection of cards determined by time range.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param start time_t variable specifying start for range. Included in search.
|
||||||
|
* @param end time_t variable specifying end for range. Included in search.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_get_object(response* result,
|
||||||
|
time_t start,
|
||||||
|
time_t end,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all cards from the collection.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_getall_object(response* result,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all cards from the collection.
|
||||||
|
* This version stores the URI as a VCARD parameter.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_getall_object_by_uri(response* result,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting the stored display name for the collection.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_get_displayname(response* result,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to test wether a calendar resource is CardDAV enabled or not.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for
|
||||||
|
* freeing the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @result 0 (zero) means no CardDAV support, otherwise CardDAV support
|
||||||
|
* detechted.
|
||||||
|
*/
|
||||||
|
int carddav_enabled_resource(const char* URL, runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting free/busy information.
|
||||||
|
* @param result A pointer to struct _response where the result is to stored.
|
||||||
|
* @see response. Caller is responsible for freeing the memory.
|
||||||
|
* @param start time_t variable specifying start and end for range. Both
|
||||||
|
* are included in range.
|
||||||
|
* @param end time_t variable specifying start and end for range. Both
|
||||||
|
* are included in range.
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for freeing
|
||||||
|
* the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @return Ok, FORBIDDEN, or CONFLICT. @see CARDDAV_RESPONSE
|
||||||
|
*/
|
||||||
|
CARDDAV_RESPONSE carddav_get_freebusy(response *result,
|
||||||
|
time_t start,
|
||||||
|
time_t end,
|
||||||
|
const char* URL,
|
||||||
|
runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Always returns an initialized empty carddav_error
|
||||||
|
* Function to call in case of errors.
|
||||||
|
* Caller provides a pointer to a local carddav_error structure.
|
||||||
|
* Carddav_get_error will initialize pointer if NULL.
|
||||||
|
* Caller is responsible for freeing returned memory.
|
||||||
|
* After the first call the internal error buffer is reset.
|
||||||
|
* @param lib_error A pointer to a struct _carddav_error. @see _carddav_error
|
||||||
|
* @return An initialized carddav_error pointer to memory where error
|
||||||
|
* messages can be found from the last call to the library.
|
||||||
|
*/
|
||||||
|
carddav_error* carddav_get_error(carddav_error* lib_error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for freeing memory for a previous initialization of a
|
||||||
|
* carddav_error. @see carddav_get_error()
|
||||||
|
* Caller provides a pointer to a local carddav_error structure.
|
||||||
|
* @param lib_error A pointer to a struct _carddav_error. @see _carddav_error
|
||||||
|
*/
|
||||||
|
void carddav_free_error(carddav_error* lib_error);
|
||||||
|
|
||||||
|
/* Setting various options in library */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Does nothing
|
||||||
|
* Function which supports sending various options inside the library.
|
||||||
|
* @param curl_options A struct debug_curl. See debug_curl.
|
||||||
|
*/
|
||||||
|
void carddav_set_options(debug_curl curl_options);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to call to get a list of supported CardDAV options for a server
|
||||||
|
* @param URL Defines CardDAV resource. Receiver is responsible for
|
||||||
|
* freeing the memory. [http://][username[:password]@]host[:port]/url-path.
|
||||||
|
* See (RFC1738).
|
||||||
|
* @param info Pointer to a runtime_info structure. @see runtime_info
|
||||||
|
* @result A list of available options or NULL in case of any error.
|
||||||
|
*/
|
||||||
|
char** carddav_get_server_options(const char* URL, runtime_info* info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting an initialized runtime_info structure
|
||||||
|
* @return runtime_info. @see runtime_info
|
||||||
|
*/
|
||||||
|
runtime_info* carddav_get_runtime_info();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for freeing memory for a previous initialization of an info
|
||||||
|
* structure
|
||||||
|
* @param info Address to a pointer to a runtime_info structure. @see
|
||||||
|
* runtime_info
|
||||||
|
*/
|
||||||
|
void carddav_free_runtime_info(runtime_info** info);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting an initialized response structure
|
||||||
|
* @return response. @see _response
|
||||||
|
*/
|
||||||
|
response* carddav_get_response();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for freeing memory for a previous initialization of an response
|
||||||
|
* structure
|
||||||
|
* @param info Address to a pointer to a response structure. @see
|
||||||
|
* _response
|
||||||
|
*/
|
||||||
|
void carddav_free_response(response** info);
|
||||||
|
|
||||||
|
#endif
|
@ -0,0 +1,470 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "delete-carddav-object.h"
|
||||||
|
#include "lock-carddav-object.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the first part of the calendar query.
|
||||||
|
* The actual UID to use for the query is added at runtime.
|
||||||
|
*/
|
||||||
|
static char* search_head =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>"
|
||||||
|
"<C:addressbook-query xmlns:D=\"DAV:\""
|
||||||
|
" xmlns:C=\"urn:ietf:params:xml:ns:carddav\">"
|
||||||
|
" <D:prop>"
|
||||||
|
" <D:getetag/>"
|
||||||
|
" <C:address-data>"
|
||||||
|
" <C:allprop/>"
|
||||||
|
" </C:address-data>"
|
||||||
|
" </D:prop>"
|
||||||
|
" <C:filter test=\"anyof\">"
|
||||||
|
" <C:prop-filter name=\"UID\">";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the last part of the calendar query
|
||||||
|
*/
|
||||||
|
static char* search_tail =
|
||||||
|
" </C:prop-filter>"
|
||||||
|
" </C:filter>"
|
||||||
|
"</C:addressbook-query>\r\n";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting an event.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_delete(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gchar* search;
|
||||||
|
gchar* uid;
|
||||||
|
gboolean LOCKSUPPORT = FALSE;
|
||||||
|
gchar* lock_token = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: infinity");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
gchar* file = g_strdup(settings->file);
|
||||||
|
if ((uid = get_response_header("uid", file, FALSE)) == NULL) {
|
||||||
|
g_free(file);
|
||||||
|
error->code = 1;
|
||||||
|
error->str = g_strdup("Error: Missing required UID for object");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
g_free(file);
|
||||||
|
/*
|
||||||
|
* ICalendar server does not support collation
|
||||||
|
* <C:text-match collation=\"i;ascii-casemap\">%s</C:text-match>
|
||||||
|
*/
|
||||||
|
search = g_strdup_printf(
|
||||||
|
"%s<C:text-match collation=\"i;unicode-casemap\" negate-condition=\"no\" match-type=\"exact\">%s</C:text-match>%s",
|
||||||
|
search_head, uid, search_tail);
|
||||||
|
g_free(uid);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, search);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(search));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "REPORT");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
g_free(search);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
http_header = NULL;
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 207) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* enable uploading */
|
||||||
|
gchar* url = NULL;
|
||||||
|
gchar* etag = NULL;
|
||||||
|
url = get_url(chunk.memory);
|
||||||
|
if (url) {
|
||||||
|
etag = get_etag(chunk.memory);
|
||||||
|
if (etag) {
|
||||||
|
gchar* host = get_host(settings->url);
|
||||||
|
if (host) {
|
||||||
|
file = g_strdup(url);
|
||||||
|
g_free(url);
|
||||||
|
url = g_strdup_printf("%s%s", host, file);
|
||||||
|
g_free(file);
|
||||||
|
g_free(host);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(etag);
|
||||||
|
g_free(url);
|
||||||
|
url = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(url);
|
||||||
|
url = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (url) {
|
||||||
|
int lock = 0;
|
||||||
|
carddav_error lock_error;
|
||||||
|
|
||||||
|
file = g_strdup(etag);
|
||||||
|
g_free(etag);
|
||||||
|
etag = g_strdup_printf("If-Match: %s", file);
|
||||||
|
g_free(file);
|
||||||
|
http_header = curl_slist_append(http_header, etag);
|
||||||
|
g_free(etag);
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: text/directory; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
if (settings->use_locking)
|
||||||
|
LOCKSUPPORT = carddav_lock_support(settings, &lock_error);
|
||||||
|
else
|
||||||
|
LOCKSUPPORT = FALSE;
|
||||||
|
if (LOCKSUPPORT) {
|
||||||
|
lock_token = carddav_lock_object(url, settings, &lock_error);
|
||||||
|
if (lock_token) {
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, g_strdup_printf(
|
||||||
|
"If: (%s)", lock_token));
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 423 (Resource is LOCKED) bail out
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 423) {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 501 (Not implemented) we continue
|
||||||
|
* hoping for the best.
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 501) {
|
||||||
|
lock_token = g_strdup("");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (! LOCKSUPPORT || (LOCKSUPPORT && lock_token && lock_error.code != 423)) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, rebuild_url(settings, url));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, NULL);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, 0);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "DELETE");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (LOCKSUPPORT && lock_token) {
|
||||||
|
carddav_unlock_object(
|
||||||
|
lock_token, url, settings, &lock_error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_free(url);
|
||||||
|
g_free(lock_token);
|
||||||
|
if (res != 0 || lock < 0) {
|
||||||
|
/* Is this a lock_error don't change error*/
|
||||||
|
if (lock == 0 || lock_error.code == 423) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = lock_error.code;
|
||||||
|
error->str = g_strdup(lock_error.str);
|
||||||
|
}
|
||||||
|
result = TRUE;
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(
|
||||||
|
curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 204) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = code;
|
||||||
|
if (chunk.memory)
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
else
|
||||||
|
error->str = g_strdup("No object found");
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting an event by URI.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_delete_by_uri(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gchar* search;
|
||||||
|
gchar* uid;
|
||||||
|
gboolean LOCKSUPPORT = FALSE;
|
||||||
|
gchar* lock_token = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: infinity");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
gchar* file = g_strdup(settings->file);
|
||||||
|
if ((uid = get_response_header("uri", file, FALSE)) == NULL) {
|
||||||
|
g_free(file);
|
||||||
|
error->code = 1;
|
||||||
|
error->str = g_strdup("Error: Missing required URI for object\nThe requested contact may not exist on the server");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
g_free(file);
|
||||||
|
|
||||||
|
// Use the given URI to issue the delete command
|
||||||
|
/* enable uploading */
|
||||||
|
long code;
|
||||||
|
gchar* url = NULL;
|
||||||
|
gchar* etag = NULL;
|
||||||
|
url = uid;
|
||||||
|
if (url) {
|
||||||
|
gchar* host = get_host(settings->url);
|
||||||
|
if (host) {
|
||||||
|
file = g_strdup(url);
|
||||||
|
g_free(url);
|
||||||
|
url = g_strdup_printf("%s%s", host, file);
|
||||||
|
g_free(file);
|
||||||
|
g_free(host);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (url) {
|
||||||
|
int lock = 0;
|
||||||
|
carddav_error lock_error;
|
||||||
|
|
||||||
|
file = g_strdup(etag);
|
||||||
|
g_free(etag);
|
||||||
|
etag = g_strdup_printf("If-Match: %s", file);
|
||||||
|
g_free(file);
|
||||||
|
http_header = curl_slist_append(http_header, etag);
|
||||||
|
g_free(etag);
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: text/directory; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
if (settings->use_locking)
|
||||||
|
LOCKSUPPORT = carddav_lock_support(settings, &lock_error);
|
||||||
|
else
|
||||||
|
LOCKSUPPORT = FALSE;
|
||||||
|
if (LOCKSUPPORT) {
|
||||||
|
lock_token = carddav_lock_object(url, settings, &lock_error);
|
||||||
|
if (lock_token) {
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, g_strdup_printf(
|
||||||
|
"If: (%s)", lock_token));
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 423 (Resource is LOCKED) bail out
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 423) {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 501 (Not implemented) we continue
|
||||||
|
* hoping for the best.
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 501) {
|
||||||
|
lock_token = g_strdup("");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (! LOCKSUPPORT || (LOCKSUPPORT && lock_token && lock_error.code != 423)) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, rebuild_url(settings, url));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, NULL);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, 0);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "DELETE");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (LOCKSUPPORT && lock_token) {
|
||||||
|
carddav_unlock_object(
|
||||||
|
lock_token, url, settings, &lock_error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_free(url);
|
||||||
|
g_free(lock_token);
|
||||||
|
if (res != 0 || lock < 0) {
|
||||||
|
/* Is this a lock_error don't change error*/
|
||||||
|
if (lock == 0 || lock_error.code == 423) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = lock_error.code;
|
||||||
|
error->str = g_strdup(lock_error.str);
|
||||||
|
}
|
||||||
|
result = TRUE;
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(
|
||||||
|
curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 204) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = code;
|
||||||
|
if (chunk.memory)
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
else
|
||||||
|
error->str = g_strdup("No object found");
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
@ -0,0 +1,44 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __DELETE_CARDDAV_OBJECT_H__
|
||||||
|
#define __DELETE_CARDDAV_OBJECT_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "carddav.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting a card.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_delete(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for deleting a card by URI.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_delete_by_uri(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,375 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4 smarttab: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "get-carddav-report.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the webdav query for fetching
|
||||||
|
* the names of all vcf files in the directory
|
||||||
|
*/
|
||||||
|
static const char* dirlist_request =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>"
|
||||||
|
"<a:propfind xmlns:a=\"DAV:\">"
|
||||||
|
" <a:prop><a:resourcetype/></a:prop>"
|
||||||
|
"</a:propfind>\r\n";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the card query for fetching
|
||||||
|
* all cards from collection.
|
||||||
|
*/
|
||||||
|
static const char* getall_request_header =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>"
|
||||||
|
"<C:addressbook-multiget xmlns:D=\"DAV:\""
|
||||||
|
" xmlns:C=\"urn:ietf:params:xml:ns:carddav\">"
|
||||||
|
" <D:prop>"
|
||||||
|
" <D:getetag/>"
|
||||||
|
" <C:address-data>"
|
||||||
|
" <C:allprop/>"
|
||||||
|
" </C:address-data>"
|
||||||
|
" </D:prop>";
|
||||||
|
|
||||||
|
static const char* getall_request_footer =
|
||||||
|
"</C:addressbook-multiget>\r\n";
|
||||||
|
|
||||||
|
#define ELEM_HREF "href"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for listing a directory.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
static gchar* carddav_dirlist(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gchar* all_href = NULL;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: 1");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, dirlist_request);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(dirlist_request));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PROPFIND");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 207) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(headers.memory);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
gchar* tmp_report = NULL;
|
||||||
|
gchar* href = NULL;
|
||||||
|
gchar* tmp = NULL;
|
||||||
|
char* pos;
|
||||||
|
tmp_report = g_strdup(chunk.memory);
|
||||||
|
href = get_tag(ELEM_HREF, tmp_report);
|
||||||
|
/* Maybe namespace prefixed */
|
||||||
|
if (!href) {
|
||||||
|
href = get_tag("D:href", tmp_report);
|
||||||
|
}
|
||||||
|
pos = strstr(tmp_report, href);
|
||||||
|
all_href = g_strdup_printf("");
|
||||||
|
while ((href != NULL) && (pos != NULL)) {
|
||||||
|
href = get_tag(ELEM_HREF, pos);
|
||||||
|
/* Maybe namespace prefixed */
|
||||||
|
if (!href) {
|
||||||
|
href = get_tag("D:href", pos);
|
||||||
|
}
|
||||||
|
if (!href)
|
||||||
|
break;
|
||||||
|
pos = strstr(pos, href);
|
||||||
|
tmp = g_strdup(all_href);
|
||||||
|
g_free(all_href);
|
||||||
|
all_href = g_strdup_printf("%s <D:href>%s</D:href>\r\n", tmp, href);
|
||||||
|
g_free(tmp);
|
||||||
|
}
|
||||||
|
g_free(tmp_report);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return all_href;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all cards from collection.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getall(carddav_settings* settings, carddav_error* error) {
|
||||||
|
gchar * dav_file_listing;
|
||||||
|
dav_file_listing = carddav_dirlist(settings, error);
|
||||||
|
if (dav_file_listing == NULL)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: 1");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
/* assemble request */
|
||||||
|
gchar * get_request;
|
||||||
|
get_request = g_strdup_printf("%s%s%s\r\n", getall_request_header, dav_file_listing, getall_request_footer);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, get_request);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(get_request));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "REPORT");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 207) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(headers.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
gchar* report;
|
||||||
|
report = parse_carddav_report(
|
||||||
|
chunk.memory, "address-data", "VCARD");
|
||||||
|
settings->file = g_strdup(report);
|
||||||
|
g_free(report);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
g_free(dav_file_listing);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all cards from collection.
|
||||||
|
* This version stores each object's URI in a VCARD parameter.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getall_by_uri(carddav_settings* settings, carddav_error* error) {
|
||||||
|
gchar * dav_file_listing;
|
||||||
|
dav_file_listing = carddav_dirlist(settings, error);
|
||||||
|
if (dav_file_listing == NULL)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: 1");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
/* assemble request */
|
||||||
|
gchar * get_request;
|
||||||
|
get_request = g_strdup_printf("%s%s%s\r\n", getall_request_header, dav_file_listing, getall_request_footer);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, get_request);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(get_request));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "REPORT");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 207) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(headers.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
gchar* report;
|
||||||
|
report = parse_carddav_report(
|
||||||
|
chunk.memory, "address-data", "VCARD");
|
||||||
|
settings->file = g_strdup(report);
|
||||||
|
g_free(report);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
g_free(dav_file_listing);
|
||||||
|
return result;
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GET_CARDDAV_REPORT_H__
|
||||||
|
#define __GET_CARDDAV_REPORT_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "carddav.h"
|
||||||
|
#include <glib.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting a WebDAV directory listing.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return string containing list of href elements for search
|
||||||
|
*/
|
||||||
|
static gchar* carddav_dirlist(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all cards from collection.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getall(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting all cards from collection.
|
||||||
|
* This version stores each object's URI in a VCARD parameter.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getall_by_uri(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
#endif
|
@ -0,0 +1,140 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4 smarttab: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "get-carddav-report.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the carddav query for fetching
|
||||||
|
* the stored display name for the collection.
|
||||||
|
*/
|
||||||
|
static const char* getname_request =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>"
|
||||||
|
"<D:propfind xmlns:D=\"DAV:\""
|
||||||
|
" xmlns:C=\"urn:ietf:params:xml:ns:carddav\">"
|
||||||
|
" <D:prop>"
|
||||||
|
" <D:displayname/>"
|
||||||
|
" </D:prop>"
|
||||||
|
"</D:propfind>\r\n";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting the display name from collection.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getname(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: 0");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, getname_request);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(getname_request));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PROPFIND");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 207) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(headers.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
gchar* displayname;
|
||||||
|
displayname = get_tag("displayname", chunk.memory);
|
||||||
|
/* Maybe namespace prefixed */
|
||||||
|
if (!displayname) {
|
||||||
|
displayname = get_tag("D:displayname", chunk.memory);
|
||||||
|
}
|
||||||
|
settings->file = (displayname) ?
|
||||||
|
g_strdup(displayname) : g_strdup("");
|
||||||
|
g_free(displayname);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,35 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GET_DISPLAY_NAME_H__
|
||||||
|
#define __GET_DISPLAY_NAME_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting the display name from collection.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getname(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,295 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "lock-carddav-object.h"
|
||||||
|
#include "options-carddav-server.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the lock query.
|
||||||
|
*/
|
||||||
|
static char* lock_query =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>"
|
||||||
|
"<D:lockinfo xmlns:D=\"DAV:\">"
|
||||||
|
" <D:lockscope><D:exclusive/></D:lockscope>"
|
||||||
|
" <D:locktype><D:write/></D:locktype>"
|
||||||
|
"</D:lockinfo>";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function which requests a lock on a calendar resource
|
||||||
|
* @param URI The resource to request lock on.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return The Lock-Token or NULL in case of error
|
||||||
|
*/
|
||||||
|
gchar* carddav_lock_object(
|
||||||
|
gchar* URI, carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gchar* lock_token = NULL;
|
||||||
|
gchar* url;
|
||||||
|
|
||||||
|
if (! carddav_lock_support(settings, error))
|
||||||
|
return lock_token;
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return lock_token;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Timeout: Second-300");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
if (settings->usehttps) {
|
||||||
|
url = g_strdup_printf("https://%s", URI);
|
||||||
|
} else {
|
||||||
|
url = g_strdup_printf("http://%s", URI);
|
||||||
|
}
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
|
g_free(url);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, lock_query);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(lock_query));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "LOCK");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 200) {
|
||||||
|
gchar* status = get_tag("status", chunk.memory);
|
||||||
|
if (status && strstr(status, "423") != NULL) {
|
||||||
|
error->code = 423;
|
||||||
|
error->str = g_strdup(status);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
}
|
||||||
|
g_free(status);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
lock_token = get_response_header(
|
||||||
|
"Lock-Token", headers.memory, FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return lock_token;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function which requests to have a lock removed from a calendar resource
|
||||||
|
* @param lock_token A privious aquired Lock-Token
|
||||||
|
* @param URI The resource to request unlock on.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return False in case the lock could not be removed. True otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_unlock_object(gchar* lock_token, gchar* URI,
|
||||||
|
carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
gchar* url;
|
||||||
|
|
||||||
|
if (! carddav_lock_support(settings, error))
|
||||||
|
return result;
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
g_strdup_printf("Lock-Token: %s", lock_token));
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
if (settings->usehttps) {
|
||||||
|
url = g_strdup_printf("https://%s", URI);
|
||||||
|
} else {
|
||||||
|
url = g_strdup_printf("http://%s", URI);
|
||||||
|
}
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, url);
|
||||||
|
g_free(url);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "UNLOCK");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 204) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to test whether the server supports locking or not. Searching
|
||||||
|
* for PROP LOCK. If LOCK is present then according to RFC4791 PROP UNLOCK
|
||||||
|
* must also be present.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return True if locking is supported by the server. False otherwise
|
||||||
|
*/
|
||||||
|
gboolean carddav_lock_support(carddav_settings* settings, carddav_error* error) {
|
||||||
|
gboolean found = FALSE;
|
||||||
|
gchar* url = NULL;
|
||||||
|
gchar* mystr = NULL;
|
||||||
|
runtime_info* info;
|
||||||
|
|
||||||
|
info = carddav_get_runtime_info();
|
||||||
|
info->options->verify_ssl_certificate = settings->verify_ssl_certificate;
|
||||||
|
info->options->custom_cacert = g_strdup(settings->custom_cacert);
|
||||||
|
if (settings->usehttps) {
|
||||||
|
mystr = g_strdup("https://");
|
||||||
|
} else {
|
||||||
|
mystr = g_strdup("http://");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (settings->username && settings->password) {
|
||||||
|
url = g_strdup_printf("%s%s:%s@%s",
|
||||||
|
mystr, settings->username, settings->password, settings->url);
|
||||||
|
}
|
||||||
|
else if (settings->username) {
|
||||||
|
url = g_strdup_printf("%s%s@%s",
|
||||||
|
mystr, settings->username, settings->url);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
url = g_strdup_printf("%s%s", mystr, settings->url);
|
||||||
|
}
|
||||||
|
gchar** options = carddav_get_server_options(url, info);
|
||||||
|
g_free(url);
|
||||||
|
gchar** tmp = options;
|
||||||
|
carddav_free_runtime_info(&info);
|
||||||
|
while (*options) {
|
||||||
|
if (strcmp(*options++, "LOCK") == 0) {
|
||||||
|
found = TRUE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_strfreev(tmp);
|
||||||
|
g_free(mystr);
|
||||||
|
return found;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,56 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __LOCK_CARDDAV_OBJECT_H__
|
||||||
|
#define __LOCK_CARDDAV_OBJECT_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "carddav.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function which requests a lock on an addressbook resource
|
||||||
|
* @param URI The resource to request lock on.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return The Lock-Token or NULL in case of error
|
||||||
|
*/
|
||||||
|
gchar* carddav_lock_object(
|
||||||
|
gchar* URI, carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function which requests to have a lock removed from a addressbook resource
|
||||||
|
* @param lock_token A privious aquired Lock-Token
|
||||||
|
* @param URI The resource to request unlock on.
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return False in case the lock could not be removed. True otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_unlock_object(gchar* lock_token, gchar* URI,
|
||||||
|
carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to test whether the server supports locking or not
|
||||||
|
* @param settings @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return True if locking is supported by the server. False otherwise
|
||||||
|
*/
|
||||||
|
gboolean carddav_lock_support(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
#endif
|
@ -0,0 +1,442 @@
|
|||||||
|
/** md5.c - MD5 Message-Digest Algorithm
|
||||||
|
* Copyright (C) 1995, 1996, 1998, 1999 Free Software Foundation, Inc.
|
||||||
|
*
|
||||||
|
* according to the definition of MD5 in RFC 1321 from April 1992.
|
||||||
|
* NOTE: This is *not* the same file as the one from glibc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by the
|
||||||
|
* Free Software Foundation; either version 3, or (at your option) any
|
||||||
|
* later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* Written by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
|
||||||
|
* heavily modified for GnuPG by <werner.koch@guug.de>.
|
||||||
|
* modified again for Sylpheed by <wk@gnupg.org> 2001-02-11.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* Test values:
|
||||||
|
* "" D4 1D 8C D9 8F 00 B2 04 E9 80 09 98 EC F8 42 7E
|
||||||
|
* "a" 0C C1 75 B9 C0 F1 B6 A8 31 C3 99 E2 69 77 26 61
|
||||||
|
* "abc 90 01 50 98 3C D2 4F B0 D6 96 3F 7D 28 E1 7F 72
|
||||||
|
* "message digest" F9 6B 69 7D 7C B7 93 8D 52 5A 2F 31 AA F1 61 D0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "md5.h"
|
||||||
|
|
||||||
|
/****************
|
||||||
|
* Rotate a 32 bit integer by n bytes
|
||||||
|
*/
|
||||||
|
#if defined(__GNUC__) && defined(__i386__)
|
||||||
|
static inline u32
|
||||||
|
rol( u32 x, int n)
|
||||||
|
{
|
||||||
|
__asm__("roll %%cl,%0"
|
||||||
|
:"=r" (x)
|
||||||
|
:"0" (x),"c" (n));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#define rol(x,n) ( ((x) << (n)) | ((x) >> (32-(n))) )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
md5_init(MD5_CONTEXT *ctx)
|
||||||
|
{
|
||||||
|
ctx->A = 0x67452301;
|
||||||
|
ctx->B = 0xefcdab89;
|
||||||
|
ctx->C = 0x98badcfe;
|
||||||
|
ctx->D = 0x10325476;
|
||||||
|
|
||||||
|
ctx->nblocks = 0;
|
||||||
|
ctx->count = 0;
|
||||||
|
ctx->finalized = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* These are the four functions used in the four steps of the MD5 algorithm
|
||||||
|
and defined in the RFC 1321. The first function is a little bit optimized
|
||||||
|
(as found in Colin Plumbs public domain implementation). */
|
||||||
|
/* #define FF(b, c, d) ((b & c) | (~b & d)) */
|
||||||
|
#define FF(b, c, d) (d ^ (b & (c ^ d)))
|
||||||
|
#define FG(b, c, d) FF (d, b, c)
|
||||||
|
#define FH(b, c, d) (b ^ c ^ d)
|
||||||
|
#define FI(b, c, d) (c ^ (b | ~d))
|
||||||
|
|
||||||
|
|
||||||
|
/****************
|
||||||
|
* transform n*64 bytes
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
transform(MD5_CONTEXT *ctx, const unsigned char *data)
|
||||||
|
{
|
||||||
|
u32 correct_words[16];
|
||||||
|
u32 A = ctx->A;
|
||||||
|
u32 B = ctx->B;
|
||||||
|
u32 C = ctx->C;
|
||||||
|
u32 D = ctx->D;
|
||||||
|
u32 *cwp = correct_words;
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_HOST
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
unsigned char *p2;
|
||||||
|
const unsigned char *p1;
|
||||||
|
|
||||||
|
for (i = 0, p1 = data, p2 = (unsigned char*)correct_words;
|
||||||
|
i < 16; i++, p2 += 4) {
|
||||||
|
p2[3] = *p1++;
|
||||||
|
p2[2] = *p1++;
|
||||||
|
p2[1] = *p1++;
|
||||||
|
p2[0] = *p1++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
memcpy(correct_words, data, 64);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define OP(a, b, c, d, s, T) \
|
||||||
|
do { \
|
||||||
|
a += FF (b, c, d) + (*cwp++) + T; \
|
||||||
|
a = rol(a, s); \
|
||||||
|
a += b; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
/* Before we start, one word about the strange constants.
|
||||||
|
They are defined in RFC 1321 as
|
||||||
|
|
||||||
|
T[i] = (int) (4294967296.0 * fabs (sin (i))), i=1..64
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Round 1. */
|
||||||
|
OP (A, B, C, D, 7, 0xd76aa478);
|
||||||
|
OP (D, A, B, C, 12, 0xe8c7b756);
|
||||||
|
OP (C, D, A, B, 17, 0x242070db);
|
||||||
|
OP (B, C, D, A, 22, 0xc1bdceee);
|
||||||
|
OP (A, B, C, D, 7, 0xf57c0faf);
|
||||||
|
OP (D, A, B, C, 12, 0x4787c62a);
|
||||||
|
OP (C, D, A, B, 17, 0xa8304613);
|
||||||
|
OP (B, C, D, A, 22, 0xfd469501);
|
||||||
|
OP (A, B, C, D, 7, 0x698098d8);
|
||||||
|
OP (D, A, B, C, 12, 0x8b44f7af);
|
||||||
|
OP (C, D, A, B, 17, 0xffff5bb1);
|
||||||
|
OP (B, C, D, A, 22, 0x895cd7be);
|
||||||
|
OP (A, B, C, D, 7, 0x6b901122);
|
||||||
|
OP (D, A, B, C, 12, 0xfd987193);
|
||||||
|
OP (C, D, A, B, 17, 0xa679438e);
|
||||||
|
OP (B, C, D, A, 22, 0x49b40821);
|
||||||
|
|
||||||
|
#undef OP
|
||||||
|
#define OP(f, a, b, c, d, k, s, T) \
|
||||||
|
do { \
|
||||||
|
a += f (b, c, d) + correct_words[k] + T; \
|
||||||
|
a = rol(a, s); \
|
||||||
|
a += b; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
/* Round 2. */
|
||||||
|
OP (FG, A, B, C, D, 1, 5, 0xf61e2562);
|
||||||
|
OP (FG, D, A, B, C, 6, 9, 0xc040b340);
|
||||||
|
OP (FG, C, D, A, B, 11, 14, 0x265e5a51);
|
||||||
|
OP (FG, B, C, D, A, 0, 20, 0xe9b6c7aa);
|
||||||
|
OP (FG, A, B, C, D, 5, 5, 0xd62f105d);
|
||||||
|
OP (FG, D, A, B, C, 10, 9, 0x02441453);
|
||||||
|
OP (FG, C, D, A, B, 15, 14, 0xd8a1e681);
|
||||||
|
OP (FG, B, C, D, A, 4, 20, 0xe7d3fbc8);
|
||||||
|
OP (FG, A, B, C, D, 9, 5, 0x21e1cde6);
|
||||||
|
OP (FG, D, A, B, C, 14, 9, 0xc33707d6);
|
||||||
|
OP (FG, C, D, A, B, 3, 14, 0xf4d50d87);
|
||||||
|
OP (FG, B, C, D, A, 8, 20, 0x455a14ed);
|
||||||
|
OP (FG, A, B, C, D, 13, 5, 0xa9e3e905);
|
||||||
|
OP (FG, D, A, B, C, 2, 9, 0xfcefa3f8);
|
||||||
|
OP (FG, C, D, A, B, 7, 14, 0x676f02d9);
|
||||||
|
OP (FG, B, C, D, A, 12, 20, 0x8d2a4c8a);
|
||||||
|
|
||||||
|
/* Round 3. */
|
||||||
|
OP (FH, A, B, C, D, 5, 4, 0xfffa3942);
|
||||||
|
OP (FH, D, A, B, C, 8, 11, 0x8771f681);
|
||||||
|
OP (FH, C, D, A, B, 11, 16, 0x6d9d6122);
|
||||||
|
OP (FH, B, C, D, A, 14, 23, 0xfde5380c);
|
||||||
|
OP (FH, A, B, C, D, 1, 4, 0xa4beea44);
|
||||||
|
OP (FH, D, A, B, C, 4, 11, 0x4bdecfa9);
|
||||||
|
OP (FH, C, D, A, B, 7, 16, 0xf6bb4b60);
|
||||||
|
OP (FH, B, C, D, A, 10, 23, 0xbebfbc70);
|
||||||
|
OP (FH, A, B, C, D, 13, 4, 0x289b7ec6);
|
||||||
|
OP (FH, D, A, B, C, 0, 11, 0xeaa127fa);
|
||||||
|
OP (FH, C, D, A, B, 3, 16, 0xd4ef3085);
|
||||||
|
OP (FH, B, C, D, A, 6, 23, 0x04881d05);
|
||||||
|
OP (FH, A, B, C, D, 9, 4, 0xd9d4d039);
|
||||||
|
OP (FH, D, A, B, C, 12, 11, 0xe6db99e5);
|
||||||
|
OP (FH, C, D, A, B, 15, 16, 0x1fa27cf8);
|
||||||
|
OP (FH, B, C, D, A, 2, 23, 0xc4ac5665);
|
||||||
|
|
||||||
|
/* Round 4. */
|
||||||
|
OP (FI, A, B, C, D, 0, 6, 0xf4292244);
|
||||||
|
OP (FI, D, A, B, C, 7, 10, 0x432aff97);
|
||||||
|
OP (FI, C, D, A, B, 14, 15, 0xab9423a7);
|
||||||
|
OP (FI, B, C, D, A, 5, 21, 0xfc93a039);
|
||||||
|
OP (FI, A, B, C, D, 12, 6, 0x655b59c3);
|
||||||
|
OP (FI, D, A, B, C, 3, 10, 0x8f0ccc92);
|
||||||
|
OP (FI, C, D, A, B, 10, 15, 0xffeff47d);
|
||||||
|
OP (FI, B, C, D, A, 1, 21, 0x85845dd1);
|
||||||
|
OP (FI, A, B, C, D, 8, 6, 0x6fa87e4f);
|
||||||
|
OP (FI, D, A, B, C, 15, 10, 0xfe2ce6e0);
|
||||||
|
OP (FI, C, D, A, B, 6, 15, 0xa3014314);
|
||||||
|
OP (FI, B, C, D, A, 13, 21, 0x4e0811a1);
|
||||||
|
OP (FI, A, B, C, D, 4, 6, 0xf7537e82);
|
||||||
|
OP (FI, D, A, B, C, 11, 10, 0xbd3af235);
|
||||||
|
OP (FI, C, D, A, B, 2, 15, 0x2ad7d2bb);
|
||||||
|
OP (FI, B, C, D, A, 9, 21, 0xeb86d391);
|
||||||
|
|
||||||
|
/* Put checksum in context given as argument. */
|
||||||
|
ctx->A += A;
|
||||||
|
ctx->B += B;
|
||||||
|
ctx->C += C;
|
||||||
|
ctx->D += D;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* The routine updates the message-digest context to
|
||||||
|
* account for the presence of each of the characters inBuf[0..inLen-1]
|
||||||
|
* in the message whose digest is being computed.
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
md5_update(MD5_CONTEXT *hd, const unsigned char *inbuf, size_t inlen)
|
||||||
|
{
|
||||||
|
if (hd->count == 64) { /* flush the buffer */
|
||||||
|
transform( hd, hd->buf );
|
||||||
|
hd->count = 0;
|
||||||
|
hd->nblocks++;
|
||||||
|
}
|
||||||
|
if (!inbuf)
|
||||||
|
return;
|
||||||
|
if (hd->count) {
|
||||||
|
for (; inlen && hd->count < 64; inlen--)
|
||||||
|
hd->buf[hd->count++] = *inbuf++;
|
||||||
|
md5_update(hd, NULL, 0);
|
||||||
|
if (!inlen)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (inlen >= 64) {
|
||||||
|
transform(hd, inbuf);
|
||||||
|
hd->count = 0;
|
||||||
|
hd->nblocks++;
|
||||||
|
inlen -= 64;
|
||||||
|
inbuf += 64;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (; inlen && hd->count < 64; inlen--)
|
||||||
|
hd->buf[hd->count++] = *inbuf++;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* The routine final terminates the message-digest computation and
|
||||||
|
* ends with the desired message digest in mdContext->digest[0...15].
|
||||||
|
* The handle is prepared for a new MD5 cycle.
|
||||||
|
* Returns 16 bytes representing the digest.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_final(MD5_CONTEXT *hd)
|
||||||
|
{
|
||||||
|
u32 t, msb, lsb;
|
||||||
|
unsigned char *p;
|
||||||
|
|
||||||
|
md5_update(hd, NULL, 0); /* flush */
|
||||||
|
|
||||||
|
msb = 0;
|
||||||
|
t = hd->nblocks;
|
||||||
|
if ((lsb = t << 6) < t) /* multiply by 64 to make a byte count */
|
||||||
|
msb++;
|
||||||
|
msb += t >> 26;
|
||||||
|
t = lsb;
|
||||||
|
if ((lsb = t + hd->count) < t) /* add the count */
|
||||||
|
msb++;
|
||||||
|
t = lsb;
|
||||||
|
if ((lsb = t << 3) < t) /* multiply by 8 to make a bit count */
|
||||||
|
msb++;
|
||||||
|
msb += t >> 29;
|
||||||
|
|
||||||
|
if (hd->count < 56) { /* enough room */
|
||||||
|
hd->buf[hd->count++] = 0x80; /* pad */
|
||||||
|
while(hd->count < 56)
|
||||||
|
hd->buf[hd->count++] = 0; /* pad */
|
||||||
|
} else { /* need one extra block */
|
||||||
|
hd->buf[hd->count++] = 0x80; /* pad character */
|
||||||
|
while (hd->count < 64)
|
||||||
|
hd->buf[hd->count++] = 0;
|
||||||
|
md5_update(hd, NULL, 0); /* flush */
|
||||||
|
memset(hd->buf, 0, 56); /* fill next block with zeroes */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* append the 64 bit count */
|
||||||
|
hd->buf[56] = lsb ;
|
||||||
|
hd->buf[57] = lsb >> 8;
|
||||||
|
hd->buf[58] = lsb >> 16;
|
||||||
|
hd->buf[59] = lsb >> 24;
|
||||||
|
hd->buf[60] = msb ;
|
||||||
|
hd->buf[61] = msb >> 8;
|
||||||
|
hd->buf[62] = msb >> 16;
|
||||||
|
hd->buf[63] = msb >> 24;
|
||||||
|
transform(hd, hd->buf);
|
||||||
|
|
||||||
|
p = hd->buf;
|
||||||
|
#ifdef BIG_ENDIAN_HOST
|
||||||
|
#define X(a) do { *p++ = hd->a ; *p++ = hd->a >> 8; \
|
||||||
|
*p++ = hd->a >> 16; *p++ = hd->a >> 24; } while(0)
|
||||||
|
#else /* little endian */
|
||||||
|
/*#define X(a) do { *(u32*)p = hd->##a ; p += 4; } while(0)*/
|
||||||
|
/* Unixware's cpp doesn't like the above construct so we do it his way:
|
||||||
|
* (reported by Allan Clark) */
|
||||||
|
#define X(a) do { *(u32*)p = (*hd).a ; p += 4; } while(0)
|
||||||
|
#endif
|
||||||
|
X(A);
|
||||||
|
X(B);
|
||||||
|
X(C);
|
||||||
|
X(D);
|
||||||
|
#undef X
|
||||||
|
hd->finalized = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
md5_final(unsigned char *digest, MD5_CONTEXT *ctx)
|
||||||
|
{
|
||||||
|
if (!ctx->finalized)
|
||||||
|
do_final(ctx);
|
||||||
|
memcpy(digest, ctx->buf, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Creates a MD5 digest in hex fomrat (lowercase letters) from the
|
||||||
|
* string S. hextdigest but be buffer of at lease 33 bytes!
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
md5_hex_digest(char *hexdigest, const unsigned char *s)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
MD5_CONTEXT context;
|
||||||
|
unsigned char digest[16];
|
||||||
|
|
||||||
|
md5_init(&context);
|
||||||
|
md5_update(&context, s, strlen((gchar *) s));
|
||||||
|
md5_final(digest, &context);
|
||||||
|
|
||||||
|
for (i = 0; i < 16; i++)
|
||||||
|
sprintf(hexdigest + 2 * i, "%02x", digest[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Function: md5_hmac
|
||||||
|
** taken from the file rfc2104.txt
|
||||||
|
** written by Martin Schaaf <mascha@ma-scha.de>
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
md5_hmac(unsigned char *digest,
|
||||||
|
const unsigned char* text, int text_len,
|
||||||
|
const unsigned char* key, int key_len)
|
||||||
|
{
|
||||||
|
MD5_CONTEXT context;
|
||||||
|
unsigned char k_ipad[64]; /* inner padding -
|
||||||
|
* key XORd with ipad
|
||||||
|
*/
|
||||||
|
unsigned char k_opad[64]; /* outer padding -
|
||||||
|
* key XORd with opad
|
||||||
|
*/
|
||||||
|
/* unsigned char tk[16]; */
|
||||||
|
int i;
|
||||||
|
|
||||||
|
/* start out by storing key in pads */
|
||||||
|
memset(k_ipad, 0, sizeof k_ipad);
|
||||||
|
memset(k_opad, 0, sizeof k_opad);
|
||||||
|
if (key_len > 64) {
|
||||||
|
/* if key is longer than 64 bytes reset it to key=MD5(key) */
|
||||||
|
MD5_CONTEXT tctx;
|
||||||
|
|
||||||
|
md5_init(&tctx);
|
||||||
|
md5_update(&tctx, key, key_len);
|
||||||
|
md5_final(k_ipad, &tctx);
|
||||||
|
md5_final(k_opad, &tctx);
|
||||||
|
} else {
|
||||||
|
memcpy(k_ipad, key, key_len);
|
||||||
|
memcpy(k_opad, key, key_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* the HMAC_MD5 transform looks like:
|
||||||
|
*
|
||||||
|
* MD5(K XOR opad, MD5(K XOR ipad, text))
|
||||||
|
*
|
||||||
|
* where K is an n byte key
|
||||||
|
* ipad is the byte 0x36 repeated 64 times
|
||||||
|
* opad is the byte 0x5c repeated 64 times
|
||||||
|
* and text is the data being protected
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* XOR key with ipad and opad values */
|
||||||
|
for (i = 0; i < 64; i++) {
|
||||||
|
k_ipad[i] ^= 0x36;
|
||||||
|
k_opad[i] ^= 0x5c;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* perform inner MD5
|
||||||
|
*/
|
||||||
|
md5_init(&context); /* init context for 1st
|
||||||
|
* pass */
|
||||||
|
md5_update(&context, k_ipad, 64); /* start with inner pad */
|
||||||
|
md5_update(&context, text, text_len); /* then text of datagram */
|
||||||
|
md5_final(digest, &context); /* finish up 1st pass */
|
||||||
|
/*
|
||||||
|
* perform outer MD5
|
||||||
|
*/
|
||||||
|
md5_init(&context); /* init context for 2nd
|
||||||
|
* pass */
|
||||||
|
md5_update(&context, k_opad, 64); /* start with outer pad */
|
||||||
|
md5_update(&context, digest, 16); /* then results of 1st
|
||||||
|
* hash */
|
||||||
|
md5_final(digest, &context); /* finish up 2nd pass */
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
md5_hex_hmac(char *hexdigest,
|
||||||
|
const unsigned char* text, int text_len,
|
||||||
|
const unsigned char* key, int key_len)
|
||||||
|
{
|
||||||
|
unsigned char digest[16];
|
||||||
|
int i;
|
||||||
|
|
||||||
|
md5_hmac(digest, text, text_len, key, key_len);
|
||||||
|
for (i = 0; i < 16; i++)
|
||||||
|
sprintf(hexdigest + 2 * i, "%02x", digest[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void carddav_md5_hex_digest(char *hexdigest, const unsigned char *s) {
|
||||||
|
md5_hex_digest(hexdigest, s);
|
||||||
|
}
|
||||||
|
|
||||||
|
void carddav_md5_hex_hmac(char *hexdigest,
|
||||||
|
const unsigned char* text, int text_len,
|
||||||
|
const unsigned char* key, int key_len) {
|
||||||
|
md5_hex_hmac(hexdigest, text, text_len, key, key_len);
|
||||||
|
}
|
@ -0,0 +1,52 @@
|
|||||||
|
/**
|
||||||
|
* md5.h - MD5 Message-Digest Algorithm
|
||||||
|
* Copyright (C) 1995, 1996, 1998, 1999 Free Software Foundation, Inc.
|
||||||
|
*
|
||||||
|
* according to the definition of MD5 in RFC 1321 from April 1992.
|
||||||
|
* NOTE: This is *not* the same file as the one from glibc
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by the
|
||||||
|
* Free Software Foundation; either version 3, or (at your option) any
|
||||||
|
* later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _MD5_HDR_
|
||||||
|
#define _MD5_HDR_
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef u32
|
||||||
|
* Kept this typedef for compatibility reasons
|
||||||
|
*/
|
||||||
|
#ifndef HAVE_U32_TYPEDEF
|
||||||
|
#undef u32
|
||||||
|
typedef guint32 u32;
|
||||||
|
#define HAVE_U32_TYPEDEF
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct { /* Hmm, should be private */
|
||||||
|
u32 A,B,C,D;
|
||||||
|
u32 nblocks;
|
||||||
|
unsigned char buf[64];
|
||||||
|
int count;
|
||||||
|
int finalized;
|
||||||
|
} MD5_CONTEXT;
|
||||||
|
|
||||||
|
void carddav_md5_hex_digest(char *hexdigest, const unsigned char *s);
|
||||||
|
|
||||||
|
void carddav_md5_hex_hmac(char *hexdigest,
|
||||||
|
const unsigned char* text, int text_len,
|
||||||
|
const unsigned char* key, int key_len);
|
||||||
|
|
||||||
|
#endif /* _MD5_HDR_ */
|
||||||
|
|
@ -0,0 +1,493 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "modify-carddav-object.h"
|
||||||
|
#include "lock-carddav-object.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the first part of the calendar query.
|
||||||
|
* The actual UID to use for the query is added at runtime.
|
||||||
|
*/
|
||||||
|
static char* search_head =
|
||||||
|
"<?xml version=\"1.0\" encoding=\"utf-8\" ?>"
|
||||||
|
"<C:addressbook-query xmlns:D=\"DAV:\""
|
||||||
|
" xmlns:C=\"urn:ietf:params:xml:ns:carddav\">"
|
||||||
|
" <D:prop>"
|
||||||
|
" <D:getetag/>"
|
||||||
|
" <C:address-data>"
|
||||||
|
" <C:allprop/>"
|
||||||
|
" </C:address-data>"
|
||||||
|
" </D:prop>"
|
||||||
|
" <C:filter test=\"anyof\">"
|
||||||
|
" <C:prop-filter name=\"UID\">";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A static literal string containing the last part of the calendar query
|
||||||
|
*/
|
||||||
|
static char* search_tail =
|
||||||
|
" </C:prop-filter>"
|
||||||
|
" </C:filter>"
|
||||||
|
"</C:addressbook-query>\r\n";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying a card.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_modify(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gchar* search;
|
||||||
|
gchar* uid;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
gboolean LOCKSUPPORT = FALSE;
|
||||||
|
gchar* lock_token = NULL;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: 1");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
gchar* file = g_strdup(settings->file);
|
||||||
|
if ((uid = get_response_header("uid", file, FALSE)) == NULL) {
|
||||||
|
g_free(file);
|
||||||
|
error->code = 1;
|
||||||
|
error->str = g_strdup("Error: Missing required UID for object");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
g_free(file);
|
||||||
|
/*
|
||||||
|
* collation is not supported by ICalendar.
|
||||||
|
* <C:text-match collation=\"i;ascii-casemap\">%s</C:text-match>
|
||||||
|
*/
|
||||||
|
search = g_strdup_printf(
|
||||||
|
"%s<C:text-match collation=\"i;unicode-casemap\" negate-condition=\"no\" match-type=\"exact\">%s</C:text-match>%s",
|
||||||
|
search_head, uid, search_tail);
|
||||||
|
g_free(uid);
|
||||||
|
/* enable uploading */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, search);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE, strlen(search));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "REPORT");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
http_header = NULL;
|
||||||
|
g_free(search);
|
||||||
|
if (res != 0) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup_printf("%s", error_buf);
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 207) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* enable uploading */
|
||||||
|
gchar* url = NULL;
|
||||||
|
gchar* etag = NULL;
|
||||||
|
url = get_url(chunk.memory);
|
||||||
|
if (url) {
|
||||||
|
etag = get_etag(chunk.memory);
|
||||||
|
if (etag) {
|
||||||
|
gchar* host = get_host(settings->url);
|
||||||
|
if (host) {
|
||||||
|
file = g_strdup(url);
|
||||||
|
g_free(url);
|
||||||
|
url = g_strdup_printf("%s%s", host, file);
|
||||||
|
g_free(file);
|
||||||
|
g_free(host);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(etag);
|
||||||
|
g_free(url);
|
||||||
|
url = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(url);
|
||||||
|
url = NULL;
|
||||||
|
}
|
||||||
|
if (url) {
|
||||||
|
int lock = 0;
|
||||||
|
carddav_error lock_error;
|
||||||
|
|
||||||
|
file = g_strdup(etag);
|
||||||
|
g_free(etag);
|
||||||
|
etag = g_strdup_printf("If-Match: %s", file);
|
||||||
|
g_free(file);
|
||||||
|
http_header = curl_slist_append(http_header, etag);
|
||||||
|
g_free(etag);
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: text/directory; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, "Transfer-Encoding:");
|
||||||
|
if (settings->use_locking)
|
||||||
|
LOCKSUPPORT = carddav_lock_support(settings, &lock_error);
|
||||||
|
else
|
||||||
|
LOCKSUPPORT = FALSE;
|
||||||
|
if (LOCKSUPPORT) {
|
||||||
|
lock_token = carddav_lock_object(url, settings, &lock_error);
|
||||||
|
if (lock_token) {
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, g_strdup_printf(
|
||||||
|
"If: (%s)", lock_token));
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 423 (Resource is LOCKED) bail out
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 423) {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 501 (Not implemented) we continue
|
||||||
|
* hoping for the best.
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 501) {
|
||||||
|
lock_token = g_strdup("");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (! LOCKSUPPORT || (LOCKSUPPORT && lock_token && lock_error.code != 423)) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, rebuild_url(settings, url));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, settings->file);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE,
|
||||||
|
strlen(settings->file));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PUT");
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (LOCKSUPPORT && lock_token) {
|
||||||
|
carddav_unlock_object(
|
||||||
|
lock_token, url, settings, &lock_error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_free(url);
|
||||||
|
g_free(lock_token);
|
||||||
|
if (res != 0 || lock < 0) {
|
||||||
|
/* Is this a lock_error don't change error*/
|
||||||
|
if (lock == 0 || lock_error.code == 423) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = lock_error.code;
|
||||||
|
error->str = g_strdup(lock_error.str);
|
||||||
|
}
|
||||||
|
result = TRUE;
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(
|
||||||
|
curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 204) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = code;
|
||||||
|
if (chunk.memory)
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
else
|
||||||
|
error->str = g_strdup("No object found");
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/*
|
||||||
|
* No object found on server. Posible synchronization
|
||||||
|
* problem or a server side race condition
|
||||||
|
*/
|
||||||
|
error->code = 409;
|
||||||
|
error->str = g_strdup("No object found");
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying a card by URI.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_modify_by_uri(carddav_settings* settings, carddav_error* error) {
|
||||||
|
CURL* curl;
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct config_data data;
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
struct curl_slist *http_header = NULL;
|
||||||
|
gchar* search;
|
||||||
|
gchar* uid;
|
||||||
|
gboolean result = FALSE;
|
||||||
|
gboolean LOCKSUPPORT = FALSE;
|
||||||
|
gchar* lock_token = NULL;
|
||||||
|
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
curl = get_curl(settings);
|
||||||
|
if (!curl) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("Could not initialize libcurl");
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: application/xml; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Depth: 1");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
data.trace_ascii = settings->trace_ascii;
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'headers' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGFUNCTION, my_trace);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_DEBUGDATA, &data);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
gchar* file = g_strdup(settings->file);
|
||||||
|
if ((uid = get_response_header("uri", file, FALSE)) == NULL) {
|
||||||
|
g_free(file);
|
||||||
|
error->code = 1;
|
||||||
|
error->str = g_strdup("Error: Missing required URI for object\nThe requested contact may not exist on the server");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
g_free(file);
|
||||||
|
|
||||||
|
/* enable uploading */
|
||||||
|
long code;
|
||||||
|
gchar* url = NULL;
|
||||||
|
gchar* etag = NULL;
|
||||||
|
url = uid;
|
||||||
|
if (url) {
|
||||||
|
gchar* host = get_host(settings->url);
|
||||||
|
if (host) {
|
||||||
|
file = g_strdup(url);
|
||||||
|
g_free(url);
|
||||||
|
url = g_strdup_printf("%s%s", host, file);
|
||||||
|
g_free(file);
|
||||||
|
g_free(host);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
g_free(url);
|
||||||
|
url = NULL;
|
||||||
|
}
|
||||||
|
if (url) {
|
||||||
|
int lock = 0;
|
||||||
|
carddav_error lock_error;
|
||||||
|
|
||||||
|
file = g_strdup(etag);
|
||||||
|
g_free(etag);
|
||||||
|
etag = g_strdup_printf("If-Match: %s", file);
|
||||||
|
g_free(file);
|
||||||
|
http_header = curl_slist_append(http_header, etag);
|
||||||
|
g_free(etag);
|
||||||
|
http_header = curl_slist_append(http_header,
|
||||||
|
"Content-Type: text/directory; charset=\"utf-8\"");
|
||||||
|
http_header = curl_slist_append(http_header, "Expect:");
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, "Transfer-Encoding:");
|
||||||
|
http_header = curl_slist_append(http_header, "Connection: close");
|
||||||
|
if (settings->use_locking)
|
||||||
|
LOCKSUPPORT = carddav_lock_support(settings, &lock_error);
|
||||||
|
else
|
||||||
|
LOCKSUPPORT = FALSE;
|
||||||
|
if (LOCKSUPPORT) {
|
||||||
|
lock_token = carddav_lock_object(url, settings, &lock_error);
|
||||||
|
if (lock_token) {
|
||||||
|
http_header = curl_slist_append(
|
||||||
|
http_header, g_strdup_printf(
|
||||||
|
"If: (%s)", lock_token));
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 423 (Resource is LOCKED) bail out
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 423) {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If error code is 501 (Not implemented) we continue
|
||||||
|
* hoping for the best.
|
||||||
|
*/
|
||||||
|
else if (lock_error.code == 501) {
|
||||||
|
lock_token = g_strdup("");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
lock = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (! LOCKSUPPORT || (LOCKSUPPORT && lock_token && lock_error.code != 423)) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, http_header);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, rebuild_url(settings, url));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, settings->file);
|
||||||
|
curl_easy_setopt (curl, CURLOPT_POSTFIELDSIZE,
|
||||||
|
strlen(settings->file));
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "PUT");
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (LOCKSUPPORT && lock_token) {
|
||||||
|
carddav_unlock_object(
|
||||||
|
lock_token, url, settings, &lock_error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_free(url);
|
||||||
|
g_free(lock_token);
|
||||||
|
if (res != 0 || lock < 0) {
|
||||||
|
/* Is this a lock_error don't change error*/
|
||||||
|
if (lock == 0 || lock_error.code == 423) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = lock_error.code;
|
||||||
|
error->str = g_strdup(lock_error.str);
|
||||||
|
}
|
||||||
|
result = TRUE;
|
||||||
|
g_free(settings->file);
|
||||||
|
settings->file = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(
|
||||||
|
curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code != 204) {
|
||||||
|
error->code = code;
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
curl_slist_free_all(http_header);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = code;
|
||||||
|
if (chunk.memory)
|
||||||
|
error->str = g_strdup(chunk.memory);
|
||||||
|
else
|
||||||
|
error->str = g_strdup("No object found");
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/*
|
||||||
|
* No object found on server. Posible synchronization
|
||||||
|
* problem or a server side race condition
|
||||||
|
*/
|
||||||
|
error->code = 409;
|
||||||
|
error->str = g_strdup("No object found");
|
||||||
|
result = TRUE;
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
return result;
|
||||||
|
}
|
@ -0,0 +1,43 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __MODIFY_CARDDAV_OBJECT_H__
|
||||||
|
#define __MODIFY_CARDDAV_OBJECT_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "carddav.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying a card.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_modify(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for modifying a card by URI.
|
||||||
|
* @param settings A pointer to carddav_settings. @see carddav_settings
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @return TRUE in case of error, FALSE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_modify_by_uri(carddav_settings* settings, carddav_error* error);
|
||||||
|
|
||||||
|
#endif
|
@ -0,0 +1,139 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "options-carddav-server.h"
|
||||||
|
#include <glib.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting supported options from a server.
|
||||||
|
* @param curl A pointer to an initialized CURL instance
|
||||||
|
* @param settings struct containing the URL to the server. If authentication
|
||||||
|
* is required prior to making the call the credentials must be available
|
||||||
|
* via CURLOPT_USERPWD before calling.
|
||||||
|
* @param result A pointer to a struct _response. If test is true
|
||||||
|
* this variable can be NULL. Caller is responsible for freeing associated
|
||||||
|
* memory.
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @param test if this is true response will be whether the server
|
||||||
|
* represented by the URL is a CardDAV collection or not.
|
||||||
|
* @return FALSE in case of error, TRUE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getoptions(CURL* curl, carddav_settings* settings, response* result,
|
||||||
|
carddav_error* error, gboolean test) {
|
||||||
|
CURLcode res = 0;
|
||||||
|
char error_buf[CURL_ERROR_SIZE];
|
||||||
|
struct MemoryStruct chunk;
|
||||||
|
struct MemoryStruct headers;
|
||||||
|
gboolean enabled = FALSE;
|
||||||
|
|
||||||
|
if (! curl)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (!error) {
|
||||||
|
error = (carddav_error *) malloc(sizeof(struct _carddav_error));
|
||||||
|
memset(error, '\0', sizeof(struct _carddav_error));
|
||||||
|
}
|
||||||
|
chunk.memory = NULL; /* we expect realloc(NULL, size) to work */
|
||||||
|
chunk.size = 0; /* no data at this point */
|
||||||
|
headers.memory = NULL;
|
||||||
|
headers.size = 0;
|
||||||
|
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, WriteHeaderCallback);
|
||||||
|
/* we pass our 'chunk' struct to the callback function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, (void *)&headers);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, (char *) &error_buf);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "OPTIONS");
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_UNRESTRICTED_AUTH, 1);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
|
||||||
|
if (settings->debug) {
|
||||||
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1);
|
||||||
|
}
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
if (res == 0) {
|
||||||
|
gchar* head;
|
||||||
|
head = get_response_header("DAV", headers.memory, TRUE);
|
||||||
|
if (head && strstr(head, "addressbook") != NULL) {
|
||||||
|
enabled = TRUE;
|
||||||
|
if (! test) {
|
||||||
|
result->msg = g_strdup(
|
||||||
|
get_response_header("Allow", headers.memory, FALSE));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
long code;
|
||||||
|
res = curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &code);
|
||||||
|
if (code == 200) {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("URL is not a CardDAV resource");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = -1 * code;
|
||||||
|
error->str = g_strdup(headers.memory);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_free(head);
|
||||||
|
}
|
||||||
|
else if (
|
||||||
|
(res == CURLE_SSL_CONNECT_ERROR ||
|
||||||
|
CURLE_PEER_FAILED_VERIFICATION ||
|
||||||
|
CURLE_SSL_ENGINE_NOTFOUND ||
|
||||||
|
CURLE_SSL_ENGINE_SETFAILED ||
|
||||||
|
CURLE_SSL_CERTPROBLEM ||
|
||||||
|
CURLE_SSL_CIPHER ||
|
||||||
|
CURLE_SSL_CACERT ||
|
||||||
|
CURLE_SSL_CACERT_BADFILE ||
|
||||||
|
CURLE_SSL_CRL_BADFILE ||
|
||||||
|
CURLE_SSL_ISSUER_ERROR) && settings->usehttps) {
|
||||||
|
error->code = -2;
|
||||||
|
error->str = g_strdup(error_buf);
|
||||||
|
}
|
||||||
|
else if (res == CURLE_COULDNT_RESOLVE_HOST) {
|
||||||
|
error->code = -3;
|
||||||
|
error->str = g_strdup("Could not resolve host");
|
||||||
|
}
|
||||||
|
else if (res == CURLE_COULDNT_CONNECT) {
|
||||||
|
error->code = -4;
|
||||||
|
error->str = g_strdup("Unable to connect");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
error->code = -1;
|
||||||
|
error->str = g_strdup("URL is not a CardDAV resource");
|
||||||
|
}
|
||||||
|
if (chunk.memory)
|
||||||
|
free(chunk.memory);
|
||||||
|
if (headers.memory)
|
||||||
|
free(headers.memory);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_CUSTOMREQUEST, "GET");
|
||||||
|
return enabled;
|
||||||
|
}
|
@ -0,0 +1,44 @@
|
|||||||
|
/* vim: set textwidth=80 tabstop=4: */
|
||||||
|
|
||||||
|
/* Copyright (c) 2010 Timothy Pearson (kb9vqf@pearsoncomputing.net)
|
||||||
|
* Copyright (c) 2008 Michael Rasmussen (mir@datanom.net)
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __OPTIONS_CARDDAV_SERVER_H__
|
||||||
|
#define __OPTIONS_CARDDAV_SERVER_H__
|
||||||
|
|
||||||
|
#include "carddav-utils.h"
|
||||||
|
#include "carddav.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function for getting supported options from a server.
|
||||||
|
* @param curl A pointer to an initialized CURL instance
|
||||||
|
* @param settings struct containing the URL to the server. If authentication
|
||||||
|
* is required prior to making the call the credentials must be available
|
||||||
|
* via CURLOPT_USERPWD before calling.
|
||||||
|
* @param result A pointer to a struct _response. If test is true
|
||||||
|
* this variable can be NULL. Caller is responsible for freeing associated
|
||||||
|
* memory.
|
||||||
|
* @param error A pointer to carddav_error. @see carddav_error
|
||||||
|
* @param test if this is true response will be whether the server
|
||||||
|
* represented by the URL is a CardDAV collection or not.
|
||||||
|
* @return FALSE in case of error, TRUE otherwise.
|
||||||
|
*/
|
||||||
|
gboolean carddav_getoptions(CURL* curl, carddav_settings* settings, response* result,
|
||||||
|
carddav_error* error, gboolean test);
|
||||||
|
|
||||||
|
#endif
|
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ "x$1" = "xLIBTOOL" ]; then
|
||||||
|
grep -m 1 libcarddav ChangeLog | awk '{print $2}' | \
|
||||||
|
cut -c2-4 | sed 's/\./:/g'
|
||||||
|
else
|
||||||
|
grep -m 1 libcarddav ChangeLog | awk '{print $2}' | cut -c2-6
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0
|
Loading…
Reference in new issue