1 .\"
   2 .\" CDDL HEADER START
   3 .\"
   4 .\" The contents of this file are subject to the terms of the
   5 .\" Common Development and Distribution License (the "License").
   6 .\" You may not use this file except in compliance with the License.
   7 .\"
   8 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9 .\" or http://www.opensolaris.org/os/licensing.
  10 .\" See the License for the specific language governing permissions
  11 .\" and limitations under the License.
  12 .\"
  13 .\" When distributing Covered Code, include this CDDL HEADER in each
  14 .\" file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15 .\" If applicable, add the following below this CDDL HEADER, with the
  16 .\" fields enclosed by brackets "[]" replaced with your own identifying
  17 .\" information: Portions Copyright [yyyy] [name of copyright owner]
  18 .\"
  19 .\" CDDL HEADER END
  20 .\"
  21 .\" Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
  22 .\" Use is subject to license terms.
  23 .\"
  24 .TH which_scm 1ONBLD "18 September 2009"
  25 .SH NAME
  26 which_scm \- Report Source Code Management system
  27 .SH SYNOPSIS
  28 .B which_scm
  29 
  30 .SH DESCRIPTION
  31 .B which_scm
  32 detects the Source Code Management (SCM) system in use, and prints a
  33 single line of text containing a one-word name for the SCM, followed
  34 by a space, and then the top-level directory path for the workspace.
  35 
  36 The typical usage within a ksh script is:
  37 .nf
  38         which_scm | read SCM_TYPE CODEMGR_WS || exit 1
  39 .fi
  40 
  41 If CODEMGR_WS is set in the environment, then \fBwhich_scm\fR
  42 checks only that directory, assuming that it is the top of the tree.
  43 
  44 If CODEMGR_WS is not set, then \fBwhich_scm\fR searches upwards to
  45 find the containing workspace path, and reports that path.
  46 
  47 .B which_scm
  48 can detect the following types of SCM systems (these are the keywords
  49 used in the output format):
  50 .nf
  51         cvs
  52         git
  53         mercurial
  54         rcs
  55         sccs
  56         subversion
  57         teamware
  58 .fi
  59 
  60 If the type of SCM in use is not known, then the string "unknown" is
  61 printed, and the path returned is $CODEMGR_WS (if set) or the current
  62 working directory.  The command may exit with an error if the SCM
  63 could be detected, but is unusable.
  64 
  65 .SH ENVIRONMENT VARIABLES
  66 The following environment variable is used by \fBwhich_scm\fR:
  67 
  68 .PP
  69 \fBCODEMGR_WS\fR path to current workspace.
  70 
  71 .SH SEE ALSO
  72 .IR cvs(1) ,
  73 .IR git(1) ,
  74 .IR hg(1) ,
  75 .IR sccs(1)
  76 .IR svn(1) ,
  77 .IR workspace(1)