Merge branch 'master' into assistant

This commit is contained in:
Joey Hess 2012-07-29 21:54:33 -04:00
commit de792c35e4
9 changed files with 178 additions and 7 deletions

View file

@ -0,0 +1,8 @@
[[!comment format=mdwn
username="jtang"
ip="79.97.135.214"
subject="comment 10"
date="2012-07-29T10:49:05Z"
content="""
This is looking good, no more segfaulting.
"""]]

View file

@ -0,0 +1,49 @@
I've noticed this to occur occassionally
<pre>
laplace:atest jtang$ ls
1@ 2@ 3@ 4@ 5@ readme.txt@
laplace:atest jtang$ git annex watch -d --foreground
watch . [2012-07-29 11:49:26 IST] read: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","show-ref","git-annex"]
[2012-07-29 11:49:26 IST] read: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","show-ref","--hash","refs/heads/git-annex"]
[2012-07-29 11:49:26 IST] read: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","log","refs/heads/git-annex..f85faa60e73efabc2e92f837b19c3918d3ab030f","--oneline","-n1"]
[2012-07-29 11:49:26 IST] chat: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","cat-file","--batch"]
(scanning...) [2012-07-29 11:49:26 IST] Assistant: all threads started
[2012-07-29 11:49:26 IST] Merger: watching /Users/jtang/sandbox/atest/.git/refs/heads/synced
[2012-07-29 11:49:26 IST] TransferWatcher: watching for transfers
[2012-07-29 11:49:26 IST] read: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","symbolic-ref","HEAD"]
[2012-07-29 11:49:26 IST] call: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","add","--update"]
[2012-07-29 11:49:26 IST] Merger: merging changes into Just refs/heads/master
[2012-07-29 11:49:26 IST] call: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","merge","--no-edit","refs/heads/synced/master"]
(started...) [2012-07-29 11:49:26 IST] Watcher: watching .
[2012-07-29 11:49:26 IST] WebApp: running on port 60042
Already up-to-date.
[2012-07-29 11:49:26 IST] Watcher: add symlink ./1
[2012-07-29 11:49:26 IST] chat: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","cat-file","--batch"]
[2012-07-29 11:49:26 IST] Watcher: add symlink ./2
[2012-07-29 11:49:26 IST] Watcher: add symlink ./3
[2012-07-29 11:49:26 IST] Watcher: add symlink ./4
[2012-07-29 11:49:26 IST] Watcher: add symlink ./5
[2012-07-29 11:49:26 IST] Watcher: add symlink ./readme.txt
[2012-07-29 11:49:27 IST] Committer: committing 6 changes
(Recording state in git...)
[2012-07-29 11:49:27 IST] feed: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","update-index","-z","--index-info"]
[2012-07-29 11:49:27 IST] call: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","commit","--allow-empty-message","-m","","--allow-empty","--quiet"]
[2012-07-29 11:49:28 IST] read: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","symbolic-ref","HEAD"]
[2012-07-29 11:49:28 IST] Pusher: pushing to []
[2012-07-29 11:49:28 IST] call: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","branch","-f","synced/master"]
[2012-07-29 11:49:28 IST] read: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","symbolic-ref","HEAD"]
[2012-07-29 11:49:28 IST] Merger: merging changes into Just refs/heads/master
[2012-07-29 11:49:28 IST] call: git ["--git-dir=/Users/jtang/sandbox/atest/.git","--work-tree=/Users/jtang/sandbox/atest","merge","--no-edit","refs/heads/synced/master"]
Already up-to-date.
[2012-07-29 11:49:43 IST] Watcher: file added ./.gitignore
[2012-07-29 11:49:43 IST] read: lsof ["-F0can","+d","/Users/jtang/sandbox/atest/.git/annex/tmp/"]
[2012-07-29 11:49:44 IST] Committer: delaying commit of 0 changes
[2012-07-29 11:49:45 IST] read: lsof ["-F0can","+d","/Users/jtang/sandbox/atest/.git/annex/tmp/"]
[2012-07-29 11:49:46 IST] Committer: delaying commit of 0 changes
[2012-07-29 11:49:47 IST] read: lsof ["-F0can","+d","/Users/jtang/sandbox/atest/.git/annex/tmp/"]
[2012-07-29 11:49:48 IST] Committer: delaying commit of 0 changes
[2012-07-29 11:49:49 IST] read: lsof ["-F0can","+d","/Users/jtang/sandbox/atest/.git/annex/tmp/"]
</pre>
I ran " git annex watch -d --foreground" to watch what was going one, and just created a .gitignore file and the the commiter/lsof thread just loops over and over.... I only noticed as my laptop battery had drained at somepoint when git-annex was running in the background.

View file

@ -0,0 +1,11 @@
[[!comment format=mdwn
username="http://joeyh.name/"
ip="4.153.8.133"
subject="probably a kqueue specific problem..."
date="2012-07-29T18:10:12Z"
content="""
I don't think this would eat your battery badly; it's looping for sure, but with a hardcoded 1 second delay I put in to guard against it eating all CPU.
I tried to fix this in commit c4023f785834bc237e5fcdb69e275bbae10dd40b, but I sort of doubt I did.
I made one more commit that will at least tell us what file it is trying to check over and over with lsof.
"""]]

View file

@ -26,6 +26,10 @@ References:
* <http://stackoverflow.com/questions/5151858/running-a-haskell-program-on-the-android-os> * <http://stackoverflow.com/questions/5151858/running-a-haskell-program-on-the-android-os>
* <http://www.reddit.com/r/haskell/comments/ful84/haskell_on_android/> * <http://www.reddit.com/r/haskell/comments/ful84/haskell_on_android/>
I've heard anecdoally that ipwnstudios not only has an IPhone GHC port,
but also Android. Need to get in touch with them.
<http://ipwnstudios.com/>
### Android specific features ### Android specific features
The app should be aware of power status, and avoid expensive background The app should be aware of power status, and avoid expensive background

