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.

62 lines
2.1KB

  1. /*
  2. * DISTRHO Cardinal Plugin
  3. * Copyright (C) 2021 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation; either version 3 of
  8. * the License, or any later version.
  9. *
  10. * This program 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 General Public License for more details.
  14. *
  15. * For a full copy of the GNU General Public License see the LICENSE file.
  16. */
  17. #pragma once
  18. #ifdef PRIVATE
  19. # define PRIVATE_WAS_DEFINED
  20. #endif
  21. #include_next "common.hpp"
  22. // Make binary resources work the same no matter the OS
  23. #undef BINARY
  24. #undef BINARY_START
  25. #undef BINARY_END
  26. #undef BINARY_SIZE
  27. #define BINARY(sym) extern const unsigned char sym[]; extern const unsigned int sym##_len
  28. #define BINARY_START(sym) ((const void*) sym)
  29. #define BINARY_END(sym) ((const void*) sym + sym##_len)
  30. #define BINARY_SIZE(sym) (sym##_len)
  31. #if defined(PRIVATE) && !defined(PRIVATE_WAS_DEFINED)
  32. # undef PRIVATE
  33. #endif
  34. #undef PRIVATE_WAS_DEFINED
  35. // Cardinal specific API
  36. #include <functional>
  37. #define USING_CARDINAL_NOT_RACK
  38. // opens a file browser, startDir and title can be null
  39. // action is always triggered on close (path can be null), must be freed if not null
  40. void async_dialog_filebrowser(bool saving, const char* startDir, const char* title,
  41. std::function<void(char* path)> action);
  42. // opens a message dialog with only an "ok" button
  43. void async_dialog_message(const char* message);
  44. // opens a message dialog with "ok" and "cancel" buttons
  45. // action is triggered if user presses "ok"
  46. void async_dialog_message(const char* message, std::function<void()> action);
  47. // opens a text input dialog, message and text can be null
  48. // action is always triggered on close (newText can be null), must be freed if not null
  49. void async_dialog_text_input(const char* message, const char* text, std::function<void(char* newText)> action);