enumerate_knots.cpp 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * enumerate_knots.cpp - knot enumeration utility
  3. * Copyright (C) 2017 caryoscelus
  4. *
  5. * This program is free software: you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation, either version 3 of the License, or
  8. * (at your option) 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. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. #include <geom_helpers/knots.h>
  19. #include <morphing/morphing.h>
  20. #include <fmt/format.h>
  21. #include <fmt/ostream.h>
  22. #include <iostream>
  23. #include <string>
  24. using namespace fmt::literals;
  25. const std::string tmplt = R"TMPLT(<text x="{0}" y="{1}" font-size="3px" fill="red">{2}</text>
  26. )TMPLT";
  27. void enumerate_knots(std::string const& svg) {
  28. auto path = Geom::svg_to_knots(svg.c_str());
  29. unsigned index = 0;
  30. for (auto const& knot : path.knots) {
  31. fmt::print(tmplt, knot.pos.x(), knot.pos.y(), index);
  32. ++index;
  33. }
  34. }
  35. int main(int argc, char** argv) {
  36. std::string svg;
  37. if (argc < 2) {
  38. fmt::print(std::cerr, "Usage: {} <svg-path>\n", argv[0]);
  39. return 1;
  40. } else {
  41. svg = argv[1];
  42. if (argc > 2) {
  43. fmt::print(std::cerr, "Extra arguments ignored.\n");
  44. }
  45. }
  46. enumerate_knots(svg);
  47. return 0;
  48. }