gpollableinputstream.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /* GIO - GLib Input, Output and Streaming Library
  2. *
  3. * Copyright (C) 2010 Red Hat, Inc.
  4. *
  5. * SPDX-License-Identifier: LGPL-2.1-or-later
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2.1 of the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General
  18. * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
  19. */
  20. #ifndef __G_POLLABLE_INPUT_STREAM_H__
  21. #define __G_POLLABLE_INPUT_STREAM_H__
  22. #if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
  23. #error "Only <gio/gio.h> can be included directly."
  24. #endif
  25. #include <gio/gio.h>
  26. G_BEGIN_DECLS
  27. #define G_TYPE_POLLABLE_INPUT_STREAM (g_pollable_input_stream_get_type ())
  28. #define G_POLLABLE_INPUT_STREAM(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), G_TYPE_POLLABLE_INPUT_STREAM, GPollableInputStream))
  29. #define G_IS_POLLABLE_INPUT_STREAM(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), G_TYPE_POLLABLE_INPUT_STREAM))
  30. #define G_POLLABLE_INPUT_STREAM_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), G_TYPE_POLLABLE_INPUT_STREAM, GPollableInputStreamInterface))
  31. typedef struct _GPollableInputStreamInterface GPollableInputStreamInterface;
  32. /**
  33. * GPollableInputStreamInterface:
  34. * @g_iface: The parent interface.
  35. * @can_poll: Checks if the #GPollableInputStream instance is actually pollable
  36. * @is_readable: Checks if the stream is readable
  37. * @create_source: Creates a #GSource to poll the stream
  38. * @read_nonblocking: Does a non-blocking read or returns
  39. * %G_IO_ERROR_WOULD_BLOCK
  40. *
  41. * The interface for pollable input streams.
  42. *
  43. * The default implementation of @can_poll always returns %TRUE.
  44. *
  45. * The default implementation of @read_nonblocking calls
  46. * g_pollable_input_stream_is_readable(), and then calls
  47. * g_input_stream_read() if it returns %TRUE. This means you only need
  48. * to override it if it is possible that your @is_readable
  49. * implementation may return %TRUE when the stream is not actually
  50. * readable.
  51. *
  52. * Since: 2.28
  53. */
  54. struct _GPollableInputStreamInterface
  55. {
  56. GTypeInterface g_iface;
  57. /* Virtual Table */
  58. gboolean (*can_poll) (GPollableInputStream *stream);
  59. gboolean (*is_readable) (GPollableInputStream *stream);
  60. GSource * (*create_source) (GPollableInputStream *stream,
  61. GCancellable *cancellable);
  62. gssize (*read_nonblocking) (GPollableInputStream *stream,
  63. void *buffer,
  64. gsize count,
  65. GError **error);
  66. };
  67. GIO_AVAILABLE_IN_ALL
  68. GType g_pollable_input_stream_get_type (void) G_GNUC_CONST;
  69. GIO_AVAILABLE_IN_ALL
  70. gboolean g_pollable_input_stream_can_poll (GPollableInputStream *stream);
  71. GIO_AVAILABLE_IN_ALL
  72. gboolean g_pollable_input_stream_is_readable (GPollableInputStream *stream);
  73. GIO_AVAILABLE_IN_ALL
  74. GSource *g_pollable_input_stream_create_source (GPollableInputStream *stream,
  75. GCancellable *cancellable);
  76. GIO_AVAILABLE_IN_ALL
  77. gssize g_pollable_input_stream_read_nonblocking (GPollableInputStream *stream,
  78. void *buffer,
  79. gsize count,
  80. GCancellable *cancellable,
  81. GError **error);
  82. G_END_DECLS
  83. #endif /* __G_POLLABLE_INPUT_STREAM_H__ */