The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
/**
 * @copyright
 * ====================================================================
 *    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.
 * ====================================================================
 * @endcopyright
 */

package org.tigris.subversion.javahl;

import java.util.Date;
import java.util.Set;

/**
 * this class is returned by SVNClientInterface.info2 and contains information
 * about items in the repository or working copy
 * @since 1.2
 */
public class Info2 implements java.io.Serializable
{
    // Update the serialVersionUID when there is a incompatible change
    // made to this class.  See any of the following, depending upon
    // the Java release.
    // http://java.sun.com/j2se/1.3/docs/guide/serialization/spec/version.doc7.html
    // http://java.sun.com/j2se/1.4/pdf/serial-spec.pdf
    // http://java.sun.com/j2se/1.5.0/docs/guide/serialization/spec/version.html#6678
    // http://java.sun.com/javase/6/docs/platform/serialization/spec/version.html#6678
    private static final long serialVersionUID = 1L;

    /**
     * the path of the item
     */
    private String path;

    /**
     * the url of the item
     */
    private String url;

    /**
     * the revision of the item
     */
    private long rev;

    /**
     * the item kinds (see NodeKind)
     */
    private int kind;

    /**
     * the root URL of the repository
     */
    private String reposRootUrl;

    /**
     * the UUID of the repository
     */
    private String reposUUID;

    /**
     * the revision of the last change
     */
    private long lastChangedRev;

    /**
     * the date of the last change in ns
     */
    private long lastChangedDate;

    /**
     * the author of the last change
     */
    private String lastChangedAuthor;

    /**
     * the information about any lock (may be null)
     */
    private Lock lock;

    /**
     * the flag if the remaining fields are set
     */
    private boolean hasWcInfo;

    /**
     * the scheduled operation at next commit (see ScheduleKind)
     */
    private int schedule;

    /**
     * if the item was copied, the source url
     */
    private String copyFromUrl;

    /**
     * if the item was copied, the source rev
     */
    private long copyFromRev;

    /**
     * the last time the item was changed in ns
     */
    private long textTime;

    /**
     * the last time the properties of the items were changed in ns
     */
    private long propTime;

    /**
     * the checksum of the item
     */
    private String checksum;

    /**
     * if the item is in conflict, the filename of the base version file
     */
    private String conflictOld;

    /**
     * if the item is in conflict, the filename of the last repository version
     * file
     */
    private String conflictNew;

    /**
     * if the item is in conflict, the filename of the working copy
     * version file
     */
    private String conflictWrk;

    /**
     * the property reject file
     */
    private String prejfile;

    /**
     * The name of the changelist.
     * @since 1.5
     */
    private String changelistName;

    /**
     * The size of the file after being translated into its local
     * representation, or <code>-1</code> if unknown.  Not applicable
     * for directories.
     * @since 1.5
     */
    private long workingSize;

    /**
     * The size of the file in the repository (untranslated,
     * e.g. without adjustment of line endings and keyword
     * expansion). Only applicable for file -- not directory -- URLs.
     * For working copy paths, size will be <code>-1</code>.
     * @since New in 1.5.
     */
    private long reposSize;

    /**
     * The depth of the item.
     * @since 1.6
     */
    private int depth;

    /**
     * Info on any tree conflict of which this node is a victim.
     * @since 1.6
     */
    private ConflictDescriptor treeConflict;

    /**
     * constructor to build the object by native code. See fields for
     * parameters
     * @param path
     * @param url
     * @param rev
     * @param kind
     * @param reposRootUrl
     * @param reposUUID
     * @param lastChangedRev
     * @param lastChangedDate
     * @param lastChangedAuthor
     * @param lock
     * @param hasWcInfo
     * @param schedule
     * @param copyFromUrl
     * @param copyFromRev
     * @param textTime
     * @param propTime
     * @param checksum
     * @param conflictOld
     * @param conflictNew
     * @param conflictWrk
     * @param prejfile
     * @param depth
     * @param treeConflict
     */
    Info2(String path, String url, long rev, int kind, String reposRootUrl,
          String reposUUID, long lastChangedRev, long lastChangedDate,
          String lastChangedAuthor, Lock lock, boolean hasWcInfo, int schedule,
          String copyFromUrl, long copyFromRev, long textTime, long propTime,
          String checksum, String conflictOld, String conflictNew,
          String conflictWrk, String prejfile, String changelistName,
          long workingSize, long reposSize, int depth,
          ConflictDescriptor treeConflict)
    {
        this.path = path;
        this.url = url;
        this.rev = rev;
        this.kind = kind;
        this.reposRootUrl = reposRootUrl;
        this.reposUUID = reposUUID;
        this.lastChangedRev = lastChangedRev;
        this.lastChangedDate = lastChangedDate;
        this.lastChangedAuthor = lastChangedAuthor;
        this.lock = lock;
        this.hasWcInfo = hasWcInfo;
        this.schedule = schedule;
        this.copyFromUrl = copyFromUrl;
        this.copyFromRev = copyFromRev;
        this.textTime = textTime;
        this.propTime = propTime;
        this.checksum = checksum;
        this.conflictOld = conflictOld;
        this.conflictNew = conflictNew;
        this.conflictWrk = conflictWrk;
        this.prejfile = prejfile;
        this.changelistName = changelistName;
        this.workingSize = workingSize;
        this.reposSize = reposSize;
        this.depth = depth;
        this.treeConflict = treeConflict;
    }

    static private String
    getConflictOld(Set<org.apache.subversion.javahl.ConflictDescriptor>
                   conflicts)
    {
      if (conflicts == null)
        return null;

      for (org.apache.subversion.javahl.ConflictDescriptor conflict : conflicts)
        {
          if (conflict.getKind() == org.apache.subversion.javahl.ConflictDescriptor.Kind.text)
            return conflict.getBasePath();
        }

      return null;
    }

    static private String
    getConflictNew(Set<org.apache.subversion.javahl.ConflictDescriptor>
                   conflicts)
    {
      if (conflicts == null)
        return null;

      for (org.apache.subversion.javahl.ConflictDescriptor conflict : conflicts)
        {
          if (conflict.getKind() == org.apache.subversion.javahl.ConflictDescriptor.Kind.text)
            return conflict.getTheirPath();
        }

      return null;
    }

    static private String
    getConflictWrk(Set<org.apache.subversion.javahl.ConflictDescriptor>
                   conflicts)
    {
      if (conflicts == null)
        return null;

      for (org.apache.subversion.javahl.ConflictDescriptor conflict : conflicts)
        {
          if (conflict.getKind() == org.apache.subversion.javahl.ConflictDescriptor.Kind.text)
            return conflict.getMyPath();
        }

      return null;
    }

    static private String
    getPrejfile(Set<org.apache.subversion.javahl.ConflictDescriptor>
                conflicts)
    {
      if (conflicts == null)
        return null;

      for (org.apache.subversion.javahl.ConflictDescriptor conflict : conflicts)
        {
          if (conflict.getKind() == org.apache.subversion.javahl.ConflictDescriptor.Kind.property)
            return conflict.getTheirPath();
        }

      return null;
    }

    static private ConflictDescriptor
    getTreeConflict(Set<org.apache.subversion.javahl.ConflictDescriptor>
                        conflicts)
    {
      if (conflicts == null)
        return null;

      for (org.apache.subversion.javahl.ConflictDescriptor conflict : conflicts)
        {
          if (conflict.getKind() == org.apache.subversion.javahl.ConflictDescriptor.Kind.tree)
            return new ConflictDescriptor(conflict);
        }

      return null;
    }

    static private String
    getChecksumDigest(org.apache.subversion.javahl.types.Checksum checksum)
    {
    	if (checksum == null)
    		return null;

    	if (checksum.getKind() != org.apache.subversion.javahl.types.Checksum.Kind.MD5)
    		return null;

    	StringBuffer hexDigest = new StringBuffer();
    	for (byte b : checksum.getDigest())
    	{
    		hexDigest.append(Integer.toHexString(0xFF & b));
    	}

    	return hexDigest.toString();
    }

    /**
     * A backward-compat constructor.
     */
    public Info2(org.apache.subversion.javahl.types.Info aInfo)
    {
        this(aInfo.getPath(), aInfo.getUrl(), aInfo.getRev(),
             NodeKind.fromApache(aInfo.getKind()),
             aInfo.getReposRootUrl(), aInfo.getReposUUID(),
             aInfo.getLastChangedRev(),
             aInfo.getLastChangedDate() == null ? 0
                : aInfo.getLastChangedDate().getTime() * 1000,
             aInfo.getLastChangedAuthor(),
             aInfo.getLock() == null ? null : new Lock(aInfo.getLock()),
             aInfo.isHasWcInfo(),
             aInfo.getSchedule() == null ? 0 : aInfo.getSchedule().ordinal(),
             aInfo.getCopyFromUrl(), aInfo.getCopyFromRev(),
             aInfo.getTextTime() == null ? 0
                : aInfo.getTextTime().getTime() * 1000,
             0, getChecksumDigest(aInfo.getChecksum()),
             getConflictOld(aInfo.getConflicts()),
             getConflictNew(aInfo.getConflicts()),
             getConflictWrk(aInfo.getConflicts()),
             getPrejfile(aInfo.getConflicts()),
             aInfo.getChangelistName(), aInfo.getWorkingSize(),
             aInfo.getReposSize(), Depth.fromADepth(aInfo.getDepth()),
             getTreeConflict(aInfo.getConflicts()));
    }

    /**
     * return the path of the item
     */
    public String getPath()
    {
        return path;
    }

    /**
     * return the url of the item
     */
    public String getUrl()
    {
        return url;
    }

    /**
     * return the revision of the item
     */
    public long getRev()
    {
        return rev;
    }

    /**
     * return the item kinds (see NodeKind)
     */
    public int getKind()
    {
        return kind;
    }

    /**
     * return the root URL of the repository
     */
    public String getReposRootUrl()
    {
        return reposRootUrl;
    }

    /**
     * return the UUID of the repository
     */
    public String getReposUUID()
    {
        return reposUUID;
    }

    /**
     * return the revision of the last change
     */
    public long getLastChangedRev()
    {
        return lastChangedRev;
    }

    /**
     * return the date of the last change
     */
    public Date getLastChangedDate()
    {
        if (lastChangedDate == 0)
            return null;
        else
            return new Date(lastChangedDate/1000);
    }

    /**
     * return the author of the last change
     */
    public String getLastChangedAuthor()
    {
        return lastChangedAuthor;
    }

    /**
     * return the information about any lock (may be null)
     */
    public Lock getLock()
    {
        return lock;
    }

    /**
     * return the flag if the working copy fields are set
     */
    public boolean isHasWcInfo()
    {
        return hasWcInfo;
    }

    /**
     * return the scheduled operation at next commit (see ScheduleKind)
     */
    public int getSchedule()
    {
        return schedule;
    }

    /**
     * return if the item was copied, the source url
     */
    public String getCopyFromUrl()
    {
        return copyFromUrl;
    }

    /**
     * return if the item was copied, the source rev
     */
    public long getCopyFromRev()
    {
        return copyFromRev;
    }

    /**
     * return the last time the item was changed
     */
    public Date getTextTime()
    {
        if (textTime == 0)
            return null;
        else
            return new Date(textTime/1000);
    }

    /**
     * return the last time the properties of the items were changed
     */
    public Date getPropTime()
    {
        if (propTime == 0)
            return null;
        else
            return new Date(propTime/1000);
    }

    /**
     * return the checksum of the item
     */
    public String getChecksum()
    {
        return checksum;
    }

    /**
     * return if the item is in conflict, the filename of the base version file
     */
    public String getConflictOld()
    {
        return conflictOld;
    }

    /**
     * return if the item is in conflict, the filename of the last repository
     * version file
     */
    public String getConflictNew()
    {
        return conflictNew;
    }

    /**
     * return if the item is in conflict, the filename of the working copy
     * version file
     */
    public String getConflictWrk()
    {
        return conflictWrk;
    }

    /**
     * return the property reject file
     */
    public String getPrejfile()
    {
        return prejfile;
    }

    /**
     * @return The name of the changelist.
     * @since 1.5
     */
    public String getChangelistName()
    {
        return changelistName;
    }

    /**
     * @return The size of the file after being translated into its
     * local representation, or <code>-1</code> if unknown.  Not
     * applicable for directories.
     * @since 1.5
     */
    public long getWorkingSize()
    {
        return workingSize;
    }

    /**
     * @return The size of the file in the repository (untranslated,
     * e.g. without adjustment of line endings and keyword
     * expansion). Only applicable for file -- not directory -- URLs.
     * For working copy paths, size will be <code>-1</code>.
     * @since New in 1.5.
     */
    public long getReposSize()
    {
        return reposSize;
    }

    /**
     * @return The depth of the directory or <code>null</code> if the
     * item is a file.
     * @since New in 1.5.
     */
    public int getDepth()
    {
        return depth;
    }

    /**
     * @return the tree conflict of which this node is a victim, or null if none
     * @since New in 1.6.
     */
    public ConflictDescriptor getConflictDescriptor()
    {
        return treeConflict;
    }

    /**
     * @return A string representation of this info.
     */
    public String toString()
    {
        return getUrl();
    }
}