ListParser.cs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /// Spart License (zlib/png)
  2. ///
  3. ///
  4. /// Copyright (c) 2003 Jonathan de Halleux
  5. ///
  6. /// This software is provided 'as-is', without any express or implied warranty.
  7. /// In no event will the authors be held liable for any damages arising from
  8. /// the use of this software.
  9. ///
  10. /// Permission is granted to anyone to use this software for any purpose,
  11. /// including commercial applications, and to alter it and redistribute it
  12. /// freely, subject to the following restrictions:
  13. ///
  14. /// 1. The origin of this software must not be misrepresented; you must not
  15. /// claim that you wrote the original software. If you use this software in a
  16. /// product, an acknowledgment in the product documentation would be
  17. /// appreciated but is not required.
  18. ///
  19. /// 2. Altered source versions must be plainly marked as such, and must not be
  20. /// misrepresented as being the original software.
  21. ///
  22. /// 3. This notice may not be removed or altered from any source distribution.
  23. ///
  24. /// Author: Jonathan de Halleuxusing System;
  25. namespace Spart.Parsers.Composite
  26. {
  27. using Spart.Scanners;
  28. public class ListParser : BinaryTerminalParser
  29. {
  30. public ListParser(Parser first, Parser second)
  31. :base(first, second)
  32. {}
  33. public override ParserMatch ParseMain(Spart.Scanners.IScanner scan)
  34. {
  35. long offset = scan.Offset;
  36. ParserMatch a = null;
  37. ParserMatch b = null;
  38. ParserMatch m = FirstParser.Parse(scan);
  39. if (!m.Success)
  40. {
  41. scan.Seek(offset);
  42. return scan.NoMatch;
  43. }
  44. while (!scan.AtEnd)
  45. {
  46. offset = scan.Offset;
  47. b = SecondParser.Parse(scan);
  48. if (!b.Success)
  49. {
  50. scan.Seek(offset);
  51. return m;
  52. }
  53. a = FirstParser.Parse(scan);
  54. if (!a.Success)
  55. {
  56. scan.Seek(offset);
  57. return m;
  58. }
  59. m.Concat(b);
  60. m.Concat(a);
  61. }
  62. return m;
  63. }
  64. public override Parser Clone()
  65. {
  66. return base.Clone();
  67. }
  68. }
  69. }