Audio plugin host https://kx.studio/carla
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

88 lines
2.2KB

  1. /*
  2. * DISTRHO Plugin Framework (DPF)
  3. * Copyright (C) 2012-2014 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any purpose with
  6. * or without fee is hereby granted, provided that the above copyright notice and this
  7. * permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD
  10. * TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN
  11. * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  12. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
  13. * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef DGL_APP_HPP_INCLUDED
  17. #define DGL_APP_HPP_INCLUDED
  18. #include "Base.hpp"
  19. START_NAMESPACE_DGL
  20. class Window;
  21. // -----------------------------------------------------------------------
  22. /**
  23. Base DGL Application class.
  24. One application instance is required for creating a window.
  25. There's no single/global application instance in DGL, and multiple
  26. windows can share the same app instance.
  27. In standalone mode an application will automatically quit its
  28. event-loop when all its windows are closed.
  29. */
  30. class App
  31. {
  32. public:
  33. /**
  34. Constructor.
  35. */
  36. App();
  37. /**
  38. Destructor.
  39. */
  40. ~App();
  41. /**
  42. Idle function.
  43. This calls all this app Windows' idle functions and idle callbacks.
  44. */
  45. void idle();
  46. /**
  47. Run the application event-loop until all Windows are closed.
  48. @idle() is called at regular intervals.
  49. */
  50. void exec();
  51. /**
  52. Quit the application.
  53. This stops the event-loop and closes all Windows.
  54. */
  55. void quit();
  56. /**
  57. Check if the application is about to quit.
  58. Returning true means there's no event-loop running at the moment.
  59. */
  60. bool isQuiting() const noexcept;
  61. private:
  62. struct PrivateData;
  63. PrivateData* const pData;
  64. friend class Window;
  65. DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(App)
  66. };
  67. // -----------------------------------------------------------------------
  68. END_NAMESPACE_DGL
  69. #endif // DGL_APP_HPP_INCLUDED