Hex Artifact Content

Artifact 460b9a234ec45e617ea315e1a54c595075f42365:


0000: 23 69 6e 63 6c 75 64 65 20 3c 73 79 73 2f 73 65  #include <sys/se
0010: 6e 64 66 69 6c 65 2e 68 3e 0a 23 69 6e 63 6c 75  ndfile.h>.#inclu
0020: 64 65 20 3c 73 79 73 2f 73 6f 63 6b 65 74 2e 68  de <sys/socket.h
0030: 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 79 73 2f  >.#include <sys/
0040: 74 79 70 65 73 2e 68 3e 0a 23 69 6e 63 6c 75 64  types.h>.#includ
0050: 65 20 3c 61 72 70 61 2f 69 6e 65 74 2e 68 3e 0a  e <arpa/inet.h>.
0060: 23 69 6e 63 6c 75 64 65 20 3c 73 79 73 2f 6d 6d  #include <sys/mm
0070: 61 6e 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c  an.h>.#include <
0080: 73 79 73 2f 73 74 61 74 2e 68 3e 0a 23 69 6e 63  sys/stat.h>.#inc
0090: 6c 75 64 65 20 3c 70 74 68 72 65 61 64 2e 68 3e  lude <pthread.h>
00a0: 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e  .#include <strin
00b0: 67 73 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c  gs.h>.#include <
00c0: 73 74 64 6c 69 62 2e 68 3e 0a 23 69 6e 63 6c 75  stdlib.h>.#inclu
00d0: 64 65 20 3c 75 6e 69 73 74 64 2e 68 3e 0a 23 69  de <unistd.h>.#i
00e0: 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e 67 2e 68  nclude <string.h
00f0: 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 66 63 6e 74  >.#include <fcnt
0100: 6c 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73  l.h>.#include <s
0110: 74 64 69 6f 2e 68 3e 0a 23 69 6e 63 6c 75 64 65  tdio.h>.#include
0120: 20 3c 74 69 6d 65 2e 68 3e 0a 0a 2f 2a 20 44 65   <time.h>../* De
0130: 66 61 75 6c 74 20 76 61 6c 75 65 73 20 2a 2f 0a  fault values */.
0140: 23 64 65 66 69 6e 65 20 4d 41 58 5f 46 41 49 4c  #define MAX_FAIL
0150: 55 52 45 5f 43 4f 55 4e 54 20 33 30 0a 23 64 65  URE_COUNT 30.#de
0160: 66 69 6e 65 20 50 4f 52 54 20 38 30 38 30 0a 23  fine PORT 8080.#
0170: 64 65 66 69 6e 65 20 54 48 52 45 41 44 5f 43 4f  define THREAD_CO
0180: 55 4e 54 20 31 30 0a 23 64 65 66 69 6e 65 20 42  UNT 10.#define B
0190: 49 4e 44 5f 41 44 44 52 20 22 3a 3a 22 0a 23 64  IND_ADDR "::".#d
01a0: 65 66 69 6e 65 20 43 41 43 48 45 5f 53 49 5a 45  efine CACHE_SIZE
01b0: 20 38 31 39 32 0a 0a 2f 2a 20 41 72 67 75 6d 65   8192../* Argume
01c0: 6e 74 73 20 66 6f 72 20 77 6f 72 6b 65 72 20 74  nts for worker t
01d0: 68 72 65 61 64 73 20 2a 2f 0a 73 74 72 75 63 74  hreads */.struct
01e0: 20 66 69 6c 65 64 5f 77 6f 72 6b 65 72 5f 74 68   filed_worker_th
01f0: 72 65 61 64 5f 61 72 67 73 20 7b 0a 09 69 6e 74  read_args {..int
0200: 20 66 64 3b 0a 7d 3b 0a 0a 2f 2a 20 46 69 6c 65   fd;.};../* File
0210: 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 2a 2f 0a   information */.
0220: 73 74 72 75 63 74 20 66 69 6c 65 64 5f 66 69 6c  struct filed_fil
0230: 65 69 6e 66 6f 20 7b 0a 09 70 74 68 72 65 61 64  einfo {..pthread
0240: 5f 6d 75 74 65 78 5f 74 20 6d 75 74 65 78 3b 0a  _mutex_t mutex;.
0250: 09 63 68 61 72 20 2a 70 61 74 68 3b 0a 09 69 6e  .char *path;..in
0260: 74 20 66 64 3b 0a 09 73 69 7a 65 5f 74 20 6c 65  t fd;..size_t le
0270: 6e 3b 0a 09 63 68 61 72 20 2a 6c 61 73 74 6d 6f  n;..char *lastmo
0280: 64 3b 0a 09 63 68 61 72 20 6c 61 73 74 6d 6f 64  d;..char lastmod
0290: 5f 62 5b 36 34 5d 3b 0a 09 63 68 61 72 20 2a 74  _b[64];..char *t
02a0: 79 70 65 3b 0a 7d 3b 0a 0a 2f 2a 20 52 65 71 75  ype;.};../* Requ
02b0: 65 73 74 20 76 61 72 69 61 62 6c 65 73 20 2a 2f  est variables */
02c0: 0a 73 74 72 75 63 74 20 66 69 6c 65 64 5f 68 74  .struct filed_ht
02d0: 74 70 5f 72 65 71 75 65 73 74 20 7b 0a 09 2f 2a  tp_request {../*
02e0: 2a 20 42 75 66 66 65 72 73 20 2a 2a 2f 0a 09 73  * Buffers **/..s
02f0: 74 72 75 63 74 20 66 69 6c 65 64 5f 66 69 6c 65  truct filed_file
0300: 69 6e 66 6f 20 66 69 6c 65 69 6e 66 6f 3b 0a 09  info fileinfo;..
0310: 63 68 61 72 20 70 61 74 68 5f 62 5b 31 30 31 30  char path_b[1010
0320: 5d 3b 0a 09 63 68 61 72 20 74 6d 70 62 75 66 5b  ];..char tmpbuf[
0330: 31 30 31 30 5d 3b 0a 0a 09 2f 2a 2a 20 48 54 54  1010];.../** HTT
0340: 50 20 52 65 71 75 65 73 74 20 69 6e 66 6f 72 6d  P Request inform
0350: 61 74 69 6f 6e 20 2a 2a 2f 0a 09 63 68 61 72 20  ation **/..char 
0360: 2a 70 61 74 68 3b 20 20 20 20 20 2f 2a 2a 2a 20  *path;     /*** 
0370: 50 61 74 68 20 62 65 69 6e 67 20 72 65 71 75 65  Path being reque
0380: 73 74 65 64 20 2a 2a 2a 2f 0a 09 6f 66 66 5f 74  sted ***/..off_t
0390: 20 6f 66 66 73 65 74 3b 20 20 20 2f 2a 2a 2a 20   offset;   /*** 
03a0: 52 61 6e 67 65 20 73 74 61 72 74 20 2a 2a 2a 2f  Range start ***/
03b0: 0a 09 73 73 69 7a 65 5f 74 20 6c 65 6e 67 74 68  ..ssize_t length
03c0: 3b 20 2f 2a 2a 2a 20 52 61 6e 67 65 20 6c 65 6e  ; /*** Range len
03d0: 67 74 68 20 2a 2a 2a 2f 0a 7d 3b 0a 0a 2f 2a 20  gth ***/.};../* 
03e0: 47 6c 6f 62 61 6c 20 76 61 72 69 61 62 6c 65 73  Global variables
03f0: 20 2a 2f 0a 73 74 72 75 63 74 20 66 69 6c 65 64   */.struct filed
0400: 5f 66 69 6c 65 69 6e 66 6f 20 2a 66 69 6c 65 64  _fileinfo *filed
0410: 5f 66 69 6c 65 69 6e 66 6f 5f 66 64 63 61 63 68  _fileinfo_fdcach
0420: 65 3b 0a 75 6e 73 69 67 6e 65 64 20 69 6e 74 20  e;.unsigned int 
0430: 66 69 6c 65 64 5f 66 69 6c 65 69 6e 66 6f 5f 66  filed_fileinfo_f
0440: 64 63 61 63 68 65 5f 73 69 7a 65 20 3d 20 43 41  dcache_size = CA
0450: 43 48 45 5f 53 49 5a 45 3b 0a 0a 2f 2a 20 49 6e  CHE_SIZE;../* In
0460: 69 74 69 61 6c 69 7a 65 20 70 72 6f 63 65 73 73  itialize process
0470: 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 66   */.static int f
0480: 69 6c 65 64 5f 69 6e 69 74 28 76 6f 69 64 29 20  iled_init(void) 
0490: 7b 0a 09 75 6e 73 69 67 6e 65 64 20 69 6e 74 20  {..unsigned int 
04a0: 69 64 78 3b 0a 09 69 6e 74 20 6d 75 74 65 78 5f  idx;..int mutex_
04b0: 69 6e 69 74 5f 72 65 74 3b 0a 0a 09 6d 6c 6f 63  init_ret;...mloc
04c0: 6b 61 6c 6c 28 4d 43 4c 5f 43 55 52 52 45 4e 54  kall(MCL_CURRENT
04d0: 20 7c 20 4d 43 4c 5f 46 55 54 55 52 45 29 3b 0a   | MCL_FUTURE);.
04e0: 0a 09 66 69 6c 65 64 5f 66 69 6c 65 69 6e 66 6f  ..filed_fileinfo
04f0: 5f 66 64 63 61 63 68 65 20 3d 20 6d 61 6c 6c 6f  _fdcache = mallo
0500: 63 28 73 69 7a 65 6f 66 28 2a 66 69 6c 65 64 5f  c(sizeof(*filed_
0510: 66 69 6c 65 69 6e 66 6f 5f 66 64 63 61 63 68 65  fileinfo_fdcache
0520: 29 20 2a 20 66 69 6c 65 64 5f 66 69 6c 65 69 6e  ) * filed_filein
0530: 66 6f 5f 66 64 63 61 63 68 65 5f 73 69 7a 65 29  fo_fdcache_size)
0540: 3b 0a 09 69 66 20 28 66 69 6c 65 64 5f 66 69 6c  ;..if (filed_fil
0550: 65 69 6e 66 6f 5f 66 64 63 61 63 68 65 20 3d 3d  einfo_fdcache ==
0560: 20 4e 55 4c 4c 29 20 7b 0a 09 09 72 65 74 75 72   NULL) {...retur
0570: 6e 28 31 29 3b 0a 09 7d 0a 0a 09 66 6f 72 20 28  n(1);..}...for (
0580: 69 64 78 20 3d 20 30 3b 20 69 64 78 20 3c 20 66  idx = 0; idx < f
0590: 69 6c 65 64 5f 66 69 6c 65 69 6e 66 6f 5f 66 64  iled_fileinfo_fd
05a0: 63 61 63 68 65 5f 73 69 7a 65 3b 20 69 64 78 2b  cache_size; idx+
05b0: 2b 29 20 7b 0a 09 09 6d 75 74 65 78 5f 69 6e 69  +) {...mutex_ini
05c0: 74 5f 72 65 74 20 3d 20 70 74 68 72 65 61 64 5f  t_ret = pthread_
05d0: 6d 75 74 65 78 5f 69 6e 69 74 28 26 66 69 6c 65  mutex_init(&file
05e0: 64 5f 66 69 6c 65 69 6e 66 6f 5f 66 64 63 61 63  d_fileinfo_fdcac
05f0: 68 65 5b 69 64 78 5d 2e 6d 75 74 65 78 2c 20 4e  he[idx].mutex, N
0600: 55 4c 4c 29 3b 0a 09 09 69 66 20 28 6d 75 74 65  ULL);...if (mute
0610: 78 5f 69 6e 69 74 5f 72 65 74 20 21 3d 20 30 29  x_init_ret != 0)
0620: 20 7b 0a 09 09 09 72 65 74 75 72 6e 28 31 29 3b   {....return(1);
0630: 0a 09 09 7d 0a 0a 09 09 66 69 6c 65 64 5f 66 69  ...}....filed_fi
0640: 6c 65 69 6e 66 6f 5f 66 64 63 61 63 68 65 5b 69  leinfo_fdcache[i
0650: 64 78 5d 2e 70 61 74 68 20 3d 20 73 74 72 64 75  dx].path = strdu
0660: 70 28 22 22 29 3b 0a 09 09 66 69 6c 65 64 5f 66  p("");...filed_f
0670: 69 6c 65 69 6e 66 6f 5f 66 64 63 61 63 68 65 5b  ileinfo_fdcache[
0680: 69 64 78 5d 2e 66 64 20 3d 20 2d 31 3b 0a 09 09  idx].fd = -1;...
0690: 66 69 6c 65 64 5f 66 69 6c 65 69 6e 66 6f 5f 66  filed_fileinfo_f
06a0: 64 63 61 63 68 65 5b 69 64 78 5d 2e 6c 61 73 74  dcache[idx].last
06b0: 6d 6f 64 20 3d 20 22 22 3b 0a 09 09 66 69 6c 65  mod = "";...file
06c0: 64 5f 66 69 6c 65 69 6e 66 6f 5f 66 64 63 61 63  d_fileinfo_fdcac
06d0: 68 65 5b 69 64 78 5d 2e 74 79 70 65 20 3d 20 22  he[idx].type = "
06e0: 22 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28 30  ";..}...return(0
06f0: 29 3b 0a 7d 0a 0a 2f 2a 20 4c 69 73 74 65 6e 20  );.}../* Listen 
0700: 6f 6e 20 61 20 70 61 72 74 69 63 75 6c 61 72 20  on a particular 
0710: 61 64 64 72 65 73 73 2f 70 6f 72 74 20 2a 2f 0a  address/port */.
0720: 73 74 61 74 69 63 20 69 6e 74 20 66 69 6c 65 64  static int filed
0730: 5f 6c 69 73 74 65 6e 28 63 6f 6e 73 74 20 63 68  _listen(const ch
0740: 61 72 20 2a 61 64 64 72 65 73 73 2c 20 75 6e 73  ar *address, uns
0750: 69 67 6e 65 64 20 69 6e 74 20 70 6f 72 74 29 20  igned int port) 
0760: 7b 0a 09 73 74 72 75 63 74 20 73 6f 63 6b 61 64  {..struct sockad
0770: 64 72 5f 69 6e 36 20 61 64 64 72 3b 0a 09 69 6e  dr_in6 addr;..in
0780: 74 20 70 74 6f 6e 5f 72 65 74 2c 20 62 69 6e 64  t pton_ret, bind
0790: 5f 72 65 74 2c 20 6c 69 73 74 65 6e 5f 72 65 74  _ret, listen_ret
07a0: 3b 0a 09 69 6e 74 20 66 64 3b 0a 0a 09 61 64 64  ;..int fd;...add
07b0: 72 2e 73 69 6e 36 5f 66 61 6d 69 6c 79 20 3d 20  r.sin6_family = 
07c0: 41 46 5f 49 4e 45 54 36 3b 0a 09 61 64 64 72 2e  AF_INET6;..addr.
07d0: 73 69 6e 36 5f 66 6c 6f 77 69 6e 66 6f 20 3d 20  sin6_flowinfo = 
07e0: 30 3b 0a 09 61 64 64 72 2e 73 69 6e 36 5f 73 63  0;..addr.sin6_sc
07f0: 6f 70 65 5f 69 64 20 3d 20 30 3b 0a 09 61 64 64  ope_id = 0;..add
0800: 72 2e 73 69 6e 36 5f 70 6f 72 74 20 3d 20 68 74  r.sin6_port = ht
0810: 6f 6e 73 28 70 6f 72 74 29 3b 0a 09 70 74 6f 6e  ons(port);..pton
0820: 5f 72 65 74 20 3d 20 69 6e 65 74 5f 70 74 6f 6e  _ret = inet_pton
0830: 28 41 46 5f 49 4e 45 54 36 2c 20 61 64 64 72 65  (AF_INET6, addre
0840: 73 73 2c 20 61 64 64 72 2e 73 69 6e 36 5f 61 64  ss, addr.sin6_ad
0850: 64 72 2e 73 36 5f 61 64 64 72 29 3b 0a 09 69 66  dr.s6_addr);..if
0860: 20 28 70 74 6f 6e 5f 72 65 74 20 21 3d 20 31 29   (pton_ret != 1)
0870: 20 7b 0a 09 09 72 65 74 75 72 6e 28 2d 31 29 3b   {...return(-1);
0880: 0a 09 7d 0a 0a 09 66 64 20 3d 20 73 6f 63 6b 65  ..}...fd = socke
0890: 74 28 41 46 5f 49 4e 45 54 36 2c 20 53 4f 43 4b  t(AF_INET6, SOCK
08a0: 5f 53 54 52 45 41 4d 2c 20 30 29 3b 0a 09 69 66  _STREAM, 0);..if
08b0: 20 28 66 64 20 3c 20 30 29 20 7b 0a 09 09 72 65   (fd < 0) {...re
08c0: 74 75 72 6e 28 66 64 29 3b 0a 09 7d 0a 0a 09 62  turn(fd);..}...b
08d0: 69 6e 64 5f 72 65 74 20 3d 20 62 69 6e 64 28 66  ind_ret = bind(f
08e0: 64 2c 20 28 63 6f 6e 73 74 20 73 74 72 75 63 74  d, (const struct
08f0: 20 73 6f 63 6b 61 64 64 72 20 2a 29 20 26 61 64   sockaddr *) &ad
0900: 64 72 2c 20 73 69 7a 65 6f 66 28 61 64 64 72 29  dr, sizeof(addr)
0910: 29 3b 0a 09 69 66 20 28 62 69 6e 64 5f 72 65 74  );..if (bind_ret
0920: 20 3c 20 30 29 20 7b 0a 09 09 63 6c 6f 73 65 28   < 0) {...close(
0930: 66 64 29 3b 0a 0a 09 09 72 65 74 75 72 6e 28 2d  fd);....return(-
0940: 31 29 3b 0a 09 7d 0a 0a 09 6c 69 73 74 65 6e 5f  1);..}...listen_
0950: 72 65 74 20 3d 20 6c 69 73 74 65 6e 28 66 64 2c  ret = listen(fd,
0960: 20 31 32 38 29 3b 0a 09 69 66 20 28 6c 69 73 74   128);..if (list
0970: 65 6e 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09  en_ret != 0) {..
0980: 09 63 6c 6f 73 65 28 66 64 29 3b 0a 0a 09 09 72  .close(fd);....r
0990: 65 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09  eturn(-1);..}...
09a0: 72 65 74 75 72 6e 28 66 64 29 3b 0a 7d 0a 0a 2f  return(fd);.}../
09b0: 2a 20 4c 6f 67 20 61 20 6d 65 73 73 61 67 65 20  * Log a message 
09c0: 2a 2f 0a 2f 2f 23 64 65 66 69 6e 65 20 46 49 4c  */.//#define FIL
09d0: 45 44 5f 44 4f 4e 54 5f 4c 4f 47 0a 23 69 66 64  ED_DONT_LOG.#ifd
09e0: 65 66 20 46 49 4c 45 44 5f 44 4f 4e 54 5f 4c 4f  ef FILED_DONT_LO
09f0: 47 0a 23 20 20 64 65 66 69 6e 65 20 66 69 6c 65  G.#  define file
0a00: 64 5f 6c 6f 67 67 69 6e 67 5f 74 68 72 65 61 64  d_logging_thread
0a10: 5f 69 6e 69 74 28 29 20 30 0a 23 20 20 64 65 66  _init() 0.#  def
0a20: 69 6e 65 20 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73  ine filed_log_ms
0a30: 67 5f 64 65 62 75 67 28 78 2c 20 2e 2e 2e 29 20  g_debug(x, ...) 
0a40: 2f 2a 2a 2f 0a 23 20 20 64 65 66 69 6e 65 20 66  /**/.#  define f
0a50: 69 6c 65 64 5f 6c 6f 67 5f 6d 73 67 28 78 29 20  iled_log_msg(x) 
0a60: 2f 2a 2a 2f 0a 23 65 6c 73 65 0a 2f 2a 20 49 6e  /**/.#else./* In
0a70: 69 74 69 61 6c 69 7a 65 20 6c 6f 67 67 69 6e 67  itialize logging
0a80: 20 74 68 72 65 61 64 20 2a 2f 0a 73 74 61 74 69   thread */.stati
0a90: 63 20 69 6e 74 20 66 69 6c 65 64 5f 6c 6f 67 67  c int filed_logg
0aa0: 69 6e 67 5f 74 68 72 65 61 64 5f 69 6e 69 74 28  ing_thread_init(
0ab0: 76 6f 69 64 29 20 7b 0a 09 2f 2a 20 58 58 58 3a  void) {../* XXX:
0ac0: 54 4f 44 4f 3a 20 55 6e 69 6d 70 6c 65 6d 65 6e  TODO: Unimplemen
0ad0: 74 65 64 20 2a 2f 0a 09 72 65 74 75 72 6e 28 30  ted */..return(0
0ae0: 29 3b 0a 7d 0a 0a 2f 2a 20 58 58 58 3a 54 4f 44  );.}../* XXX:TOD
0af0: 4f 3a 20 55 6e 69 6d 70 6c 65 6d 65 6e 74 65 64  O: Unimplemented
0b00: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 66 69 6c 65   */.#define file
0b10: 64 5f 6c 6f 67 5f 6d 73 67 5f 64 65 62 75 67 28  d_log_msg_debug(
0b20: 78 2c 20 2e 2e 2e 29 20 7b 20 66 70 72 69 6e 74  x, ...) { fprint
0b30: 66 28 73 74 64 65 72 72 2c 20 78 2c 20 5f 5f 56  f(stderr, x, __V
0b40: 41 5f 41 52 47 53 5f 5f 29 3b 20 66 70 72 69 6e  A_ARGS__); fprin
0b50: 74 66 28 73 74 64 65 72 72 2c 20 22 5c 6e 22 29  tf(stderr, "\n")
0b60: 3b 20 66 66 6c 75 73 68 28 73 74 64 65 72 72 29  ; fflush(stderr)
0b70: 3b 20 7d 0a 0a 73 74 61 74 69 63 20 76 6f 69 64  ; }..static void
0b80: 20 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73 67 28 63   filed_log_msg(c
0b90: 6f 6e 73 74 20 63 68 61 72 20 2a 62 75 66 66 65  onst char *buffe
0ba0: 72 29 20 7b 0a 09 2f 2a 20 58 58 58 3a 54 4f 44  r) {../* XXX:TOD
0bb0: 4f 3a 20 55 6e 69 6d 70 6c 65 6d 65 6e 74 65 64  O: Unimplemented
0bc0: 20 2a 2f 0a 09 66 70 72 69 6e 74 66 28 73 74 64   */..fprintf(std
0bd0: 65 72 72 2c 20 22 25 73 5c 6e 22 2c 20 62 75 66  err, "%s\n", buf
0be0: 66 65 72 29 3b 0a 0a 09 72 65 74 75 72 6e 3b 0a  fer);...return;.
0bf0: 7d 0a 0a 23 65 6e 64 69 66 0a 2f 2a 20 46 6f 72  }..#endif./* For
0c00: 6d 61 74 20 74 69 6d 65 20 70 65 72 20 52 46 43  mat time per RFC
0c10: 32 36 31 36 20 2a 2f 0a 73 74 61 74 69 63 20 63  2616 */.static c
0c20: 68 61 72 20 2a 66 69 6c 65 64 5f 66 6f 72 6d 61  har *filed_forma
0c30: 74 5f 74 69 6d 65 28 63 68 61 72 20 2a 62 75 66  t_time(char *buf
0c40: 66 65 72 2c 20 73 69 7a 65 5f 74 20 62 75 66 66  fer, size_t buff
0c50: 65 72 5f 6c 65 6e 2c 20 63 6f 6e 73 74 20 74 69  er_len, const ti
0c60: 6d 65 5f 74 20 74 69 6d 65 69 6e 66 6f 29 20 7b  me_t timeinfo) {
0c70: 0a 09 73 74 72 75 63 74 20 74 6d 20 74 69 6d 65  ..struct tm time
0c80: 69 6e 66 6f 5f 74 6d 2c 20 2a 74 69 6d 65 69 6e  info_tm, *timein
0c90: 66 6f 5f 74 6d 5f 70 3b 0a 0a 09 74 69 6d 65 69  fo_tm_p;...timei
0ca0: 6e 66 6f 5f 74 6d 5f 70 20 3d 20 67 6d 74 69 6d  nfo_tm_p = gmtim
0cb0: 65 5f 72 28 26 74 69 6d 65 69 6e 66 6f 2c 20 26  e_r(&timeinfo, &
0cc0: 74 69 6d 65 69 6e 66 6f 5f 74 6d 29 3b 0a 09 69  timeinfo_tm);..i
0cd0: 66 20 28 74 69 6d 65 69 6e 66 6f 5f 74 6d 5f 70  f (timeinfo_tm_p
0ce0: 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09 72 65   == NULL) {...re
0cf0: 74 75 72 6e 28 22 75 6e 6b 6e 6f 77 6e 22 29 3b  turn("unknown");
0d00: 0a 09 7d 0a 0a 09 62 75 66 66 65 72 5b 62 75 66  ..}...buffer[buf
0d10: 66 65 72 5f 6c 65 6e 20 2d 20 31 5d 20 3d 20 27  fer_len - 1] = '
0d20: 5c 30 27 3b 0a 09 62 75 66 66 65 72 5f 6c 65 6e  \0';..buffer_len
0d30: 20 3d 20 73 74 72 66 74 69 6d 65 28 62 75 66 66   = strftime(buff
0d40: 65 72 2c 20 62 75 66 66 65 72 5f 6c 65 6e 20 2d  er, buffer_len -
0d50: 20 31 2c 20 22 25 61 2c 20 25 64 20 25 62 20 25   1, "%a, %d %b %
0d60: 59 20 25 48 3a 25 4d 3a 25 53 20 47 4d 54 22 2c  Y %H:%M:%S GMT",
0d70: 20 74 69 6d 65 69 6e 66 6f 5f 74 6d 5f 70 29 3b   timeinfo_tm_p);
0d80: 0a 0a 09 72 65 74 75 72 6e 28 62 75 66 66 65 72  ...return(buffer
0d90: 29 3b 0a 7d 0a 0a 2f 2a 20 68 61 73 68 20 2a 2f  );.}../* hash */
0da0: 0a 73 74 61 74 69 63 20 75 6e 73 69 67 6e 65 64  .static unsigned
0db0: 20 69 6e 74 20 66 69 6c 65 64 5f 68 61 73 68 28   int filed_hash(
0dc0: 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63  const unsigned c
0dd0: 68 61 72 20 2a 76 61 6c 75 65 2c 20 75 6e 73 69  har *value, unsi
0de0: 67 6e 65 64 20 69 6e 74 20 6d 6f 64 75 6c 75 73  gned int modulus
0df0: 29 20 7b 0a 09 75 6e 73 69 67 6e 65 64 20 63 68  ) {..unsigned ch
0e00: 61 72 20 63 75 72 72 3b 0a 09 75 6e 73 69 67 6e  ar curr;..unsign
0e10: 65 64 20 69 6e 74 20 72 65 74 76 61 6c 3b 0a 0a  ed int retval;..
0e20: 09 72 65 74 76 61 6c 20 3d 20 6d 6f 64 75 6c 75  .retval = modulu
0e30: 73 20 2d 20 31 3b 0a 0a 09 77 68 69 6c 65 20 28  s - 1;...while (
0e40: 28 63 75 72 72 20 3d 20 2a 76 61 6c 75 65 29 29  (curr = *value))
0e50: 20 7b 0a 09 09 69 66 20 28 63 75 72 72 20 3c 20   {...if (curr < 
0e60: 33 32 29 20 7b 0a 09 09 09 63 75 72 72 20 3d 20  32) {....curr = 
0e70: 32 35 35 20 2d 20 63 75 72 72 3b 0a 09 09 7d 20  255 - curr;...} 
0e80: 65 6c 73 65 20 7b 0a 09 09 09 63 75 72 72 20 2d  else {....curr -
0e90: 3d 20 33 32 3b 0a 09 09 7d 0a 0a 09 09 72 65 74  = 32;...}....ret
0ea0: 76 61 6c 20 3c 3c 3d 20 35 3b 0a 09 09 72 65 74  val <<= 5;...ret
0eb0: 76 61 6c 20 2b 3d 20 63 75 72 72 3b 0a 0a 09 09  val += curr;....
0ec0: 76 61 6c 75 65 2b 2b 3b 0a 09 7d 0a 0a 09 72 65  value++;..}...re
0ed0: 74 76 61 6c 20 3d 20 72 65 74 76 61 6c 20 25 20  tval = retval % 
0ee0: 6d 6f 64 75 6c 75 73 3b 0a 0a 09 72 65 74 75 72  modulus;...retur
0ef0: 6e 28 72 65 74 76 61 6c 29 3b 0a 7d 0a 0a 2f 2a  n(retval);.}../*
0f00: 20 4f 70 65 6e 20 61 20 66 69 6c 65 20 61 6e 64   Open a file and
0f10: 20 72 65 74 75 72 6e 20 66 69 6c 65 20 69 6e 66   return file inf
0f20: 6f 72 6d 61 74 69 6f 6e 20 2a 2f 0a 73 74 61 74  ormation */.stat
0f30: 69 63 20 73 74 72 75 63 74 20 66 69 6c 65 64 5f  ic struct filed_
0f40: 66 69 6c 65 69 6e 66 6f 20 2a 66 69 6c 65 64 5f  fileinfo *filed_
0f50: 6f 70 65 6e 5f 66 69 6c 65 28 63 6f 6e 73 74 20  open_file(const 
0f60: 63 68 61 72 20 2a 70 61 74 68 2c 20 73 74 72 75  char *path, stru
0f70: 63 74 20 66 69 6c 65 64 5f 66 69 6c 65 69 6e 66  ct filed_fileinf
0f80: 6f 20 2a 62 75 66 66 65 72 29 20 7b 0a 09 73 74  o *buffer) {..st
0f90: 72 75 63 74 20 66 69 6c 65 64 5f 66 69 6c 65 69  ruct filed_filei
0fa0: 6e 66 6f 20 2a 63 61 63 68 65 3b 0a 09 75 6e 73  nfo *cache;..uns
0fb0: 69 67 6e 65 64 20 69 6e 74 20 63 61 63 68 65 5f  igned int cache_
0fc0: 69 64 78 3b 0a 09 6f 66 66 5f 74 20 6c 65 6e 3b  idx;..off_t len;
0fd0: 0a 09 69 6e 74 20 66 64 3b 0a 0a 09 63 61 63 68  ..int fd;...cach
0fe0: 65 5f 69 64 78 20 3d 20 66 69 6c 65 64 5f 68 61  e_idx = filed_ha
0ff0: 73 68 28 28 63 6f 6e 73 74 20 75 6e 73 69 67 6e  sh((const unsign
1000: 65 64 20 63 68 61 72 20 2a 29 20 70 61 74 68 2c  ed char *) path,
1010: 20 66 69 6c 65 64 5f 66 69 6c 65 69 6e 66 6f 5f   filed_fileinfo_
1020: 66 64 63 61 63 68 65 5f 73 69 7a 65 29 3b 0a 0a  fdcache_size);..
1030: 09 63 61 63 68 65 20 3d 20 26 66 69 6c 65 64 5f  .cache = &filed_
1040: 66 69 6c 65 69 6e 66 6f 5f 66 64 63 61 63 68 65  fileinfo_fdcache
1050: 5b 63 61 63 68 65 5f 69 64 78 5d 3b 0a 0a 09 66  [cache_idx];...f
1060: 69 6c 65 64 5f 6c 6f 67 5f 6d 73 67 5f 64 65 62  iled_log_msg_deb
1070: 75 67 28 22 4c 6f 63 6b 69 6e 67 20 6d 75 74 65  ug("Locking mute
1080: 78 20 66 6f 72 20 69 64 78 3a 20 25 6c 75 22 2c  x for idx: %lu",
1090: 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 29   (unsigned long)
10a0: 20 63 61 63 68 65 5f 69 64 78 29 3b 0a 0a 09 70   cache_idx);...p
10b0: 74 68 72 65 61 64 5f 6d 75 74 65 78 5f 6c 6f 63  thread_mutex_loc
10c0: 6b 28 26 63 61 63 68 65 2d 3e 6d 75 74 65 78 29  k(&cache->mutex)
10d0: 3b 0a 0a 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73  ;...filed_log_ms
10e0: 67 5f 64 65 62 75 67 28 22 43 6f 6d 70 6c 65 74  g_debug("Complet
10f0: 65 64 20 6c 6f 63 6b 69 6e 67 20 6d 75 74 65 78  ed locking mutex
1100: 20 66 6f 72 20 69 64 78 3a 20 25 6c 75 22 2c 20   for idx: %lu", 
1110: 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 29 20  (unsigned long) 
1120: 63 61 63 68 65 5f 69 64 78 29 3b 0a 0a 09 69 66  cache_idx);...if
1130: 20 28 73 74 72 63 6d 70 28 70 61 74 68 2c 20 63   (strcmp(path, c
1140: 61 63 68 65 2d 3e 70 61 74 68 29 20 21 3d 20 30  ache->path) != 0
1150: 29 20 7b 0a 09 09 66 69 6c 65 64 5f 6c 6f 67 5f  ) {...filed_log_
1160: 6d 73 67 5f 64 65 62 75 67 28 22 43 61 63 68 65  msg_debug("Cache
1170: 20 6d 69 73 73 20 66 6f 72 20 69 64 78 3a 20 25   miss for idx: %
1180: 6c 75 3a 20 4f 4c 44 20 5c 22 25 73 5c 22 2c 20  lu: OLD \"%s\", 
1190: 4e 45 57 20 5c 22 25 73 5c 22 22 2c 20 28 75 6e  NEW \"%s\"", (un
11a0: 73 69 67 6e 65 64 20 6c 6f 6e 67 29 20 63 61 63  signed long) cac
11b0: 68 65 5f 69 64 78 2c 20 63 61 63 68 65 2d 3e 70  he_idx, cache->p
11c0: 61 74 68 2c 20 70 61 74 68 29 3b 0a 0a 09 09 66  ath, path);....f
11d0: 64 20 3d 20 6f 70 65 6e 28 70 61 74 68 2c 20 4f  d = open(path, O
11e0: 5f 52 44 4f 4e 4c 59 29 3b 0a 09 09 69 66 20 28  _RDONLY);...if (
11f0: 66 64 20 3c 20 30 29 20 7b 0a 09 09 09 70 74 68  fd < 0) {....pth
1200: 72 65 61 64 5f 6d 75 74 65 78 5f 75 6e 6c 6f 63  read_mutex_unloc
1210: 6b 28 26 63 61 63 68 65 2d 3e 6d 75 74 65 78 29  k(&cache->mutex)
1220: 3b 0a 0a 09 09 09 72 65 74 75 72 6e 28 4e 55 4c  ;.....return(NUL
1230: 4c 29 3b 0a 09 09 7d 0a 0a 09 09 66 72 65 65 28  L);...}....free(
1240: 63 61 63 68 65 2d 3e 70 61 74 68 29 3b 0a 09 09  cache->path);...
1250: 69 66 20 28 63 61 63 68 65 2d 3e 66 64 20 3e 3d  if (cache->fd >=
1260: 20 30 29 20 7b 0a 09 09 09 63 6c 6f 73 65 28 63   0) {....close(c
1270: 61 63 68 65 2d 3e 66 64 29 3b 0a 09 09 7d 0a 0a  ache->fd);...}..
1280: 09 09 6c 65 6e 20 3d 20 6c 73 65 65 6b 28 66 64  ..len = lseek(fd
1290: 2c 20 30 2c 20 53 45 45 4b 5f 45 4e 44 29 3b 0a  , 0, SEEK_END);.
12a0: 09 09 6c 73 65 65 6b 28 66 64 2c 20 30 2c 20 53  ..lseek(fd, 0, S
12b0: 45 45 4b 5f 53 45 54 29 3b 0a 0a 09 09 63 61 63  EEK_SET);....cac
12c0: 68 65 2d 3e 66 64 20 3d 20 66 64 3b 0a 09 09 63  he->fd = fd;...c
12d0: 61 63 68 65 2d 3e 6c 65 6e 20 3d 20 6c 65 6e 3b  ache->len = len;
12e0: 0a 09 09 63 61 63 68 65 2d 3e 70 61 74 68 20 3d  ...cache->path =
12f0: 20 73 74 72 64 75 70 28 70 61 74 68 29 3b 0a 0a   strdup(path);..
1300: 09 09 2f 2a 20 58 58 58 3a 54 4f 44 4f 3a 20 44  ../* XXX:TODO: D
1310: 65 74 65 72 6d 69 6e 65 20 2a 2f 0a 09 09 63 61  etermine */...ca
1320: 63 68 65 2d 3e 74 79 70 65 20 3d 20 22 61 70 70  che->type = "app
1330: 6c 69 63 61 74 69 6f 6e 2f 6f 63 74 65 74 2d 73  lication/octet-s
1340: 74 72 65 61 6d 22 3b 0a 09 09 63 61 63 68 65 2d  tream";...cache-
1350: 3e 6c 61 73 74 6d 6f 64 20 3d 20 66 69 6c 65 64  >lastmod = filed
1360: 5f 66 6f 72 6d 61 74 5f 74 69 6d 65 28 63 61 63  _format_time(cac
1370: 68 65 2d 3e 6c 61 73 74 6d 6f 64 5f 62 2c 20 73  he->lastmod_b, s
1380: 69 7a 65 6f 66 28 63 61 63 68 65 2d 3e 6c 61 73  izeof(cache->las
1390: 74 6d 6f 64 5f 62 29 2c 20 74 69 6d 65 28 4e 55  tmod_b), time(NU
13a0: 4c 4c 29 20 2d 20 33 30 29 3b 0a 09 7d 20 65 6c  LL) - 30);..} el
13b0: 73 65 20 7b 0a 09 09 66 69 6c 65 64 5f 6c 6f 67  se {...filed_log
13c0: 5f 6d 73 67 5f 64 65 62 75 67 28 22 43 61 63 68  _msg_debug("Cach
13d0: 65 20 68 69 74 20 66 6f 72 20 69 64 78 3a 20 25  e hit for idx: %
13e0: 6c 75 3a 20 50 41 54 48 20 5c 22 25 73 5c 22 22  lu: PATH \"%s\""
13f0: 2c 20 28 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67  , (unsigned long
1400: 29 20 63 61 63 68 65 5f 69 64 78 2c 20 70 61 74  ) cache_idx, pat
1410: 68 29 3b 0a 09 7d 0a 0a 09 2f 2a 0a 09 20 2a 20  h);..}.../*.. * 
1420: 57 65 20 68 61 76 65 20 74 6f 20 6d 61 6b 65 20  We have to make 
1430: 61 20 64 75 70 6c 69 63 61 74 65 20 46 44 2c 20  a duplicate FD, 
1440: 62 65 63 61 75 73 65 20 6f 6e 63 65 20 77 65 20  because once we 
1450: 72 65 6c 65 61 73 65 20 74 68 65 20 63 61 63 68  release the cach
1460: 65 0a 09 20 2a 20 6d 75 74 65 78 2c 20 74 68 65  e.. * mutex, the
1470: 20 66 69 6c 65 20 64 65 73 63 72 69 70 74 6f 72   file descriptor
1480: 20 6d 61 79 20 62 65 20 63 6c 6f 73 65 64 0a 09   may be closed..
1490: 20 2a 2f 0a 09 66 64 20 3d 20 64 75 70 28 63 61   */..fd = dup(ca
14a0: 63 68 65 2d 3e 66 64 29 3b 0a 09 69 66 20 28 66  che->fd);..if (f
14b0: 64 20 3c 20 30 29 20 7b 0a 09 09 70 74 68 72 65  d < 0) {...pthre
14c0: 61 64 5f 6d 75 74 65 78 5f 75 6e 6c 6f 63 6b 28  ad_mutex_unlock(
14d0: 26 63 61 63 68 65 2d 3e 6d 75 74 65 78 29 3b 0a  &cache->mutex);.
14e0: 0a 09 09 72 65 74 75 72 6e 28 4e 55 4c 4c 29 3b  ...return(NULL);
14f0: 0a 09 7d 0a 0a 09 62 75 66 66 65 72 2d 3e 66 64  ..}...buffer->fd
1500: 20 3d 20 66 64 3b 0a 09 62 75 66 66 65 72 2d 3e   = fd;..buffer->
1510: 6c 65 6e 20 3d 20 63 61 63 68 65 2d 3e 6c 65 6e  len = cache->len
1520: 3b 0a 09 62 75 66 66 65 72 2d 3e 74 79 70 65 20  ;..buffer->type 
1530: 3d 20 63 61 63 68 65 2d 3e 74 79 70 65 3b 0a 09  = cache->type;..
1540: 6d 65 6d 63 70 79 28 62 75 66 66 65 72 2d 3e 6c  memcpy(buffer->l
1550: 61 73 74 6d 6f 64 5f 62 2c 20 63 61 63 68 65 2d  astmod_b, cache-
1560: 3e 6c 61 73 74 6d 6f 64 5f 62 2c 20 73 69 7a 65  >lastmod_b, size
1570: 6f 66 28 62 75 66 66 65 72 2d 3e 6c 61 73 74 6d  of(buffer->lastm
1580: 6f 64 5f 62 29 29 3b 0a 09 62 75 66 66 65 72 2d  od_b));..buffer-
1590: 3e 6c 61 73 74 6d 6f 64 20 3d 20 62 75 66 66 65  >lastmod = buffe
15a0: 72 2d 3e 6c 61 73 74 6d 6f 64 5f 62 20 2b 20 28  r->lastmod_b + (
15b0: 63 61 63 68 65 2d 3e 6c 61 73 74 6d 6f 64 20 2d  cache->lastmod -
15c0: 20 63 61 63 68 65 2d 3e 6c 61 73 74 6d 6f 64 5f   cache->lastmod_
15d0: 62 29 3b 0a 0a 09 70 74 68 72 65 61 64 5f 6d 75  b);...pthread_mu
15e0: 74 65 78 5f 75 6e 6c 6f 63 6b 28 26 63 61 63 68  tex_unlock(&cach
15f0: 65 2d 3e 6d 75 74 65 78 29 3b 0a 0a 09 72 65 74  e->mutex);...ret
1600: 75 72 6e 28 62 75 66 66 65 72 29 3b 0a 7d 0a 0a  urn(buffer);.}..
1610: 2f 2a 20 50 72 6f 63 65 73 73 20 61 6e 20 48 54  /* Process an HT
1620: 54 50 20 72 65 71 75 65 73 74 20 61 6e 64 20 72  TP request and r
1630: 65 74 75 72 6e 20 74 68 65 20 70 61 74 68 20 72  eturn the path r
1640: 65 71 75 65 73 74 65 64 20 2a 2f 0a 73 74 61 74  equested */.stat
1650: 69 63 20 73 74 72 75 63 74 20 66 69 6c 65 64 5f  ic struct filed_
1660: 68 74 74 70 5f 72 65 71 75 65 73 74 20 2a 66 69  http_request *fi
1670: 6c 65 64 5f 67 65 74 5f 68 74 74 70 5f 72 65 71  led_get_http_req
1680: 75 65 73 74 28 46 49 4c 45 20 2a 66 70 2c 20 73  uest(FILE *fp, s
1690: 74 72 75 63 74 20 66 69 6c 65 64 5f 68 74 74 70  truct filed_http
16a0: 5f 72 65 71 75 65 73 74 20 2a 62 75 66 66 65 72  _request *buffer
16b0: 5f 73 74 29 20 7b 0a 09 63 68 61 72 20 2a 6d 65  _st) {..char *me
16c0: 74 68 6f 64 2c 20 2a 70 61 74 68 3b 0a 09 63 68  thod, *path;..ch
16d0: 61 72 20 2a 62 75 66 66 65 72 2c 20 2a 74 6d 70  ar *buffer, *tmp
16e0: 62 75 66 66 65 72 2c 20 2a 77 6f 72 6b 62 75 66  buffer, *workbuf
16f0: 66 65 72 2c 20 2a 77 6f 72 6b 62 75 66 66 65 72  fer, *workbuffer
1700: 5f 6e 65 78 74 3b 0a 09 73 69 7a 65 5f 74 20 62  _next;..size_t b
1710: 75 66 66 65 72 5f 6c 65 6e 2c 20 74 6d 70 62 75  uffer_len, tmpbu
1720: 66 66 65 72 5f 6c 65 6e 3b 0a 09 6f 66 66 5f 74  ffer_len;..off_t
1730: 20 72 61 6e 67 65 5f 73 74 61 72 74 2c 20 72 61   range_start, ra
1740: 6e 67 65 5f 65 6e 64 3b 0a 09 73 73 69 7a 65 5f  nge_end;..ssize_
1750: 74 20 72 61 6e 67 65 5f 6c 65 6e 67 74 68 3b 0a  t range_length;.
1760: 09 69 6e 74 20 69 3b 0a 0a 09 72 61 6e 67 65 5f  .int i;...range_
1770: 73 74 61 72 74 20 3d 20 30 3b 0a 09 72 61 6e 67  start = 0;..rang
1780: 65 5f 65 6e 64 20 20 20 3d 20 30 3b 0a 09 72 61  e_end   = 0;..ra
1790: 6e 67 65 5f 6c 65 6e 67 74 68 20 3d 20 2d 31 3b  nge_length = -1;
17a0: 0a 0a 09 62 75 66 66 65 72 20 3d 20 62 75 66 66  ...buffer = buff
17b0: 65 72 5f 73 74 2d 3e 70 61 74 68 5f 62 3b 0a 09  er_st->path_b;..
17c0: 62 75 66 66 65 72 5f 6c 65 6e 20 3d 20 73 69 7a  buffer_len = siz
17d0: 65 6f 66 28 62 75 66 66 65 72 5f 73 74 2d 3e 70  eof(buffer_st->p
17e0: 61 74 68 5f 62 29 3b 0a 0a 09 74 6d 70 62 75 66  ath_b);...tmpbuf
17f0: 66 65 72 20 3d 20 62 75 66 66 65 72 5f 73 74 2d  fer = buffer_st-
1800: 3e 74 6d 70 62 75 66 3b 0a 09 74 6d 70 62 75 66  >tmpbuf;..tmpbuf
1810: 66 65 72 5f 6c 65 6e 20 3d 20 73 69 7a 65 6f 66  fer_len = sizeof
1820: 28 62 75 66 66 65 72 5f 73 74 2d 3e 74 6d 70 62  (buffer_st->tmpb
1830: 75 66 29 3b 0a 0a 09 66 69 6c 65 64 5f 6c 6f 67  uf);...filed_log
1840: 5f 6d 73 67 28 22 57 41 49 54 5f 46 4f 52 5f 52  _msg("WAIT_FOR_R
1850: 45 51 55 45 53 54 20 46 44 3d 2e 2e 2e 22 29 3b  EQUEST FD=...");
1860: 0a 0a 09 66 67 65 74 73 28 62 75 66 66 65 72 2c  ...fgets(buffer,
1870: 20 62 75 66 66 65 72 5f 6c 65 6e 2c 20 66 70 29   buffer_len, fp)
1880: 3b 0a 0a 09 6d 65 74 68 6f 64 20 3d 20 62 75 66  ;...method = buf
1890: 66 65 72 3b 0a 0a 09 62 75 66 66 65 72 20 3d 20  fer;...buffer = 
18a0: 73 74 72 63 68 72 28 62 75 66 66 65 72 2c 20 27  strchr(buffer, '
18b0: 20 27 29 3b 0a 09 69 66 20 28 62 75 66 66 65 72   ');..if (buffer
18c0: 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09 66 69   == NULL) {...fi
18d0: 6c 65 64 5f 6c 6f 67 5f 6d 73 67 28 22 47 4f 54  led_log_msg("GOT
18e0: 5f 52 45 51 55 45 53 54 20 46 44 3d 2e 2e 2e 20  _REQUEST FD=... 
18f0: 45 52 52 4f 52 3d 66 6f 72 6d 61 74 22 29 3b 0a  ERROR=format");.
1900: 0a 09 09 72 65 74 75 72 6e 28 4e 55 4c 4c 29 3b  ...return(NULL);
1910: 0a 09 7d 0a 0a 09 2a 62 75 66 66 65 72 20 3d 20  ..}...*buffer = 
1920: 27 5c 30 27 3b 0a 09 62 75 66 66 65 72 2b 2b 3b  '\0';..buffer++;
1930: 0a 0a 09 70 61 74 68 20 3d 20 62 75 66 66 65 72  ...path = buffer
1940: 3b 0a 0a 09 62 75 66 66 65 72 20 3d 20 73 74 72  ;...buffer = str
1950: 63 68 72 28 62 75 66 66 65 72 2c 20 27 20 27 29  chr(buffer, ' ')
1960: 3b 0a 09 69 66 20 28 62 75 66 66 65 72 20 21 3d  ;..if (buffer !=
1970: 20 4e 55 4c 4c 29 20 7b 0a 09 09 2a 62 75 66 66   NULL) {...*buff
1980: 65 72 20 3d 20 27 5c 30 27 3b 0a 09 09 62 75 66  er = '\0';...buf
1990: 66 65 72 2b 2b 3b 0a 09 7d 0a 0a 09 66 69 6c 65  fer++;..}...file
19a0: 64 5f 6c 6f 67 5f 6d 73 67 28 22 47 4f 54 5f 52  d_log_msg("GOT_R
19b0: 45 51 55 45 53 54 20 46 44 3d 2e 2e 2e 20 50 41  EQUEST FD=... PA
19c0: 54 48 3d 2e 2e 2e 22 29 3b 0a 0a 09 66 69 6c 65  TH=...");...file
19d0: 64 5f 6c 6f 67 5f 6d 73 67 28 22 57 41 49 54 5f  d_log_msg("WAIT_
19e0: 46 4f 52 5f 48 45 41 44 45 52 53 20 46 44 3d 2e  FOR_HEADERS FD=.
19f0: 2e 2e 22 29 3b 0a 0a 09 66 6f 72 20 28 69 20 3d  ..");...for (i =
1a00: 20 30 3b 20 69 20 3c 20 31 30 30 3b 20 69 2b 2b   0; i < 100; i++
1a10: 29 20 7b 0a 09 09 66 67 65 74 73 28 74 6d 70 62  ) {...fgets(tmpb
1a20: 75 66 66 65 72 2c 20 74 6d 70 62 75 66 66 65 72  uffer, tmpbuffer
1a30: 5f 6c 65 6e 2c 20 66 70 29 3b 0a 0a 09 09 69 66  _len, fp);....if
1a40: 20 28 73 74 72 6e 63 61 73 65 63 6d 70 28 74 6d   (strncasecmp(tm
1a50: 70 62 75 66 66 65 72 2c 20 22 52 61 6e 67 65 3a  pbuffer, "Range:
1a60: 20 22 2c 20 37 29 20 3d 3d 20 30 29 20 7b 0a 09   ", 7) == 0) {..
1a70: 09 09 77 6f 72 6b 62 75 66 66 65 72 20 3d 20 74  ..workbuffer = t
1a80: 6d 70 62 75 66 66 65 72 20 2b 20 37 3b 0a 0a 09  mpbuffer + 7;...
1a90: 09 09 69 66 20 28 73 74 72 6e 63 61 73 65 63 6d  ..if (strncasecm
1aa0: 70 28 77 6f 72 6b 62 75 66 66 65 72 2c 20 22 62  p(workbuffer, "b
1ab0: 79 74 65 73 3d 22 2c 20 36 29 20 3d 3d 20 30 29  ytes=", 6) == 0)
1ac0: 20 7b 0a 09 09 09 09 77 6f 72 6b 62 75 66 66 65   {.....workbuffe
1ad0: 72 20 2b 3d 20 36 3b 0a 0a 09 09 09 09 72 61 6e  r += 6;......ran
1ae0: 67 65 5f 73 74 61 72 74 20 3d 20 73 74 72 74 6f  ge_start = strto
1af0: 75 6c 28 77 6f 72 6b 62 75 66 66 65 72 2c 20 26  ul(workbuffer, &
1b00: 77 6f 72 6b 62 75 66 66 65 72 5f 6e 65 78 74 2c  workbuffer_next,
1b10: 20 31 30 29 3b 0a 0a 09 09 09 09 77 6f 72 6b 62   10);......workb
1b20: 75 66 66 65 72 20 3d 20 77 6f 72 6b 62 75 66 66  uffer = workbuff
1b30: 65 72 5f 6e 65 78 74 3b 0a 0a 09 09 09 09 69 66  er_next;......if
1b40: 20 28 2a 77 6f 72 6b 62 75 66 66 65 72 20 3d 3d   (*workbuffer ==
1b50: 20 27 2d 27 29 20 7b 0a 09 09 09 09 09 77 6f 72   '-') {......wor
1b60: 6b 62 75 66 66 65 72 2b 2b 3b 0a 0a 09 09 09 09  kbuffer++;......
1b70: 09 69 66 20 28 2a 77 6f 72 6b 62 75 66 66 65 72  .if (*workbuffer
1b80: 20 21 3d 20 27 5c 72 27 20 26 26 20 2a 77 6f 72   != '\r' && *wor
1b90: 6b 62 75 66 66 65 72 20 21 3d 20 27 5c 6e 27 29  kbuffer != '\n')
1ba0: 20 7b 0a 09 09 09 09 09 09 72 61 6e 67 65 5f 65   {.......range_e
1bb0: 6e 64 20 3d 20 73 74 72 74 6f 75 6c 28 77 6f 72  nd = strtoul(wor
1bc0: 6b 62 75 66 66 65 72 2c 20 26 77 6f 72 6b 62 75  kbuffer, &workbu
1bd0: 66 66 65 72 5f 6e 65 78 74 2c 20 31 30 29 3b 0a  ffer_next, 10);.
1be0: 09 09 09 09 09 7d 0a 09 09 09 09 7d 0a 09 09 09  .....}.....}....
1bf0: 7d 0a 09 09 7d 0a 0a 09 09 69 66 20 28 6d 65 6d  }...}....if (mem
1c00: 63 6d 70 28 74 6d 70 62 75 66 66 65 72 2c 20 22  cmp(tmpbuffer, "
1c10: 5c 72 5c 6e 22 2c 20 32 29 20 3d 3d 20 30 29 20  \r\n", 2) == 0) 
1c20: 7b 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09 7d 0a  {....break;...}.
1c30: 09 7d 0a 0a 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d  .}...filed_log_m
1c40: 73 67 28 22 47 4f 54 5f 48 45 41 44 45 52 53 20  sg("GOT_HEADERS 
1c50: 46 44 3d 2e 2e 2e 22 29 3b 0a 0a 09 2f 2a 20 57  FD=...");.../* W
1c60: 65 20 6f 6e 6c 79 20 68 61 6e 64 6c 65 20 74 68  e only handle th
1c70: 65 20 22 47 45 54 22 20 6d 65 74 68 6f 64 20 2a  e "GET" method *
1c80: 2f 0a 09 69 66 20 28 73 74 72 63 61 73 65 63 6d  /..if (strcasecm
1c90: 70 28 6d 65 74 68 6f 64 2c 20 22 67 65 74 22 29  p(method, "get")
1ca0: 20 21 3d 20 30 29 20 7b 0a 09 09 72 65 74 75 72   != 0) {...retur
1cb0: 6e 28 4e 55 4c 4c 29 3b 0a 09 7d 0a 0a 09 2f 2a  n(NULL);..}.../*
1cc0: 20 44 65 74 65 72 6d 69 6e 65 20 72 61 6e 67 65   Determine range
1cd0: 20 2a 2f 0a 09 69 66 20 28 72 61 6e 67 65 5f 65   */..if (range_e
1ce0: 6e 64 20 21 3d 20 30 29 20 7b 0a 09 09 69 66 20  nd != 0) {...if 
1cf0: 28 72 61 6e 67 65 5f 65 6e 64 20 3c 3d 20 72 61  (range_end <= ra
1d00: 6e 67 65 5f 73 74 61 72 74 29 20 7b 0a 09 09 09  nge_start) {....
1d10: 72 65 74 75 72 6e 28 4e 55 4c 4c 29 3b 0a 09 09  return(NULL);...
1d20: 7d 0a 0a 09 09 72 61 6e 67 65 5f 6c 65 6e 67 74  }....range_lengt
1d30: 68 20 3d 20 72 61 6e 67 65 5f 65 6e 64 20 2d 20  h = range_end - 
1d40: 72 61 6e 67 65 5f 73 74 61 72 74 3b 0a 09 7d 0a  range_start;..}.
1d50: 0a 09 2f 2a 20 46 69 6c 6c 20 75 70 20 73 74 72  ../* Fill up str
1d60: 75 63 74 75 72 65 20 74 6f 20 72 65 74 75 72 6e  ucture to return
1d70: 20 2a 2f 0a 09 62 75 66 66 65 72 5f 73 74 2d 3e   */..buffer_st->
1d80: 70 61 74 68 20 20 20 3d 20 70 61 74 68 3b 0a 09  path   = path;..
1d90: 62 75 66 66 65 72 5f 73 74 2d 3e 6f 66 66 73 65  buffer_st->offse
1da0: 74 20 3d 20 72 61 6e 67 65 5f 73 74 61 72 74 3b  t = range_start;
1db0: 0a 09 62 75 66 66 65 72 5f 73 74 2d 3e 6c 65 6e  ..buffer_st->len
1dc0: 67 74 68 20 3d 20 72 61 6e 67 65 5f 6c 65 6e 67  gth = range_leng
1dd0: 74 68 3b 0a 0a 09 72 65 74 75 72 6e 28 62 75 66  th;...return(buf
1de0: 66 65 72 5f 73 74 29 3b 0a 7d 0a 0a 2f 2a 20 52  fer_st);.}../* R
1df0: 65 74 75 72 6e 20 61 6e 20 65 72 72 6f 72 20 70  eturn an error p
1e00: 61 67 65 20 2a 2f 0a 73 74 61 74 69 63 20 76 6f  age */.static vo
1e10: 69 64 20 66 69 6c 65 64 5f 65 72 72 6f 72 5f 70  id filed_error_p
1e20: 61 67 65 28 46 49 4c 45 20 2a 66 70 2c 20 63 6f  age(FILE *fp, co
1e30: 6e 73 74 20 63 68 61 72 20 2a 64 61 74 65 5f 63  nst char *date_c
1e40: 75 72 72 65 6e 74 2c 20 69 6e 74 20 65 72 72 6f  urrent, int erro
1e50: 72 5f 6e 75 6d 62 65 72 29 20 7b 0a 09 63 68 61  r_number) {..cha
1e60: 72 20 2a 65 72 72 6f 72 5f 73 74 72 69 6e 67 20  r *error_string 
1e70: 3d 20 22 3c 68 74 6d 6c 3e 3c 68 65 61 64 3e 3c  = "<html><head><
1e80: 74 69 74 6c 65 3e 45 52 52 4f 52 3c 2f 74 69 74  title>ERROR</tit
1e90: 6c 65 3e 3c 2f 68 65 61 64 3e 3c 62 6f 64 79 3e  le></head><body>
1ea0: 55 6e 61 62 6c 65 20 74 6f 20 70 72 6f 63 65 73  Unable to proces
1eb0: 73 20 72 65 71 75 65 73 74 3c 2f 62 6f 64 79 3e  s request</body>
1ec0: 3c 2f 68 74 6d 6c 3e 22 3b 0a 0a 09 66 70 72 69  </html>";...fpri
1ed0: 6e 74 66 28 66 70 2c 20 22 48 54 54 50 2f 31 2e  ntf(fp, "HTTP/1.
1ee0: 31 20 25 69 20 4f 4b 5c 72 5c 6e 44 61 74 65 3a  1 %i OK\r\nDate:
1ef0: 20 25 73 5c 72 5c 6e 53 65 72 76 65 72 3a 20 66   %s\r\nServer: f
1f00: 69 6c 65 64 5c 72 5c 6e 4c 61 73 74 2d 4d 6f 64  iled\r\nLast-Mod
1f10: 69 66 69 65 64 3a 20 25 73 5c 72 5c 6e 43 6f 6e  ified: %s\r\nCon
1f20: 74 65 6e 74 2d 4c 65 6e 67 74 68 3a 20 25 6c 6c  tent-Length: %ll
1f30: 75 5c 72 5c 6e 43 6f 6e 74 65 6e 74 2d 54 79 70  u\r\nContent-Typ
1f40: 65 3a 20 25 73 5c 72 5c 6e 43 6f 6e 6e 65 63 74  e: %s\r\nConnect
1f50: 69 6f 6e 3a 20 63 6c 6f 73 65 5c 72 5c 6e 5c 72  ion: close\r\n\r
1f60: 5c 6e 25 73 22 2c 0a 09 09 65 72 72 6f 72 5f 6e  \n%s",...error_n
1f70: 75 6d 62 65 72 2c 0a 09 09 64 61 74 65 5f 63 75  umber,...date_cu
1f80: 72 72 65 6e 74 2c 0a 09 09 64 61 74 65 5f 63 75  rrent,...date_cu
1f90: 72 72 65 6e 74 2c 0a 09 09 28 75 6e 73 69 67 6e  rrent,...(unsign
1fa0: 65 64 20 6c 6f 6e 67 20 6c 6f 6e 67 29 20 73 74  ed long long) st
1fb0: 72 6c 65 6e 28 65 72 72 6f 72 5f 73 74 72 69 6e  rlen(error_strin
1fc0: 67 29 2c 0a 09 09 22 74 65 78 74 2f 68 74 6d 6c  g),..."text/html
1fd0: 22 2c 0a 09 09 65 72 72 6f 72 5f 73 74 72 69 6e  ",...error_strin
1fe0: 67 0a 09 29 3b 0a 7d 0a 0a 2f 2a 20 48 61 6e 64  g..);.}../* Hand
1ff0: 6c 65 20 61 20 73 69 6e 67 6c 65 20 72 65 71 75  le a single requ
2000: 65 73 74 20 66 72 6f 6d 20 61 20 63 6c 69 65 6e  est from a clien
2010: 74 20 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  t */.static void
2020: 20 66 69 6c 65 64 5f 68 61 6e 64 6c 65 5f 63 6c   filed_handle_cl
2030: 69 65 6e 74 28 69 6e 74 20 66 64 2c 20 73 74 72  ient(int fd, str
2040: 75 63 74 20 66 69 6c 65 64 5f 68 74 74 70 5f 72  uct filed_http_r
2050: 65 71 75 65 73 74 20 2a 72 65 71 75 65 73 74 29  equest *request)
2060: 20 7b 0a 09 73 74 72 75 63 74 20 66 69 6c 65 64   {..struct filed
2070: 5f 66 69 6c 65 69 6e 66 6f 20 2a 66 69 6c 65 69  _fileinfo *filei
2080: 6e 66 6f 3b 0a 09 73 73 69 7a 65 5f 74 20 73 65  nfo;..ssize_t se
2090: 6e 64 66 69 6c 65 5f 72 65 74 3b 0a 09 73 69 7a  ndfile_ret;..siz
20a0: 65 5f 74 20 73 65 6e 64 66 69 6c 65 5f 6c 65 6e  e_t sendfile_len
20b0: 3b 0a 09 6f 66 66 5f 74 20 73 65 6e 64 66 69 6c  ;..off_t sendfil
20c0: 65 5f 6f 66 66 73 65 74 3b 0a 09 63 68 61 72 20  e_offset;..char 
20d0: 2a 70 61 74 68 3b 0a 09 63 68 61 72 20 2a 64 61  *path;..char *da
20e0: 74 65 5f 63 75 72 72 65 6e 74 2c 20 64 61 74 65  te_current, date
20f0: 5f 63 75 72 72 65 6e 74 5f 62 5b 36 34 5d 3b 0a  _current_b[64];.
2100: 09 69 6e 74 20 68 74 74 70 5f 63 6f 64 65 3b 0a  .int http_code;.
2110: 09 46 49 4c 45 20 2a 66 70 3b 0a 0a 09 2f 2a 20  .FILE *fp;.../* 
2120: 44 65 74 65 72 6d 69 6e 65 20 63 75 72 72 65 6e  Determine curren
2130: 74 20 74 69 6d 65 20 2a 2f 0a 09 64 61 74 65 5f  t time */..date_
2140: 63 75 72 72 65 6e 74 20 3d 20 66 69 6c 65 64 5f  current = filed_
2150: 66 6f 72 6d 61 74 5f 74 69 6d 65 28 64 61 74 65  format_time(date
2160: 5f 63 75 72 72 65 6e 74 5f 62 2c 20 73 69 7a 65  _current_b, size
2170: 6f 66 28 64 61 74 65 5f 63 75 72 72 65 6e 74 5f  of(date_current_
2180: 62 29 2c 20 74 69 6d 65 28 4e 55 4c 4c 29 29 3b  b), time(NULL));
2190: 0a 0a 09 2f 2a 20 4f 70 65 6e 20 73 6f 63 6b 65  .../* Open socke
21a0: 74 20 61 73 20 41 4e 53 49 20 49 2f 4f 20 66 6f  t as ANSI I/O fo
21b0: 72 20 65 61 73 65 20 6f 66 20 75 73 65 20 2a 2f  r ease of use */
21c0: 0a 09 66 70 20 3d 20 66 64 6f 70 65 6e 28 66 64  ..fp = fdopen(fd
21d0: 2c 20 22 77 2b 62 22 29 3b 0a 09 69 66 20 28 66  , "w+b");..if (f
21e0: 70 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09 63  p == NULL) {...c
21f0: 6c 6f 73 65 28 66 64 29 3b 0a 0a 09 09 72 65 74  lose(fd);....ret
2200: 75 72 6e 3b 0a 09 7d 0a 0a 09 72 65 71 75 65 73  urn;..}...reques
2210: 74 20 3d 20 66 69 6c 65 64 5f 67 65 74 5f 68 74  t = filed_get_ht
2220: 74 70 5f 72 65 71 75 65 73 74 28 66 70 2c 20 72  tp_request(fp, r
2230: 65 71 75 65 73 74 29 3b 0a 0a 09 70 61 74 68 20  equest);...path 
2240: 3d 20 72 65 71 75 65 73 74 2d 3e 70 61 74 68 3b  = request->path;
2250: 0a 0a 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73 67  ...filed_log_msg
2260: 28 22 50 52 4f 43 45 53 53 5f 52 45 50 4c 59 5f  ("PROCESS_REPLY_
2270: 53 54 41 52 54 20 46 44 3d 2e 2e 2e 20 50 41 54  START FD=... PAT
2280: 48 3d 2e 2e 2e 20 52 41 4e 47 45 5f 53 54 41 52  H=... RANGE_STAR
2290: 54 3d 2e 2e 2e 20 52 41 4e 47 45 5f 4c 45 4e 47  T=... RANGE_LENG
22a0: 54 48 3d 2e 2e 2e 22 29 3b 0a 0a 09 69 66 20 28  TH=...");...if (
22b0: 70 61 74 68 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a  path == NULL) {.
22c0: 09 09 66 69 6c 65 64 5f 65 72 72 6f 72 5f 70 61  ..filed_error_pa
22d0: 67 65 28 66 70 2c 20 64 61 74 65 5f 63 75 72 72  ge(fp, date_curr
22e0: 65 6e 74 2c 20 35 30 30 29 3b 0a 0a 09 09 66 69  ent, 500);....fi
22f0: 6c 65 64 5f 6c 6f 67 5f 6d 73 67 28 22 50 52 4f  led_log_msg("PRO
2300: 43 45 53 53 5f 52 45 50 4c 59 5f 43 4f 4d 50 4c  CESS_REPLY_COMPL
2310: 45 54 45 20 46 44 3d 2e 2e 2e 20 45 52 52 4f 52  ETE FD=... ERROR
2320: 3d 35 30 30 22 29 3b 0a 0a 09 09 66 63 6c 6f 73  =500");....fclos
2330: 65 28 66 70 29 3b 0a 0a 09 09 72 65 74 75 72 6e  e(fp);....return
2340: 3b 0a 09 7d 0a 0a 09 68 74 74 70 5f 63 6f 64 65  ;..}...http_code
2350: 20 3d 20 2d 31 3b 0a 0a 09 66 69 6c 65 69 6e 66   = -1;...fileinf
2360: 6f 20 3d 20 66 69 6c 65 64 5f 6f 70 65 6e 5f 66  o = filed_open_f
2370: 69 6c 65 28 70 61 74 68 2c 20 26 72 65 71 75 65  ile(path, &reque
2380: 73 74 2d 3e 66 69 6c 65 69 6e 66 6f 29 3b 0a 09  st->fileinfo);..
2390: 69 66 20 28 66 69 6c 65 69 6e 66 6f 20 3d 3d 20  if (fileinfo == 
23a0: 4e 55 4c 4c 29 20 7b 0a 09 09 66 69 6c 65 64 5f  NULL) {...filed_
23b0: 65 72 72 6f 72 5f 70 61 67 65 28 66 70 2c 20 64  error_page(fp, d
23c0: 61 74 65 5f 63 75 72 72 65 6e 74 2c 20 34 30 34  ate_current, 404
23d0: 29 3b 0a 0a 09 09 66 69 6c 65 64 5f 6c 6f 67 5f  );....filed_log_
23e0: 6d 73 67 28 22 50 52 4f 43 45 53 53 5f 52 45 50  msg("PROCESS_REP
23f0: 4c 59 5f 43 4f 4d 50 4c 45 54 45 20 46 44 3d 2e  LY_COMPLETE FD=.
2400: 2e 2e 20 45 52 52 4f 52 3d 34 30 34 22 29 3b 0a  .. ERROR=404");.
2410: 09 7d 20 65 6c 73 65 20 7b 0a 09 09 69 66 20 28  .} else {...if (
2420: 72 65 71 75 65 73 74 2d 3e 6f 66 66 73 65 74 20  request->offset 
2430: 21 3d 20 30 20 7c 7c 20 72 65 71 75 65 73 74 2d  != 0 || request-
2440: 3e 6c 65 6e 67 74 68 20 3e 3d 20 30 29 20 7b 0a  >length >= 0) {.
2450: 09 09 09 69 66 20 28 28 73 69 7a 65 5f 74 29 20  ...if ((size_t) 
2460: 72 65 71 75 65 73 74 2d 3e 6f 66 66 73 65 74 20  request->offset 
2470: 3e 3d 20 66 69 6c 65 69 6e 66 6f 2d 3e 6c 65 6e  >= fileinfo->len
2480: 29 20 7b 0a 09 09 09 09 66 69 6c 65 64 5f 6c 6f  ) {.....filed_lo
2490: 67 5f 6d 73 67 28 22 50 52 4f 43 45 53 53 5f 52  g_msg("PROCESS_R
24a0: 45 50 4c 59 5f 43 4f 4d 50 4c 45 54 45 20 46 44  EPLY_COMPLETE FD
24b0: 3d 2e 2e 2e 20 45 52 52 4f 52 3d 34 31 36 22 29  =... ERROR=416")
24c0: 3b 0a 0a 09 09 09 09 66 69 6c 65 64 5f 65 72 72  ;......filed_err
24d0: 6f 72 5f 70 61 67 65 28 66 70 2c 20 64 61 74 65  or_page(fp, date
24e0: 5f 63 75 72 72 65 6e 74 2c 20 34 31 36 29 3b 0a  _current, 416);.
24f0: 09 09 09 7d 0a 0a 09 09 09 69 66 20 28 72 65 71  ...}.....if (req
2500: 75 65 73 74 2d 3e 6c 65 6e 67 74 68 20 3c 20 30  uest->length < 0
2510: 29 20 7b 0a 09 09 09 09 72 65 71 75 65 73 74 2d  ) {.....request-
2520: 3e 6c 65 6e 67 74 68 20 3d 20 66 69 6c 65 69 6e  >length = filein
2530: 66 6f 2d 3e 6c 65 6e 20 2d 20 72 65 71 75 65 73  fo->len - reques
2540: 74 2d 3e 6f 66 66 73 65 74 3b 0a 09 09 09 7d 0a  t->offset;....}.
2550: 0a 09 09 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73  ....filed_log_ms
2560: 67 5f 64 65 62 75 67 28 22 50 61 72 74 69 61 6c  g_debug("Partial
2570: 20 72 65 71 75 65 73 74 2c 20 73 74 61 72 74 69   request, starti
2580: 6e 67 20 61 74 3a 20 25 6c 75 20 61 6e 64 20 72  ng at: %lu and r
2590: 75 6e 6e 69 6e 67 20 66 6f 72 20 25 6c 75 20 62  unning for %lu b
25a0: 79 74 65 73 22 2c 20 28 75 6e 73 69 67 6e 65 64  ytes", (unsigned
25b0: 20 6c 6f 6e 67 29 20 72 65 71 75 65 73 74 2d 3e   long) request->
25c0: 6f 66 66 73 65 74 2c 20 28 75 6e 73 69 67 6e 65  offset, (unsigne
25d0: 64 20 6c 6f 6e 67 29 20 72 65 71 75 65 73 74 2d  d long) request-
25e0: 3e 6c 65 6e 67 74 68 29 3b 0a 0a 09 09 09 68 74  >length);.....ht
25f0: 74 70 5f 63 6f 64 65 20 3d 20 32 31 36 3b 0a 09  tp_code = 216;..
2600: 09 7d 20 65 6c 73 65 20 7b 0a 09 09 09 68 74 74  .} else {....htt
2610: 70 5f 63 6f 64 65 20 3d 20 32 30 30 3b 0a 09 09  p_code = 200;...
2620: 09 72 65 71 75 65 73 74 2d 3e 6f 66 66 73 65 74  .request->offset
2630: 20 3d 20 30 3b 0a 09 09 09 72 65 71 75 65 73 74   = 0;....request
2640: 2d 3e 6c 65 6e 67 74 68 20 3d 20 66 69 6c 65 69  ->length = filei
2650: 6e 66 6f 2d 3e 6c 65 6e 3b 0a 09 09 7d 0a 0a 09  nfo->len;...}...
2660: 09 69 66 20 28 68 74 74 70 5f 63 6f 64 65 20 3e  .if (http_code >
2670: 20 30 29 20 7b 0a 09 09 09 66 70 72 69 6e 74 66   0) {....fprintf
2680: 28 66 70 2c 20 22 48 54 54 50 2f 31 2e 31 20 25  (fp, "HTTP/1.1 %
2690: 69 20 4f 4b 5c 72 5c 6e 44 61 74 65 3a 20 25 73  i OK\r\nDate: %s
26a0: 5c 72 5c 6e 53 65 72 76 65 72 3a 20 66 69 6c 65  \r\nServer: file
26b0: 64 5c 72 5c 6e 4c 61 73 74 2d 4d 6f 64 69 66 69  d\r\nLast-Modifi
26c0: 65 64 3a 20 25 73 5c 72 5c 6e 43 6f 6e 74 65 6e  ed: %s\r\nConten
26d0: 74 2d 4c 65 6e 67 74 68 3a 20 25 6c 6c 75 5c 72  t-Length: %llu\r
26e0: 5c 6e 43 6f 6e 74 65 6e 74 2d 52 61 6e 67 65 3a  \nContent-Range:
26f0: 20 25 6c 6c 75 2d 25 6c 6c 75 2f 25 6c 6c 75 5c   %llu-%llu/%llu\
2700: 72 5c 6e 43 6f 6e 74 65 6e 74 2d 54 79 70 65 3a  r\nContent-Type:
2710: 20 25 73 5c 72 5c 6e 43 6f 6e 6e 65 63 74 69 6f   %s\r\nConnectio
2720: 6e 3a 20 63 6c 6f 73 65 5c 72 5c 6e 5c 72 5c 6e  n: close\r\n\r\n
2730: 22 2c 0a 09 09 09 09 68 74 74 70 5f 63 6f 64 65  ",.....http_code
2740: 2c 0a 09 09 09 09 64 61 74 65 5f 63 75 72 72 65  ,.....date_curre
2750: 6e 74 2c 0a 09 09 09 09 66 69 6c 65 69 6e 66 6f  nt,.....fileinfo
2760: 2d 3e 6c 61 73 74 6d 6f 64 2c 0a 09 09 09 09 28  ->lastmod,.....(
2770: 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 6c 6f  unsigned long lo
2780: 6e 67 29 20 72 65 71 75 65 73 74 2d 3e 6c 65 6e  ng) request->len
2790: 67 74 68 2c 0a 09 09 09 09 28 75 6e 73 69 67 6e  gth,.....(unsign
27a0: 65 64 20 6c 6f 6e 67 20 6c 6f 6e 67 29 20 72 65  ed long long) re
27b0: 71 75 65 73 74 2d 3e 6f 66 66 73 65 74 2c 20 28  quest->offset, (
27c0: 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 6c 6f  unsigned long lo
27d0: 6e 67 29 20 28 72 65 71 75 65 73 74 2d 3e 6f 66  ng) (request->of
27e0: 66 73 65 74 20 2b 20 72 65 71 75 65 73 74 2d 3e  fset + request->
27f0: 6c 65 6e 67 74 68 20 2d 20 31 29 2c 20 28 75 6e  length - 1), (un
2800: 73 69 67 6e 65 64 20 6c 6f 6e 67 20 6c 6f 6e 67  signed long long
2810: 29 20 66 69 6c 65 69 6e 66 6f 2d 3e 6c 65 6e 2c  ) fileinfo->len,
2820: 0a 09 09 09 09 66 69 6c 65 69 6e 66 6f 2d 3e 74  .....fileinfo->t
2830: 79 70 65 0a 09 09 09 29 3b 0a 09 09 09 66 66 6c  ype....);....ffl
2840: 75 73 68 28 66 70 29 3b 0a 0a 09 09 09 66 69 6c  ush(fp);.....fil
2850: 65 64 5f 6c 6f 67 5f 6d 73 67 28 22 50 52 4f 43  ed_log_msg("PROC
2860: 45 53 53 5f 52 45 50 4c 59 5f 43 4f 4d 50 4c 45  ESS_REPLY_COMPLE
2870: 54 45 20 46 44 3d 2e 2e 2e 20 53 54 41 54 55 53  TE FD=... STATUS
2880: 3d 32 30 30 22 29 3b 0a 0a 09 09 09 66 69 6c 65  =200");.....file
2890: 64 5f 6c 6f 67 5f 6d 73 67 28 22 53 45 4e 44 5f  d_log_msg("SEND_
28a0: 53 54 41 52 54 20 49 46 44 3d 2e 2e 2e 20 4f 46  START IFD=... OF
28b0: 44 3d 2e 2e 2e 20 42 59 54 45 53 3d 2e 2e 2e 22  D=... BYTES=..."
28c0: 29 3b 0a 0a 09 09 09 73 65 6e 64 66 69 6c 65 5f  );.....sendfile_
28d0: 6f 66 66 73 65 74 20 3d 20 72 65 71 75 65 73 74  offset = request
28e0: 2d 3e 6f 66 66 73 65 74 3b 0a 09 09 09 73 65 6e  ->offset;....sen
28f0: 64 66 69 6c 65 5f 6c 65 6e 20 3d 20 72 65 71 75  dfile_len = requ
2900: 65 73 74 2d 3e 6c 65 6e 67 74 68 3b 0a 09 09 09  est->length;....
2910: 77 68 69 6c 65 20 28 31 29 20 7b 0a 09 09 09 09  while (1) {.....
2920: 73 65 6e 64 66 69 6c 65 5f 72 65 74 20 3d 20 73  sendfile_ret = s
2930: 65 6e 64 66 69 6c 65 28 66 64 2c 20 66 69 6c 65  endfile(fd, file
2940: 69 6e 66 6f 2d 3e 66 64 2c 20 26 73 65 6e 64 66  info->fd, &sendf
2950: 69 6c 65 5f 6f 66 66 73 65 74 2c 20 73 65 6e 64  ile_offset, send
2960: 66 69 6c 65 5f 6c 65 6e 29 3b 0a 09 09 09 09 69  file_len);.....i
2970: 66 20 28 73 65 6e 64 66 69 6c 65 5f 72 65 74 20  f (sendfile_ret 
2980: 3c 3d 20 30 29 20 7b 0a 09 09 09 09 09 62 72 65  <= 0) {......bre
2990: 61 6b 3b 0a 09 09 09 09 7d 0a 0a 09 09 09 09 73  ak;.....}......s
29a0: 65 6e 64 66 69 6c 65 5f 6c 65 6e 20 2d 3d 20 73  endfile_len -= s
29b0: 65 6e 64 66 69 6c 65 5f 72 65 74 3b 0a 09 09 09  endfile_ret;....
29c0: 09 69 66 20 28 73 65 6e 64 66 69 6c 65 5f 6c 65  .if (sendfile_le
29d0: 6e 20 3d 3d 20 30 29 20 7b 0a 09 09 09 09 09 62  n == 0) {......b
29e0: 72 65 61 6b 3b 0a 09 09 09 09 7d 0a 09 09 09 7d  reak;.....}....}
29f0: 0a 0a 09 09 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d  .....filed_log_m
2a00: 73 67 28 22 53 45 4e 44 5f 43 4f 4d 50 4c 45 54  sg("SEND_COMPLET
2a10: 45 20 53 54 41 54 55 53 3d 2e 2e 2e 20 49 46 44  E STATUS=... IFD
2a20: 3d 2e 2e 2e 20 4f 46 44 3d 2e 2e 2e 20 42 59 54  =... OFD=... BYT
2a30: 45 53 3d 2e 2e 2e 20 42 59 54 45 53 5f 53 45 4e  ES=... BYTES_SEN
2a40: 54 3d 2e 2e 2e 22 29 3b 0a 09 09 7d 0a 0a 09 09  T=...");...}....
2a50: 63 6c 6f 73 65 28 66 69 6c 65 69 6e 66 6f 2d 3e  close(fileinfo->
2a60: 66 64 29 3b 0a 0a 09 09 66 69 6c 65 64 5f 6c 6f  fd);....filed_lo
2a70: 67 5f 6d 73 67 28 22 43 4c 4f 53 45 5f 46 49 4c  g_msg("CLOSE_FIL
2a80: 45 20 46 44 3d 2e 2e 2e 22 29 3b 0a 09 7d 0a 0a  E FD=...");..}..
2a90: 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73 67 28 22  .filed_log_msg("
2aa0: 43 4c 4f 53 45 5f 43 4f 4e 4e 45 43 54 49 4f 4e  CLOSE_CONNECTION
2ab0: 20 46 44 3d 2e 2e 2e 22 29 3b 0a 0a 09 66 63 6c   FD=...");...fcl
2ac0: 6f 73 65 28 66 70 29 3b 0a 0a 09 72 65 74 75 72  ose(fp);...retur
2ad0: 6e 3b 0a 7d 0a 0a 2f 2a 20 48 61 6e 64 6c 65 20  n;.}../* Handle 
2ae0: 69 6e 63 6f 6d 69 6e 67 20 63 6f 6e 6e 65 63 74  incoming connect
2af0: 69 6f 6e 73 20 2a 2f 0a 73 74 61 74 69 63 20 76  ions */.static v
2b00: 6f 69 64 20 2a 66 69 6c 65 64 5f 77 6f 72 6b 65  oid *filed_worke
2b10: 72 5f 74 68 72 65 61 64 28 76 6f 69 64 20 2a 61  r_thread(void *a
2b20: 72 67 5f 76 29 20 7b 0a 09 73 74 72 75 63 74 20  rg_v) {..struct 
2b30: 66 69 6c 65 64 5f 77 6f 72 6b 65 72 5f 74 68 72  filed_worker_thr
2b40: 65 61 64 5f 61 72 67 73 20 2a 61 72 67 3b 0a 09  ead_args *arg;..
2b50: 73 74 72 75 63 74 20 66 69 6c 65 64 5f 68 74 74  struct filed_htt
2b60: 70 5f 72 65 71 75 65 73 74 20 72 65 71 75 65 73  p_request reques
2b70: 74 3b 0a 09 73 74 72 75 63 74 20 73 6f 63 6b 61  t;..struct socka
2b80: 64 64 72 5f 69 6e 36 20 61 64 64 72 3b 0a 09 73  ddr_in6 addr;..s
2b90: 6f 63 6b 6c 65 6e 5f 74 20 61 64 64 72 6c 65 6e  ocklen_t addrlen
2ba0: 3b 0a 09 69 6e 74 20 66 61 69 6c 75 72 65 5f 63  ;..int failure_c
2bb0: 6f 75 6e 74 20 3d 20 30 2c 20 6d 61 78 5f 66 61  ount = 0, max_fa
2bc0: 69 6c 75 72 65 5f 63 6f 75 6e 74 20 3d 20 4d 41  ilure_count = MA
2bd0: 58 5f 46 41 49 4c 55 52 45 5f 43 4f 55 4e 54 3b  X_FAILURE_COUNT;
2be0: 0a 09 69 6e 74 20 6d 61 73 74 65 72 5f 66 64 2c  ..int master_fd,
2bf0: 20 66 64 3b 0a 0a 09 2f 2a 20 52 65 61 64 20 61   fd;.../* Read a
2c00: 72 67 75 6d 65 6e 74 73 20 2a 2f 0a 09 61 72 67  rguments */..arg
2c10: 20 3d 20 61 72 67 5f 76 3b 0a 0a 09 6d 61 73 74   = arg_v;...mast
2c20: 65 72 5f 66 64 20 3d 20 61 72 67 2d 3e 66 64 3b  er_fd = arg->fd;
2c30: 0a 0a 09 77 68 69 6c 65 20 28 31 29 20 7b 0a 09  ...while (1) {..
2c40: 09 2f 2a 20 46 61 69 6c 75 72 65 20 6c 6f 6f 70  ./* Failure loop
2c50: 20 70 72 65 76 65 6e 74 69 6f 6e 20 2a 2f 0a 09   prevention */..
2c60: 09 69 66 20 28 66 61 69 6c 75 72 65 5f 63 6f 75  .if (failure_cou
2c70: 6e 74 20 3e 20 6d 61 78 5f 66 61 69 6c 75 72 65  nt > max_failure
2c80: 5f 63 6f 75 6e 74 29 20 7b 0a 09 09 09 62 72 65  _count) {....bre
2c90: 61 6b 3b 0a 09 09 7d 0a 0a 09 09 2f 2a 20 41 63  ak;...}..../* Ac
2ca0: 63 65 70 74 20 61 20 6e 65 77 20 63 6c 69 65 6e  cept a new clien
2cb0: 74 20 2a 2f 0a 09 09 61 64 64 72 6c 65 6e 20 3d  t */...addrlen =
2cc0: 20 73 69 7a 65 6f 66 28 61 64 64 72 29 3b 0a 09   sizeof(addr);..
2cd0: 09 66 64 20 3d 20 61 63 63 65 70 74 28 6d 61 73  .fd = accept(mas
2ce0: 74 65 72 5f 66 64 2c 20 28 73 74 72 75 63 74 20  ter_fd, (struct 
2cf0: 73 6f 63 6b 61 64 64 72 20 2a 29 20 26 61 64 64  sockaddr *) &add
2d00: 72 2c 20 26 61 64 64 72 6c 65 6e 29 3b 0a 0a 09  r, &addrlen);...
2d10: 09 2f 2a 0a 09 09 20 2a 20 49 66 20 77 65 20 66  ./*... * If we f
2d20: 61 69 6c 2c 20 6d 61 6b 65 20 61 20 6e 6f 74 65  ail, make a note
2d30: 20 6f 66 20 69 74 20 73 6f 20 77 65 20 64 6f 6e   of it so we don
2d40: 27 74 20 67 6f 20 69 6e 74 6f 20 61 20 6c 6f 6f  't go into a loo
2d50: 70 20 6f 66 0a 09 09 20 2a 20 61 63 63 65 70 74  p of... * accept
2d60: 28 29 20 66 61 69 6c 69 6e 67 0a 09 09 20 2a 2f  () failing... */
2d70: 0a 09 09 69 66 20 28 66 64 20 3c 20 30 29 20 7b  ...if (fd < 0) {
2d80: 0a 09 09 09 2f 2a 20 4c 6f 67 20 74 68 65 20 6e  ..../* Log the n
2d90: 65 77 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f  ew connection */
2da0: 0a 09 09 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d 73  ....filed_log_ms
2db0: 67 28 22 41 43 43 45 50 54 5f 46 41 49 4c 45 44  g("ACCEPT_FAILED
2dc0: 22 29 3b 0a 0a 09 09 09 66 61 69 6c 75 72 65 5f  ");.....failure_
2dd0: 63 6f 75 6e 74 2b 2b 3b 0a 0a 09 09 09 63 6f 6e  count++;.....con
2de0: 74 69 6e 75 65 3b 0a 09 09 7d 0a 0a 09 09 2f 2a  tinue;...}..../*
2df0: 20 4c 6f 67 20 74 68 65 20 6e 65 77 20 63 6f 6e   Log the new con
2e00: 6e 65 63 74 69 6f 6e 20 2a 2f 0a 09 09 66 69 6c  nection */...fil
2e10: 65 64 5f 6c 6f 67 5f 6d 73 67 28 22 4e 45 57 5f  ed_log_msg("NEW_
2e20: 43 4f 4e 4e 45 43 54 49 4f 4e 20 53 52 43 5f 41  CONNECTION SRC_A
2e30: 44 44 52 3d 2e 2e 2e 20 53 52 43 5f 50 4f 52 54  DDR=... SRC_PORT
2e40: 3d 2e 2e 2e 20 46 44 3d 2e 2e 2e 22 29 3b 0a 0a  =... FD=...");..
2e50: 09 09 2f 2a 20 52 65 73 65 74 20 66 61 69 6c 75  ../* Reset failu
2e60: 72 65 20 63 6f 75 6e 74 2a 2f 0a 09 09 66 61 69  re count*/...fai
2e70: 6c 75 72 65 5f 63 6f 75 6e 74 20 3d 20 30 3b 0a  lure_count = 0;.
2e80: 0a 09 09 2f 2a 20 48 61 6e 64 6c 65 20 73 6f 63  .../* Handle soc
2e90: 6b 65 74 20 2a 2f 0a 09 09 66 69 6c 65 64 5f 68  ket */...filed_h
2ea0: 61 6e 64 6c 65 5f 63 6c 69 65 6e 74 28 66 64 2c  andle_client(fd,
2eb0: 20 26 72 65 71 75 65 73 74 29 3b 0a 09 7d 0a 0a   &request);..}..
2ec0: 09 2f 2a 20 52 65 70 6f 72 74 20 65 72 72 6f 72  ./* Report error
2ed0: 20 2a 2f 0a 09 66 69 6c 65 64 5f 6c 6f 67 5f 6d   */..filed_log_m
2ee0: 73 67 28 22 54 48 52 45 41 44 5f 44 49 45 44 20  sg("THREAD_DIED 
2ef0: 41 42 4e 4f 52 4d 41 4c 22 29 3b 0a 0a 09 72 65  ABNORMAL");...re
2f00: 74 75 72 6e 28 4e 55 4c 4c 29 3b 0a 7d 0a 0a 2f  turn(NULL);.}../
2f10: 2a 20 43 72 65 61 74 65 20 77 6f 72 6b 65 72 20  * Create worker 
2f20: 74 68 72 65 61 64 73 20 2a 2f 0a 73 74 61 74 69  threads */.stati
2f30: 63 20 69 6e 74 20 66 69 6c 65 64 5f 77 6f 72 6b  c int filed_work
2f40: 65 72 5f 74 68 72 65 61 64 73 5f 69 6e 69 74 28  er_threads_init(
2f50: 69 6e 74 20 66 64 2c 20 69 6e 74 20 74 68 72 65  int fd, int thre
2f60: 61 64 5f 63 6f 75 6e 74 29 20 7b 0a 09 73 74 72  ad_count) {..str
2f70: 75 63 74 20 66 69 6c 65 64 5f 77 6f 72 6b 65 72  uct filed_worker
2f80: 5f 74 68 72 65 61 64 5f 61 72 67 73 20 2a 61 72  _thread_args *ar
2f90: 67 3b 0a 09 70 74 68 72 65 61 64 5f 74 20 74 68  g;..pthread_t th
2fa0: 72 65 61 64 69 64 3b 0a 09 69 6e 74 20 70 74 68  readid;..int pth
2fb0: 72 65 61 64 5f 72 65 74 3b 0a 09 69 6e 74 20 69  read_ret;..int i
2fc0: 3b 0a 0a 09 66 6f 72 20 28 69 20 3d 20 30 3b 20  ;...for (i = 0; 
2fd0: 69 20 3c 20 74 68 72 65 61 64 5f 63 6f 75 6e 74  i < thread_count
2fe0: 3b 20 69 2b 2b 29 20 7b 0a 09 09 61 72 67 20 3d  ; i++) {...arg =
2ff0: 20 6d 61 6c 6c 6f 63 28 73 69 7a 65 6f 66 28 2a   malloc(sizeof(*
3000: 61 72 67 29 29 3b 0a 0a 09 09 61 72 67 2d 3e 66  arg));....arg->f
3010: 64 20 3d 20 66 64 3b 0a 0a 09 09 70 74 68 72 65  d = fd;....pthre
3020: 61 64 5f 72 65 74 20 3d 20 70 74 68 72 65 61 64  ad_ret = pthread
3030: 5f 63 72 65 61 74 65 28 26 74 68 72 65 61 64 69  _create(&threadi
3040: 64 2c 20 4e 55 4c 4c 2c 20 66 69 6c 65 64 5f 77  d, NULL, filed_w
3050: 6f 72 6b 65 72 5f 74 68 72 65 61 64 2c 20 61 72  orker_thread, ar
3060: 67 29 3b 0a 09 09 69 66 20 28 70 74 68 72 65 61  g);...if (pthrea
3070: 64 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09 09  d_ret != 0) {...
3080: 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 09 7d  .return(-1);...}
3090: 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28 30 29 3b  ..}...return(0);
30a0: 0a 7d 0a 0a 2f 2a 20 52 75 6e 20 70 72 6f 63 65  .}../* Run proce
30b0: 73 73 20 2a 2f 0a 69 6e 74 20 6d 61 69 6e 28 69  ss */.int main(i
30c0: 6e 74 20 61 72 67 63 2c 20 63 68 61 72 20 2a 2a  nt argc, char **
30d0: 61 72 67 76 29 20 7b 0a 09 69 6e 74 20 70 6f 72  argv) {..int por
30e0: 74 20 3d 20 50 4f 52 54 2c 20 74 68 72 65 61 64  t = PORT, thread
30f0: 5f 63 6f 75 6e 74 20 3d 20 54 48 52 45 41 44 5f  _count = THREAD_
3100: 43 4f 55 4e 54 3b 0a 09 63 6f 6e 73 74 20 63 68  COUNT;..const ch
3110: 61 72 20 2a 62 69 6e 64 5f 61 64 64 72 20 3d 20  ar *bind_addr = 
3120: 42 49 4e 44 5f 41 44 44 52 3b 0a 09 69 6e 74 20  BIND_ADDR;..int 
3130: 69 6e 69 74 5f 72 65 74 3b 0a 09 69 6e 74 20 66  init_ret;..int f
3140: 64 3b 0a 0a 09 2f 2a 20 58 58 58 3a 20 54 4f 44  d;.../* XXX: TOD
3150: 4f 3a 20 50 72 6f 63 65 73 73 20 61 72 67 75 6d  O: Process argum
3160: 65 6e 74 73 20 2a 2f 0a 09 61 72 67 63 20 3d 20  ents */..argc = 
3170: 61 72 67 63 3b 0a 09 61 72 67 76 20 3d 20 61 72  argc;..argv = ar
3180: 67 76 3b 0a 0a 09 2f 2a 20 43 72 65 61 74 65 20  gv;.../* Create 
3190: 6c 69 73 74 65 6e 69 6e 67 20 73 6f 63 6b 65 74  listening socket
31a0: 20 2a 2f 0a 09 66 64 20 3d 20 66 69 6c 65 64 5f   */..fd = filed_
31b0: 6c 69 73 74 65 6e 28 62 69 6e 64 5f 61 64 64 72  listen(bind_addr
31c0: 2c 20 70 6f 72 74 29 3b 0a 09 69 66 20 28 66 64  , port);..if (fd
31d0: 20 3c 20 30 29 20 7b 0a 09 09 70 65 72 72 6f 72   < 0) {...perror
31e0: 28 22 66 69 6c 65 64 5f 6c 69 73 74 65 6e 22 29  ("filed_listen")
31f0: 3b 0a 0a 09 09 72 65 74 75 72 6e 28 31 29 3b 0a  ;....return(1);.
3200: 09 7d 0a 0a 09 2f 2a 20 42 65 63 6f 6d 65 20 61  .}.../* Become a
3210: 20 64 61 65 6d 6f 6e 20 2a 2f 0a 09 2f 2a 20 58   daemon */../* X
3220: 58 58 3a 54 4f 44 4f 3a 20 42 65 63 6f 6d 65 20  XX:TODO: Become 
3230: 61 20 64 61 65 6d 6f 6e 20 2a 2f 0a 0a 09 2f 2a  a daemon */.../*
3240: 20 49 6e 69 74 69 61 6c 69 7a 65 20 2a 2f 0a 09   Initialize */..
3250: 69 6e 69 74 5f 72 65 74 20 3d 20 66 69 6c 65 64  init_ret = filed
3260: 5f 69 6e 69 74 28 29 3b 0a 09 69 66 20 28 69 6e  _init();..if (in
3270: 69 74 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09  it_ret != 0) {..
3280: 09 70 65 72 72 6f 72 28 22 66 69 6c 65 64 5f 69  .perror("filed_i
3290: 6e 69 74 22 29 3b 0a 0a 09 09 72 65 74 75 72 6e  nit");....return
32a0: 28 33 29 3b 0a 09 7d 0a 0a 09 2f 2a 20 43 72 65  (3);..}.../* Cre
32b0: 61 74 65 20 6c 6f 67 67 69 6e 67 20 74 68 72 65  ate logging thre
32c0: 61 64 20 2a 2f 0a 09 69 6e 69 74 5f 72 65 74 20  ad */..init_ret 
32d0: 3d 20 66 69 6c 65 64 5f 6c 6f 67 67 69 6e 67 5f  = filed_logging_
32e0: 74 68 72 65 61 64 5f 69 6e 69 74 28 29 3b 0a 09  thread_init();..
32f0: 69 66 20 28 69 6e 69 74 5f 72 65 74 20 21 3d 20  if (init_ret != 
3300: 30 29 20 7b 0a 09 09 70 65 72 72 6f 72 28 22 66  0) {...perror("f
3310: 69 6c 65 64 5f 6c 6f 67 67 69 6e 67 5f 74 68 72  iled_logging_thr
3320: 65 61 64 5f 69 6e 69 74 22 29 3b 0a 0a 09 09 72  ead_init");....r
3330: 65 74 75 72 6e 28 34 29 3b 0a 09 7d 0a 0a 09 2f  eturn(4);..}.../
3340: 2a 20 43 72 65 61 74 65 20 77 6f 72 6b 65 72 20  * Create worker 
3350: 74 68 72 65 61 64 73 20 2a 2f 0a 09 69 6e 69 74  threads */..init
3360: 5f 72 65 74 20 3d 20 66 69 6c 65 64 5f 77 6f 72  _ret = filed_wor
3370: 6b 65 72 5f 74 68 72 65 61 64 73 5f 69 6e 69 74  ker_threads_init
3380: 28 66 64 2c 20 74 68 72 65 61 64 5f 63 6f 75 6e  (fd, thread_coun
3390: 74 29 3b 0a 09 69 66 20 28 69 6e 69 74 5f 72 65  t);..if (init_re
33a0: 74 20 21 3d 20 30 29 20 7b 0a 09 09 70 65 72 72  t != 0) {...perr
33b0: 6f 72 28 22 66 69 6c 65 64 5f 77 6f 72 6b 65 72  or("filed_worker
33c0: 5f 74 68 72 65 61 64 73 5f 69 6e 69 74 22 29 3b  _threads_init");
33d0: 0a 0a 09 09 72 65 74 75 72 6e 28 34 29 3b 0a 09  ....return(4);..
33e0: 7d 0a 0a 09 2f 2a 20 57 61 69 74 20 66 6f 72 20  }.../* Wait for 
33f0: 74 68 72 65 61 64 73 20 74 6f 20 65 78 69 74 20  threads to exit 
3400: 2a 2f 0a 09 2f 2a 20 58 58 58 3a 54 4f 44 4f 3a  */../* XXX:TODO:
3410: 20 4d 6f 6e 69 74 6f 72 20 74 68 72 65 61 64 20   Monitor thread 
3420: 75 73 61 67 65 20 2a 2f 0a 09 77 68 69 6c 65 20  usage */..while 
3430: 28 31 29 20 7b 0a 09 09 73 6c 65 65 70 28 36 30  (1) {...sleep(60
3440: 29 3b 0a 09 7d 0a 0a 09 2f 2a 20 52 65 74 75 72  );..}.../* Retur
3450: 6e 20 69 6e 20 66 61 69 6c 75 72 65 20 2a 2f 0a  n in failure */.
3460: 09 72 65 74 75 72 6e 28 32 29 3b 0a 7d 0a        .return(2);.}.