OnWorks favicon

cvsconvert - Online in the Cloud

Run cvsconvert in OnWorks free hosting provider over Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

This is the command cvsconvert that can be run in the OnWorks free hosting provider using one of our multiple free online workstations such as Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator



cvsconvert - perform a Git conversion and test against the CVS original


cvsconvert [-v] [-n] [-p] [-k expandspec] [repo | repo/module]


cvsconvert performs a conversion of a CVS repository to Git and checks the tree contents
at all branch tips and tags to verify that the histories are the same.

(An exception: synthetic gitspace branches enamed *-UNNAMED-BRANCH created to collect
homeless CVS commits are not checked. You will see a warning when one of these is

The single argument must be a path to a directory containing a a CVS repository or module.
If it is a CVS top-level directory and there is only one module beneath the module need
not be specified.

The Git conversion is left in a directory named after the repo argument, with a suffix of

Normal behavior is for the program to report on each branch and tag, saying "trees match
as expected". There are two kinds of problem report:

"file manifests don’t match": Indicates that the CVS and Git versions of this revision in
the history contain some filenames that don’t pair up with each other. (Git and CVS
ignore-pattern files are ignored and will not trigger this message.) When this message
occurs, files in common are still checked for equality.

"%s and %s are different": Two corresponding CVS and Git files do not compare equal. A
diff listing will follow.


There are two kinds of non-serious conversion glitches: file content mismatches due to
expanded keyword fields in masters, and files deleted in CVS that occur only in the
gitspace manifests associated with tags.

You can spot content mismatches due to keyword expansion easily. They will produce
single-line diffs of lines containing dollar signs surrounding keyword text. Because
binary files can be corrupted by keyword expansion, by default cvs-fast-export behaves
like cvs -kb mode and does no keyword expansion of its own. Thus, you should never see
such mismatches unless you have passed in a -k option.

However, you might want to pass in -k k if (a) you believe the CVS masters might contain
expanded keyword fields but don’t want to clean them up by hand, and (b) you are confident
your repository contains no binary files that might false-match an RCS/CVS keyword. If you
are wrong about assumption (b) you will receive warning messages about content mismatches
in the binary files.

Manifest mismatches on tags are most likely to occur on files which were deleted in CVS
but persist under later tags in the Git conversion. You can bet this is what’s going on
if, when you search for the pathname in the CVS repository, you find it in an attic

These spurious reports happens because CVS does not always retain enough information to
track deletions reliably and is somewhat flaky in its handling of "dead"-state revisions.
To make your CVS and git repos match perfectly, you may need to use add delete fileops to
the conversion - or, more likely, move existing ones back along their branches to commits
that predate the gitspace tag - using reposurgeon(1).

Manifest mismatches in the other direction (present in CVS, absent in gitspace) should
never occur. If one does, submit a bug report.

Any other kind of content or manifest match - but especially any on the master branch - is
bad news and indicates either a severe repository malformation or a bug in cvs-fast-export
(or possibly both). Any such situation should be reported as a bug.

Conversion bugs are disproportionately likely to occur on older, branches or tags from
before CVS had reliable commitids. Often the most efficient remedy is simply to delete
junk branches and tags; reposurgeon(1) makes this easy to do.

If you need to file a bug, please visit the project website to learn about the
bug-reporting procedure. There are specific things you can do when preparing the report to
make a rapid resolution of the problem more likely.


Enable progress reports from cvs-fast-export as it runs.

Pass a keyword-expansion specification to cvs-fast-export(1) and cvs(1).

Test only, do not keep the Git conversion after emitting diagnostics.

Verbose. Show subcommands as they are being executed, and various debugging messages.

Tell cvs-fast-export to run quietly.


This program does not cope gracefully if CVS tagnames that are not legal for Git had to be
sanitized during conversion.

Because of the way this program works around CVS’s requirement for a CVSROOT directory, it
will require directory write permission on the repository directory in that case -
otherwise it will abort after a CVS message "failed to obtain dir lock in repository". The
repository contents are not modified.

The program needs the cvs -R option to access the repository read-only. It will therefore
fail with versions of GNU CVS older than 1.12.1 (2005) that do not have this option.


Report bugs to Eric S. Raymond <esr@thyrsus.com>. The project page is at

Use cvsconvert online using onworks.net services

Free Servers & Workstations

Download Windows & Linux apps

  • 1
    OpenFOAM - The Open Source CFD Toolbox.
    OpenFOAM is a generic, programmable
    software tool for Computational Fluid
    Dynamics (CFD). For more information,
    see: - ...
    Download OpenFOAM
  • 2
    PostInstallerF will install all the
    software that Fedora Linux and others
    doesn't include by default, after
    running Fedora for the first time. Its
    easy for...
    Download PostInstallerF
  • 3
    The strace project has been moved to
    https://strace.io. strace is a
    diagnostic, debugging and instructional
    userspace tracer for Linux. It is used
    to monitor a...
    Download strace
  • 4
    JasperReports Library
    JasperReports Library
    JasperReports Library is the
    world's most popular open source
    business intelligence and reporting
    engine. It is entirely written in Java
    and it is able to ...
    Download JasperReports Library
  • 5
    Numerical Python
    Numerical Python
    NEWS: NumPy 1.11.2 is the last release
    that will be made on sourceforge. Wheels
    for Windows, Mac, and Linux as well as
    archived source distributions can be fou...
    Download Numerical Python
  • 6
    CMU Sphinx
    CMU Sphinx
    CMUSphinx is a speaker-independent large
    vocabulary continuous speech recognizer
    released under BSD style license. It is
    also a collection of open source tools ...
    Download CMU Sphinx
  • 7
    Old Feren OS Repositories
    Old Feren OS Repositories
    This was the Official Repository for
    Feren OS. To add the latest one, run
    this command: (16.04-based) echo
    "deb ...
    Download Old Feren OS Repositories
  • More »

Linux commands