2014-06-17 18:33:47 +00:00
|
|
|
The git-annex Windows port is beta, but rapidly becoming polished and
|
|
|
|
usable!
|
2012-01-13 17:55:14 +00:00
|
|
|
|
2013-05-11 21:17:38 +00:00
|
|
|
## status
|
2011-06-10 19:55:38 +00:00
|
|
|
|
2015-01-06 22:02:56 +00:00
|
|
|
* There can be problems when the git-annex repository is in a deep
|
|
|
|
or long path. Ie, `C:\loooooooooooooooooongdir\`.
|
|
|
|
[Details here](http://git-annex.branchable.com/bugs/__34__git-annex:_direct:_1_failed__34___on_Windows)
|
|
|
|
Workaround: Put your git-annex repo in `C:\annex` or some similar short
|
|
|
|
path if possible.
|
|
|
|
|
2014-02-26 23:44:25 +00:00
|
|
|
* XMPP library not yet built. (See below.)
|
2014-02-14 18:39:54 +00:00
|
|
|
|
2014-02-10 22:24:36 +00:00
|
|
|
* Local pairing seems to fail, after acking on Linux box, it stalls.
|
2014-02-25 19:13:27 +00:00
|
|
|
(Also, of course, the Windows box is unlikely to have a ssh server,
|
|
|
|
so only pairing with a !Windows box will work.)
|
2014-02-14 18:39:54 +00:00
|
|
|
|
2014-02-10 22:24:36 +00:00
|
|
|
* gcrypt is not ported to windows (and as a shell script, may need
|
|
|
|
to be rewritten)
|
2014-02-14 18:39:54 +00:00
|
|
|
|
2014-02-13 16:40:10 +00:00
|
|
|
* Incremental fsck sets the sticky bit to record when a file is fscked,
|
|
|
|
and this is not done on windows, so fsck doesn't behave incrementally
|
|
|
|
there.
|
2014-02-14 18:39:54 +00:00
|
|
|
|
2014-02-13 16:55:27 +00:00
|
|
|
* Deleting a git repository from inside the webapp fails "RemoveDirectory
|
2014-02-14 18:06:51 +00:00
|
|
|
permision denied ... file is being used by another process"
|
2014-02-11 20:12:22 +00:00
|
|
|
|
2014-03-19 18:49:01 +00:00
|
|
|
## potential encoding problems
|
|
|
|
|
|
|
|
[[bugs/Unicode_file_names_ignored_on_Windows]] is fixed, but some potential
|
|
|
|
problems remain, since the FileSystemEncoding that git-annex relies on
|
|
|
|
seems unreliable/broken on Windows.
|
|
|
|
|
|
|
|
* When git-annex displays a filename that it's acting on, there
|
|
|
|
can be mojibake on Windows. For example, "háčky.txt" displays
|
|
|
|
the accented characters as instead the pairs of bytes making
|
|
|
|
up the utf-8. Tried doing various things to the stdout handle
|
|
|
|
to avoid this, but only ended up with encoding crashes, or worse
|
|
|
|
mojibake than this.
|
|
|
|
|
|
|
|
* `md5FilePath` still uses the filesystem encoding, and so may produce the
|
|
|
|
wrong value on Windows. This would impact keys that contain problem characters
|
|
|
|
(probably coming from the filename extension), and might cause
|
|
|
|
interoperability problems when git-annex generates the hash directories of a
|
|
|
|
remote, for example a rsync remote.
|
|
|
|
|
|
|
|
* `encodeW8` is used in Git.UnionMerge, and while I fixed the other calls to
|
|
|
|
encodeW8, which all involved ByteStrings reading from git and so can just
|
|
|
|
treat it as utf-8 on Windows (via `decodeBS`), in the union merge case,
|
|
|
|
the ByteString has no defined encoding. It may have been written on Unix
|
|
|
|
and contain keys with invalid unicode in them. On windows, the union
|
|
|
|
merge code should probably check if it's valid utf-8, and if not,
|
|
|
|
abort the merge.
|
|
|
|
|
|
|
|
* If interoperating with a git-annex repository from a unix system, it's
|
|
|
|
possible for a key to contain some invalid utf-8, which means its filename
|
|
|
|
cannot even be represented on Windows, so who knows what will happen in that
|
|
|
|
case -- probably it will fail in some way when adding the object file
|
|
|
|
to the Windows repo.
|
|
|
|
|
|
|
|
* If data from the git repo does not have a unicode encoding, it will be
|
|
|
|
mangled in various places on Windows, which can lead to undefined behavior.
|
|
|
|
|
2014-02-14 18:39:54 +00:00
|
|
|
## minor problems
|
|
|
|
|
|
|
|
* webapp lets user choose to encrypt repo, and generate gpg key,
|
|
|
|
before checking that gcrypt is not installed
|
|
|
|
* Ssh connection caching does not work on Windows, so `git annex get`
|
|
|
|
has to connect twice to the remote system over ssh per file, which
|
|
|
|
is much slower than on systems supporting connection caching.
|
|
|
|
* glacier-cli is not easily available (probably)
|
|
|
|
|
2014-02-11 20:12:22 +00:00
|
|
|
## stuff needing testing
|
|
|
|
|
|
|
|
* test that adding a repo on a removable drive works; that git is synced to
|
|
|
|
it and files can be transferred to it and back
|
2014-02-13 18:00:15 +00:00
|
|
|
* Does stopping in progress transfers work in the webapp?
|
2014-02-26 23:44:25 +00:00
|
|
|
|
|
|
|
## trying to build XMPP
|
|
|
|
|
2014-02-27 17:35:06 +00:00
|
|
|
Lots of library deps:
|
|
|
|
|
|
|
|
1. gsasl-$LATEST.zip from <http://josefsson.org/gnutls4win/> (includes
|
|
|
|
gnuidn and gnutls)
|
2014-02-27 15:34:06 +00:00
|
|
|
2. pkg-config from
|
|
|
|
<http://sourceforge.net/projects/pkgconfiglite/files/latest/download?source=files>
|
|
|
|
3. libxml2 from mingw:
|
|
|
|
<http://sourceforge.net/projects/mingw/files/MSYS/Extension/libxml2/libxml2-2.7.6-1/>
|
|
|
|
both the -dll and the -dev
|
|
|
|
3. Extract all the above into the Haskell platform's mingw directory. Note
|
|
|
|
that pkg-config needs to be moved out of a named subdirectory.
|
2014-02-27 17:35:06 +00:00
|
|
|
4. Run in DOS prompt (not cygwin!): cabal install network-protocol-xmpp
|
|
|
|
|
|
|
|
Current FAIL:
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
Loading package gnutls-0.1.5 ... ghc.exe: internal error: Misaligned section: 18206e5b
|
|
|
|
(GHC version 7.6.3 for i386_unknown_mingw32)
|
|
|
|
Please report this as a GHC bug:
|
|
|
|
http://www.haskell.org/ghc/reportabug
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<https://ghc.haskell.org/trac/ghc/ticket/8830>
|
2014-02-26 23:44:25 +00:00
|
|
|
|
2014-02-27 17:35:06 +00:00
|
|
|
Note: This only happens in the TH link stage. So building w/o the webapp
|
2014-02-27 21:29:03 +00:00
|
|
|
works with XMPP.
|
|
|
|
|
|
|
|
Options:
|
|
|
|
|
|
|
|
1. Use EvilSplicer, building first without XMPP library, but with its UI,
|
|
|
|
and a second time without TH, but with the XMPP library. Partially done
|
|
|
|
on the `winsplicehack` branch, but requires building patched versions
|
|
|
|
of lots of yesod dependency chain to export modules referenced by TH
|
|
|
|
splices, like had to be done on Android. Horrible pain. Ugly as hell.
|
|
|
|
2. Make a helper program with the XMPP support in it, that does not use TH.
|
2014-03-20 16:51:47 +00:00
|
|
|
3. Swich to a different XMPP client library, like
|
|
|
|
<http://hackage.haskell.org/package/pontarius-xmpp>
|