I found this by looking for an option that would let "git remote update" only fetch a subset of the remotes I have attached.
Thoughts and comments by John Sumsion about life and software.
Alma 34:38 Live in thanksgiving daily, for the many mercies and blessings which he doth bestow upon you.
31 December 2011
Useful Git Tips
I found this by looking for an option that would let "git remote update" only fetch a subset of the remotes I have attached.
Subscribing to FamilySearch Updates
Most sites give you large categories of feeds to track, but FamilySearch has all of 14 different feeds, some of which overlap or not (the feeds are available by appending '/feed' to the URL). But I couldn't find any "everything" feed URL.
Because I work for FamilySearch, and because I care about what goes on around me, I want to subscribe to everything, if only just to skim. The most important announcements get forwarded through internal email, however the additional articles are very useful context, especially for an employee.
Unfortunately, the default "subscribe" link just subscribes you to feeds #2, #3, & #4, or Indexing, Record Search, & Indexing, respectively. The "Subscribe" link is visible on an individual article's page, but isn't even present on the main blog page.
Here is the feed link you can put in your feed reader to subscribe to everything:
When feed/category/blog #15 gets defined, this feed URL will be invalid again. Maybe there is a better way. If anyone knows a better way, please let me know.
I want an "everything" subscribe link that I won't have to update in my feed reader, or maybe an "everything but trivia" link.
24 December 2011
Missed Tweets Through News.me
However, people have been saying and linking to important things on twitter for a while now. I'm just not discerning enough and don't have enough time to filter the firehose in a useful way.
The most helpful summary of interesting news I skim regularly is the weekly LinkedIn emails. In fact, I think it may have been through a link chain from one of those emails that I stumbled on unionfs, as reported in the last post. If I could have the same thing for twitter, but personalized to the people I follow, that would be really helpful!
Ironically, as part of the effort to make this blog more stuble-upon-able, I was looking for a way to auto-post on twitter and facebook whenever I post on this blog, and I found twitterfeed.com, which does all of that and more. And it's easy to set up.
After setting that up this morning, I wondered: "What is the company behind twitterfeed.com?", and found betaworks. They run some very interesting sites/companies, some of which I knew about (bit.ly), some of which were new to me (findings.com, chartbeat.com). The interesting one for me right now was another site called news.me.
Turns out that news.me is just the kind of thing that has the chance of making twitter useful to me. If things go well, you'll probably hear more about it.
21 December 2011
Intrusion Detection through Stackable Filesystems
When I stumbled upon unionfs a couple weeks ago, I thought that was an interesting idea from a change-logging perspective. It's sometimes useful to be able to keep a filesystem-based diff of what a certain operation does to a system, and then bake it onto the system when I know it did what I wanted to. The takeaway for me was that unionfs's performance profile had the opportunity to be so low because it was so thin and so baked into the kernel.
This compounded with my recent discovery and fiddling with fusefs (in user-land) and I wondered about what kind of useful logic I could put underneath a filesystem. The GlusterFS feature set, the recent LessFS GC stuff, the bup-fuse stuff, and the S3FS stuff is all just *really* cool. I ended up gazing longingly at the big backlog of fuse filsystem suggestions on their wiki, and wandered back into the unionfs space.
So, when I saw the I3FS paper (linked from here) about the modular application of this technique to intrusion detection, this really triggered the Useful *AND* Performant neurons and I got really excited.
Unfortunately, on first glance, the stackable filesystems stuff seemed pretty cryptic to set up in a lightweight, just-works kind of way (think custom mount command-lines complete with arcane stacking options).
It would be soooo awesome to have an easy-to-compose ruby DSL for doing some kind of rack-like filesystem mashup with a kernel-level unionfs layer underneath a user-land fusefs layer, but all expressed in the same DSL.
This would be an awesome tool to put on top of the Arch-derived clone I want to put up for people at work. There are folks who care about living more on the edge of linux stuff, but that don't care to install from scratch, and also might not care that much about not having a full Gnome stack if things just work. And if I could give them the same tuned IDS-on-the-desktop solution (or upgrade their developer stack by letting them pull a filesystem delta over), that would be really cool.
The cheap development observation [PDF, linked from] because of modularity is one of attributes valued highly by the Ruby community as well. It is one the key things that makes Ruby as a community awesome.
These kinds of ideas really matter, and making them so cheap and stable that you don't have to think about them really matters even more.
NOTE: The I3FS paper is really pretty old (2004), and the whole unionfs stack is older than that. The fuse stack came into the kernel a long time ago too (2005). So while this is new to me, it's been around for quite a long time. I'm playing catch-up.
Unicode Support Better Now in Ruby
- unicode_utils - includes implementations of word-break functionality, grapheme boundaries, etc.
- jcode (if you're stuck on ruby 1.8.x)
Semantic Versioning
19 December 2011
Some Git/Ruby stuff of interest
While taking the git survey a while back, I encountered:
- git-annex: awesome git-enabled large file archive support
which led me to:
- git-bup: way cool! git-like backup, even serves as a remote for git-annex
also this morning ran into:
- rib: irb, except better, including rib-heroku
- rest-core: like rack, except for RESTful clients
- gemgem: easy gem building, without all the hoe dependency cruft
I just wish that gem-man read the README{,.md} in the root of a gem (like gemgem does) if that gem didn't have a manpage. Sounds like a good patch to send. That will help me understand how gems can access their own filesystem post-install.
Thought you might like to know.
And btw, rbenv is way nicer to interact with than rvm, at least that's been my experience over the last couple weeks.
15 December 2011
srev-taming: Migrating Subversion to Git
Mass svn => git migration tooling doesn't really exist in the way I wish.
The most popular tool is probably svn2git. But even with all the conversion goodies baked into it, it's still based on git-svn.
Anything based on git-svn means that for an svn repo that has multiple projects in it, you have to take N passes over the repository, which is a huge hit for repos in the 20,000+ commit range.
The most performant conversion tool is svn-fe, but it doesn't do much more than just import at the repo boundary: 1 svn repo => 1 git repo. And it doesn't even begin to deal with the situation of multiple svn histories as we have migrated from one repo to another.
The closest thing that exists is a set of scripts posted as part of this thread.
Here is a rough cut of a project I wish existed:
"srev-taming" ~~ "svn-migrate"
(anagram, in the spirit of "snerp-vortex" ~~ "svn-exporter")
- scan of SVN dump for projects & codelines => annotated projects & branches list
- easy invocation of svn-fe for mass-import => generate me a command-line
- editable auto-detected project tags & codelines => language that easily expresses projects, codelines & grafts
- easy clone/filter-branch invocation to extract & stitch codelines together (based on projects & branches list and configured grafts)
- post-import filter for author fixup, SVN & migration artifact removal => generation of starting author list & svn URL minifier
29 October 2011
Backwards Names
I was just sitting on the couch tonight after a long Saturday and not thinking about backwards names at all. I had my laptop open to get some work done, but my son sat down next to me, and I wanted to show him some programming.
I started out in irb and just did some simple string substitution with his name, but irb and ruby make it so easy to just mess around that I ended up with an implementation of Backwards Names before I knew it.
Here it is:
It was just really fun to do that with him and see lights start to turn on about what programming was like.
19 October 2011
Git as Menograph
In Mar. 2010, Matz came and talked at MWRC.
The awesome talk focused around Ruby as a great invention that makes it possible for programmers to bring a new world into being that could only be imagined before.
He made reference to the inventor in Hugo Gernsback's book: Ralph 124c 41 +. The name was a play on words "One to foresee for one", with "+" being reserved for the 10 or so greatest inventors currently living.
Although Matz's reference could be interpreted as prideful, anyone who has ever had anything to do with him would correct you -- he is a very humble programmer who does awesome stuff.
Because I wanted to understand Matz's reference very thoroughly, I went and read the book. I was able to appreciate the scope of Matz's talk much more clearly after having read about Ralph, the great inventor.
Menograph, the invention
One thing that Ralph invented was a Menograph. It was a mind-recording device, operated by pressing a button that started a mind wave recorder and operated a scroll of fabric on which the waves were traced in ink, similar to an old-style seismograph.
The Menograph was one of Ralph 124C 41 +'s earliest inventions, and entirely superseded the pen and pencil. It was only necessary to press the button when an idea was to be recorded and to release the button when one merely reflected and did not wish the thought-words recorded.
Those thoughts could then be replayed again verbatim by any person by use of a device called a Hypnobioscope.
After reading an account of Ralph using this invention, which is more detailed than I am able to reproduce here, I had a vague sense that I had experienced a similar feeling before while programming.
Git as Menograph
After thinking about it for a while, I realized that how Ralph used his Menograph is how I use git.
While coding, I work on stuff, then I record commits into git. Then I work on stuff some more, then record commits.
Then I take passes back over what I've recorded and get rid of the bad stuff and keep the good stuff. Then I push it out to the team. Sometimes, a pair or triple on the team do this as a group exercise, working history over a few time until it won't break the world.
The parallel to git was eye-opening. In fact, after having noticed this behavior in myself, and seeing the behavior tendency grow over time, I'd say that git encourages multi-pass thinking styles.
P.S. If you care at all about Ruby, listen to Matz's talk. Some of the future stuff he was talking about is already in Ruby 1.9.2. NOTE: I'm on linux, and I had to use the flash player to get the video to show.
18 October 2011
Attention to Error vs Attention to Detail
Why Do Some People Learn Faster?
Attention to Error
Some people might say this is what the scientific method is all about. I'm less methodical than a scientist would be -- I find it nevertheless useful to constantly put myself in situations where I can learn informally from comparing what I expect to what actually happens.
05 October 2011
Link to Paper
I've wanted to link to pages of books, or at least down to the chapter, or subhead.
Take, for example, the following blog post:
http://deliberate-thinking.blogspot.com/2010/04/reality-quotient.htmlIn that post, I refer to printed, copyrighted content by URL, but with lame google books URLs that have nothing to do with the structure of the book, and that border on the potentially problematic situation traditionally called "deep linking".
Look for the following text in the blog post:
- text: Total Useful Mental Discriminations
- and link: http://books.google.com/books?id=563gvssRPvkC&lpg=PR1&dq=slack&pg=PA72#v=onepage
- text: capable people are credible
- and link: http://books.google.com/books?id=31Qe_e61Y10C&lpg=PP1&ots=bBbef5O2a3&dq=speed%20of%20trust&pg=PA92#v=onepage
Not page linking, but sections as defined by the work itself. No content extraction except perhaps to put the subhead text in the URL itself (either in English, or in the work's native language, or both). Now there would be a global permalink for a given chunk of a work.
So, as an example of what I'm shooting for, the following author has already done this with his book:
http://book.personalmba.com/bootstrapping/ (full of promotional material)Even though this page is full of promotional material, the link itself has value, because now I can refer to that small section of the book and talk about my own ideas, relative to that section.
And I can do so in a web-friendly way, with a meaningful URL.
The closest think I found was OpenLibrary itself with canonical URLs to Works and Editions. But has anyone done "link to paper" in a general sense?
Sincerely,
John...
Word Mixed With Faith
Ye shall know them by their fruits.Paul wrote to the Hebrews:
For unto us was the gospel preached, as well as unto them: but the word preached did not profit them, not being mixed with faith in them that heard it.It feels a lot like the recipe for inspiration and blessings from God includes the following ingredients:
- Word of God, shared or published
- Faith in those who receive it
27 September 2011
Using dot from graphviz
I've also watched developers try to use design tools for high-level sketch kind of diagrams and get bogged down with superfluous code-sync features.
- official site
- gallery of examples, also
- up-to-date language reference, and other documentation
- outdated, but very well-organized Users Guide
- dot-functions.sh
Here is the source of dot-functions.sh:
Another very helpful article was written on this topic by Diomidis Spinellis. Now that I think about it, there is another very helpful article about how to get a hand-written sketch into digital form.
Keeping a Beginner's Mind
I appreciated the wider perspective that I got from glancing through these slides by Patrick Kua:
The Beginner's MindAlthough I had seen and skimmed Pragmatic Thinking & Learning, this presentation was a gentle and useful introduction to the whole idea of the Dreyfus model of skill aquisition.
Another very useful idea that this presentation expressed was the contrast between "skill-acquiring apprentice" vs. "closed-minded expert". Patrick said that the "skill-acquiring" attribute can also apply to highly-skilled practitioners.
Among the tips Patrick gave, the following were useful to me:
- You can't be an expert on everything. [so don't even try]
- How can I try this safely?
- How does this fit in my world?
- Remain curious.
- Mix with diverse groups.
- Beware of built-in biases.
- Avoid judging early.
The reason I decided to compare/contrast some of the ideas in this presentation was actually because of my forays into the Pragmatic Thinking & Learning book, which was one of three "Further Resources" offered at the end.
Patrick recommended the following books for further learning:
Because of the context in which the Apprenticeship Patterns book appears, I want to read that as a next step for learning how to make a real difference at FamilySearch.
07 September 2011
Any reason not to post this?
It was then that the whole Cluetrain Manifesto finally clicked for me.
And I realized that the real question wasn't:
Would this topic be something I could post on my blog?but was really a quick:
Any reason not to post this? (right before hitting the Publish button)Seems like I've been kind of dense about this sort of thing.
31 August 2011
Lazy Developer plus No Slack equals Funding Guilt
- Pragmatic Thinking & Learning (personal learning)
- Driving Technical Change (organizational rollout affordances)
- Mythical Man-month (multi-pass thinking)
- using Git on a daily basis (multi-pass thinking)
- Pay to Learn when playing the game of software (optimizing for learning)
- Sooner Not Faster (optimizing for learning)
- Reductionist Agile Manifesto (paring things down to the core)
01 May 2011
Heralds of Life
My sister, Ann Sumsion wrote the following poem on Thursday, and I asked her if I could post it here. She said yes, so here it is:
Heralds of Life
Daffodils, the Trumpets of the Lord,
Speak peace and courage, love and faith,
To souls cold in world's winter.
Their warm and yellow blooms
Are testament of His enduring Grace
And Tender Mercies.
They cry, "The Lord is my Light,
And my Strength, and my Song.
He is my Salvation."
Heads bowed in strong Humility,
They nod in gentle breeze and bend in mighty tempest.
As leaves of grass, they die and fade,
In heat of summer's day.
But the memory of their bright nodding heads
Brought back in dark of night, and chill of frost,
Recalls Life, death overcome.
Their clarion trumpets echo their Master,
And cry, "Spring forth,
And Rise again."
I'm grateful for Ann's friendship and love for me. Her love for and confidence in her Savior are also qualities that I admire in her and want to emulate.
23 April 2011
These things transferred to myself
Moveover it is required in stewards, that a man be found faithful.Nephi said (see 1 Ne. 19:23, emphasis mine):
... yea, I judge not mine own self.
For I know nothing by myself; yet am I not hereby justified: but he that judgeth me is the Lord.
... And these things, brethren, I have in a figure transferred to myself and to Apollos for your sakes; that ye might learn in us not to think of men above that which is written, that no one of you be puffed up for one against the other.
but that I might more fully persuade them to believe in the Lord their Redeemer I did read unto them that which was written by the prophet Isaiah; for I did liken all scriptures unto us, that it might be for our profit and learning.I see the following three ideas present in both statements:
- habit of personalizing scriptural teaching
- attempt to teach by example
- making reference to prior patterns of personalization in a teaching situation
I've been in teaching/learning situations like this, and it feels really good to have a teacher that both understands the material and is willing to put it on your level when explaining it.
I'm grateful for Paul's and Nephi's willingness to be as frank and humble as they were in these scriptures. It's been a blessing to me to read, compare, and contrast the two scriptures.
06 April 2011
Core Goals of Version Control
The value is expressible in 4 goals.
Core Goals
- Capture source artifacts
- Isolate stable codelines from WIP
- Enable concurrent WIP
- Make it easy to leave sensible history behind
WIP = Work In Progress
The continuous delivery crowd says that WIP should be basically zero. I think that there is space for a fairly short development pipeline (3-5d) that can free developers up to capture ideas and then wrangle them into shape in a second or third pass.
Capture Source Artifacts
As a developer, I feel happy when I can push a save button when I've taken a small step -- and then never have think about it again. I also feel happy when I can save, even if I'm based on a slightly out-of-date base. I also feel happy when I don't have to worry about binary vs. text -- as long as its a true source file of a reasonable size.
I feel happiest when I don't have to be distracted by superfluous concerns, and can focus on the task at hand and save the results easily.
Main Point: A good version control system makes it easy to capture source artifacts.
Isolate Stable Codelines From WIP
Software is hard to get right, and once things get stable, the only way to keep them there is to avoid making risky changes. But stability is always balanced against the common desire for enhancement and restructuring.
A typical bug fix is one or two isolated commits that fix a specific problem. Most version control systems more or less support cherry-picking a small change over into another codeline.
I feel happy when I'm able to easily take an isolated series of commits from the development codeline into a stable one, even if the fix turns out to be a little larger than a couple commits.
Main Point: A good version control system makes it easy to cherry-pick changes, and even longer patch sequences, from one codeline to another with easy reconciliation of overlapping edits.
Enable Concurrent WIP
For software developed by a team larger than 2-3 people, it is useful to be able to work in parallel with each other, even on the same feature. Sometimes you can arrange your work so as not to overlap at all, but there are real situations where you want to track someone else's development within the fairly short development pipeline (3-5d) before things have gotten stable.
I feel happy when I don't have to catch people up on what I've been doing, and when they don't have to catch me up on what they've been doing, and we can get to the point easily and quickly. I also feel happy when we can leap-frog each other with ideas and real implementation.
Main Point: A good version control system makes it easy to track other team members' work, and easy to tentatively integrate with that work.
Make It Easy To Leave Sensible History Behind
After stepping away from a piece of software, it is easy to lose context and forget the concerns that shaped the development of that software. It doesn't take long. For me, about 2 weeks is enough for me to start forgetting details and motivations.
Of course, it is important to leave a properly structured artifact behind. Proper naming means a lot; proper factoring is important. Once you comprehend the structure, it is possible to change things without introducing big problems.
But often, full comprehension isn't practical, and a flat 2D view of the artifact is insufficient for reasoning about the thing itself. Often, it is often very useful to be able to get a vector on where the software came from, and interpolate from that vector where it was headed.
The creative process is messy, filled with double steps and backtracking. Don't confuse me with all the noise. Give me a history that, given all the knowledge you had when it got stable, at least looks well-reasoned.
I feel happy when I'm able to take an easy editing pass following capture/review that lets me intentionally craft history as an email to the future about the vector of change that is inherent in a certain patch sequence. I also feel very happy to not have to think about this during the creative, messy, focus-draining capture/review pass.
Main Point: A good version control system includes tools to both: 1) enable the developers to easily leave behind meaningful history, and 2) extract focused history for all or part of a piece of software.
30 March 2011
AN: Innovative genealogy information graphic
I went to the lightning talks at RootsTech and saw a 5m presentation from Antoninus Niemiec, an MFA student from New York working on genealogy visualization. He called his presentation "Not Your Father's Chart".
With permission, here are two fuzzed views of the charts so you can get the overall picture.
Plate A is a traditional ancestry chart:
Plate B is the same ancestry, laid out in this new and innovative way:
Here is a close-up of a given family:
Antoninus presented a very innovative information graphic of a 5 generation ancestry. At a high level, his work is firmly grounded in Tufte's information graphic design priciples. There were no wasted pixels and no chartjunk, just content.
It was organized with a radial feel to it, with the descendant family clusters in the center, and ancestor family clusters radiating outward toward the edge of the page. Each family cluster was organized into two tree-rings, one for the father, one for the mother-and-children. Each tree ring meant a decade, birth and death dates were plotted on a 360 degree circle, angle determined my how far into the year the event happened.
He told me he is working on publishing this work on his website. He said he did it in Adobe InDesign using Javascript with some hand-tweaking afterwards.
This spawned an interesting conversation afterward about the possibility for a visualization challenge for RootsTech 2012:
- fixed content corpus
- released shortly before the conference
- awards in traditional media (print, web, video)
- award for most innovative visualization, regardless of format
BTW, this was the same lightning round that Tevya talked about.
10 March 2011
Flesh pots & Resistance to change
2 And the whole congregation of the children of Israel murmered against Moses and Aaron in the wilderness:
3 And the children of Israel said unto them, Would to God we had died by the hand of the Lord in the land of Egypt, when we sat by the flesh pots, and when we did eat bread to the full; for ye have brought us forth into this wilderness, to kill this whole assembly with hunger.
7 And it came to pass that I, Nephi, said unto my father: I will go and do the things which the Lord hath commanded, for I know that the Lord giveth no commandments unto the children of men, save he shall prepare a way for them that they may accomplish the thing which he commandeth them.
Willingness to move forward and change and follow inspired leadership is a quality that I value, and that I seek to emulate & encourage.