<feed xmlns='http://www.w3.org/2005/Atom'>
<title>notmuch/test/T860-git-remote.sh, branch master</title>
<subtitle>thread-based email index, search, and tagging</subtitle>
<id>https://git.notmuchmail.org/git/notmuch/atom?h=master</id>
<link rel='self' href='https://git.notmuchmail.org/git/notmuch/atom?h=master'/>
<link rel='alternate' type='text/html' href='https://git.notmuchmail.org/git/notmuch/'/>
<updated>2026-02-15T22:24:18Z</updated>
<entry>
<title>cli/git-remote: add check for missing messages</title>
<updated>2026-02-15T22:24:18Z</updated>
<author>
<name>David Bremner</name>
<email>david@tethera.net</email>
</author>
<published>2026-01-24T22:56:40Z</published>
<link rel='alternate' type='text/html' href='https://git.notmuchmail.org/git/notmuch/commit/?id=3f51f62eaf44842eb7f67536ff49b0ec972f8fe2'/>
<id>urn:sha1:3f51f62eaf44842eb7f67536ff49b0ec972f8fe2</id>
<content type='text'>
In cases where a given 'export' both adds and deletes messages, we may
not know what messages are actually missing until the end of
processing. We thus do single pass of all remaining message-ids, and
report any that are still missing at the end of the "export"
operation.
</content>
</entry>
<entry>
<title>cli/git-remote: handle message deletions</title>
<updated>2026-02-15T22:24:18Z</updated>
<author>
<name>David Bremner</name>
<email>david@tethera.net</email>
</author>
<published>2026-01-24T22:56:39Z</published>
<link rel='alternate' type='text/html' href='https://git.notmuchmail.org/git/notmuch/commit/?id=b7df6feb9809fa9735141fad01616555f4b21726'/>
<id>urn:sha1:b7df6feb9809fa9735141fad01616555f4b21726</id>
<content type='text'>
There are two main possibilities. One is explicit delete ('D' command
in the stream from git fast-export) and one is files disappearing
between commits. It is less clear the latter can happen in well formed
sequence of commits, but it could result e.g. from manual changes to
the repo.
</content>
</entry>
<entry>
<title>cli/git-remote: add export command</title>
<updated>2026-02-15T22:24:18Z</updated>
<author>
<name>David Bremner</name>
<email>david@tethera.net</email>
</author>
<published>2026-01-24T22:56:38Z</published>
<link rel='alternate' type='text/html' href='https://git.notmuchmail.org/git/notmuch/commit/?id=c4c0843d8fed39d4d7da6be493248f75d0c0d706'/>
<id>urn:sha1:c4c0843d8fed39d4d7da6be493248f75d0c0d706</id>
<content type='text'>
Two (sub)features are stubbed out in this initial implementation:
deleting messages (as opposed to tags), and missing messages. There
are two corresponding tests marked as broken in T860-git-remote.sh.
A third test passes with the stub, which is maybe not ideal, but at
least it acts as a regression test.
</content>
</entry>
<entry>
<title>cli/git-remote: add import command</title>
<updated>2026-02-15T22:24:18Z</updated>
<author>
<name>David Bremner</name>
<email>david@tethera.net</email>
</author>
<published>2026-01-24T22:56:37Z</published>
<link rel='alternate' type='text/html' href='https://git.notmuchmail.org/git/notmuch/commit/?id=cfc4af0e2bdf8f82ad14342baa6578d4dd366cd9'/>
<id>urn:sha1:cfc4af0e2bdf8f82ad14342baa6578d4dd366cd9</id>
<content type='text'>
The output in default.import is based on a modified version
of Felipe's git-remote-nm with Blake2 hashing replaced by SHA1
(for portability). This enable fetch/pull/clone, so test that as well.
</content>
</entry>
<entry>
<title>cli: start remote helper for git.</title>
<updated>2026-02-15T22:24:18Z</updated>
<author>
<name>David Bremner</name>
<email>david@tethera.net</email>
</author>
<published>2026-01-24T22:56:36Z</published>
<link rel='alternate' type='text/html' href='https://git.notmuchmail.org/git/notmuch/commit/?id=fcc41c82c4596aef1598eb9ea52c4b0cb4bb3c53'/>
<id>urn:sha1:fcc41c82c4596aef1598eb9ea52c4b0cb4bb3c53</id>
<content type='text'>
This is closely based on git-remote-nm (in ruby) by Felipe Contreras.
Initially just implement the commands 'capabilities' and 'list'.  This
isn't enough to do anything useful but we can run some simple unit tests. Testing
of URL passing will be done after clone (import command) support is
added.
</content>
</entry>
</feed>
