UNPKG

bitmark-grammar

Version:
38 lines (37 loc) 1.65 kB
/*! * Copyright 2016 The ANTLR Project. All rights reserved. * Licensed under the BSD-3-Clause license. See LICENSE file in the project root for license information. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; // CONVERSTION complete, Burt Harris 10/14/2016 import { Override } from "../../Decorators"; import { TerminalNode } from "../TerminalNode"; import { Trees } from "../Trees"; import { XPathElement } from "./XPathElement"; export class XPathTokenElement extends XPathElement { constructor(tokenName, tokenType) { super(tokenName); this.tokenType = tokenType; } evaluate(t) { // return all children of t that match nodeName let nodes = []; for (let c of Trees.getChildren(t)) { if (c instanceof TerminalNode) { if ((c.symbol.type === this.tokenType && !this.invert) || (c.symbol.type !== this.tokenType && this.invert)) { nodes.push(c); } } } return nodes; } } __decorate([ Override ], XPathTokenElement.prototype, "evaluate", null);