private IPvFuture decode_IPvFuture() { push("IPvFuture"); bool decoded = true; int s0 = index; var e0 = new List<Rule>(); Rule rule; decoded = false; if (!decoded) { { var e1 = new List<Rule>(); int s1 = index; decoded = true; if (decoded) { bool f1 = true; int c1 = 0; for (int i1 = 0; i1 < 1 && f1; i1++) { rule = decode_StringValue("v"); if ((f1 = rule != null)) { e1.Add(rule); c1++; } } decoded = c1 == 1; } if (decoded) { bool f1 = true; int c1 = 0; for (int i1 = 0; i1 < 1 && f1; i1++) { rule = decode_HEXDIG(); if ((f1 = rule != null)) { e1.Add(rule); c1++; } } while (f1) { rule = decode_HEXDIG(); if ((f1 = rule != null)) { e1.Add(rule); c1++; } } decoded = c1 >= 1; } if (decoded) { bool f1 = true; int c1 = 0; for (int i1 = 0; i1 < 1 && f1; i1++) { rule = decode_StringValue("."); if ((f1 = rule != null)) { e1.Add(rule); c1++; } } decoded = c1 == 1; } if (decoded) { bool f1 = true; int c1 = 0; for (int i1 = 0; i1 < 1 && f1; i1++) { decoded = false; if (!decoded) { { var e2 = new List<Rule>(); int s2 = index; decoded = true; if (decoded) { bool f2 = true; int c2 = 0; for (int i2 = 0; i2 < 1 && f2; i2++) { rule = decode_unreserved(); if ((f2 = rule != null)) { e2.Add(rule); c2++; } } decoded = c2 == 1; } if (decoded) e1.AddRange(e2); else index = s2; } } if (!decoded) { { var e2 = new List<Rule>(); int s2 = index; decoded = true; if (decoded) { bool f2 = true; int c2 = 0; for (int i2 = 0; i2 < 1 && f2; i2++) { rule = decode_sub_delims(); if ((f2 = rule != null)) { e2.Add(rule); c2++; } } decoded = c2 == 1; } if (decoded) e1.AddRange(e2); else index = s2; } } if (!decoded) { { var e2 = new List<Rule>(); int s2 = index; decoded = true; if (decoded) { bool f2 = true; int c2 = 0; for (int i2 = 0; i2 < 1 && f2; i2++) { rule = decode_StringValue(":"); if ((f2 = rule != null)) { e2.Add(rule); c2++; } } decoded = c2 == 1; } if (decoded) e1.AddRange(e2); else index = s2; } } if (decoded) c1++; f1 = decoded; } while (f1) { decoded = false; if (!decoded) { { var e2 = new List<Rule>(); int s2 = index; decoded = true; if (decoded) { bool f2 = true; int c2 = 0; for (int i2 = 0; i2 < 1 && f2; i2++) { rule = decode_unreserved(); if ((f2 = rule != null)) { e2.Add(rule); c2++; } } decoded = c2 == 1; } if (decoded) e1.AddRange(e2); else index = s2; } } if (!decoded) { { var e2 = new List<Rule>(); int s2 = index; decoded = true; if (decoded) { bool f2 = true; int c2 = 0; for (int i2 = 0; i2 < 1 && f2; i2++) { rule = decode_sub_delims(); if ((f2 = rule != null)) { e2.Add(rule); c2++; } } decoded = c2 == 1; } if (decoded) e1.AddRange(e2); else index = s2; } } if (!decoded) { { var e2 = new List<Rule>(); int s2 = index; decoded = true; if (decoded) { bool f2 = true; int c2 = 0; for (int i2 = 0; i2 < 1 && f2; i2++) { rule = decode_StringValue(":"); if ((f2 = rule != null)) { e2.Add(rule); c2++; } } decoded = c2 == 1; } if (decoded) e1.AddRange(e2); else index = s2; } } if (decoded) c1++; f1 = decoded; } decoded = c1 >= 1; } if (decoded) e0.AddRange(e1); else index = s1; } } rule = null; if (decoded) rule = new IPvFuture(text.Substring(s0, index - s0), e0); else index = s0; pop("IPvFuture", decoded, index - s0); return (IPvFuture)rule; }
public IPvFuture(IPvFuture rule) : base(rule.spelling, rule.rules) { }