NAME
VCP::UIMachines - State machines for user interface
SYNOPSIS
Called by VCP::UI
DESCRIPTION
The user interface module VCP::UI is a framework that bolts the implementation of the user interface to a state machine representing the user interface.
Each state in this state machine is a method that runs the state and returns a result (or dies to exit the program).
API
- new
-
Creates a new user interface object.
- run
-
Executes the user interface.
Interactive Methods
- init
-
Initialize the machine
Next state: source_id_prompt
- source_id_prompt: Source id
-
A symbolic name for the source repository. This is used to organize the VCP databases and to refer to the source repository in other places.
Must consist of a leading letter then letters, numbers, underscores and dashes only.
Valid answers:
=> source_type_prompt
- source_type_prompt: Source type
-
The kind of repository to copy data from.
Valid answers:
p4 => source_p4_run_p4d_prompt vss => source_vss_vssroot_prompt cvs => source_cvs_cvsroot_prompt
- dest_id_prompt: Destination id
-
A symbolic name for the destination repository. This is used to organize the VCP databases and to refer to the destination repository in other places.
Must consist of a leading letter then letters, numbers, underscores and dashes only.
Valid answers:
=> dest_type_prompt
- dest_type_prompt: Destination SCM type
-
The kind of repository to copy data to.
Valid answers:
cvs => dest_cvs_cvsroot_prompt p4 => dest_p4_run_p4d_prompt vss => dest_vss_vssroot_prompt
- wrapup: Next step
-
What to do with all of the entered options.
Valid answers:
Save config file and run => save_config_file Run without saving config file => convert Save config file and exit => save_config_file
- save_config_file: Config file name
-
What filename to write the configuration file to.
Valid answers:
Config filename => convert
- convert
-
Run VCP with the options entered
- dest_p4_run_p4d_prompt: Launch a p4d for the destination
-
If you would like to insert into an offline repository in a local directory, vcp can launch a 'p4d' daemon for you in that directory. It will use a random high numbered TCP port.
Valid answers:
yes => dest_p4_p4d_dir_prompt no => dest_p4_host_prompt
- dest_p4_p4d_dir_prompt: Destination P4ROOT
-
The directory of the destination repository, p4d will be launched here.
Valid answers:
=> dest_p4_user_prompt
- dest_p4_host_prompt: Destination P4PORT
-
The hostname/IP address and port of the p4d to write to, separated by a colon. Defaults to the default P4PORT variable as reported by the 'p4 set' command (with a final default to "perforce:1666" if the p4 set command does not return anything).
Valid answers:
perforce:1666 => dest_p4_user_prompt
- dest_p4_user_prompt: Destination P4USER
-
The username to connect to the destination p4d with. Defaults to the user reported by the 'p4 set' command (with a final default to the USER environment variable if the p4 set command does not return anything).
Valid answers:
=> dest_p4_password_prompt
- dest_p4_password_prompt: Destination P4PASSWD
-
The P4PASSWD needed to access the server. Leave blank to use the default reported by P4PASSWD.
WARNING: entering a password will cause it to be echoed in plain text to the terminal.
Valid answers:
=> dest_p4_filespec_prompt
- dest_p4_filespec_prompt: Destination File Specification
-
Where to place the transferred revisions. This is a perforce repository spec and must begin with "//" and a depot name ("//depot"), not a local filesystem spec or a "//client" or "//label" spec.
Valid answers:
//depot/directory-path/... => wrapup
- dest_cvs_cvsroot_prompt: Destination CVSROOT
-
Specifies the destination CVS repository location and protocol. Defaults to the CVSROOT environment variable. If this is a local directory, VCP can initialize it for you.
Valid answers:
=> dest_cvs_filespec_prompt
- dest_cvs_filespec_prompt: Destination CVS filespec
-
Where to copy revisions to in the destination specified by CVSROOT. This must start with a CVS module name and may be in a subdirectory of the result:
module/... module/path/to/directory/... module/path/to/file
For directories, this should contain a trailing "..." wildcard, like "module/b/..." to indicate that the path is a directory.
Valid answers:
module/filepath/... => dest_cvs_init_cvsroot_prompt
- dest_cvs_init_cvsroot_prompt: 'cvs init' the destination CVSROOT
-
If the destination CVSROOT is a local directory, should VCP initialize a cvs repository in it?
Valid answers:
yes => wrapup no => wrapup
- dest_vss_vssroot_prompt: Destination SSDIR
-
The directory that will contain the srcsafe.ini file for the destination repostiory.
Valid answers:
=> dest_vss_user_prompt
- dest_vss_user_prompt: Destination SSUSER
-
Enter the SSUSER value needed to access the destination server. Defaults to the current environment's SSUSER or 'Admin'.
Valid answers:
=> dest_vss_password_prompt
- dest_vss_password_prompt: Destination SSPWD
-
If a password (SSPWD) is needed to access the destination server, enter it here. Defaults to the current SSPWD if one is set.
WARNING: entering a password will cause it to be echoed in plain text to the terminal.
Valid answers:
=> dest_vss_filespec_prompt
- dest_vss_filespec_prompt: Destination VSS filespec
-
Enter the vss filespec of the destination directory, with or without a leading "$/" or "/" (all names are taken as absolute).
Valid answers:
=> dest_vss_mkss_prompt
- dest_vss_mkss_prompt: 'mkss' the destination SSDIR
-
If the destination SSDIR is a local directory, should VCP use mkss to initialize a vss repository in it?
Valid answers:
yes => wrapup no => wrapup
- source_p4_run_p4d_prompt: Launch a p4d for the source
-
If you would like to extract from an offline repository in a local directory, vcp can launch a 'p4d' daemon for you in that directory. It will use a random high numbered TCP port.
Valid answers:
no => source_p4_host_prompt yes => source_p4_p4d_dir_prompt
- source_p4_p4d_dir_prompt: Source P4ROOT
-
The directory of the source repository. The source p4d will be launched here.
Valid answers:
=> source_p4_user_prompt
- source_p4_host_prompt: Source P4PORT
-
Enter the name and port of the p4d to read from, separated by a colon. Defaults to what is in config file, then the P4HOST environment variable if set or "perforce:1666" if not.
Valid answers:
perforce:1666 => source_p4_user_prompt
- source_p4_user_prompt: Source P4USER
-
Enter the P4USER value needed to access the server. Defaults to the P4USER value reported by p4 set (with a final default to the USER environment variable if p4 set does not return anything).
Valid answers:
=> source_p4_password_prompt
- source_p4_password_prompt: Source P4PASSWD
-
If a password (P4PASSWD) is needed to access the server, enter it here. Defaults to the current P4PASSWD if one is set.
WARNING: entering a password will cause it to be echoed in plain text to the terminal.
Valid answers:
=> source_p4_filespec_prompt
- source_p4_filespec_prompt: Source File specification
-
If you want to copy a portion of the source repository, enter a p4 filespec starting with the depot name. Do not enter any revision or change number information.
Valid answers:
//depot/directory-path/... => dest_id_prompt
- source_cvs_cvsroot_prompt: Source CVSROOT
-
The CVSROOT to read revisions from. Defaults to the CVSROOT environment variable.
Valid answers:
cvsroot spec => source_cvs_filespec_prompt
- source_cvs_filespec_prompt: Source CVS filespec
-
Enter the cvs filespec of the file(s) to copy. This must start with a CVS module name and end in a filename, directory name, or "..." wildcard:
module/... module/file module/path/to/subdir/... module/path/to/subdir/file
Valid answers:
module/filepath/... => source_cvs_working_directory_prompt
- source_cvs_working_directory_prompt: Source CVS working directory
-
Enter the CVS working directory (Optional). VCP::Source::cvs will cd to this directory before calling cvs and won't initialize a CVS workspace of its own. Leave blank to allow VCP to use a temporary directory.
Valid answers:
=> source_cvs_binary_checkout_prompt
- source_cvs_binary_checkout_prompt: Force binary checkout
-
Pass the -kb option to cvs, to force a binary checkout. This is useful when you want a text file to be checked out with Unix linends, or if you know that some files in the repository are not flagged as binary files and should be.
Valid answers:
no => source_cvs_use_cvs_prompt yes => source_cvs_use_cvs_prompt
- source_cvs_use_cvs_prompt: Use cvs executable
-
This forces VCP to use the cvs executable rather than read local CVSROOT directories directly. This is slower, but may be used to work around any limitations that might crop up in VCP's RCS file parser.
Valid answers:
yes => dest_id_prompt no => dest_id_prompt
- source_vss_vssroot_prompt: Source SSDIR
-
The directory containing the srcsafe.ini file for the source repository.
Valid answers:
=> source_vss_user_prompt
- source_vss_user_prompt: Source SSUSER
-
Enter the SSUSER value needed to access the server. Defaults to the current environment's SSUSER or 'Admin'.
Valid answers:
=> source_vss_password_prompt
- source_vss_password_prompt: Source SSPWD
-
If a password (SSPWD) is needed to access the server, enter it here. Defaults to the current SSPWD if one is set.
WARNING: entering a password will cause it to be echoed in plain text to the terminal.
Valid answers:
=> source_vss_filespec_prompt
- source_vss_filespec_prompt: Source VSS filespec
-
Enter the vss filespec of the file(s) to copy, with or without a leading "$/" or "/" (all names are taken as absolute). To copy more than one file, use a "..." or "*" wildcard:
... Copy entire repository project1/... Copy entire project project1/file Copy one file project1/dir/... Copy a subdirectory project1/dir/file*.bas Copy a set of files
Valid answers:
=> source_vss_undocheckout_prompt
- source_vss_undocheckout_prompt: Issue "ss undocheckout" as needed
-
If set, VCP will undo users' checkouts when it runs in to the "File ... is checked out by ..." error. This occurs, at least, when scanning metadata for a checked-out file when there is also a deleted version of the same file.
Valid answers:
yes => dest_id_prompt no => dest_id_prompt
WARNING: AUTOGENERATED
This module is autogenerated in the pre-distribution build process, so to change it, you need the master repository files in ui_machines/..., not a CPAN/PPM/tarball/.zip/etc. distribution.
COPYRIGHT
Copyright 2003, Perforce Software, Inc. All Rights Reserved.
This module and the VCP package are licensed according to the terms given in the file LICENSE accompanying this distribution, a copy of which is included in vcp.
AUTHOR
Barrie Slaymaker <barries@slaysys.com>