| Sun, 03 Aug 2014 18:09:00 +0200 | Artem Tikhomirov | Mac support: respect Mac alternatives of command-line arguments for common unix tools
   default tip | 
 
  | Sun, 03 Aug 2014 18:04:13 +0200 | Artem Tikhomirov | Issue 49: NoClassDefFoundError: org/tmatesoft/hg/auth/HgAuthenticator. Missing package in the binary bundle | 
 
  | Fri, 11 Oct 2013 21:35:41 +0200 | Artem Tikhomirov | Keyword filtering that doesn't depend on input buffer size and the way input lines got split between filter() calls. KewordFilter got state to keep processed suspicious ...$ lines | 
 
  | Mon, 07 Oct 2013 01:56:05 +0200 | Artem Tikhomirov | KeywordFilter: 'IllegalStateException: need buffer of at least...' during status op for a small file | 
 
  | Wed, 21 Aug 2013 16:23:27 +0200 | Artem Tikhomirov | Report merged lines as changed block if possible, not as a sequence of added/deleted blocks. To facilitate access to merge parent lines AddBlock got mergeLineAt() method that reports index of the line in the second parent (if any), while insertedAt() has been changed to report index in the first parent always | 
 
  | Tue, 20 Aug 2013 18:41:34 +0200 | Artem Tikhomirov | Merge: tests for resolver and complex scenario. Enable commit for merged revisions. Reuse file revisions if nothing changed | 
 
  | Fri, 16 Aug 2013 19:22:59 +0200 | Artem Tikhomirov | Merge: support 'unresolved' resolution with MergeStateBuilder | 
 
  | Fri, 16 Aug 2013 14:54:09 +0200 | Artem Tikhomirov | Merge: tests for mediator notifications | 
 
  | Thu, 15 Aug 2013 18:43:50 +0200 | Artem Tikhomirov | Merge command: implement conflict resolution alternatives | 
 
  | Wed, 14 Aug 2013 20:07:26 +0200 | Artem Tikhomirov | Merge command introduced | 
 
  | Wed, 14 Aug 2013 14:51:51 +0200 | Artem Tikhomirov | Refactor: move diff/blame related code to a separate package | 
 
  | Thu, 08 Aug 2013 21:32:22 +0200 | Artem Tikhomirov | Reference ssh-dependant class by the fq name to avoid runtime dependency from the ssh library | 
 
  | Thu, 08 Aug 2013 21:05:21 +0200 | Artem Tikhomirov | Added tag v1.2m2 for changeset 6e7786086f77 | 
 
  | Thu, 08 Aug 2013 21:04:52 +0200 | Artem Tikhomirov | Update gradle build to respect new dependency from trilead
   v1.2m2 | 
 
  | Thu, 08 Aug 2013 19:18:50 +0200 | Artem Tikhomirov | Provisional APIs and respective implementation for http, https and ssh remote repositories | 
 
  | Tue, 06 Aug 2013 21:18:33 +0200 | Artem Tikhomirov | in, out and clone tests pass for ssh repositories. Infrastructure to decouple HgRemoteRepository from specific Connector implementation | 
 
  | Tue, 06 Aug 2013 13:34:34 +0200 | Artem Tikhomirov | Respect the fact ssh and http protocols use different compression approach to sent changegroup data | 
 
  | Mon, 05 Aug 2013 19:03:22 +0200 | Artem Tikhomirov | Replaced ganymed ssh2 library with trilead | 
 
  | Mon, 05 Aug 2013 18:45:16 +0200 | Artem Tikhomirov | Refactoring: nice Revlog.indexWalk() implementation | 
 
  | Mon, 05 Aug 2013 17:42:10 +0200 | Artem Tikhomirov | Speed up (a) file rename history to minimize file reads; (b) file.isCopy(int) to read metadata for few revisions at once (use pattern assumes earlier revisions are likely to be queried, too); (c) HgIgnore.isIgnored by caching matched initial fragments (to substitute more expensive Matcher.matches with cheaper HashMap.contains) | 
 
  | Mon, 05 Aug 2013 12:45:36 +0200 | Artem Tikhomirov | Fix file.isCopy() use for Log/History command. File revisions originating from another file list no parents even in the middle of revision chain | 
 
  | Sat, 03 Aug 2013 17:11:33 +0200 | Artem Tikhomirov | Refactor HgLogCommand to utilize correct file.isCopy(int) | 
 
  | Fri, 02 Aug 2013 23:07:23 +0200 | Artem Tikhomirov | Fix file.isCopy() for blame/annotate. Refactor status and blame to use newly introduced FileHistory helper that builds file rename history | 
 
  | Thu, 01 Aug 2013 21:45:47 +0200 | Artem Tikhomirov | Fix file.isCopy() use for status and cat commands | 
 
  | Sat, 27 Jul 2013 22:06:14 +0200 | Artem Tikhomirov | Issue 44: Renames/copies other than for the very first revision of a file are not recognized | 
 
  | Sat, 27 Jul 2013 20:15:37 +0200 | Artem Tikhomirov | Defect: copies are not reported with default settings (not even as added!). Parameter needCopies removed as there seems to be no reason to condition copies for hi-level api (HgStatus.isCopy() is way down the road) | 
 
  | Sat, 27 Jul 2013 18:34:14 +0200 | Artem Tikhomirov | Towards ssh remote repositories: refactor HgRemoteRepository - move http related code to HttpConnector | 
 
  | Thu, 25 Jul 2013 22:12:14 +0200 | Artem Tikhomirov | Annotated file is not always changed in the latest changeset, need to find out last changest it was changed at (iow, diffed to with BlameHelper) | 
 
  | Thu, 25 Jul 2013 21:32:09 +0200 | Artem Tikhomirov | Towards ssh remote repositories: use ganymed library for ssh transport | 
 
  | Thu, 25 Jul 2013 21:31:23 +0200 | Artem Tikhomirov | Full text of GPL 2.0 in COPYING as http://www.gnu.org/licenses/gpl-howto.html suggests | 
 
  | Wed, 24 Jul 2013 16:40:15 +0200 | Artem Tikhomirov | Update commands to use changeset Nodeid and int in uniform way, clients of core.* classes shall not go back and forth from int to Nodeid | 
 
  | Mon, 22 Jul 2013 22:47:06 +0200 | Artem Tikhomirov | Compile with Java5, ensure generics are fine for other compilers, too | 
 
  | Sun, 21 Jul 2013 17:48:05 +0200 | Artem Tikhomirov | Do not instantiate thousands of small arrays(numerous readInt/readLong calls) | 
 
  | Sun, 21 Jul 2013 17:15:34 +0200 | Artem Tikhomirov | Blame: alternative strategy to handle merge revisions: map(diff(p1->base->p2)) to understand merge intentions better | 
 
  | Sat, 20 Jul 2013 17:40:52 +0200 | Artem Tikhomirov | HgParentChildMap: deduce common ancestor functionality | 
 
  | Fri, 19 Jul 2013 15:36:29 +0200 | Artem Tikhomirov | Towards better blame of merge revisions: refactor merge handling strategy | 
 
  | Thu, 18 Jul 2013 18:47:45 +0200 | Artem Tikhomirov | Report line number at the first appearance, like 'hg annotate -l' does | 
 
  | Thu, 18 Jul 2013 18:03:51 +0200 | Artem Tikhomirov | Switch to alternative annotate producer (walks from parents to children). Refactor FileAnnotation to match updated annotate approach | 
 
  | Thu, 18 Jul 2013 18:02:36 +0200 | Artem Tikhomirov | Respect default range (0..tip) | 
 
  | Wed, 17 Jul 2013 15:40:51 +0200 | Artem Tikhomirov | Introduced dedicated IntSliceSeq/IntTuple in place of IntArray with subsequences | 
 
  | Fri, 12 Jul 2013 20:14:24 +0200 | Artem Tikhomirov | Refactor HgBundle.GroupElement (clear experimental mark), resolve few technical debt issues | 
 
  | Fri, 12 Jul 2013 16:29:06 +0200 | Artem Tikhomirov | Effective update of HgParentChildMap when repository got few revisions added | 
 
  | Fri, 12 Jul 2013 15:29:37 +0200 | Artem Tikhomirov | AIOOBE in BundleGenerator.ChunkGenerator.iterate when there are no outgoing changes on push | 
 
  | Fri, 12 Jul 2013 15:27:43 +0200 | Artem Tikhomirov | AIOOBE in BundleGenerator.ChunkGenerator.iterate when there are no outgoing changes on push | 
 
  | Thu, 11 Jul 2013 20:49:33 +0200 | Artem Tikhomirov | Pull: sample command-line utility | 
 
  | Thu, 11 Jul 2013 18:41:40 +0200 | Artem Tikhomirov | Delete bundle with push/pull changes once command completes successfully. Test for bundle generator | 
 
  | Thu, 11 Jul 2013 17:54:08 +0200 | Artem Tikhomirov | Refactoring: move all encoding/decoding operations into single place, EncodingHelper | 
 
  | Wed, 10 Jul 2013 20:22:07 +0200 | Artem Tikhomirov | Added tag v1.2m1 for changeset dde18bc7053b | 
 
  | Wed, 10 Jul 2013 20:16:37 +0200 | Artem Tikhomirov | Test Copy-on-Write transactions
   v1.2m1 | 
 
  | Wed, 10 Jul 2013 19:33:51 +0200 | Artem Tikhomirov | Utilize transaction when writing fncache. Better HgIOException | 
 
  | Wed, 10 Jul 2013 16:41:49 +0200 | Artem Tikhomirov | Pull: phase2 - update phases from remote, fncache with added files. Tests | 
 
  | Wed, 10 Jul 2013 11:53:19 +0200 | Artem Tikhomirov | Merge branch smartgit-4.6 | 
 
  | Wed, 10 Jul 2013 11:48:55 +0200 | Artem Tikhomirov | Merge branch smartgit-4.5 (no actual changes, merely to denote branch is inactive | 
 
  | Tue, 09 Jul 2013 21:46:45 +0200 | Artem Tikhomirov | Pull: phase1 get remote changes and add local revisions | 
 
  | Fri, 05 Jul 2013 20:42:45 +0200 | Artem Tikhomirov | Poor performance when reading/collecting branch information. Respect new cache location for recent mercurial revisions. Use different algorithm to build branch cache
   smartgit-4.6 | 
 
  | Thu, 04 Jul 2013 21:09:33 +0200 | Artem Tikhomirov | javac complained about casts, while eclipse compiler is fine | 
 
  | Thu, 04 Jul 2013 20:27:45 +0200 | Artem Tikhomirov | ParentChildMap can supply RevisionMap. Refactor ArrayHelper to keep most of sorted/reverse index magic inside | 
 
  | Thu, 04 Jul 2013 18:40:03 +0200 | Artem Tikhomirov | Performance: rebuild information about branches takes too long (my improvement: 3 times, 11-15 s to less than 4 sec) | 
 
  | Thu, 04 Jul 2013 18:36:38 +0200 | Artem Tikhomirov | Performance: reuse unzip output buffer | 
 
  | Wed, 03 Jul 2013 15:11:40 +0200 | Artem Tikhomirov | 1) Console push tool. 2) Pass class to blame into FileUtils | 
 
  | Wed, 03 Jul 2013 14:38:30 +0200 | Artem Tikhomirov | Tests for recent changes in HgParentChildMap and RepositoryComparator (outgoing to respect drafts and Issue 47) | 
 
  | Tue, 02 Jul 2013 23:21:16 +0200 | Artem Tikhomirov | Push: tests. Commit respects phases.new-commit setting. Fix outgoing when changes are not children of common (Issue 47) | 
 
  | Mon, 01 Jul 2013 21:19:53 +0200 | Artem Tikhomirov | Push: tests (push to empty, push changes, respect secret) | 
 
  | Fri, 28 Jun 2013 19:27:26 +0200 | Artem Tikhomirov | Push: phase4 - settle local and remote phases, push updated phases regardless of server publishing state, do not push secret changesets | 
 
  | Wed, 26 Jun 2013 20:52:38 +0200 | Artem Tikhomirov | Push: phase4 - update local and remote phase information | 
 
  | Tue, 25 Jun 2013 20:48:37 +0200 | Artem Tikhomirov | Introduced RevisionSet to ease update of phase roots on push | 
 
  | Tue, 25 Jun 2013 18:53:18 +0200 | Artem Tikhomirov | Location of repository files as enumeration, use file constants instead of plain names | 
 
  | Fri, 21 Jun 2013 18:30:35 +0200 | Artem Tikhomirov | Push: phase3 - update matching remote bookmarks | 
 
  | Thu, 20 Jun 2013 19:15:09 +0200 | Artem Tikhomirov | Push: phase2 - upload bundle with changes to remote server | 
 
  | Wed, 19 Jun 2013 16:04:24 +0200 | Artem Tikhomirov | Push: phase1 - prepare bundle with changes | 
 
  | Wed, 19 Jun 2013 16:03:11 +0200 | Artem Tikhomirov | v1.2 line of dev: update versions, use patch merge code by default | 
 
  | Tue, 11 Jun 2013 16:32:12 +0200 | Artem Tikhomirov | Added tag v1.1.0 for changeset 2f33f102a8fa | 
 
  | Tue, 11 Jun 2013 16:31:42 +0200 | Artem Tikhomirov | Updated copyright year
   v1.1.0 | 
 
  | Tue, 11 Jun 2013 16:25:01 +0200 | Artem Tikhomirov | Deprecated code removed | 
 
  | Thu, 06 Jun 2013 14:21:11 +0200 | Artem Tikhomirov | Issue 46: Files with backslashes (legal on Linux) cause troubles
   smartgit-4.5 | 
 
  | Fri, 07 Jun 2013 13:21:20 +0200 | Artem Tikhomirov | AIOOBE in HgManifest.RevisionMapper: provide more details about exception context. Create lock file atomically. Picked from changeset 8a5cdcb27b8f
   smartgit-4.5 | 
 
  | Fri, 07 Jun 2013 12:32:15 +0200 | Artem Tikhomirov | HgInitCommand: expose repo init functionality | 
 
  | Thu, 06 Jun 2013 19:39:06 +0200 | Artem Tikhomirov | HgCommitCommand: save last commit message | 
 
  | Thu, 06 Jun 2013 18:42:38 +0200 | Artem Tikhomirov | Compound test scenario for checkout, add, remove, revert and commit | 
 
  | Thu, 06 Jun 2013 14:21:11 +0200 | Artem Tikhomirov | Issue 46: Files with backslashes (legal on Linux) cause troubles | 
 
  | Thu, 30 May 2013 16:14:46 +0200 | Artem Tikhomirov | Added tag v1.1rc2 for changeset 54e16ab771ec | 
 
  | Thu, 30 May 2013 16:13:43 +0200 | Artem Tikhomirov | Progress/cancel for HgDiffCommand. Renamed execute method
   v1.1rc2 | 
 
  | Thu, 30 May 2013 15:24:17 +0200 | Artem Tikhomirov | AIOOBE in HgManifest.RevisionMapper. Provide more details about exception context. Create lock file atomically. Test concurrent pull-rebase and read | 
 
  | Thu, 23 May 2013 19:44:28 +0200 | Artem Tikhomirov | HgDiffCommand. Do not use deprecated code. Javadoc | 
 
  | Wed, 22 May 2013 16:46:15 +0200 | Artem Tikhomirov | Diff/blame methods as command, their residence in HgDataFile was a mistake | 
 
  | Wed, 22 May 2013 15:52:31 +0200 | Artem Tikhomirov | Explicit HgRuntimeException to facilitate easy switch from runtime to checked exceptions | 
 
  | Tue, 21 May 2013 20:17:33 +0200 | Artem Tikhomirov | Added tag v1.1rc1 for changeset 5afc7eedb3dd | 
 
  | Tue, 21 May 2013 19:30:12 +0200 | Artem Tikhomirov | @since, TODOs. Tests: add 1 sec to deal with fs timestamp granularity on linux
   v1.1rc1 | 
 
  | Tue, 21 May 2013 17:24:22 +0200 | Artem Tikhomirov | Refactor internals of blame support, tests | 
 
  | Mon, 20 May 2013 20:34:33 +0200 | Artem Tikhomirov | FIXMEs and TODOs: pay some technical debt | 
 
  | Mon, 20 May 2013 18:35:13 +0200 | Artem Tikhomirov | Update tests for Windows; TestCommit: use copy of a repo (not clone) to preserve old timestamps | 
 
  | Mon, 20 May 2013 16:56:40 +0200 | Artem Tikhomirov | Update to comply with Java 1.5 target | 
 
  | Sat, 18 May 2013 22:23:57 +0200 | Artem Tikhomirov | RevlogStream: be aware of existence (not HgDataFile), facilitate use of an added HgDataFile over a commit; Rollback: be more sensitive about file changes (file size is not enough: write/rollback leaves it intact); tests | 
 
  | Sat, 18 May 2013 21:55:31 +0200 | Artem Tikhomirov | Do not cache branch value of working copy as it's not possible to refresh it after commit now | 
 
  | Fri, 17 May 2013 22:04:23 +0200 | Artem Tikhomirov | Close FIS, not FileChannel, to clear both references to FileDescriptor right away | 
 
  | Thu, 16 May 2013 19:46:13 +0200 | Artem Tikhomirov | Refactor approach how content finds it way down to a commit revision | 
 
  | Wed, 15 May 2013 20:10:09 +0200 | Artem Tikhomirov | Rollback support for commands that modify repository. Strategy to keep complete copy of a file being changed | 
 
  | Tue, 14 May 2013 17:31:35 +0200 | Artem Tikhomirov | encode directories as demanded by fncache format | 
 
  | Mon, 13 May 2013 22:48:29 +0200 | Artem Tikhomirov | Test for repository locks | 
 
  | Fri, 10 May 2013 17:31:54 +0200 | Artem Tikhomirov | Added tag v1.1m4 for changeset f41dd9a3b8af | 
 
  | Fri, 10 May 2013 17:31:27 +0200 | Artem Tikhomirov | Remove few Experimental annotations as the API they've marked graduates
   v1.1m4 | 
 
  | Fri, 10 May 2013 14:29:35 +0200 | Artem Tikhomirov | Test tags, branches and hgingore information get refreshed on external (and/or internal) change | 
 
  | Thu, 09 May 2013 21:52:01 +0200 | Artem Tikhomirov | Tests for tailored sections in HgRepoConfig | 
 
  | Thu, 09 May 2013 21:06:48 +0200 | Artem Tikhomirov | Refresh tags, branches, bookmarks and ignore when their files (or csets in the repo) are changed | 
 
  | Wed, 08 May 2013 17:11:45 +0200 | Artem Tikhomirov | Test TODOs: test for ConfigFile (covering %include and %unset directives) | 
 
  | Tue, 07 May 2013 21:27:51 +0200 | Artem Tikhomirov | Clean, organize and resolve some TODOs and FIXMEs: minor refactorings and comments | 
 
  | Tue, 07 May 2013 16:52:46 +0200 | Artem Tikhomirov | Refresh revlogs if a change to a file has been detected; do not force reload of the whole repository | 
 
  | Tue, 07 May 2013 14:16:35 +0200 | Artem Tikhomirov | Avoid mmap files when only few bytes are to be read | 
 
  | Mon, 06 May 2013 20:28:21 +0200 | Artem Tikhomirov | Commit: update active bookmark with new revision | 
 
  | Mon, 06 May 2013 18:53:04 +0200 | Artem Tikhomirov | Use nodeid reverse lookup speedup cache for #isKnown, if available | 
 
  | Mon, 06 May 2013 18:29:57 +0200 | Artem Tikhomirov | Refactor HgBlameFacility: relevant action methods moved to proper home (HgDataFile), as facility doesn't provide anything but packaging of relevant methods/interfaces | 
 
  | Mon, 06 May 2013 17:11:29 +0200 | Artem Tikhomirov | Refactor metadata parsing in HgDataFile, moved to standalone class | 
 
  | Mon, 06 May 2013 17:10:46 +0200 | Artem Tikhomirov | Remove debug timestamps | 
 
  | Fri, 03 May 2013 17:03:31 +0200 | Artem Tikhomirov | Utilize RevisionLookup to speed-up getRevisionIndex of both manifest and changelog | 
 
  | Fri, 03 May 2013 15:29:26 +0200 | Artem Tikhomirov | Do not instantiate intermediate arrays | 
 
  | Fri, 03 May 2013 15:19:18 +0200 | Artem Tikhomirov | Utilize the fact nodeids are very different and are read anyway to speed up reverse lookup | 
 
  | Fri, 03 May 2013 14:10:40 +0200 | Artem Tikhomirov | Wrap manifest revision map completion into single file access | 
 
  | Thu, 02 May 2013 19:23:53 +0200 | Artem Tikhomirov | HgBlameFacility refactoring: extract code to build file history that spans renames | 
 
  | Thu, 02 May 2013 19:23:35 +0200 | Artem Tikhomirov | Filter shall notify delegate about reset, too | 
 
  | Thu, 02 May 2013 19:22:43 +0200 | Artem Tikhomirov | Cache only in-memory revision representations | 
 
  | Thu, 02 May 2013 16:51:02 +0200 | Artem Tikhomirov | Share last revision read between #iterate() invocations, to save revision rebuild efforts when few subsequent revisions are read | 
 
  | Wed, 01 May 2013 14:03:10 +0200 | Artem Tikhomirov | Command-line sample for commit command | 
 
  | Tue, 30 Apr 2013 18:55:42 +0200 | Artem Tikhomirov | CommitFacility as internal class; refactored infrastructure around internals (access to RevlogStream) | 
 
  | Mon, 29 Apr 2013 17:04:51 +0200 | Artem Tikhomirov | Use requested encoding in LineReader | 
 
  | Mon, 29 Apr 2013 17:02:30 +0200 | Artem Tikhomirov | Username in changeset uses UTF-8, not system encoding | 
 
  | Mon, 29 Apr 2013 16:37:57 +0200 | Artem Tikhomirov | Update dirstate after commit | 
 
  | Fri, 26 Apr 2013 20:04:17 +0200 | Artem Tikhomirov | Minimize vectors re-allocating when merging patches | 
 
  | Fri, 26 Apr 2013 18:38:41 +0200 | Artem Tikhomirov | HgCommitCommand initial support | 
 
  | Thu, 25 Apr 2013 17:53:44 +0200 | Artem Tikhomirov | Access to base revision filed comes handy for debug sometimes | 
 
  | Thu, 25 Apr 2013 16:08:17 +0200 | Artem Tikhomirov | Conditionally enable effective patch merge alternative for revlog reading | 
 
  | Wed, 24 Apr 2013 15:39:53 +0200 | Artem Tikhomirov | Effective revlog patching | 
 
  | Mon, 22 Apr 2013 19:17:29 +0200 | Artem Tikhomirov | Delegate cancel to original support, do not implement CancelSupport ourselves | 
 
  | Mon, 22 Apr 2013 16:02:17 +0200 | Artem Tikhomirov | Progress/cancel support in new commands | 
 
  | Fri, 19 Apr 2013 20:30:34 +0200 | Artem Tikhomirov | Respect unix flags for checkout/revert | 
 
  | Wed, 17 Apr 2013 16:06:10 +0200 | Artem Tikhomirov | Provide means to read user-specific configuration, with no specific repository selected | 
 
  | Wed, 17 Apr 2013 16:02:52 +0200 | Artem Tikhomirov | Throw exception if repository encountered is too old for Hg4J | 
 
  | Tue, 16 Apr 2013 20:41:36 +0200 | Artem Tikhomirov | Enlarge inflater buffer to reduce number of inflates per read | 
 
  | Tue, 16 Apr 2013 19:31:57 +0200 | Artem Tikhomirov | Issue 43: poor performance with InflaterDataAccess. Phase 2: inflate into buffer, effective skip and readByte/readBytes() | 
 
  | Tue, 16 Apr 2013 16:59:59 +0200 | Artem Tikhomirov | Issue 43: poor performance with InflaterDataAccess. Phase 1: test existing code, fix defects found | 
 
  | Tue, 16 Apr 2013 14:44:57 +0200 | Artem Tikhomirov | Improve memory consumption of HgManifest#getFileRevision(): avoid extra byte[] instances | 
 
  | Fri, 12 Apr 2013 19:50:21 +0200 | Artem Tikhomirov | Partial blame when start/end revisions are in the middle of a single filename history | 
 
  | Fri, 12 Apr 2013 18:30:55 +0200 | Artem Tikhomirov | Report file object in case of error to be helpful as much as possible | 
 
  | Thu, 11 Apr 2013 16:27:06 +0200 | Artem Tikhomirov | Let session context control creation of Path instances | 
 
  | Thu, 11 Apr 2013 16:07:17 +0200 | Artem Tikhomirov | Tests for HgAnnotateCommand with follow/no-follow option | 
 
  | Wed, 10 Apr 2013 20:04:54 +0200 | Artem Tikhomirov | Support for copy/rename follow/no-follow for annotate | 
 
  | Wed, 10 Apr 2013 15:45:53 +0200 | Artem Tikhomirov | Blame facility refactored, get ready for follow/no-follow support | 
 
  | Tue, 09 Apr 2013 19:27:32 +0200 | Artem Tikhomirov | Added tag v1.1m3 for changeset 32453f30de07 | 
 
  | Tue, 09 Apr 2013 19:25:34 +0200 | Artem Tikhomirov | Annotate command with command-line example
   v1.1m3 | 
 
  | Tue, 09 Apr 2013 17:15:30 +0200 | Artem Tikhomirov | Refactor common code to initialize changelog revision for a command into standalone class | 
 
  | Wed, 03 Apr 2013 21:28:06 +0200 | Artem Tikhomirov | Recognize re: in-line prefix for regular expressions as native client does, despite silence in hgingore.5 | 
 
  | Thu, 28 Feb 2013 16:34:33 +0100 | Artem Tikhomirov | HgCheckoutCommand: clean parameter, discard changes in WD, test for clean checkout | 
 
  | Thu, 28 Feb 2013 15:57:04 +0100 | Artem Tikhomirov | Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception | 
 
  | Wed, 27 Feb 2013 19:37:58 +0100 | Artem Tikhomirov | Do not process child revisions before all possible parent paths were visited | 
 
  | Tue, 26 Feb 2013 21:06:43 +0100 | Artem Tikhomirov | Exception when no blocks from merged revision were reported and merge parent was not recorded for future use | 
 
  | Mon, 25 Feb 2013 19:48:20 +0100 | Artem Tikhomirov | Commit: tests and fixes for defects discovered | 
 
  | Mon, 25 Feb 2013 18:41:44 +0100 | Artem Tikhomirov | Annotate: refactor/reuse range handling code | 
 
  | Sun, 24 Feb 2013 00:11:40 +0100 | Artem Tikhomirov | Annotate: Line annotation needs true line position from merged blocks; test-annotate repo updated to show elements from both parents in the merged revision | 
 
  | Fri, 22 Feb 2013 20:21:24 +0100 | Artem Tikhomirov | AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc | 
 
  | Fri, 22 Feb 2013 19:03:25 +0100 | Artem Tikhomirov | Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision | 
 
  | Thu, 21 Feb 2013 21:53:55 +0100 | Artem Tikhomirov | Access to content of annotated files through BlockData interface | 
 
  | Thu, 21 Feb 2013 20:25:26 +0100 | Artem Tikhomirov | Test (with tailored repository) for annotation of multiple revisions | 
 
  | Wed, 20 Feb 2013 22:23:50 +0100 | Artem Tikhomirov | Annotate file changes through few revisions, walking either direction (old to new and vice versa) | 
 
  | Wed, 20 Feb 2013 18:19:52 +0100 | Artem Tikhomirov | Better (precise) name for diff facility, tests | 
 
  | Tue, 19 Feb 2013 21:35:09 +0100 | Artem Tikhomirov | Regression: expect file to be missing in a manifest | 
 
  | Tue, 19 Feb 2013 21:17:39 +0100 | Artem Tikhomirov | Annotate merge revision (combined diff against two parents without looking further) | 
 
  | Mon, 18 Feb 2013 19:58:51 +0100 | Artem Tikhomirov | Line-by-line annotation API and support code in place | 
 
  | Mon, 18 Feb 2013 19:58:10 +0100 | Artem Tikhomirov | #getFileRevision() shall accept TIP as an argument | 
 
  | Mon, 18 Feb 2013 19:19:48 +0100 | Artem Tikhomirov | File annotate test. Refactored FileAnnotation as standalone class, introduced LineInspector to make line offset calc code shared | 
 
  | Fri, 15 Feb 2013 22:15:13 +0100 | Artem Tikhomirov | First round of annotate file is functional | 
 
  | Fri, 15 Feb 2013 16:48:54 +0100 | Artem Tikhomirov | Refactor PatchGenerator to be generic and welcome sequence of any nature | 
 
  | Fri, 15 Feb 2013 15:52:03 +0100 | Artem Tikhomirov | Report line index for insertion and deletion, test against 'hg diff' output | 
 
  | Thu, 14 Feb 2013 16:36:13 +0100 | Artem Tikhomirov | Towards annotate/blame support: general outline of the functionality | 
 
  | Wed, 13 Feb 2013 19:42:22 +0100 | Artem Tikhomirov | PatchGenerator: refactoring to facilitate use in annotate/blame | 
 
  | Wed, 13 Feb 2013 19:41:33 +0100 | Artem Tikhomirov | Include commit tests into Ant's test suite | 
 
  | Wed, 13 Feb 2013 18:44:58 +0100 | Artem Tikhomirov | Commit: handle empty repository case | 
 
  | Tue, 05 Feb 2013 22:30:21 +0100 | Artem Tikhomirov | Commit: first working version | 
 
  | Tue, 05 Feb 2013 20:06:22 +0100 | Artem Tikhomirov | Update javadoc for HgManifest.Inspector and fix erroneous internal API | 
 
  | Tue, 05 Feb 2013 16:36:58 +0100 | Artem Tikhomirov | Tests: refactor various utility methods to a single location | 
 
  | Tue, 05 Feb 2013 15:54:37 +0100 | Artem Tikhomirov | Issue 42: tolerate lines in .hgtags that do not conform to its format specification | 
 
  | Mon, 04 Feb 2013 18:00:55 +0100 | Artem Tikhomirov | Commit: refactor revision creation code from clone command to work separately, fit into existing library structure | 
 
  | Wed, 30 Jan 2013 15:48:36 +0100 | Artem Tikhomirov | Generate patches using diff algorithm | 
 
  | Wed, 23 Jan 2013 19:14:15 +0100 | Artem Tikhomirov | Introduce explicit reference to base patch in bundle's group element, use it when cloning to fix defect when few revisions list null,null parents | 
 
  | Wed, 23 Jan 2013 18:03:13 +0100 | Artem Tikhomirov | Throw specific exception when checksum calculation fails | 
 
  | Wed, 23 Jan 2013 17:46:12 +0100 | Artem Tikhomirov | Towards commit command: refactor clone, extract pieces to reuse. Describe a defect discovered when bundle has few patches with 0,0 parents | 
 
  | Mon, 21 Jan 2013 19:41:51 +0100 | Artem Tikhomirov | Command to schedule addition/removal of repository files | 
 
  | Thu, 17 Jan 2013 19:23:52 +0100 | Artem Tikhomirov | Report rename when walking file history regardless of followRenames parameter, solely based on HgFileRenameHandlerMixin presence | 
 
  | Tue, 15 Jan 2013 19:46:19 +0100 | Artem Tikhomirov | Tests for present HgCheckoutCommand functionality. Update branch information on checkout. Use UTF8 encoding for the branch file | 
 
  | Tue, 15 Jan 2013 17:07:19 +0100 | Artem Tikhomirov | Initial support for Revert command with accompanying minor refactoring | 
 
  | Fri, 11 Jan 2013 18:12:39 +0100 | Artem Tikhomirov | Repository checkout support, first iteration | 
 
  | Fri, 11 Jan 2013 18:10:29 +0100 | Artem Tikhomirov | @since tag for HgIterateDirection | 
 
  | Wed, 26 Dec 2012 18:16:48 +0100 | Artem Tikhomirov | Added tag v1.1m2 for changeset 2103388d4010 | 
 
  | Wed, 26 Dec 2012 18:14:53 +0100 | Artem Tikhomirov | Expose option to report changesets in reversed order
   v1.1m2 | 
 
  | Wed, 26 Dec 2012 17:51:07 +0100 | Artem Tikhomirov | Cover ChangesetTreeHandler with various followRename, followAncestry and direction | 
 
  | Fri, 21 Dec 2012 21:20:26 +0100 | Artem Tikhomirov | Experimental support for inverse direction history walking. Refactored/streamlined cancellation in HgLogCommand and down the stack | 
 
  | Thu, 20 Dec 2012 20:21:59 +0100 | Artem Tikhomirov | Few toString() implementations to ease debug | 
 
  | Thu, 20 Dec 2012 19:55:45 +0100 | Artem Tikhomirov | Tests for HgLogCommand#execute(HgChangesetHandler) with various combination of follow renames and ancestry | 
 
  | Tue, 18 Dec 2012 19:08:00 +0100 | Artem Tikhomirov | Update test to use new command configuration argument (used to have followAncestry == true by default) | 
 
  | Tue, 18 Dec 2012 18:57:03 +0100 | Artem Tikhomirov | Allow walking file rename history independently from file ancestry (native hg log --follow does both at once) | 
 
  | Mon, 17 Dec 2012 20:51:12 +0100 | Artem Tikhomirov | Provide access to HgDataFile being iterated into HgChangesetTreeHandler.TreeElement to give context for renamed files | 
 
  | Mon, 17 Dec 2012 19:06:07 +0100 | Artem Tikhomirov | Report renames when following file history tree with HgFileRenameHandlerMixin | 
 
  | Mon, 17 Dec 2012 15:01:57 +0100 | Artem Tikhomirov | Issue 39: HgCloneCommand doesn't use CancelSupport/ProgressSupport handlers | 
 
  | Fri, 14 Dec 2012 20:10:15 +0100 | Artem Tikhomirov | Issue 39: Progress and Cancel support for Clone command | 
 
  | Fri, 14 Dec 2012 15:39:49 +0100 | Artem Tikhomirov | Respect multiple joins/forks in a history of a single file | 
 
  | Thu, 13 Dec 2012 15:46:40 +0100 | Artem Tikhomirov | Full-fledged test repo to follow file history. Investigating iteration direction alternatives (from new to old in addition to existing old to new) | 
 
  | Thu, 13 Dec 2012 13:18:35 +0100 | Artem Tikhomirov | Establish parent-child between first and last elements of history chunks for two renamed files | 
 
  | Wed, 12 Dec 2012 20:52:10 +0100 | Artem Tikhomirov | Support follow history option when walking file history tree | 
 
  | Wed, 12 Dec 2012 14:17:12 +0100 | Artem Tikhomirov | Test for HgChangesetTreeHandler - make sure nothing is broken prior to adding --follow support | 
 
  | Fri, 30 Nov 2012 22:52:39 +0100 | Artem Tikhomirov | Experiment to add a facility to check working files for actual changes | 
 
  | Fri, 30 Nov 2012 22:08:11 +0100 | Artem Tikhomirov | Use checked exception to indicate fs lock entanglements | 
 
  | Fri, 30 Nov 2012 21:58:00 +0100 | Artem Tikhomirov | Allow to override lock timeout from within Hg4J | 
 
  | Wed, 31 Oct 2012 15:17:21 +0100 | Artem Tikhomirov | Add lookup of remote paths from repository's .hg/hgrc, respect default (origin) | 
 
  | Mon, 29 Oct 2012 20:06:16 +0100 | Artem Tikhomirov | Respect changesets with no list of changed files, as discovered with Issue 41 | 
 
  | Mon, 29 Oct 2012 19:04:13 +0100 | Artem Tikhomirov | Change the way extensions are accessed (with ExtensionsManager now), add preliminary Rebase extension support | 
 
  | Mon, 29 Oct 2012 18:16:21 +0100 | Artem Tikhomirov | Tailored subclass of IAE for malformed Nodeids:HgBadNodeidFormatException | 
 
  | Fri, 26 Oct 2012 18:21:50 +0200 | Artem Tikhomirov | Issue 38: add test for new keys and new section | 
 
  | Fri, 26 Oct 2012 18:17:15 +0200 | Artem Tikhomirov | Issue 38: preserve user formatting and comments when updating configuration files | 
 
  | Thu, 25 Oct 2012 19:59:08 +0200 | Artem Tikhomirov | Issue 38. Towards gentle handling of config files - parse them and keep every possible user change | 
 
  | Mon, 22 Oct 2012 20:33:20 +0200 | Artem Tikhomirov | Recognize 'merged from parent' metastate in dirstate | 
 
  | Fri, 19 Oct 2012 16:03:21 +0200 | Artem Tikhomirov | Do not use exception when only metadata processing is needed. For hg4j repo, status 0:-1 changed from 500 to 60 ms | 
 
  | Thu, 18 Oct 2012 19:51:07 +0200 | Artem Tikhomirov | Defect: use of 0 as configuration value for mapio boundary results in every file being memmap-ed | 
 
  | Thu, 18 Oct 2012 18:36:13 +0200 | Artem Tikhomirov | Refactor to keep knowledge about repository control files and their location in respect to .hg/ in a single place (facilitate future adoption of shared repositories) | 
 
  | Thu, 18 Oct 2012 16:27:32 +0200 | Artem Tikhomirov | Leave path as close as possible to one supplied by user. No need to keep it as canonical | 
 
  | Tue, 16 Oct 2012 21:07:27 +0200 | Artem Tikhomirov | Javadoc for HgRepository#getLocation() | 
 
  | Thu, 16 Aug 2012 17:08:34 +0200 | Artem Tikhomirov | Refactoring: move HgRepository's implementation aspects to Internals (which is now its imlementation counterpart and primary repository class to be used by other parts of the library) |