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.

75 lines
2.4KB

  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. StringPool& Identifier::getPool()
  19. {
  20. static StringPool pool;
  21. return pool;
  22. }
  23. Identifier::Identifier() noexcept
  24. : name (nullptr)
  25. {
  26. }
  27. Identifier::Identifier (const Identifier& other) noexcept
  28. : name (other.name)
  29. {
  30. }
  31. Identifier& Identifier::operator= (const Identifier& other) noexcept
  32. {
  33. name = other.name;
  34. return *this;
  35. }
  36. Identifier::Identifier (const String& nm)
  37. : name (Identifier::getPool().getPooledString (nm))
  38. {
  39. /* An Identifier string must be suitable for use as a script variable or XML
  40. attribute, so it can only contain this limited set of characters.. */
  41. jassert (isValidIdentifier (nm));
  42. }
  43. Identifier::Identifier (const char* const nm)
  44. : name (Identifier::getPool().getPooledString (nm))
  45. {
  46. /* An Identifier string must be suitable for use as a script variable or XML
  47. attribute, so it can only contain this limited set of characters.. */
  48. jassert (isValidIdentifier (toString()));
  49. }
  50. Identifier::~Identifier()
  51. {
  52. }
  53. Identifier Identifier::null;
  54. bool Identifier::isValidIdentifier (const String& possibleIdentifier) noexcept
  55. {
  56. return possibleIdentifier.isNotEmpty()
  57. && possibleIdentifier.containsOnly ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_-:#@$%");
  58. }