Kernel.java 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /*
  2. * Copyright (c) 2011 jMonkeyEngine
  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 are
  7. * met:
  8. *
  9. * * Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. *
  12. * * Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. *
  16. * * Neither the name of 'jMonkeyEngine' nor the names of its contributors
  17. * may be used to endorse or promote products derived from this software
  18. * without specific prior written permission.
  19. *
  20. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  21. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
  22. * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  23. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  24. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  25. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  26. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  27. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  28. * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  29. * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  30. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  31. */
  32. package com.jme3.network.kernel;
  33. import java.nio.ByteBuffer;
  34. import java.util.Collection;
  35. /**
  36. * Defines the basic byte[] passing messaging
  37. * kernel.
  38. *
  39. * @version $Revision$
  40. * @author Paul Speed
  41. */
  42. public interface Kernel
  43. {
  44. /**
  45. * Initializes the kernel and starts any internal processing.
  46. */
  47. public void initialize();
  48. /**
  49. * Gracefully terminates the kernel and stops any internal
  50. * daemon processing. This method will not return until all
  51. * internal threads have been shut down.
  52. */
  53. public void terminate() throws InterruptedException;
  54. /**
  55. * Dispatches the data to all endpoints managed by the
  56. * kernel. 'routing' is currently ignored.
  57. */
  58. public void broadcast( Object routing, ByteBuffer data, boolean reliable );
  59. /**
  60. * Returns true if there are waiting envelopes.
  61. */
  62. public boolean hasEnvelopes();
  63. /**
  64. * Removes one envelope from the received messages queue or
  65. * blocks until one is available.
  66. */
  67. public Envelope read() throws InterruptedException;
  68. /**
  69. * Removes and returnsn one endpoint event from the event queue or
  70. * null if there are no endpoint events.
  71. */
  72. public EndpointEvent nextEvent();
  73. }