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.

67 lines
2.2 KiB

  1. /*
  2. * This program source code file is part of KiCad, a free EDA CAD application.
  3. *
  4. * Copyright The KiCad Developers, see AUTHORS.TXT for contributors.
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License
  8. * as published by the Free Software Foundation; either version 2
  9. * of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, you may find one here:
  18. * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
  19. * or you may search the http://www.gnu.org website for the version 2 license,
  20. * or you may write to the Free Software Foundation, Inc.,
  21. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
  22. */
  23. #include <array_pad_number_provider.h>
  24. #include <pad.h>
  25. ARRAY_PAD_NUMBER_PROVIDER::ARRAY_PAD_NUMBER_PROVIDER( const std::set<wxString>& aExistingPadNumbers,
  26. const ARRAY_OPTIONS& aArrayOpts )
  27. : m_arrayOpts( aArrayOpts )
  28. {
  29. // start by numbering the first new item
  30. m_current_pad_index = 0;
  31. // construct the set of existing pad numbers
  32. if( aArrayOpts.GetNumberingStartIsSpecified() )
  33. {
  34. // if we start from a specified point, we don't look at existing
  35. // names, so it's just an empty "reserved" set
  36. }
  37. else
  38. {
  39. m_existing_pad_numbers = aExistingPadNumbers;
  40. }
  41. }
  42. wxString ARRAY_PAD_NUMBER_PROVIDER::GetNextPadNumber()
  43. {
  44. return getNextNumber( m_current_pad_index, m_existing_pad_numbers );
  45. }
  46. wxString ARRAY_PAD_NUMBER_PROVIDER::getNextNumber( int& aIndex,
  47. const std::set<wxString>& aExisting )
  48. {
  49. wxString next_number;
  50. do
  51. {
  52. next_number = m_arrayOpts.GetItemNumber( aIndex );
  53. aIndex++;
  54. } while( aExisting.count( next_number ) != 0 );
  55. return next_number;
  56. }