Perhaps make Md5sum() and Modtime() optional.  Define the zero values
"" and 0. Make it so we can support remotes which can't do those.

Fix the docs
  * factor the README.md into the docs directory
  * create it as part of make by assembling other parts
  * write long docs about each flag

Change lsd command so it doesn't show -1
  * Make sure all Fses show -1 for objects Zero for dates etc
  * Make test?

Put the TestRemote names into the Fs description
Make test_all.sh use the TestRemote name automatically

Run errcheck and go vet in the make file
.. Also race detector?
.. go tool vet -shadow

Get rid of Storable?

Write developer manual

Todo
  * FIXME: More -dry-run checks for object transfer
  * Might be quicker to check md5sums first? for swift <-> swift certainly, and maybe for small files
  * swift: Ignoring the pseudo directories
    * if object.PseudoDirectory {
      * fmt.Printf("%9s %19s %s\n", "Directory", "-", fs.Remote())
  * Make Account wrapper
    * make Account do progress meter
  * -timeout: Make all timeouts be settable with command line parameters
  * Add max object size to fs metadata - 5GB for swift, infinite for local, ? for s3
    * tie into -max-size flag
  * FIXME Make NewFs to return err.IsAnObject so can put the LimitedFs
    creation in common code? Or try for as much as possible?
  * FIXME Account all the transactons (ls etc) using a different
    Roundtripper wrapper which wraps the transactions?

More rsync features
  * include
  * exclude
  * max size
  * -c, --checksum              skip based on checksum, not mod-time & size

Ideas for flags
  * --retries N flag which would make rclone retry a sync until successful or it tried N times.

Ideas
  * could do encryption - put IV into metadata?
  * optimise remote copy container to another container using remote
    copy if local is same as remote - use an optional Copier interface
  * support
      * sftp
      * scp
      * rsync over ssh
  * control times sync (which is slow with some remotes) with -a --archive flag?
  * Copy a glob pattern - could do with LimitedFs

Make an encryption layer.

This would layer over the source FS to
    * decrypt all gets
    * encrypt all puts
    * encrypt file names in list
    * decrypt them in list

Would like to be able to see unencrypted file names in remote though? How?  Or is that two encryption layers..?

Bugs
  * Non verbose - not sure number transferred got counted up? CHECK
  * When doing copy it recurses the whole of the destination FS which isn't necessary