aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki/Plugin/norcs.pm
diff options
context:
space:
mode:
authorJoey Hess <joey@kodama.kitenet.net>2008-07-26 22:27:08 -0400
committerJoey Hess <joey@kodama.kitenet.net>2008-07-26 22:27:24 -0400
commit14cd75746a2c73b50548b6fdb3583d536b6ef9bd (patch)
tree4e9390041f63ced41683be40a8946078af7ab92d /IkiWiki/Plugin/norcs.pm
parentbb888daea0786a69d017b7617920827b637e954a (diff)
downloadikiwiki-14cd75746a2c73b50548b6fdb3583d536b6ef9bd.tar
ikiwiki-14cd75746a2c73b50548b6fdb3583d536b6ef9bd.tar.gz
Version control backends promoted to first-class plugins
Diffstat (limited to 'IkiWiki/Plugin/norcs.pm')
-rw-r--r--IkiWiki/Plugin/norcs.pm99
1 files changed, 99 insertions, 0 deletions
diff --git a/IkiWiki/Plugin/norcs.pm b/IkiWiki/Plugin/norcs.pm
new file mode 100644
index 000000000..04ba5f028
--- /dev/null
+++ b/IkiWiki/Plugin/norcs.pm
@@ -0,0 +1,99 @@
+#!/usr/bin/perl
+# Stubs for no revision control.
+
+package IkiWiki;
+
+use warnings;
+use strict;
+use IkiWiki;
+
+sub rcs_update () {
+ # Update working directory to current version.
+ # (May be more complex for distributed RCS.)
+}
+
+sub rcs_prepedit ($) {
+ # Prepares to edit a file under revision control. Returns a token
+ # that must be passed into rcs_commit when the file is ready
+ # for committing.
+ # The file is relative to the srcdir.
+ return ""
+}
+
+sub rcs_commit ($$$;$$) {
+ # Tries to commit the page; returns undef on _success_ and
+ # a version of the page with the rcs's conflict markers on failure.
+ # The file is relative to the srcdir.
+ my ($file, $message, $rcstoken, $user, $ipaddr) = @_;
+ return undef # success
+}
+
+sub rcs_commit_staged ($$$) {
+ # Commits all staged changes. Changes can be staged using rcs_add,
+ # rcs_remove, and rcs_rename.
+ my ($message, $user, $ipaddr)=@_;
+ return undef # success
+}
+
+sub rcs_add ($) {
+ # Add a file. The filename is relative to the root of the srcdir.
+ # Note that this should not check the new file in, it should only
+ # prepare for it to be checked in when rcs_commit is called.
+ # Note that the file may be in a new subdir that is not yet added
+ # to version control; the subdir can be added if so.
+}
+
+sub rcs_remove ($) {
+ # Remove a file. The filename is relative to the root of the srcdir.
+ # Note that this should not check the removal in, it should only
+ # prepare for it to be checked in when rcs_commit is called.
+ # Note that the new file may be in a new subdir that is not yet added
+ # to version control; the subdir can be added if so.
+}
+
+sub rcs_rename ($$) {
+ # Rename a file. The filenames are relative to the root of the srcdir.
+ # Note that this should not commit the rename, it should only
+ # prepare it for when rcs_commit is called.
+ # The new filename may be in a new subdir, that is not yet added to
+ # version control. If so, the subdir will exist already, and should
+ # be added to revision control.
+}
+
+sub rcs_recentchanges ($) {
+ # Examine the RCS history and generate a list of recent changes.
+ # The data structure returned for each change is:
+ # {
+ # rev => # the RCSs id for this commit
+ # user => # name of user who made the change,
+ # committype => # either "web" or the name of the rcs,
+ # when => # time when the change was made,
+ # message => [
+ # { line => "commit message line" },
+ # { line => "commit message line" },
+ # # etc,
+ # ],
+ # pages => [
+ # {
+ # page => # name of page changed,
+ # diffurl => # optional url to a diff showing
+ # # the changes,
+ # },
+ # # repeat for each page changed in this commit,
+ # ],
+ # }
+}
+
+sub rcs_diff ($) {
+ # Optional, used to get diffs for recentchanges.
+ # The parameter is the rev from rcs_recentchanges.
+ # Should return a list of lines of the diff (including \n) in list
+ # context, and the whole diff in scalar context.
+}
+
+sub rcs_getctime ($) {
+ # Optional, used to get the page creation time from the RCS.
+ error gettext("getctime not implemented");
+}
+
+1