⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pathvalue.java

📁 jsr170接口的java实现。是个apache的开源项目。
💻 JAVA
字号:
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at * *      http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.apache.jackrabbit.value;import org.apache.jackrabbit.name.MalformedPathException;import org.apache.jackrabbit.name.PathFormat;import javax.jcr.PropertyType;import javax.jcr.RepositoryException;import javax.jcr.ValueFormatException;import java.util.Calendar;/** * A <code>PathValue</code> provides an implementation * of the <code>Value</code> interface representing a <code>PATH</code> value * (an absolute or relative workspace path). */public class PathValue extends BaseValue {    public static final int TYPE = PropertyType.PATH;    private final String path;    /**     * Returns a new <code>PathValue</code> initialized to the value     * represented by the specified <code>String</code>.     * <p/>     * The specified <code>String</code> must be a valid absolute or relative     * path.     *     * @param s the string to be parsed.     * @return a newly constructed <code>PathValue</code> representing the     *         the specified value.     * @throws javax.jcr.ValueFormatException If the <code>String</code> is not a valid     *                              absolute or relative path.     */    public static PathValue valueOf(String s) throws ValueFormatException {        if (s != null) {            try {                PathFormat.checkFormat(s);            } catch (MalformedPathException mpe) {                throw new ValueFormatException(mpe.getMessage());            }            return new PathValue(s);        } else {            throw new ValueFormatException("not a valid path format");        }    }    /**     * Protected constructor creating a <code>PathValue</code> object     * without validating the path.     *     * @param path the path this <code>PathValue</code> should represent     * @see #valueOf     */    protected PathValue(String path) {        super(TYPE);        this.path = path;    }    /**     * Indicates whether some other object is "equal to" this one.     * <p/>     * The result is <code>true</code> if and only if the argument is not     * <code>null</code> and is a <code>PathValue</code> object that     * represents the same value as this object.     *     * @param obj the reference object with which to compare.     * @return <code>true</code> if this object is the same as the obj     *         argument; <code>false</code> otherwise.     */    public boolean equals(Object obj) {        if (this == obj) {            return true;        }        if (obj instanceof PathValue) {            PathValue other = (PathValue) obj;            if (path == other.path) {                return true;            } else if (path != null && other.path != null) {                return path.equals(other.path);            }        }        return false;    }    /**     * Returns zero to satisfy the Object equals/hashCode contract.     * This class is mutable and not meant to be used as a hash key.     *     * @return always zero     * @see Object#hashCode()     */    public int hashCode() {        return 0;    }    //------------------------------------------------------------< BaseValue >    /**     * {@inheritDoc}     */    protected String getInternalString() throws ValueFormatException {        if (path != null) {            return path;        } else {            throw new ValueFormatException("empty value");        }    }    //----------------------------------------------------------------< Value >    /**     * {@inheritDoc}     */    public Calendar getDate()            throws ValueFormatException, IllegalStateException,            RepositoryException {        setValueConsumed();        throw new ValueFormatException("conversion to date failed: inconvertible types");    }    /**     * {@inheritDoc}     */    public long getLong()            throws ValueFormatException, IllegalStateException,            RepositoryException {        setValueConsumed();        throw new ValueFormatException("conversion to long failed: inconvertible types");    }    /**     * {@inheritDoc}     */    public boolean getBoolean()            throws ValueFormatException, IllegalStateException,            RepositoryException {        setValueConsumed();        throw new ValueFormatException("conversion to boolean failed: inconvertible types");    }    /**     * {@inheritDoc}     */    public double getDouble()            throws ValueFormatException, IllegalStateException,            RepositoryException {        setValueConsumed();        throw new ValueFormatException("conversion to double failed: inconvertible types");    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -