Package org.tmatesoft.hg.core

Source Code of org.tmatesoft.hg.core.SessionContext$SourcePrim

/*
* Copyright (c) 2011-2013 TMate Software Ltd
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
* GNU General Public License for more details.
*
* For information on how to redistribute this software under
* the terms of a license other than GNU General Public License
* contact TMate Software at support@hg4j.com
*/
package org.tmatesoft.hg.core;

import java.net.URI;

import org.tmatesoft.hg.auth.HgAuthenticator;
import org.tmatesoft.hg.internal.BasicSessionContext;
import org.tmatesoft.hg.internal.Experimental;
import org.tmatesoft.hg.internal.remote.BasicAuthenticator;
import org.tmatesoft.hg.internal.remote.RemoteConnectorDescriptor;
import org.tmatesoft.hg.repo.HgRemoteRepository;
import org.tmatesoft.hg.util.LogFacility;
import org.tmatesoft.hg.util.Path;

/**
* Access to objects that might need to be shared between various distinct operations ran during the same working session
* (i.e. caches, log, etc.). It's unspecified whether session context is per repository or can span multiple repositories
*
* <p>Note, API is likely to be extended in future versions, adding more object to share.
*
* @author Artem Tikhomirov
* @author TMate Software Ltd.
*/
public abstract class SessionContext {
  // abstract class to facilitate adding more functionality without API break
 
  /**
   * Access wrapper for a system log facility.
   * @return facility to direct dumps to, never <code>null</code>
   */
  public abstract LogFacility getLog();
 
  /**
   * Access configuration parameters of the session.
   * @param name name of the session configuration parameter
   * @param defaultValue value to return if parameter is not configured
   * @return value of the session parameter, defaultValue if none found
   */
  public abstract Object getConfigurationProperty(String name, Object defaultValue);
  // perhaps, later may add Configuration object, with PropertyMarshal's helpers
  // e.g. when there's standalone Caches and WritableSessionProperties objects

  /**
   * Provide a factory to create {@link Path} objects.
   *
   * Occasionally, there's a need to construct a {@link Path} object from a string/byte data
   * kept in mercurial control files. Generally, default implementation (with {@link Path#create(CharSequence)}
   * is enough, however, if there's a need to control number of string objects in memory (i.e. prevent duplicates),
   * default implementation might need to be replaced with more sophisticated (e.g. using weak references or
   * just a huge hash set).
   *
   * @return factory to construct Path objects, never <code>null</code>
   */
  public Path.Source getPathFactory() {
    return new Path.Source() {
      public Path path(CharSequence p) {
        return Path.create(p);
      }
    };
  }

  /**
   * Work in progress, provisional API.
   *
   * Provides descriptor that knows how to handle connections of specific kind
   *
   * FIXME Perhaps, implementation here shall return null for any URI, while the one
   * in {@link BasicSessionContext} shall use our internal classes? However,
   * present implementation provides support for uris handled in the library itself, and likely
   * most clients need this, even if they supply own SessionContext
   * 
   * @return <code>null</code> if supplied URI doesn't point to a remote repository or repositories of that kind are not supported
   */
  @Experimental(reason="Provisional API. Work in progress")
  public HgRemoteRepository.RemoteDescriptor getRemoteDescriptor(URI uri) {
    return new RemoteConnectorDescriptor.Provider().get(this, uri);
  }
 
  /**
   * Facility to perform authentication for a given remote connection
   * @return never <code>null</code>
   */
  @Experimental(reason="Provisional API. Work in progress")
  public HgAuthenticator getAuthenticator(HgRemoteRepository.RemoteDescriptor rd) {
    return new BasicAuthenticator(getLog());
  }

  /**
   * Providers of the context may implement
   */
  public interface Source {
    SessionContext getSessionContext();
  }
 
  public static final class SourcePrim implements Source {
    private final SessionContext ctx;

    public SourcePrim(SessionContext sessionContext) {
      assert sessionContext != null;
      ctx = sessionContext;
    }
    public SessionContext getSessionContext() {
      return ctx;
    }
  }
}
TOP

Related Classes of org.tmatesoft.hg.core.SessionContext$SourcePrim

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.