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.

78 lines
2.5KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library - "Jules' Utility Class Extensions"
  4. Copyright 2004-11 by Raw Material Software Ltd.
  5. ------------------------------------------------------------------------------
  6. JUCE can be redistributed and/or modified under the terms of the GNU General
  7. Public License (Version 2), as published by the Free Software Foundation.
  8. A copy of the license is included in the JUCE distribution, or can be found
  9. online at www.gnu.org/licenses.
  10. JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
  11. WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  12. A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  13. ------------------------------------------------------------------------------
  14. To release a closed-source product which uses JUCE, commercial licenses are
  15. available: visit www.rawmaterialsoftware.com/juce for more information.
  16. ==============================================================================
  17. */
  18. BEGIN_JUCE_NAMESPACE
  19. //==============================================================================
  20. StringPool& Identifier::getPool()
  21. {
  22. static StringPool pool;
  23. return pool;
  24. }
  25. Identifier::Identifier() noexcept
  26. : name (nullptr)
  27. {
  28. }
  29. Identifier::Identifier (const Identifier& other) noexcept
  30. : name (other.name)
  31. {
  32. }
  33. Identifier& Identifier::operator= (const Identifier& other) noexcept
  34. {
  35. name = other.name;
  36. return *this;
  37. }
  38. Identifier::Identifier (const String& name_)
  39. : name (Identifier::getPool().getPooledString (name_))
  40. {
  41. /* An Identifier string must be suitable for use as a script variable or XML
  42. attribute, so it can only contain this limited set of characters.. */
  43. jassert (isValidIdentifier (name_));
  44. }
  45. Identifier::Identifier (const char* const name_)
  46. : name (Identifier::getPool().getPooledString (name_))
  47. {
  48. /* An Identifier string must be suitable for use as a script variable or XML
  49. attribute, so it can only contain this limited set of characters.. */
  50. jassert (isValidIdentifier (toString()));
  51. }
  52. Identifier::~Identifier()
  53. {
  54. }
  55. bool Identifier::isValidIdentifier (const String& possibleIdentifier) noexcept
  56. {
  57. return possibleIdentifier.isNotEmpty()
  58. && possibleIdentifier.containsOnly ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_-:#@$%");
  59. }
  60. END_JUCE_NAMESPACE