archive_read_support_format_empty.c 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*-
  2. * Copyright (c) 2003-2007 Tim Kientzle
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. *
  14. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
  15. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  16. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  17. * IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
  18. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  19. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  20. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  21. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  22. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  23. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  24. */
  25. #include "archive_platform.h"
  26. #include "archive.h"
  27. #include "archive_entry.h"
  28. #include "archive_private.h"
  29. #include "archive_read_private.h"
  30. static int archive_read_format_empty_bid(struct archive_read *, int);
  31. static int archive_read_format_empty_read_data(struct archive_read *,
  32. const void **, size_t *, int64_t *);
  33. static int archive_read_format_empty_read_header(struct archive_read *,
  34. struct archive_entry *);
  35. int
  36. archive_read_support_format_empty(struct archive *_a)
  37. {
  38. struct archive_read *a = (struct archive_read *)_a;
  39. int r;
  40. archive_check_magic(_a, ARCHIVE_READ_MAGIC,
  41. ARCHIVE_STATE_NEW, "archive_read_support_format_empty");
  42. r = __archive_read_register_format(a,
  43. NULL,
  44. "empty",
  45. archive_read_format_empty_bid,
  46. NULL,
  47. archive_read_format_empty_read_header,
  48. archive_read_format_empty_read_data,
  49. NULL,
  50. NULL,
  51. NULL,
  52. NULL,
  53. NULL);
  54. return (r);
  55. }
  56. static int
  57. archive_read_format_empty_bid(struct archive_read *a, int best_bid)
  58. {
  59. if (best_bid < 1 && __archive_read_ahead(a, 1, NULL) == NULL)
  60. return (1);
  61. return (-1);
  62. }
  63. static int
  64. archive_read_format_empty_read_header(struct archive_read *a,
  65. struct archive_entry *entry)
  66. {
  67. (void)a; /* UNUSED */
  68. (void)entry; /* UNUSED */
  69. a->archive.archive_format = ARCHIVE_FORMAT_EMPTY;
  70. a->archive.archive_format_name = "Empty file";
  71. return (ARCHIVE_EOF);
  72. }
  73. static int
  74. archive_read_format_empty_read_data(struct archive_read *a,
  75. const void **buff, size_t *size, int64_t *offset)
  76. {
  77. (void)a; /* UNUSED */
  78. (void)buff; /* UNUSED */
  79. (void)size; /* UNUSED */
  80. (void)offset; /* UNUSED */
  81. return (ARCHIVE_EOF);
  82. }