diff options
author | Christian Grothoff <christian@grothoff.org> | 2007-01-10 04:12:34 +0000 |
---|---|---|
committer | Christian Grothoff <christian@grothoff.org> | 2007-01-10 04:12:34 +0000 |
commit | 1eecc125a9fad0676ddf0d58ce939e77787dfd17 (patch) | |
tree | 9cb574185b60e7b1bb16c852c56e7b7bcac01ca3 | |
parent | 16d0362f4f0ca069d4c5d7409ff402efbbd1d7b9 (diff) | |
download | libmicrohttpd-1eecc125a9fad0676ddf0d58ce939e77787dfd17.tar.gz libmicrohttpd-1eecc125a9fad0676ddf0d58ce939e77787dfd17.zip |
more
-rw-r--r-- | AUTHORS | 2 | ||||
-rw-r--r-- | COPYING | 340 | ||||
-rw-r--r-- | ChangeLog | 2 | ||||
-rw-r--r-- | INSTALL | 229 | ||||
-rw-r--r-- | Makefile.am | 2 | ||||
-rw-r--r-- | NEWS | 2 | ||||
-rw-r--r-- | README | 33 | ||||
-rw-r--r-- | acinclude.m4 | 60 | ||||
-rw-r--r-- | configure.ac | 3 | ||||
-rw-r--r-- | src/daemon/Makefile.am | 10 | ||||
-rw-r--r-- | src/daemon/daemontest.c | 34 | ||||
-rw-r--r-- | src/include/Makefile.am | 2 | ||||
-rw-r--r-- | src/include/microhttpd.h | 17 |
13 files changed, 725 insertions, 11 deletions
diff --git a/AUTHORS b/AUTHORS new file mode 100644 index 00000000..e01f07ab --- /dev/null +++ b/AUTHORS | |||
@@ -0,0 +1,2 @@ | |||
1 | Christian Grothoff <christian@grothoff.org> | ||
2 | Chris GauthierDickey <chrisg@cs.du.edu> | ||
diff --git a/COPYING b/COPYING new file mode 100644 index 00000000..d60c31a9 --- /dev/null +++ b/COPYING | |||
@@ -0,0 +1,340 @@ | |||
1 | GNU GENERAL PUBLIC LICENSE | ||
2 | Version 2, June 1991 | ||
3 | |||
4 | Copyright (C) 1989, 1991 Free Software Foundation, Inc. | ||
5 | 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
6 | Everyone is permitted to copy and distribute verbatim copies | ||
7 | of this license document, but changing it is not allowed. | ||
8 | |||
9 | Preamble | ||
10 | |||
11 | The licenses for most software are designed to take away your | ||
12 | freedom to share and change it. By contrast, the GNU General Public | ||
13 | License is intended to guarantee your freedom to share and change free | ||
14 | software--to make sure the software is free for all its users. This | ||
15 | General Public License applies to most of the Free Software | ||
16 | Foundation's software and to any other program whose authors commit to | ||
17 | using it. (Some other Free Software Foundation software is covered by | ||
18 | the GNU Library General Public License instead.) You can apply it to | ||
19 | your programs, too. | ||
20 | |||
21 | When we speak of free software, we are referring to freedom, not | ||
22 | price. Our General Public Licenses are designed to make sure that you | ||
23 | have the freedom to distribute copies of free software (and charge for | ||
24 | this service if you wish), that you receive source code or can get it | ||
25 | if you want it, that you can change the software or use pieces of it | ||
26 | in new free programs; and that you know you can do these things. | ||
27 | |||
28 | To protect your rights, we need to make restrictions that forbid | ||
29 | anyone to deny you these rights or to ask you to surrender the rights. | ||
30 | These restrictions translate to certain responsibilities for you if you | ||
31 | distribute copies of the software, or if you modify it. | ||
32 | |||
33 | For example, if you distribute copies of such a program, whether | ||
34 | gratis or for a fee, you must give the recipients all the rights that | ||
35 | you have. You must make sure that they, too, receive or can get the | ||
36 | source code. And you must show them these terms so they know their | ||
37 | rights. | ||
38 | |||
39 | We protect your rights with two steps: (1) copyright the software, and | ||
40 | (2) offer you this license which gives you legal permission to copy, | ||
41 | distribute and/or modify the software. | ||
42 | |||
43 | Also, for each author's protection and ours, we want to make certain | ||
44 | that everyone understands that there is no warranty for this free | ||
45 | software. If the software is modified by someone else and passed on, we | ||
46 | want its recipients to know that what they have is not the original, so | ||
47 | that any problems introduced by others will not reflect on the original | ||
48 | authors' reputations. | ||
49 | |||
50 | Finally, any free program is threatened constantly by software | ||
51 | patents. We wish to avoid the danger that redistributors of a free | ||
52 | program will individually obtain patent licenses, in effect making the | ||
53 | program proprietary. To prevent this, we have made it clear that any | ||
54 | patent must be licensed for everyone's free use or not licensed at all. | ||
55 | |||
56 | The precise terms and conditions for copying, distribution and | ||
57 | modification follow. | ||
58 | |||
59 | GNU GENERAL PUBLIC LICENSE | ||
60 | TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION | ||
61 | |||
62 | 0. This License applies to any program or other work which contains | ||
63 | a notice placed by the copyright holder saying it may be distributed | ||
64 | under the terms of this General Public License. The "Program", below, | ||
65 | refers to any such program or work, and a "work based on the Program" | ||
66 | means either the Program or any derivative work under copyright law: | ||
67 | that is to say, a work containing the Program or a portion of it, | ||
68 | either verbatim or with modifications and/or translated into another | ||
69 | language. (Hereinafter, translation is included without limitation in | ||
70 | the term "modification".) Each licensee is addressed as "you". | ||
71 | |||
72 | Activities other than copying, distribution and modification are not | ||
73 | covered by this License; they are outside its scope. The act of | ||
74 | running the Program is not restricted, and the output from the Program | ||
75 | is covered only if its contents constitute a work based on the | ||
76 | Program (independent of having been made by running the Program). | ||
77 | Whether that is true depends on what the Program does. | ||
78 | |||
79 | 1. You may copy and distribute verbatim copies of the Program's | ||
80 | source code as you receive it, in any medium, provided that you | ||
81 | conspicuously and appropriately publish on each copy an appropriate | ||
82 | copyright notice and disclaimer of warranty; keep intact all the | ||
83 | notices that refer to this License and to the absence of any warranty; | ||
84 | and give any other recipients of the Program a copy of this License | ||
85 | along with the Program. | ||
86 | |||
87 | You may charge a fee for the physical act of transferring a copy, and | ||
88 | you may at your option offer warranty protection in exchange for a fee. | ||
89 | |||
90 | 2. You may modify your copy or copies of the Program or any portion | ||
91 | of it, thus forming a work based on the Program, and copy and | ||
92 | distribute such modifications or work under the terms of Section 1 | ||
93 | above, provided that you also meet all of these conditions: | ||
94 | |||
95 | a) You must cause the modified files to carry prominent notices | ||
96 | stating that you changed the files and the date of any change. | ||
97 | |||
98 | b) You must cause any work that you distribute or publish, that in | ||
99 | whole or in part contains or is derived from the Program or any | ||
100 | part thereof, to be licensed as a whole at no charge to all third | ||
101 | parties under the terms of this License. | ||
102 | |||
103 | c) If the modified program normally reads commands interactively | ||
104 | when run, you must cause it, when started running for such | ||
105 | interactive use in the most ordinary way, to print or display an | ||
106 | announcement including an appropriate copyright notice and a | ||
107 | notice that there is no warranty (or else, saying that you provide | ||
108 | a warranty) and that users may redistribute the program under | ||
109 | these conditions, and telling the user how to view a copy of this | ||
110 | License. (Exception: if the Program itself is interactive but | ||
111 | does not normally print such an announcement, your work based on | ||
112 | the Program is not required to print an announcement.) | ||
113 | |||
114 | These requirements apply to the modified work as a whole. If | ||
115 | identifiable sections of that work are not derived from the Program, | ||
116 | and can be reasonably considered independent and separate works in | ||
117 | themselves, then this License, and its terms, do not apply to those | ||
118 | sections when you distribute them as separate works. But when you | ||
119 | distribute the same sections as part of a whole which is a work based | ||
120 | on the Program, the distribution of the whole must be on the terms of | ||
121 | this License, whose permissions for other licensees extend to the | ||
122 | entire whole, and thus to each and every part regardless of who wrote it. | ||
123 | |||
124 | Thus, it is not the intent of this section to claim rights or contest | ||
125 | your rights to work written entirely by you; rather, the intent is to | ||
126 | exercise the right to control the distribution of derivative or | ||
127 | collective works based on the Program. | ||
128 | |||
129 | In addition, mere aggregation of another work not based on the Program | ||
130 | with the Program (or with a work based on the Program) on a volume of | ||
131 | a storage or distribution medium does not bring the other work under | ||
132 | the scope of this License. | ||
133 | |||
134 | 3. You may copy and distribute the Program (or a work based on it, | ||
135 | under Section 2) in object code or executable form under the terms of | ||
136 | Sections 1 and 2 above provided that you also do one of the following: | ||
137 | |||
138 | a) Accompany it with the complete corresponding machine-readable | ||
139 | source code, which must be distributed under the terms of Sections | ||
140 | 1 and 2 above on a medium customarily used for software interchange; or, | ||
141 | |||
142 | b) Accompany it with a written offer, valid for at least three | ||
143 | years, to give any third party, for a charge no more than your | ||
144 | cost of physically performing source distribution, a complete | ||
145 | machine-readable copy of the corresponding source code, to be | ||
146 | distributed under the terms of Sections 1 and 2 above on a medium | ||
147 | customarily used for software interchange; or, | ||
148 | |||
149 | c) Accompany it with the information you received as to the offer | ||
150 | to distribute corresponding source code. (This alternative is | ||
151 | allowed only for noncommercial distribution and only if you | ||
152 | received the program in object code or executable form with such | ||
153 | an offer, in accord with Subsection b above.) | ||
154 | |||
155 | The source code for a work means the preferred form of the work for | ||
156 | making modifications to it. For an executable work, complete source | ||
157 | code means all the source code for all modules it contains, plus any | ||
158 | associated interface definition files, plus the scripts used to | ||
159 | control compilation and installation of the executable. However, as a | ||
160 | special exception, the source code distributed need not include | ||
161 | anything that is normally distributed (in either source or binary | ||
162 | form) with the major components (compiler, kernel, and so on) of the | ||
163 | operating system on which the executable runs, unless that component | ||
164 | itself accompanies the executable. | ||
165 | |||
166 | If distribution of executable or object code is made by offering | ||
167 | access to copy from a designated place, then offering equivalent | ||
168 | access to copy the source code from the same place counts as | ||
169 | distribution of the source code, even though third parties are not | ||
170 | compelled to copy the source along with the object code. | ||
171 | |||
172 | 4. You may not copy, modify, sublicense, or distribute the Program | ||
173 | except as expressly provided under this License. Any attempt | ||
174 | otherwise to copy, modify, sublicense or distribute the Program is | ||
175 | void, and will automatically terminate your rights under this License. | ||
176 | However, parties who have received copies, or rights, from you under | ||
177 | this License will not have their licenses terminated so long as such | ||
178 | parties remain in full compliance. | ||
179 | |||
180 | 5. You are not required to accept this License, since you have not | ||
181 | signed it. However, nothing else grants you permission to modify or | ||
182 | distribute the Program or its derivative works. These actions are | ||
183 | prohibited by law if you do not accept this License. Therefore, by | ||
184 | modifying or distributing the Program (or any work based on the | ||
185 | Program), you indicate your acceptance of this License to do so, and | ||
186 | all its terms and conditions for copying, distributing or modifying | ||
187 | the Program or works based on it. | ||
188 | |||
189 | 6. Each time you redistribute the Program (or any work based on the | ||
190 | Program), the recipient automatically receives a license from the | ||
191 | original licensor to copy, distribute or modify the Program subject to | ||
192 | these terms and conditions. You may not impose any further | ||
193 | restrictions on the recipients' exercise of the rights granted herein. | ||
194 | You are not responsible for enforcing compliance by third parties to | ||
195 | this License. | ||
196 | |||
197 | 7. If, as a consequence of a court judgment or allegation of patent | ||
198 | infringement or for any other reason (not limited to patent issues), | ||
199 | conditions are imposed on you (whether by court order, agreement or | ||
200 | otherwise) that contradict the conditions of this License, they do not | ||
201 | excuse you from the conditions of this License. If you cannot | ||
202 | distribute so as to satisfy simultaneously your obligations under this | ||
203 | License and any other pertinent obligations, then as a consequence you | ||
204 | may not distribute the Program at all. For example, if a patent | ||
205 | license would not permit royalty-free redistribution of the Program by | ||
206 | all those who receive copies directly or indirectly through you, then | ||
207 | the only way you could satisfy both it and this License would be to | ||
208 | refrain entirely from distribution of the Program. | ||
209 | |||
210 | If any portion of this section is held invalid or unenforceable under | ||
211 | any particular circumstance, the balance of the section is intended to | ||
212 | apply and the section as a whole is intended to apply in other | ||
213 | circumstances. | ||
214 | |||
215 | It is not the purpose of this section to induce you to infringe any | ||
216 | patents or other property right claims or to contest validity of any | ||
217 | such claims; this section has the sole purpose of protecting the | ||
218 | integrity of the free software distribution system, which is | ||
219 | implemented by public license practices. Many people have made | ||
220 | generous contributions to the wide range of software distributed | ||
221 | through that system in reliance on consistent application of that | ||
222 | system; it is up to the author/donor to decide if he or she is willing | ||
223 | to distribute software through any other system and a licensee cannot | ||
224 | impose that choice. | ||
225 | |||
226 | This section is intended to make thoroughly clear what is believed to | ||
227 | be a consequence of the rest of this License. | ||
228 | |||
229 | 8. If the distribution and/or use of the Program is restricted in | ||
230 | certain countries either by patents or by copyrighted interfaces, the | ||
231 | original copyright holder who places the Program under this License | ||
232 | may add an explicit geographical distribution limitation excluding | ||
233 | those countries, so that distribution is permitted only in or among | ||
234 | countries not thus excluded. In such case, this License incorporates | ||
235 | the limitation as if written in the body of this License. | ||
236 | |||
237 | 9. The Free Software Foundation may publish revised and/or new versions | ||
238 | of the General Public License from time to time. Such new versions will | ||
239 | be similar in spirit to the present version, but may differ in detail to | ||
240 | address new problems or concerns. | ||
241 | |||
242 | Each version is given a distinguishing version number. If the Program | ||
243 | specifies a version number of this License which applies to it and "any | ||
244 | later version", you have the option of following the terms and conditions | ||
245 | either of that version or of any later version published by the Free | ||
246 | Software Foundation. If the Program does not specify a version number of | ||
247 | this License, you may choose any version ever published by the Free Software | ||
248 | Foundation. | ||
249 | |||
250 | 10. If you wish to incorporate parts of the Program into other free | ||
251 | programs whose distribution conditions are different, write to the author | ||
252 | to ask for permission. For software which is copyrighted by the Free | ||
253 | Software Foundation, write to the Free Software Foundation; we sometimes | ||
254 | make exceptions for this. Our decision will be guided by the two goals | ||
255 | of preserving the free status of all derivatives of our free software and | ||
256 | of promoting the sharing and reuse of software generally. | ||
257 | |||
258 | NO WARRANTY | ||
259 | |||
260 | 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY | ||
261 | FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN | ||
262 | OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES | ||
263 | PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED | ||
264 | OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||
265 | MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS | ||
266 | TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE | ||
267 | PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, | ||
268 | REPAIR OR CORRECTION. | ||
269 | |||
270 | 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING | ||
271 | WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR | ||
272 | REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, | ||
273 | INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING | ||
274 | OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED | ||
275 | TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY | ||
276 | YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER | ||
277 | PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE | ||
278 | POSSIBILITY OF SUCH DAMAGES. | ||
279 | |||
280 | END OF TERMS AND CONDITIONS | ||
281 | |||
282 | How to Apply These Terms to Your New Programs | ||
283 | |||
284 | If you develop a new program, and you want it to be of the greatest | ||
285 | possible use to the public, the best way to achieve this is to make it | ||
286 | free software which everyone can redistribute and change under these terms. | ||
287 | |||
288 | To do so, attach the following notices to the program. It is safest | ||
289 | to attach them to the start of each source file to most effectively | ||
290 | convey the exclusion of warranty; and each file should have at least | ||
291 | the "copyright" line and a pointer to where the full notice is found. | ||
292 | |||
293 | <one line to give the program's name and a brief idea of what it does.> | ||
294 | Copyright (C) <year> <name of author> | ||
295 | |||
296 | This program is free software; you can redistribute it and/or modify | ||
297 | it under the terms of the GNU General Public License as published by | ||
298 | the Free Software Foundation; either version 2 of the License, or | ||
299 | (at your option) any later version. | ||
300 | |||
301 | This program is distributed in the hope that it will be useful, | ||
302 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
303 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
304 | GNU General Public License for more details. | ||
305 | |||
306 | You should have received a copy of the GNU General Public License | ||
307 | along with this program; if not, write to the Free Software | ||
308 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
309 | |||
310 | |||
311 | Also add information on how to contact you by electronic and paper mail. | ||
312 | |||
313 | If the program is interactive, make it output a short notice like this | ||
314 | when it starts in an interactive mode: | ||
315 | |||
316 | Gnomovision version 69, Copyright (C) year name of author | ||
317 | Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. | ||
318 | This is free software, and you are welcome to redistribute it | ||
319 | under certain conditions; type `show c' for details. | ||
320 | |||
321 | The hypothetical commands `show w' and `show c' should show the appropriate | ||
322 | parts of the General Public License. Of course, the commands you use may | ||
323 | be called something other than `show w' and `show c'; they could even be | ||
324 | mouse-clicks or menu items--whatever suits your program. | ||
325 | |||
326 | You should also get your employer (if you work as a programmer) or your | ||
327 | school, if any, to sign a "copyright disclaimer" for the program, if | ||
328 | necessary. Here is a sample; alter the names: | ||
329 | |||
330 | Yoyodyne, Inc., hereby disclaims all copyright interest in the program | ||
331 | `Gnomovision' (which makes passes at compilers) written by James Hacker. | ||
332 | |||
333 | <signature of Ty Coon>, 1 April 1989 | ||
334 | Ty Coon, President of Vice | ||
335 | |||
336 | This General Public License does not permit incorporating your program into | ||
337 | proprietary programs. If your program is a subroutine library, you may | ||
338 | consider it more useful to permit linking proprietary applications with the | ||
339 | library. If this is what you want to do, use the GNU Library General | ||
340 | Public License instead of this License. | ||
diff --git a/ChangeLog b/ChangeLog new file mode 100644 index 00000000..d9e63f27 --- /dev/null +++ b/ChangeLog | |||
@@ -0,0 +1,2 @@ | |||
1 | Tue Jan 9 20:52:48 MST 2007 | ||
2 | Created project build files and updated API. - CG | ||
diff --git a/INSTALL b/INSTALL new file mode 100644 index 00000000..54caf7c1 --- /dev/null +++ b/INSTALL | |||
@@ -0,0 +1,229 @@ | |||
1 | Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002 Free Software | ||
2 | Foundation, Inc. | ||
3 | |||
4 | This file is free documentation; the Free Software Foundation gives | ||
5 | unlimited permission to copy, distribute and modify it. | ||
6 | |||
7 | Basic Installation | ||
8 | ================== | ||
9 | |||
10 | These are generic installation instructions. | ||
11 | |||
12 | The `configure' shell script attempts to guess correct values for | ||
13 | various system-dependent variables used during compilation. It uses | ||
14 | those values to create a `Makefile' in each directory of the package. | ||
15 | It may also create one or more `.h' files containing system-dependent | ||
16 | definitions. Finally, it creates a shell script `config.status' that | ||
17 | you can run in the future to recreate the current configuration, and a | ||
18 | file `config.log' containing compiler output (useful mainly for | ||
19 | debugging `configure'). | ||
20 | |||
21 | It can also use an optional file (typically called `config.cache' | ||
22 | and enabled with `--cache-file=config.cache' or simply `-C') that saves | ||
23 | the results of its tests to speed up reconfiguring. (Caching is | ||
24 | disabled by default to prevent problems with accidental use of stale | ||
25 | cache files.) | ||
26 | |||
27 | If you need to do unusual things to compile the package, please try | ||
28 | to figure out how `configure' could check whether to do them, and mail | ||
29 | diffs or instructions to the address given in the `README' so they can | ||
30 | be considered for the next release. If you are using the cache, and at | ||
31 | some point `config.cache' contains results you don't want to keep, you | ||
32 | may remove or edit it. | ||
33 | |||
34 | The file `configure.ac' (or `configure.in') is used to create | ||
35 | `configure' by a program called `autoconf'. You only need | ||
36 | `configure.ac' if you want to change it or regenerate `configure' using | ||
37 | a newer version of `autoconf'. | ||
38 | |||
39 | The simplest way to compile this package is: | ||
40 | |||
41 | 1. `cd' to the directory containing the package's source code and type | ||
42 | `./configure' to configure the package for your system. If you're | ||
43 | using `csh' on an old version of System V, you might need to type | ||
44 | `sh ./configure' instead to prevent `csh' from trying to execute | ||
45 | `configure' itself. | ||
46 | |||
47 | Running `configure' takes awhile. While running, it prints some | ||
48 | messages telling which features it is checking for. | ||
49 | |||
50 | 2. Type `make' to compile the package. | ||
51 | |||
52 | 3. Optionally, type `make check' to run any self-tests that come with | ||
53 | the package. | ||
54 | |||
55 | 4. Type `make install' to install the programs and any data files and | ||
56 | documentation. | ||
57 | |||
58 | 5. You can remove the program binaries and object files from the | ||
59 | source code directory by typing `make clean'. To also remove the | ||
60 | files that `configure' created (so you can compile the package for | ||
61 | a different kind of computer), type `make distclean'. There is | ||
62 | also a `make maintainer-clean' target, but that is intended mainly | ||
63 | for the package's developers. If you use it, you may have to get | ||
64 | all sorts of other programs in order to regenerate files that came | ||
65 | with the distribution. | ||
66 | |||
67 | Compilers and Options | ||
68 | ===================== | ||
69 | |||
70 | Some systems require unusual options for compilation or linking that | ||
71 | the `configure' script does not know about. Run `./configure --help' | ||
72 | for details on some of the pertinent environment variables. | ||
73 | |||
74 | You can give `configure' initial values for configuration parameters | ||
75 | by setting variables in the command line or in the environment. Here | ||
76 | is an example: | ||
77 | |||
78 | ./configure CC=c89 CFLAGS=-O2 LIBS=-lposix | ||
79 | |||
80 | *Note Defining Variables::, for more details. | ||
81 | |||
82 | Compiling For Multiple Architectures | ||
83 | ==================================== | ||
84 | |||
85 | You can compile the package for more than one kind of computer at the | ||
86 | same time, by placing the object files for each architecture in their | ||
87 | own directory. To do this, you must use a version of `make' that | ||
88 | supports the `VPATH' variable, such as GNU `make'. `cd' to the | ||
89 | directory where you want the object files and executables to go and run | ||
90 | the `configure' script. `configure' automatically checks for the | ||
91 | source code in the directory that `configure' is in and in `..'. | ||
92 | |||
93 | If you have to use a `make' that does not support the `VPATH' | ||
94 | variable, you have to compile the package for one architecture at a | ||
95 | time in the source code directory. After you have installed the | ||
96 | package for one architecture, use `make distclean' before reconfiguring | ||
97 | for another architecture. | ||
98 | |||
99 | Installation Names | ||
100 | ================== | ||
101 | |||
102 | By default, `make install' will install the package's files in | ||
103 | `/usr/local/bin', `/usr/local/man', etc. You can specify an | ||
104 | installation prefix other than `/usr/local' by giving `configure' the | ||
105 | option `--prefix=PATH'. | ||
106 | |||
107 | You can specify separate installation prefixes for | ||
108 | architecture-specific files and architecture-independent files. If you | ||
109 | give `configure' the option `--exec-prefix=PATH', the package will use | ||
110 | PATH as the prefix for installing programs and libraries. | ||
111 | Documentation and other data files will still use the regular prefix. | ||
112 | |||
113 | In addition, if you use an unusual directory layout you can give | ||
114 | options like `--bindir=PATH' to specify different values for particular | ||
115 | kinds of files. Run `configure --help' for a list of the directories | ||
116 | you can set and what kinds of files go in them. | ||
117 | |||
118 | If the package supports it, you can cause programs to be installed | ||
119 | with an extra prefix or suffix on their names by giving `configure' the | ||
120 | option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'. | ||
121 | |||
122 | Optional Features | ||
123 | ================= | ||
124 | |||
125 | Some packages pay attention to `--enable-FEATURE' options to | ||
126 | `configure', where FEATURE indicates an optional part of the package. | ||
127 | They may also pay attention to `--with-PACKAGE' options, where PACKAGE | ||
128 | is something like `gnu-as' or `x' (for the X Window System). The | ||
129 | `README' should mention any `--enable-' and `--with-' options that the | ||
130 | package recognizes. | ||
131 | |||
132 | For packages that use the X Window System, `configure' can usually | ||
133 | find the X include and library files automatically, but if it doesn't, | ||
134 | you can use the `configure' options `--x-includes=DIR' and | ||
135 | `--x-libraries=DIR' to specify their locations. | ||
136 | |||
137 | Specifying the System Type | ||
138 | ========================== | ||
139 | |||
140 | There may be some features `configure' cannot figure out | ||
141 | automatically, but needs to determine by the type of machine the package | ||
142 | will run on. Usually, assuming the package is built to be run on the | ||
143 | _same_ architectures, `configure' can figure that out, but if it prints | ||
144 | a message saying it cannot guess the machine type, give it the | ||
145 | `--build=TYPE' option. TYPE can either be a short name for the system | ||
146 | type, such as `sun4', or a canonical name which has the form: | ||
147 | |||
148 | CPU-COMPANY-SYSTEM | ||
149 | |||
150 | where SYSTEM can have one of these forms: | ||
151 | |||
152 | OS KERNEL-OS | ||
153 | |||
154 | See the file `config.sub' for the possible values of each field. If | ||
155 | `config.sub' isn't included in this package, then this package doesn't | ||
156 | need to know the machine type. | ||
157 | |||
158 | If you are _building_ compiler tools for cross-compiling, you should | ||
159 | use the `--target=TYPE' option to select the type of system they will | ||
160 | produce code for. | ||
161 | |||
162 | If you want to _use_ a cross compiler, that generates code for a | ||
163 | platform different from the build platform, you should specify the | ||
164 | "host" platform (i.e., that on which the generated programs will | ||
165 | eventually be run) with `--host=TYPE'. | ||
166 | |||
167 | Sharing Defaults | ||
168 | ================ | ||
169 | |||
170 | If you want to set default values for `configure' scripts to share, | ||
171 | you can create a site shell script called `config.site' that gives | ||
172 | default values for variables like `CC', `cache_file', and `prefix'. | ||
173 | `configure' looks for `PREFIX/share/config.site' if it exists, then | ||
174 | `PREFIX/etc/config.site' if it exists. Or, you can set the | ||
175 | `CONFIG_SITE' environment variable to the location of the site script. | ||
176 | A warning: not all `configure' scripts look for a site script. | ||
177 | |||
178 | Defining Variables | ||
179 | ================== | ||
180 | |||
181 | Variables not defined in a site shell script can be set in the | ||
182 | environment passed to `configure'. However, some packages may run | ||
183 | configure again during the build, and the customized values of these | ||
184 | variables may be lost. In order to avoid this problem, you should set | ||
185 | them in the `configure' command line, using `VAR=value'. For example: | ||
186 | |||
187 | ./configure CC=/usr/local2/bin/gcc | ||
188 | |||
189 | will cause the specified gcc to be used as the C compiler (unless it is | ||
190 | overridden in the site shell script). | ||
191 | |||
192 | `configure' Invocation | ||
193 | ====================== | ||
194 | |||
195 | `configure' recognizes the following options to control how it | ||
196 | operates. | ||
197 | |||
198 | `--help' | ||
199 | `-h' | ||
200 | Print a summary of the options to `configure', and exit. | ||
201 | |||
202 | `--version' | ||
203 | `-V' | ||
204 | Print the version of Autoconf used to generate the `configure' | ||
205 | script, and exit. | ||
206 | |||
207 | `--cache-file=FILE' | ||
208 | Enable the cache: use and save the results of the tests in FILE, | ||
209 | traditionally `config.cache'. FILE defaults to `/dev/null' to | ||
210 | disable caching. | ||
211 | |||
212 | `--config-cache' | ||
213 | `-C' | ||
214 | Alias for `--cache-file=config.cache'. | ||
215 | |||
216 | `--quiet' | ||
217 | `--silent' | ||
218 | `-q' | ||
219 | Do not print messages saying which checks are being made. To | ||
220 | suppress all normal output, redirect it to `/dev/null' (any error | ||
221 | messages will still be shown). | ||
222 | |||
223 | `--srcdir=DIR' | ||
224 | Look for the package's source code in directory DIR. Usually | ||
225 | `configure' can determine that directory automatically. | ||
226 | |||
227 | `configure' also accepts some other, not widely useful, options. Run | ||
228 | `configure --help' for more details. | ||
229 | |||
diff --git a/Makefile.am b/Makefile.am index 5619ed9b..1afb2e49 100644 --- a/Makefile.am +++ b/Makefile.am | |||
@@ -1 +1,3 @@ | |||
1 | SUBDIRS = src doc . | 1 | SUBDIRS = src doc . |
2 | EXTRA_DIST = acinclude.m4 | ||
3 | |||
@@ -0,0 +1,2 @@ | |||
1 | Tue Jan 9 20:52:48 MST 2007 | ||
2 | Project posted. | ||
@@ -0,0 +1,33 @@ | |||
1 | Run "autoreconf -f -i" to create configure. | ||
2 | |||
3 | Talk to Christian or Chris if you have problems | ||
4 | with the build system or do not understand the | ||
5 | API. We can also help discuss implementation | ||
6 | choices. | ||
7 | |||
8 | |||
9 | |||
10 | Your project will be graded using the following | ||
11 | criteria: | ||
12 | |||
13 | 1) correctness | ||
14 | a) HTTP 1.1 compliance | ||
15 | b) no bugs / crashes | ||
16 | c) interoperability (firefox, IE, konqueror, | ||
17 | squid, libcurl, wget) | ||
18 | d) memory leaks | ||
19 | 2) completeness | ||
20 | a) all API functions | ||
21 | b) all options (except SSL) | ||
22 | c) portability (Linux, Solaris) | ||
23 | 2) performance | ||
24 | a) memory consumption | ||
25 | b) throughput (small and large transfers) | ||
26 | c) latency | ||
27 | d) performance with 1000 parallel sessions | ||
28 | 3) software engineering practice (subjective) | ||
29 | a) code quality | ||
30 | b) comprehensive testcases | ||
31 | c) documentation | ||
32 | |||
33 | \ No newline at end of file | ||
diff --git a/acinclude.m4 b/acinclude.m4 new file mode 100644 index 00000000..c9aa0f60 --- /dev/null +++ b/acinclude.m4 | |||
@@ -0,0 +1,60 @@ | |||
1 | # See: http://gcc.gnu.org/ml/gcc/2000-05/msg01141.html | ||
2 | AC_DEFUN([CHECK_PTHREAD], | ||
3 | [ | ||
4 | AC_CHECK_LIB(pthread,pthread_create, | ||
5 | [ | ||
6 | PTHREAD_CPPFLAGS= | ||
7 | PTHREAD_LDFLAGS= | ||
8 | PTHREAD_LIBS=-lpthread | ||
9 | ],[ | ||
10 | AC_MSG_CHECKING(if compiler supports -pthread) | ||
11 | save_CPPFLAGS="$CPPFLAGS" | ||
12 | CPPFLAGS="$CPPFLAGS -pthread" | ||
13 | AC_TRY_LINK( | ||
14 | [ | ||
15 | #include <pthread.h> | ||
16 | ],[ | ||
17 | pthread_create(0,0,0,0); | ||
18 | ],[ | ||
19 | AC_MSG_RESULT(yes) | ||
20 | PTHREAD_CPPFLAGS=-pthread | ||
21 | PTHREAD_LDFLAGS=-pthread | ||
22 | PTHREAD_LIBS= | ||
23 | ],[ | ||
24 | AC_MSG_RESULT(no) | ||
25 | AC_MSG_CHECKING(if compiler supports -pthreads) | ||
26 | save_CPPFLAGS="$CPPFLAGS" | ||
27 | CPPFLAGS="$save_CPPFLAGS -pthreads" | ||
28 | AC_TRY_LINK( | ||
29 | [ | ||
30 | #include <pthread.h> | ||
31 | ],[ | ||
32 | pthread_create(0,0,0,0); | ||
33 | ],[ | ||
34 | AC_MSG_RESULT(yes) | ||
35 | PTHREAD_CPPFLAGS=-pthreads | ||
36 | PTHREAD_LDFLAGS=-pthreads | ||
37 | PTHREAD_LIBS= | ||
38 | ],[ | ||
39 | AC_MSG_RESULT(no) | ||
40 | AC_MSG_CHECKING(if compiler supports -threads) | ||
41 | save_CPPFLAGS="$CPPFLAGS" | ||
42 | CPPFLAGS="$save_CPPFLAGS -threads" | ||
43 | AC_TRY_LINK( | ||
44 | [ | ||
45 | #include <pthread.h> | ||
46 | ],[ | ||
47 | pthread_create(0,0,0,0); | ||
48 | ],[ | ||
49 | AC_MSG_RESULT(yes) | ||
50 | PTHREAD_CPPFLAGS=-threads | ||
51 | PTHREAD_LDFLAGS=-threads | ||
52 | PTHREAD_LIBS= | ||
53 | ],[ | ||
54 | AC_MSG_ERROR([Your system is not supporting pthreads!]) | ||
55 | ]) | ||
56 | ]) | ||
57 | ]) | ||
58 | CPPFLAGS="$save_CPPFLAGS" | ||
59 | ]) | ||
60 | ]) | ||
diff --git a/configure.ac b/configure.ac index c71478e8..a8efb242 100644 --- a/configure.ac +++ b/configure.ac | |||
@@ -30,7 +30,6 @@ AH_TOP([#define _GNU_SOURCE 1]) | |||
30 | # Checks for programs. | 30 | # Checks for programs. |
31 | AC_PROG_AWK | 31 | AC_PROG_AWK |
32 | AC_PROG_CC | 32 | AC_PROG_CC |
33 | AC_PROG_CPP | ||
34 | AC_PROG_INSTALL | 33 | AC_PROG_INSTALL |
35 | AC_PROG_LN_S | 34 | AC_PROG_LN_S |
36 | AC_PROG_MAKE_SET | 35 | AC_PROG_MAKE_SET |
@@ -106,7 +105,7 @@ AC_CHECK_MEMBER(pthread_t.p, AC_DEFINE(HAVE_NEW_PTHREAD_T, 1, | |||
106 | SAVE_LIBS=$LIBS | 105 | SAVE_LIBS=$LIBS |
107 | LIBCURL_CHECK_CONFIG(,,curl=1,curl=0) | 106 | LIBCURL_CHECK_CONFIG(,,curl=1,curl=0) |
108 | AM_CONDITIONAL(HAVE_CURL, test x$curl = x1) | 107 | AM_CONDITIONAL(HAVE_CURL, test x$curl = x1) |
109 | $LIBS=$SAVE_LIBS | 108 | LIBS=$SAVE_LIBS |
110 | 109 | ||
111 | 110 | ||
112 | # large file support (> 4 GB) | 111 | # large file support (> 4 GB) |
diff --git a/src/daemon/Makefile.am b/src/daemon/Makefile.am index fcc2c495..fb9b098e 100644 --- a/src/daemon/Makefile.am +++ b/src/daemon/Makefile.am | |||
@@ -16,11 +16,13 @@ libmicrohttpd_la_SOURCES = \ | |||
16 | if HAVE_CURL | 16 | if HAVE_CURL |
17 | 17 | ||
18 | check_PROGRAMS = \ | 18 | check_PROGRAMS = \ |
19 | testdaemon | 19 | daemontest |
20 | 20 | ||
21 | test_daemon_SOURCES = \ | 21 | TESTS = $(check_PROGRAMS) |
22 | testdaemon.c | 22 | |
23 | test_daemon_LDADD = \ | 23 | daemontest_SOURCES = \ |
24 | daemontest.c | ||
25 | daemontest_LDADD = \ | ||
24 | $(top_builddir)/src/daemon/libmicrohttpd.la \ | 26 | $(top_builddir)/src/daemon/libmicrohttpd.la \ |
25 | @LIBCURL@ | 27 | @LIBCURL@ |
26 | 28 | ||
diff --git a/src/daemon/daemontest.c b/src/daemon/daemontest.c new file mode 100644 index 00000000..1b36e64f --- /dev/null +++ b/src/daemon/daemontest.c | |||
@@ -0,0 +1,34 @@ | |||
1 | /* | ||
2 | This file is part of libmicrohttpd | ||
3 | (C) 2007 YOUR NAME HERE | ||
4 | |||
5 | libmicrohttpd is free software; you can redistribute it and/or modify | ||
6 | it under the terms of the GNU General Public License as published | ||
7 | by the Free Software Foundation; either version 2, or (at your | ||
8 | option) any later version. | ||
9 | |||
10 | libmicrohttpd is distributed in the hope that it will be useful, but | ||
11 | WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
13 | General Public License for more details. | ||
14 | |||
15 | You should have received a copy of the GNU General Public License | ||
16 | along with libmicrohttpd; see the file COPYING. If not, write to the | ||
17 | Free Software Foundation, Inc., 59 Temple Place - Suite 330, | ||
18 | Boston, MA 02111-1307, USA. | ||
19 | */ | ||
20 | |||
21 | /** | ||
22 | * @file daemontest.c | ||
23 | * @brief Testcase for libmicrohttpd | ||
24 | * @author FIXME | ||
25 | */ | ||
26 | |||
27 | #include "config.h" | ||
28 | #include "microhttpd.h" | ||
29 | |||
30 | |||
31 | int main(int argc, | ||
32 | char * const * argv) { | ||
33 | return 0; /* 0 == pass */ | ||
34 | } | ||
diff --git a/src/include/Makefile.am b/src/include/Makefile.am new file mode 100644 index 00000000..c01b7979 --- /dev/null +++ b/src/include/Makefile.am | |||
@@ -0,0 +1,2 @@ | |||
1 | SUBDIRS = . | ||
2 | include_HEADERS = microhttpd.h | ||
diff --git a/src/include/microhttpd.h b/src/include/microhttpd.h index a17f41f2..13dd71e4 100644 --- a/src/include/microhttpd.h +++ b/src/include/microhttpd.h | |||
@@ -22,6 +22,7 @@ | |||
22 | * @file microhttpd.h | 22 | * @file microhttpd.h |
23 | * @brief public interface to libmicrohttpd | 23 | * @brief public interface to libmicrohttpd |
24 | * @author Christian Grothoff | 24 | * @author Christian Grothoff |
25 | * @author Chris GauthierDickey | ||
25 | * | 26 | * |
26 | * All symbols defined in this header start with MHD. MHD is a | 27 | * All symbols defined in this header start with MHD. MHD is a |
27 | * micro-httpd library. As such, it does not have any API for logging | 28 | * micro-httpd library. As such, it does not have any API for logging |
@@ -34,6 +35,12 @@ | |||
34 | * - proper API for file uploads via HTTP | 35 | * - proper API for file uploads via HTTP |
35 | * - We probably need a significantly more extensive API for | 36 | * - We probably need a significantly more extensive API for |
36 | * proper SSL support (set local certificate, etc.) | 37 | * proper SSL support (set local certificate, etc.) |
38 | * | ||
39 | * | ||
40 | * | ||
41 | * Students are encouraged to add additional HTTP status codes to this | ||
42 | * file, but should not change anything else. If you think something | ||
43 | * needs to be changed, talk to your instructor first. | ||
37 | */ | 44 | */ |
38 | 45 | ||
39 | #ifndef MHD_MICROHTTPD_H | 46 | #ifndef MHD_MICROHTTPD_H |
@@ -123,27 +130,27 @@ enum MHD_ValueKind { | |||
123 | /** | 130 | /** |
124 | * Response header | 131 | * Response header |
125 | */ | 132 | */ |
126 | MHD_RESPONSE_HEADER_KIND = 0; | 133 | MHD_RESPONSE_HEADER_KIND = 0, |
127 | 134 | ||
128 | /** | 135 | /** |
129 | * HTTP header | 136 | * HTTP header |
130 | */ | 137 | */ |
131 | MHD_HEADER_KIND = 1; | 138 | MHD_HEADER_KIND = 1, |
132 | 139 | ||
133 | /** | 140 | /** |
134 | * Cookies | 141 | * Cookies |
135 | */ | 142 | */ |
136 | MHD_COOKIE_KIND = 2; | 143 | MHD_COOKIE_KIND = 2, |
137 | 144 | ||
138 | /** | 145 | /** |
139 | * POST data | 146 | * POST data |
140 | */ | 147 | */ |
141 | MHD_POSTDATA_KIND = 4; | 148 | MHD_POSTDATA_KIND = 4, |
142 | 149 | ||
143 | /** | 150 | /** |
144 | * GET (URI) arguments | 151 | * GET (URI) arguments |
145 | */ | 152 | */ |
146 | MHD_GET_ARGUMENT_KIND = 8; | 153 | MHD_GET_ARGUMENT_KIND = 8, |
147 | 154 | ||
148 | }; | 155 | }; |
149 | 156 | ||