Mercurial > jhg
comparison src/org/tmatesoft/hg/core/HgManifestHandler.java @ 427:31a89587eb04
FIXMEs: consistent names, throws for commands and their handlers. Use of checked exceptions in hi-level api
| author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
|---|---|
| date | Thu, 29 Mar 2012 17:14:35 +0200 |
| parents | |
| children | 6526d8adbc0f |
comparison
equal
deleted
inserted
replaced
| 426:063b0663495a | 427:31a89587eb04 |
|---|---|
| 1 /* | |
| 2 * Copyright (c) 2011-2012 TMate Software Ltd | |
| 3 * | |
| 4 * This program is free software; you can redistribute it and/or modify | |
| 5 * it under the terms of the GNU General Public License as published by | |
| 6 * the Free Software Foundation; version 2 of the License. | |
| 7 * | |
| 8 * This program is distributed in the hope that it will be useful, | |
| 9 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 11 * GNU General Public License for more details. | |
| 12 * | |
| 13 * For information on how to redistribute this software under | |
| 14 * the terms of a license other than GNU General Public License | |
| 15 * contact TMate Software at support@hg4j.com | |
| 16 */ | |
| 17 package org.tmatesoft.hg.core; | |
| 18 | |
| 19 import org.tmatesoft.hg.internal.Callback; | |
| 20 import org.tmatesoft.hg.util.Path; | |
| 21 | |
| 22 /** | |
| 23 * Callback to walk file/directory tree of a revision | |
| 24 * | |
| 25 * @author Artem Tikhomirov | |
| 26 * @author TMate Software Ltd. | |
| 27 */ | |
| 28 @Callback | |
| 29 public interface HgManifestHandler { | |
| 30 /** | |
| 31 * Indicates start of manifest revision. Subsequent {@link #file(HgFileRevision)} and {@link #dir(Path)} come | |
| 32 * from the specified manifest revision until {@link #end(Nodeid)} with the matching revision is invoked. | |
| 33 * | |
| 34 * @param manifestRevision unique identifier of the manifest revision | |
| 35 * @throws HgCallbackTargetException wrapper for any exception user code may produce | |
| 36 */ | |
| 37 void begin(Nodeid manifestRevision) throws HgCallbackTargetException; | |
| 38 | |
| 39 /** | |
| 40 * If walker is configured to spit out directories, indicates files from specified directories are about to be reported. | |
| 41 * Comes prior to any files from this directory and subdirectories | |
| 42 * | |
| 43 * @param path directory known in the manifest | |
| 44 * @throws HgCallbackTargetException wrapper for any exception user code may produce | |
| 45 */ | |
| 46 void dir(Path path) throws HgCallbackTargetException; | |
| 47 | |
| 48 /** | |
| 49 * Reports a file revision entry in the manifest | |
| 50 * | |
| 51 * @param fileRevision description of the file revision | |
| 52 * @throws HgCallbackTargetException wrapper for any exception user code may produce | |
| 53 */ | |
| 54 void file(HgFileRevision fileRevision) throws HgCallbackTargetException; | |
| 55 | |
| 56 /** | |
| 57 * Indicates all files from the manifest revision have been reported. | |
| 58 * Closes {@link #begin(Nodeid)} with the same revision that came before. | |
| 59 * | |
| 60 * @param manifestRevision unique identifier of the manifest revision | |
| 61 * @throws HgCallbackTargetException wrapper for any exception user code may produce | |
| 62 */ | |
| 63 void end(Nodeid manifestRevision) throws HgCallbackTargetException; | |
| 64 } |
