Developing In Difficult Places

Over at Bite Code! there’s a post that I found really interesting. It’s about doing software deveopment or training in difficult places. “Difficult places” means places lacking the usual computing infrastructure or having a hostile political or geographical environment. The post describes what to pack and how to prepare for an assignment in one of those places.

One of the author’s main points is that you can’t depend on anything being available at the destination so you have to take everything you could possibly need—actually at least two of everything you might need—with you. That means even high end items such as laptops but also mundane items such as soap, paper and pens, cables, power strips, adaptors, and personal hygiene items.

You should, he says, expect that at least one of every type of item you take will be lost, stolen, confiscated, or broken. For that reason, you have to keep duplicates in different places. At the same time, you shouldn’t take anything that you can’t afford to lose.

Trust me when I tell you that I have no desire for such work. The joke in my family is that my idea of roughing it is poolside at the Hilton. Still, I find the post fascinating. The idea of having everything I need with me wherever I am appeals to me. It’s probably why I never go anywhere without my phone, laptop, and iPad.

I tagged this post “Emacs”, even though Emacs is never mentioned in the Bite Code! post, because Emacs in many ways exemplifies the same mindset. It packs all the documentation and tools you need in a single package.

That’s not quite true, of course, especially if you’re developing in something other than Elisp but the point stands. If you have Emacs and the appropriate packages, you have most of what you need for your day-to-day work. It doesn’t include every version of Python as discussed in the Bite Code! post but it does take you a long way and it doesn’t depend on an external connection, the cloud, license servers, or any of the other things that the post tells you to avoid for work in difficult places.

Posted in General | Tagged , | Leave a comment

Not A Text Editor

Here at Irreal, the minions and I are still decompressing from Christmas so this will be another short post. Troy Fletcher has a silly and lighthearted video on Emacs not being a text editor. The TL;DR is that Emacs is not (just) an editor but nearly everything else.

The video is an explication of all those other things. It’s not an editor, it’s an operating system. It’s not an editor, it’s a file management system. It’s not an editor, it’s an entertainment system… And on and on. Even though it’s a bit silly, it is a good rendition of many of the things that Emacs can do besides editing text.

The video is 28 minutes, 58 seconds long so there’s more to say than you might expect. The most distracting thing about it is that the inset of Fletcher is a split screen with two different views of him talking and gesticulating. I don’t know if that’s a normal part of his videos, a technical glitch, or another special piece of irony for the video.

In any event, if you have a half hour to kill, you might enjoy watching a video devoted to why Emacs is awesome.

Posted in General | Tagged | Leave a comment

Marking The Active Window

I use the default mode line and am mostly happy with it except that the difference between the mode line of the active window and the other windows can be hard to discern. I know I could make myself a custom mode line like Prot did that makes the active window obvious but I’m not a fan of bling and it always seemed more trouble than it’s worth.

Still, it would be nice to have the active window clearly marked. James Dyer had a similar problem and found a nice solution. His idea was to color the left hand fringe of the active window red. That turns out to be pretty easy as you can see from his post.

Another, possibly better, solution is to set the background color of the active window’s mode line to a different color. That’s what happens now, of course, but I have in mind something a little more distinctive than slightly different shades of gray. In theory, that shouldn’t be too hard but as Prot showed messing around with the mode line is trickier than you might think.

In any event, take a look at Dyer’s post for one good solution. There are doubtless others so feel free to leave a comment if you have one.

Posted in General | Tagged | Leave a comment

Custom Emacs Command Line Flags

I’m writing this on Christmas day so the festivities mean that I don’t have as much time as usual available for writing this post. Happily, I came across this post by Norman Walsh in which he mentions a fact that I didn’t know and you probably don’t either. It turns out you can define custom flags for the Emacs command line.

That’s pretty easy to do: You just add a (flag . handler) cons to the command-switch-alist variable. You can see an example of it in Walsh’s post. You might wonder why you’d want to do that. Walsh gives one use case in his post but it probably always boils down to wanting to perform some special, optional configuration when Emacs is started.

Wash’s post isn’t so much about that ability as it is the use case he has for it. It’s a short post and worth a minute or so to read.

Posted in General | Tagged | Leave a comment

Holding NSA’s Feet To The Fire

Senator Ron Wyden is on a tear. It’s probably not fair to describe him as the only legislator fighting for the fourth amendment in the face of fierce opposition from various law enforcement agencies but he’s certainly the most prominent.

His latest crusade is to get the NSA to come clean on their Fourth Amendment skirting program to purchase Americans’ location information from commercial data brokers. He not even asking them to drop the program, just to release the details of what they’re doing. The NSA, of course, is having none of that and is refusing to comply.

Wyden is responding by holding up the confirmation of the NSA’s new director, Lieutenant General Timothy Haugh. Wyden is quick to say that he has nothing against Haugh: he just wants the NSA to answer his questions.

The information isn’t even classified. The NSA is relying on the fact that it’s marked “Controlled Unclassified Information” (CUI), a made up designation with no legal basis. Rather it’s something that President Obama decreed into existence with an executive order.

Questions of what information agencies such as the NSA should release are difficult. On the one hand we want them to protect the country. On the other, we don’t want them trampling citizens rights while they’re doing that. In this case, it’s pretty clear that the reason to withhold the information is to avoid embarrassment and blowback from the citizenry. When the information is needed for legitimate purposes, the government should get a warrant as they’re supposed to. But that’s such a bother. Easier just to buy it and refuse to admit what you’re doing.

Posted in General | Tagged | Leave a comment

A GTD Workflow

