As part of teaching myself PowerShell (and converting a legacy mess of perl scripts into something more manageable), I needed a way to export the files that were added or modified between two SVN revisions. After some searching, I came up with this PowerShell script: it takes a repository URL, a from and to revision numbers, and an output directory into which to export the files.
This script uses
Resolve-FullPath cmdlet from the Carbon project. Turns out, PowerShell’s own
Resolve-Path doesn’t work on files/paths that do not exist.
Here’s how it works:
- It executes svn diff command with –r switch, which takes a range of revisions, e.g. 1000:1050. The summarize argument shows only the high-level information, and xml outputs the data as XML.
- This XML is being queried with an XPath, extracting only the names of the items of kind ˜file’ which were ˜added’ or *˜modified’.
- For every such file, its relative path is being taken by subtracting the repository path from the full filename.
- The target (sub)directory for that file is being created, if it doesn’t exist.
- It then executes svn export command on the current filename, limiting it to the to revision, so that the changes are taken only until that revision. The file is written in the relative target directory.
This is probably far from idiomatic PowerShell, but it gets the job done! Your improvements are welcome, feel free to comment on the Gist!