So you want to be an iPad Developer Nomad. A person who can do all their development on the iPad. I’m not sure why you’d want to be such a character, in fact, I’m not sure why I want to be such a character, but I do, and here’s how I do it. To be a developer nomad, you better already be a command line wiz. If you’re not at an expert at the terminal, vim or Emacs and TMUX - don’t even try.
There are three paths - remote development, local development, and hybrid. For all of these you’ll need an external keyboard, which I’ll also discuss.
- Remote Development - Blink
- Local Development - iSh, iVIM, Working Copy, etc
- Hybrid development - Consistency
- The external keyboard.
- Related links
Remote Development - Blink
This is the easy way, but you’re going to need a good low latency network.
First you need a remote box, I use lightsail. For 10$ a month I’ve never run out of CPU or disk. Next you need to be able to connect to the box using SSH, and that requires an ssh client. I use blink and couldn’t be happier. Great product, great support.
ssh super powers - port forwarding and TMUX auto-attach
Because ssh doesn’t keep persistent sessions, I use TMUX with an auto reattach script. If you’re not doing this, go learn how it’s awesome. You should also know about ssh port forwarding
My dot files should provide some insights on powerful command line tricks. For inspiration, here’s what my TMUX sessions look like (press C-B w to get this view)
(0) - main: 6 windows (attached)
(1) ├> 0: vim* (1 panes) "ip-172-26-8-55"
(2) ├> 1: zsh- (1 panes) "ip-172-26-8-55"
(3) ├> 2: glances (1 panes) "ip-172-26-8-55"
(4) ├> + 3: ntop (2 panes)
(5) ├> 7: zsh (1 panes) "ip-172-26-8-55"
(6) - servers: 3 windows
(7) ├> 0: jekyll blog* (1 panes) "ip-172-26-8-55"
(8) ├> 1: techdiary grip- (1 panes) "ip-172-26-8-55"
(9) └> 2: jupyter serve (1 panes) "ip-172-26-8-55"
(For folks that are considering MOSH, MOSH has great promise, but the project hasn’t been updated in years, and still doesn’t support true color. For my needs ssh+TMUX+auto-reconnect is perfect.)
Local Development - iSh, iVIM, Working Copy, etc
Remote development is perfect, except of course when you have no and or slow network. At this point you need to get creative. Luckily, there has been lots of improvement in this space.
Run Linux - iSH
The holy grail. iSH takes a very impressive approach. And tbodt the author of iSH is incredibly cool, I have the utmost respect for his project and his style, and I even have his user name memorized.
iSH Creates an x86 emulated machine (e.g. simulate execution), and run alpine Linux in it. I love this but it has two big gaps. A) Compatibility B) Speed. There are still CPU instructions and system calls that aren’t supported so large swaths of applications don’t work - E.g. NPM, Rust. B) Because it’s emulated it’s slow, so I need to use trimmed down versions of all my configurations.
When your software can run iSH, and is fast enough, you’re done. However because of the compatibility and speed concerns, you’ll often need other solutions to augment iSH. Here are the ones I use
Useful ish tips:
- Run ssh-keygen then you can ssh into your other machines
- You can access clipboard by cat or pipe-in to /dev/clipboard
Run git - Working copy
Working Copy - the best git client for iOS, it’s truly fantastic. So many features you should read the documentation as carefully as you would for TMUX.
Even though it’s graphical it can be automated because it exposes iOS APIs via URL that other tools (like VIM) can execute. Super cool.
Example callbacks I use are:
Pull All Repos:
working-copy://x-callback-url/pull?key=secret&repo=%2A
A cousin to Working Copy is Git Hawk this tool allows you to monitor your GitHub messages.
Run Vim - iVIM
iVIM does a great job being VIM, but you tend not to use VIM in isolation, you need Git and Plugins and often some command line integration. There are workarounds, some of which painful, but I’ll describe them here.
OK - this stuff is now pretty stale, be sure to use ivim to look at the ios specific help.
iVIM now support:
- Some plugin integration
- Nice font upgrade :ifont increase
-
Preview windows (in New tab, and works with markdown render in realtime) :ipreview -w
- git integration
For this you load your files into working copy and link them via idoc dir, and then they are available locally
:iexdir add
-
bundle/plugin integration
:iplug
-
Ctags support wow!
!ctags
Run python - Pyto
Pythonista used to be the bomb, but now Pyto looks like it’s actively updated
Run Jupyter - Carnets
Edit markdown
- Editorial - Markdown editor that can interact with Working Copy (seems nicer then Byword)
- Byword - Markdown editor that can interact with Working Copy
- MWeb - Markdown editor that can interact with Working Copy
Hybrid development - Consistency
What is hybrid development? It’s remote development when you’ve got the network and local development when you don’t. This model is similar to having to work on multiple machines at the same time.
The main complexity with hybrid development is keeping everything in sync. To do this I keep everything in git, and then run a cron job that’s pushing and pulling continuously. My cron job approach is:
https://github.com/idvorkin/Settings/blob/master/shared/cron_git_sync.sh
The two gaps here are merge conflicts (which I handle manually), and not syncing on my iPad, which is tricky because I haven’t found a way to do a periodic timer to arbitray command execution yet (TK: Holler if you have a good way to do this)
The external keyboard
The keyboard I use
I’m a huge fan of ergo keyboards. iClever makes a cheap folding ergo Bluetooth keyboard that support up to 3 devices. I prefer this to all my laptop keyboards.
See more details at
The iPad stand I use
Getting a good stand is hard and I’m constantly iterating.
For places I use my iPad a lot at home I use this ergo monitor arm equivalent. It lets you position your relatively heavy iPad into any position or orientation.
For remote use, I want something that is light and fits in my bag. I’ve tried slews of stands and I dislike all of them. I’m currently using the moko folding , which I’m not thrilled with, but best I’ve found.
Caps to Control
Finally, built into iOS 13.4
Back tick to escape
The keyboard I use has backtick where escape should be. In VIM this is super painful iSH and blink have options to flip this. In iVIM you can do a key remap - e.g.
:imap ` <C-[>
:cmap ` <C-[>
Carrying bags
Slightly off topic, but if you made it this far, you probably care about small bags as well.
It’s taken me several tries, but I’ve concluded I like the smallest bag possible. I use a 13” macbook pro laptop and an iPad Pro 10” and this is the perfect bag for me:
https://www.amazon.com/gp/product/B07WNPPF72
There’s also the horizontal version - which is slightly bigger but also nice:
https://www.amazon.com/gp/product/B07H4QYC2D/
Related links
- My general iOS tips.
- Automating iOS
- x-callback-urls for OmniFocus