Gopar, over at the Goparism YouTube channel has posted a video on how he uses Emacs Org mode and Org Roam as his GTD framework. For those not familiar with GTD it’s a methodology developed by David Allen in his book Getting Things Done for organizing your tasks in such a way as to maximize your productivity.

Org mode is ideal for handling the mechanical aspects of the GTD program. A lot of the system involves mindset and processes but there is also a large component of recording and organizing tasks as well as making daily TODO lists. Org, of course, is seemingly custom built for those functions.

Gopar’s method depends mainly upon the agenda with some custom displays. Those are easy to setup as Gopar shows. He also uses the Org capture system to make it easy for him to add and schedule tasks.

The salient fact about his method is how easy it is Mostly it’s just a few added agenda commands and some capture templates. Although I don’t follow the GTD method and don’t know a lot about it, my agenda system is very similar to Gopar’s. That’s because Org makes it natural to organize things that way.

The video is 13 minutes, 49 seconds so you’ll need to schedule some time but how else are you going to spend the holidays?

Posted in General | Tagged , | Leave a comment

PDFs And Diffs In Emacs

Derek Taylor over at DistroTube has a nice introduction to reading PDFs and doing diffs from within Emacs. As Taylor says, almost all of us have standalone applications to do these things but even if you don’t belong to the Alles in Emacs camp, it’s nice to perform these tasks from within Emacs if you’re already there.

Taylor approaches the issues through his latest Emacs configuration so he discusses things like his custom keybindings that you probably won’t care about. But he does demonstrate both applications. For PDFs he uses the excellent pdf-tools package. He shows basic navigation and how to annotate PDFs. This is a great package that I use all the time. Unless a PDF comes up in my browser, it’s the only PDF reader I use.

He also demonstrates the builtin Ediff package. As I’ve written before, I’ve long had a difficult time with Ediff but Prot’s video cured me of that. Taylor’s video also helps demystify Ediff and show how easy to use if you ignore most of the fancy commands. The great thing about Ediff, of course, is that you can move any given difference from one file to the other.

It’s a nice video, especially if you’re interested in reading PDFs or performing diffs. The video is 18 minutes, 43 seconds long so you’ll have to schedule some time.

Update [2023-12-24 Sun 10:46]: Added link to video.

Posted in General | Tagged | Leave a comment

Writing LaTeX In Emacs

As many of you know, I have a long standing fascination with taking class notes in LaTeX using Emacs. This despite the fact that my days in the classroom are long over. Just a week ago, I wrote about laas, a package much like CDLaTeX that provides shortcuts for LaTeX commands to make writing LaTeX speedier.

MLStudent Odyssey has a short video that describes his system for writing LaTeX in Emacs. He’s not concerned with taking notes in class but with writing up notes after a class. His strategy consists of some custom LaTeX macros and some Emacs keyboard macros that he’s named and saved.

The macros could, of course, be replaced with a bit of Elisp but MLStudent Odyssey’s method shows that even if you don’t know any Elisp, you can still get Emacs to enter arbitrary text for you on demand.

As I say, the video is short—only 3 minutes, 58 seconds—so don’t expect a complete note taking system. Still, there are a couple of good ideas in the video and it’s well worth watching. It’s so short you should be able to fit it in without trouble.

Posted in General | Tagged | Leave a comment

Using Transient For Isearch

Charles Choy has another great post documenting his never ending quest to make Emacs behave exactly the way he wishes. This post is about using Transient to call isearch.

Virtually every Emacs user knows about isearch. It’s the fundamental say of searching for strings in an Emacs buffer. But isearch is actually a complicated command with many subcommands, many of which the average user doesn’t know about. That’s bad enough but, as Choi says, the shortcut bindings for those commands are obscure in the extreme.

What to do? My solution for this sort of thing is to put together a hydra. I have several hydras that do exactly this sort of thing, although not for isearch. But there’s a new kid in town. Since Emacs 29.1 the Transient library from Magit is built into Emacs and it can provide an equivalent solution to that provided by hydra. To the end user, the two solutions look the same: you get a menu with the various choices from which you can select your desired action.

I’m completely agnostic on which solution is better. To me, they seem equivalent but I’ve seen more than one post or comment claiming that the poster never liked hydras. These claims are never accompanied by an explanation so I don’t know if they’re simple prejudice or supported by sound reasoning.

Regardless, Choi gives the code for his Transient implementation of an isearch menu so if you’re interested in a solution to the isearch complexity problem, take a look a Choi’s post.

Posted in General | Tagged | Leave a comment

Prot’s Literate Emacs Configuration

Protesilaos Stavrou (Prot) has a new way of managing his Emacs configuration. As you can guess from the above title, it’s a literate document based on Org-mode code blocks. He has a video up explaining his new configuation and how it works.

You’re probably yawning and thinking, “So what? Prot discovered literate programming.” But that’s not the case. His previous configuration was also literate but depended upon Org to load it and execute the code blocks. That’s the normal strategy. It has the advantage of having only a single file used both for coding and execution: you don’t have to worry about source and target files getting out of sync.

The problem was that Prot’s configuration is quite lengthy and caused Emacs to load slowly. For me, and maybe for you, that’s not a problem because I don’t start Emacs very often—it’s always running. But Prot does a lot of Emacs package development so he is always restarting it and the long startup time starts to add up.

For various reasons explained in the video, he didn’t want to give up his literate configuration so he changed it to tangle the code blocks into various module files. The result is a single Org file that builds a complex but modular system of configuration files.

Having everything is a single Org file makes it easy to export. Here it is from his Web site. It’s still a work in progress but you can see how valuable it is for understanding his configuration.

The video is just shy of 25 minutes so you’ll have to schedule some time but it’s a nice video and worth your time.

Posted in General | Tagged , | Leave a comment