001/* 002 * Licensed to the Apache Software Foundation (ASF) under one or more 003 * contributor license agreements. See the NOTICE file distributed with 004 * this work for additional information regarding copyright ownership. 005 * The ASF licenses this file to You under the Apache License, Version 2.0 006 * (the "License"); you may not use this file except in compliance with 007 * the License. You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017package org.apache.commons.jxpath.ri.compiler; 018 019import org.apache.commons.jxpath.ri.Compiler; 020 021/** 022 * @author Dmitri Plotnikov 023 * @version $Revision: 652845 $ $Date: 2008-05-02 19:46:46 +0200 (Fr, 02 Mai 2008) $ 024 */ 025public class NodeTypeTest extends NodeTest { 026 private int nodeType; 027 028 /** 029 * Create a new NodeTypeTest. 030 * @param nodeType to match 031 */ 032 public NodeTypeTest(int nodeType) { 033 this.nodeType = nodeType; 034 } 035 036 /** 037 * Get the nodeType. 038 * @return int 039 */ 040 public int getNodeType() { 041 return nodeType; 042 } 043 044 public String toString() { 045 return nodeTypeToString(nodeType) + "()"; 046 } 047 048 /** 049 * Render the given node type as a String. 050 * @param code int 051 * @return String 052 */ 053 public static String nodeTypeToString(int code) { 054 switch (code) { 055 case Compiler.NODE_TYPE_NODE : 056 return "node"; 057 case Compiler.NODE_TYPE_TEXT : 058 return "text"; 059 case Compiler.NODE_TYPE_COMMENT : 060 return "comment"; 061 case Compiler.NODE_TYPE_PI : 062 return "processing-instruction"; 063 default: 064 return "UNKNOWN"; 065 } 066 } 067}