mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-02 17:35:18 +00:00
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/WCM-DEV2/root@4417 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
239 lines
4.2 KiB
Java
239 lines
4.2 KiB
Java
/*
|
|
* Copyright (C) 2006 Alfresco, Inc.
|
|
*
|
|
* Licensed under the Mozilla Public License version 1.1
|
|
* with a permitted attribution clause. You may obtain a
|
|
* copy of the License at
|
|
*
|
|
* http://www.alfresco.org/legal/license.txt
|
|
*
|
|
* 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.alfresco.filesys.avm;
|
|
|
|
import org.alfresco.filesys.server.filesys.FileName;
|
|
|
|
/**
|
|
* AVM Path Class
|
|
*
|
|
* <p>Parses a share relative path into store, version and remaining path values.
|
|
*
|
|
* @author gkspencer
|
|
*/
|
|
public class AVMPath {
|
|
|
|
// Constants
|
|
//
|
|
// Invalid version id value
|
|
|
|
private static final int InvalidVersionId = -2;
|
|
|
|
// Version id string for the head version
|
|
|
|
private static final String VersionNameHead = "Head";
|
|
|
|
// AVM path seperator
|
|
|
|
public static final char AVM_SEPERATOR = '/';
|
|
|
|
// Store name
|
|
|
|
private String m_storeName;
|
|
|
|
// Version id
|
|
|
|
private int m_version = InvalidVersionId;
|
|
|
|
// Remaining path
|
|
|
|
private String m_path;
|
|
|
|
// AVM style path
|
|
|
|
private String m_avmPath;
|
|
|
|
/**
|
|
* Class constructor
|
|
*
|
|
* @param shrPath String
|
|
*/
|
|
public AVMPath(String shrPath)
|
|
{
|
|
// Parse the path
|
|
|
|
parsePath( shrPath);
|
|
}
|
|
|
|
/**
|
|
* Return the store name
|
|
*
|
|
* @return String
|
|
*/
|
|
public final String getStoreName()
|
|
{
|
|
return m_storeName;
|
|
}
|
|
|
|
/**
|
|
* Check if the version id was specified in the path
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public final boolean hasVersion()
|
|
{
|
|
return m_version != InvalidVersionId ? true : false;
|
|
}
|
|
|
|
/**
|
|
* Return the version id
|
|
*
|
|
* @return int
|
|
*/
|
|
public final int getVersion()
|
|
{
|
|
return m_version;
|
|
}
|
|
|
|
/**
|
|
* Return the share relative path
|
|
*
|
|
* @return String
|
|
*/
|
|
public final String getRelativePath()
|
|
{
|
|
return m_path;
|
|
}
|
|
|
|
/**
|
|
* Return the AVM style path, in <store>:/<path> format
|
|
*
|
|
* @return String
|
|
*/
|
|
public final String getAVMPath()
|
|
{
|
|
return m_avmPath;
|
|
}
|
|
|
|
/**
|
|
* Check if the path is valid
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public final boolean isValid()
|
|
{
|
|
return m_storeName == null ? false : true;
|
|
}
|
|
|
|
/**
|
|
* Parse the path
|
|
*
|
|
* @param path String
|
|
*/
|
|
private final void parsePath( String path)
|
|
{
|
|
// Split the path
|
|
|
|
String[] paths = FileName.splitAllPaths(path);
|
|
|
|
if ( paths == null || paths.length == 0)
|
|
return;
|
|
|
|
// Set the store name
|
|
|
|
m_storeName = paths[0];
|
|
|
|
if ( paths.length > 1)
|
|
{
|
|
// Validate the version id
|
|
|
|
String verStr = paths[1];
|
|
if ( verStr.equalsIgnoreCase( VersionNameHead))
|
|
m_version = -1;
|
|
else
|
|
{
|
|
try
|
|
{
|
|
// Parse the version id
|
|
|
|
m_version = Integer.parseInt( verStr);
|
|
|
|
// Validate the version id
|
|
|
|
if ( m_version < 0)
|
|
{
|
|
// Invalid version id
|
|
|
|
m_storeName = null;
|
|
return;
|
|
}
|
|
}
|
|
catch ( NumberFormatException ex)
|
|
{
|
|
m_storeName = null;
|
|
return;
|
|
}
|
|
}
|
|
|
|
// If there additional path elements build the share and AVM relative paths
|
|
|
|
if ( paths.length > 2)
|
|
{
|
|
// Build the share relative path
|
|
|
|
StringBuilder pathStr = new StringBuilder();
|
|
|
|
for ( int i = 2; i < paths.length; i++)
|
|
{
|
|
pathStr.append( FileName.DOS_SEPERATOR);
|
|
pathStr.append( paths[i]);
|
|
}
|
|
|
|
m_path = pathStr.toString();
|
|
|
|
// Build the AVM path, in <store>:/<path> format
|
|
|
|
pathStr.setLength( 0);
|
|
|
|
pathStr.append( m_storeName);
|
|
pathStr.append( ":");
|
|
pathStr.append( m_path.replace( FileName.DOS_SEPERATOR, AVM_SEPERATOR));
|
|
|
|
m_avmPath = pathStr.toString();
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return the AVM path details as a string
|
|
*
|
|
* @return String
|
|
*/
|
|
public String toString()
|
|
{
|
|
StringBuilder str = new StringBuilder();
|
|
|
|
str.append("[");
|
|
str.append(getStoreName());
|
|
str.append(",");
|
|
|
|
if ( hasVersion())
|
|
str.append(getVersion());
|
|
else
|
|
str.append("NoVersion");
|
|
|
|
str.append(",");
|
|
str.append(getRelativePath());
|
|
str.append(":");
|
|
str.append(getAVMPath());
|
|
str.append("]");
|
|
|
|
return str.toString();
|
|
}
|
|
}
|