fs.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /**
  2. * Copyright (c) 2001-2003 Swedish Institute of Computer Science.
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without modification,
  6. * are permitted provided that the following conditions are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright notice,
  9. * this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright notice,
  11. * this list of conditions and the following disclaimer in the documentation
  12. * and/or other materials provided with the distribution.
  13. * 3. The name of the author may not be used to endorse or promote products
  14. * derived from this software without specific prior written permission.
  15. *
  16. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
  17. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  18. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
  19. * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  20. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
  21. * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  22. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  23. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
  24. * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
  25. * OF SUCH DAMAGE.
  26. *
  27. * This file is part of the lwIP TCP/IP stack.
  28. *
  29. * Author: Adam Dunkels <adam@sics.se>
  30. *
  31. **/
  32. #ifndef __FS_H__
  33. #define __FS_H__
  34. #include "lwip/opt.h"
  35. /** Set this to 1 and provide the functions:
  36. * - "int fs_open_custom(struct fs_file *file, const char *name)"
  37. * Called first for every opened file to allow opening files
  38. * that are not included in fsdata(_custom).c
  39. * - "void fs_close_custom(struct fs_file *file)"
  40. * Called to free resources allocated by fs_open_custom().
  41. */
  42. #ifndef LWIP_HTTPD_CUSTOM_FILES
  43. #define LWIP_HTTPD_CUSTOM_FILES 0
  44. #endif
  45. /** Set this to 1 to include an application state argument per file
  46. * that is opened. This allows to keep a state per connection/file.
  47. */
  48. #ifndef LWIP_HTTPD_FILE_STATE
  49. #define LWIP_HTTPD_FILE_STATE 0
  50. #endif
  51. /** HTTPD_PRECALCULATED_CHECKSUM==1: include precompiled checksums for
  52. * predefined (MSS-sized) chunks of the files to prevent having to calculate
  53. * the checksums at runtime. */
  54. #ifndef HTTPD_PRECALCULATED_CHECKSUM
  55. #define HTTPD_PRECALCULATED_CHECKSUM 0
  56. #endif
  57. #if HTTPD_PRECALCULATED_CHECKSUM
  58. struct fsdata_chksum {
  59. u32_t offset;
  60. u16_t chksum;
  61. u16_t len;
  62. };
  63. #endif /* HTTPD_PRECALCULATED_CHECKSUM */
  64. struct fs_file {
  65. const char *data;
  66. int len;
  67. int index;
  68. void *pextension;
  69. #if HTTPD_PRECALCULATED_CHECKSUM
  70. const struct fsdata_chksum *chksum;
  71. u16_t chksum_count;
  72. #endif /* HTTPD_PRECALCULATED_CHECKSUM */
  73. u8_t http_header_included;
  74. #if LWIP_HTTPD_CUSTOM_FILES
  75. u8_t is_custom_file;
  76. #endif /* LWIP_HTTPD_CUSTOM_FILES */
  77. #if LWIP_HTTPD_FILE_STATE
  78. void *state;
  79. #endif /* LWIP_HTTPD_FILE_STATE */
  80. };
  81. struct fs_file *fs_open(const char *name);
  82. void fs_close(struct fs_file *file);
  83. int fs_read(struct fs_file *file, char *buffer, int count);
  84. int fs_bytes_left(struct fs_file *file);
  85. struct fs_file *fs_open(const char *name);
  86. #if LWIP_HTTPD_FILE_STATE
  87. /** This user-defined function is called when a file is opened. */
  88. void *fs_state_init(struct fs_file *file, const char *name);
  89. /** This user-defined function is called when a file is closed. */
  90. void fs_state_free(struct fs_file *file, void *state);
  91. #endif /* #if LWIP_HTTPD_FILE_STATE */
  92. #endif /* __FS_H__ */