The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
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.

128 lines
3.8KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2020 - Raw Material Software Limited
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. By using JUCE, you agree to the terms of both the JUCE 6 End-User License
  8. Agreement and JUCE Privacy Policy (both effective as of the 16th June 2020).
  9. End User License Agreement: www.juce.com/juce-6-licence
  10. Privacy Policy: www.juce.com/juce-privacy-policy
  11. Or: You may also use this code under the terms of the GPL v3 (see
  12. www.gnu.org/licenses).
  13. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  14. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  15. DISCLAIMED.
  16. ==============================================================================
  17. */
  18. namespace juce
  19. {
  20. //==============================================================================
  21. class UIAValueProvider : public UIAProviderBase,
  22. public ComBaseClassHelper<IValueProvider>
  23. {
  24. public:
  25. UIAValueProvider (AccessibilityNativeHandle* nativeHandle)
  26. : UIAProviderBase (nativeHandle)
  27. {
  28. }
  29. //==============================================================================
  30. JUCE_COMRESULT SetValue (LPCWSTR val) override
  31. {
  32. if (! isElementValid())
  33. return UIA_E_ELEMENTNOTAVAILABLE;
  34. const auto& handler = getHandler();
  35. const auto sendValuePropertyChangeMessage = [&]()
  36. {
  37. VARIANT newValue;
  38. VariantHelpers::setString (getCurrentValueString(), &newValue);
  39. sendAccessibilityPropertyChangedEvent (handler, UIA_ValueValuePropertyId, newValue);
  40. };
  41. if (isEditableText (handler))
  42. {
  43. handler.getTextInterface()->setText (String (val));
  44. sendValuePropertyChangeMessage();
  45. return S_OK;
  46. }
  47. if (auto* valueInterface = handler.getValueInterface())
  48. {
  49. if (! valueInterface->isReadOnly())
  50. {
  51. valueInterface->setValueAsString (String (val));
  52. sendValuePropertyChangeMessage();
  53. return S_OK;
  54. }
  55. }
  56. return UIA_E_NOTSUPPORTED;
  57. }
  58. JUCE_COMRESULT get_Value (BSTR* pRetVal) override
  59. {
  60. return withCheckedComArgs (pRetVal, *this, [&]
  61. {
  62. auto currentValue = getCurrentValueString();
  63. *pRetVal = SysAllocString ((const OLECHAR*) currentValue.toWideCharPointer());
  64. return S_OK;
  65. });
  66. }
  67. JUCE_COMRESULT get_IsReadOnly (BOOL* pRetVal) override
  68. {
  69. return withCheckedComArgs (pRetVal, *this, [&]
  70. {
  71. *pRetVal = true;
  72. const auto& handler = getHandler();
  73. if (isEditableText (handler)
  74. || (handler.getValueInterface() != nullptr
  75. && ! handler.getValueInterface()->isReadOnly()))
  76. {
  77. *pRetVal = false;
  78. }
  79. return S_OK;
  80. });
  81. }
  82. private:
  83. String getCurrentValueString() const
  84. {
  85. const auto& handler = getHandler();
  86. if (isEditableText (handler))
  87. if (auto* textInterface = getHandler().getTextInterface())
  88. return textInterface->getText ({ 0, textInterface->getTotalNumCharacters() });
  89. if (auto* valueInterface = getHandler().getValueInterface())
  90. return valueInterface->getCurrentValueAsString();
  91. jassertfalse;
  92. return {};
  93. }
  94. //==============================================================================
  95. JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (UIAValueProvider)
  96. };
  97. } // namespace juce