View file

@ -0,0 +1,68 @@
Focus today was writing a notification broadcaster library. This is a way to
send a notification to a set of clients, any of which can be blocked
waiting for a new notification to arrive. A complication is that any number
of clients may be be dead, and we don't want stale notifications for those
clients to pile up and leak memory.
It took me 3 tries to find the solution, which turns out to be head-smackingly
simple: An array of SampleVars, one per client.
Using SampleVars means that clients only see the most recent notification,
but when the notification is just "the assistant's state changed somehow;
display a refreshed rendering of it", that's sufficient.
----
First use of that was to make the thread that woke up every 10 minutes
and checkpointed the daemon status to disk also wait for a notification
that it changed. So that'll be more current, and use less IO.
----
Second use, of course, was to make the WebApp block long polling clients
until there is really a change since the last time the client polled.
To do that, I made one change to my Yesod routes:
[[!format diff """
-/status StatusR GET
+/status/#NotificationId StatusR GET
"""]]
Now I find another reason to love Yesod, because after doing that,
I hit "make".. and fixed the type error. And hit make.. and fixed
the type error. And then it just freaking worked! Html was generated with
all urls to /status including a `NotificationId`, and the handler for
that route got it and was able to use it:
[[!format haskell """
{- Block until there is an updated status to display. -}
b <- liftIO $ getNotificationBroadcaster webapp
liftIO $ waitNotification $ notificationHandleFromId b nid
"""]]
And now the WebApp is able to display transfers in realtime!
When I have both the WebApp and `git annex get` running on the same screen,
the WebApp displays files that git-annex is transferring about as fast
as the terminal updates.
The [[progressbars]] still need to be sorted out, but otherwise
the WebApp is a nice live view of file transfers.
---
I also had some fun with Software Transactional Memory. Now when the
assistant moves a transfer from its queue of transfers to do, to its map of
transfers that are currently running, it does so in an atomic transaction.
This will avoid the transfer seeming to go missing (or be listed twice) if
the webapp refreshes at just the wrong point in time. I'm really starting
to get into STM.
----
Next up, I will be making the WebApp maintain a list of notices, displayed
on its sidebar, scrolling new notices into view, and removing ones the user
closes, and ones that expire. This will be used for displaying errors, as
well as other communication with the user (such as displaying a notice
while a git sync is in progress with a remote, etc). Seems worth doing now,
so the basic UI of the WebApp is complete with no placeholders.

View file

@ -0,0 +1,14 @@
Some days I spend 2 hours chasing red herrings (like "perhaps my JSON ajax
calls arn't running asynchronoously?") that turn out to be a simple
one-word typo. This was one of them.
However, I did get the sidebar displaying alert messages, which can be
easily sent to the user from any part of the assistant. This includes
transient alerts of things it's doing, which disappear once the action
finishes, and long-term alerts that are displayed until the user closes
them. It even supports rendering arbitrary Yesod widgets as alerts, so
they can also be used for asking questions, etc.
Time for a screencast!
<video controls src="http://joeyh.name/screencasts/git-annex-webapp.ogg"></video>

View file

@ -0,0 +1,18 @@
[[!comment format=mdwn
username="https://www.google.com/accounts/o8/id?id=AItOawkpEY8WTFDhjIVTWG38Ph7ppmuXUTJAHAg"
nickname="Justin"
subject="selective sync"
date="2012-07-28T04:08:00Z"
content="""
hey joey
great work!!
will partial content work like selective sync in dropbox
use case: on desktop i have photos/mp3s/docs, but would only want to sync the docs to my netbook
cheers
justin
"""]]

View file

@ -16,7 +16,7 @@ The webapp is a web server that displays a shiny interface.
## interface ## interface
* list of files uploading and downloading * list of files uploading and downloading **done**
* progress bars for each file * progress bars for each file
* drag and drop to reorder * drag and drop to reorder
* cancel and pause * cancel and pause
@ -27,15 +27,14 @@ The webapp is a web server that displays a shiny interface.
* there could be a UI to export a file, which would make it be served up * there could be a UI to export a file, which would make it be served up
over http by the web app over http by the web app
* Display any relevant warning messages. One is the `inotify max_user_watches` * Display any relevant warning messages. One is the `inotify max_user_watches`
exceeded message. Need to lift such messages into DaemonStatus exceeded message.
so the WebApp can include them in its rendering of DaemonStatus.
## implementation ## implementation
* perhaps define a custom `errorHandler`, which could avoid the potential
of leaking auth tokens on error pages. Or make the test suite test for
leakage.
* possibly lose the ugly auth= token past the first page, * possibly lose the ugly auth= token past the first page,
and use a client-side session. It could be encrypted using the token and use a client-side session. It could be encrypted using the token
as the `encryptKey`. Note: Would need to set the session duration as the `encryptKey`. Note: Would need to set the session duration
to infinite (how?) to infinite (how?)
* Fix notification handle leakage on pages other than the main page.
The javascript should use AJAX to request handles, that way
they won't be allocated at all in noscript.

View file

@ -1,7 +1,7 @@
The `git annex sync` command provides an easy way to keep several The `git annex sync` command provides an easy way to keep several
repositories in sync. repositories in sync.
Often git is used in a centralized fashion with a central bare repositry Often git is used in a centralized fashion with a central bare repository
which changes are pulled and pushed to using normal git commands. which changes are pulled and pushed to using normal git commands.
That works fine, if you don't mind having a central repository. That works fine, if you don't mind having a central repository.