/generated/gtkd/gio/TcpConnection.d

http://github.com/gtkd-developers/GtkD · D · 107 lines · 36 code · 13 blank · 58 comment · 2 complexity · 3ae7b1d9c6b1584e14d9396d3ad04426 MD5 · raw file

  1. /*
  2. * This file is part of gtkD.
  3. *
  4. * gtkD is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU Lesser General Public License
  6. * as published by the Free Software Foundation; either version 3
  7. * of the License, or (at your option) any later version, with
  8. * some exceptions, please read the COPYING file.
  9. *
  10. * gtkD is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU Lesser General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU Lesser General Public License
  16. * along with gtkD; if not, write to the Free Software
  17. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
  18. */
  19. // generated automatically - do not change
  20. // find conversion definition on APILookup.txt
  21. // implement new conversion functionalities on the wrap.utils pakage
  22. module gio.TcpConnection;
  23. private import gio.SocketConnection;
  24. private import gio.c.functions;
  25. public import gio.c.types;
  26. public import gtkc.giotypes;
  27. /**
  28. * This is the subclass of #GSocketConnection that is created
  29. * for TCP/IP sockets.
  30. *
  31. * Since: 2.22
  32. */
  33. public class TcpConnection : SocketConnection
  34. {
  35. /** the main Gtk struct */
  36. protected GTcpConnection* gTcpConnection;
  37. /** Get the main Gtk struct */
  38. public GTcpConnection* getTcpConnectionStruct(bool transferOwnership = false)
  39. {
  40. if (transferOwnership)
  41. ownedRef = false;
  42. return gTcpConnection;
  43. }
  44. /** the main Gtk struct as a void* */
  45. protected override void* getStruct()
  46. {
  47. return cast(void*)gTcpConnection;
  48. }
  49. /**
  50. * Sets our main struct and passes it to the parent class.
  51. */
  52. public this (GTcpConnection* gTcpConnection, bool ownedRef = false)
  53. {
  54. this.gTcpConnection = gTcpConnection;
  55. super(cast(GSocketConnection*)gTcpConnection, ownedRef);
  56. }
  57. /** */
  58. public static GType getType()
  59. {
  60. return g_tcp_connection_get_type();
  61. }
  62. /**
  63. * Checks if graceful disconnects are used. See
  64. * g_tcp_connection_set_graceful_disconnect().
  65. *
  66. * Returns: %TRUE if graceful disconnect is used on close, %FALSE otherwise
  67. *
  68. * Since: 2.22
  69. */
  70. public bool getGracefulDisconnect()
  71. {
  72. return g_tcp_connection_get_graceful_disconnect(gTcpConnection) != 0;
  73. }
  74. /**
  75. * This enables graceful disconnects on close. A graceful disconnect
  76. * means that we signal the receiving end that the connection is terminated
  77. * and wait for it to close the connection before closing the connection.
  78. *
  79. * A graceful disconnect means that we can be sure that we successfully sent
  80. * all the outstanding data to the other end, or get an error reported.
  81. * However, it also means we have to wait for all the data to reach the
  82. * other side and for it to acknowledge this by closing the socket, which may
  83. * take a while. For this reason it is disabled by default.
  84. *
  85. * Params:
  86. * gracefulDisconnect = Whether to do graceful disconnects or not
  87. *
  88. * Since: 2.22
  89. */
  90. public void setGracefulDisconnect(bool gracefulDisconnect)
  91. {
  92. g_tcp_connection_set_graceful_disconnect(gTcpConnection, gracefulDisconnect);
  93. }
  94. }