Which bass does Geddy Lee use for each song on Moving Pictures?

I have a reason, which will be revealed on my YouTube channel next week, for considering which type of bass Geddy Lee plays on each track of Rush’s 1981 masterpiece album Moving Pictures. There seems to be much debate out there in the world over which basses he used especially on Permanent Waves (1980), Moving Pictures, and Signals (1982), because he was known to play a Rickenbacker 4001 almost exclusively on their late ’70s prog albums, but he briefly worked a Fender Jazz Bass into the mix before going all-in on Wal basses in the mid-’80s (with an occasional Steinberger thrown in for peak ’80s futurism). From the mid-’90s on, Geddy has almost exclusively gone back to the Fender Jazz Bass.

So Moving Pictures really is kind of a pivot point, both for the band stylistically and for Geddy in terms of his bass gear. It is (I think?) well known that he used both the Rick and the Jazz on Moving Pictures, but which one does he use on which song, and how can you tell?

Well, “how can you tell?” comes down to ear and familiarity with the sonic characteristics of the different instruments. The Rickenbacker tends to have very deep, round low end and a ringing high end, with a bit of a scoop in the middle, whereas the Jazz Bass has a lot more midrange growl. That’s oversimplifying it, but once you know the sound, it’s not too hard to tell. So, let’s investigate, track by track.

“Tom Sawyer”
This one is kind of tough, actually. I feel like I could make a good argument for either, but I think my impression of the whole thing is too muddled because I’ve heard so many subsequent live versions of this song — Rickenbacker on Exit Stage Left and then Jazz on the 2000s live albums, plus the 5 times I saw them live — and Geddy kind of has “his sound” regardless of which instrument he’s playing, that I just can’t tell. Fortunately I do not just need to use my ears. The band produced music videos for several songs on the album from the recording sessions at Le Studio, and we can easily see in the video that Geddy is playing a Rickenbacker.

Update (3/8/2023): Not so fast! Geddy himself says in this video that he used a Jazz Bass on “Tom Sawyer.”

“Red Barchetta”
This one, I am fairly certain, is a Rickenbacker, even though Geddy has the mids cranked up. It’s really that first note he hits at the beginning of the guitar solo around 3:20 that is the giveaway to me. There’s no Le Studio video for this one, and on Exit Stage Left he’s playing a Rick, but he plays a Rick on pretty much all of that, so no help there. Not that we really need it.

“YYZ”
It’s kind of hard to nail down the bass tone here because there’s a bunch of chorus on it, but I am fairly confident it’s a Jazz Bass. It has that Jazz Bass growl (as opposed to, y’know, that Rickenbacker growl). Once again you kind of have to focus on the bass during the guitar solo, because when Geddy and Alex are playing together in unison their sounds blend too much. I just think I am hearing the snarl of a Jazz Bass bridge pickup here. My introduction to this song was the A Show of Hands video from the late ’80s, and there, of course, he’s playing a Wal.)

“Limelight”
OK, in listening to this one I absolutely thought it was the Rickenbacker, but hey there’s another music video from the recording of the album, and Geddy is playing a Jazz Bass. Of course the video also cuts to some fake “live” footage that shows Geddy playing a Rick, but that’s from the A Farewell to Kings era, carefully edited to make it (sort of) look like they’re playing “Limelight.” So I think it’s safe to say we definitely have a Jazz here.

“The Camera Eye”
This one is definitely a Rickenbacker. Probably the easiest one to tell on the entire album. I think the verse that starts at 7:30 is where it’s easiest to tell. No question on this one. I was lucky enough to see the band on the Time Machine tour, where they played this album in its entirety, and of course at that point Geddy played it on a Jazz Bass. (Side note: No disrespect to Geddy, but you can tell he is really reaching for some of those high notes, 30 years later. Reaching, but generally hitting them!)

“Witch Hunt”
This song really doesn’t sound like any other in the band’s entire catalog. And the bass on it is unquestionably a Fender Jazz Bass. I think once again the thing that distinguishes it for me is the midrange. The Rickenbacker has a scoop in the midrange but the Jazz Bass seems to be pumping out consistently at all frequencies. (But if your eyes can handle it, you can check out Geddy playing it on a Steinberger on the Grace Under Pressure tour a few years later.)

“Vital Signs”
This one also definitely sounds like the Jazz Bass to me. I think around 1:20 is where it is very easy to pick out the bass tone. Fortunately this is another one with a Le Studio music video, so we can confirm it.

So there you have it. To put it another way, here’s how I break down the album:

Rickenbacker 4001: “Tom Sawyer,” “Red Barchetta,” “The Camera Eye.”
Fender Jazz Bass: “Tom Sawyer”, “YYZ”, “Limelight,” “Witch Hunt,” “Vital Signs.”

Update (3/10/2023): Over at Scott’s Bass Lessons, my fellow Minneapolitan Ian Martin Allison has his take on each track. Our only difference, once I corrected my take on “Tom Sawyer” two days ago, is “YYZ.” But I still say I think he’s playing a Jazz Bass on that one!

Not everything needs to be secure

Just saving this for future reference. I got on the “all HTTPS all the time” bandwagon without questioning it, because enough of the sites I create do collect user data that needs to be secure. But some — like this blog, for instance — do not.

But here’s an angle on it that I hadn’t considered:

If Google succeeds, it will make a lot of the web’s history inaccessible. People put stuff on the web precisely so it would be preserved over time. That’s why it’s important that no one has the power to change what the web is.

Dave Winer

Google of course is always trying to change what the web is, just as Facebook does. I really got into a lather over AMP because it was immediately clear to me as a web developer how it is bad for the open web. Forcing everything to HTTPS is not quite as obviously “wrong,” but when you investigate it… yeah, it is.

This site uses HTTPS because… well, why not? I use Let’s Encrypt, so it’s free and easy. And I configured the server to automatically redirect HTTP traffic, so old links still work. But people shouldn’t be expected to understand what I understand about the web in order to use it… and not just as passive consumers, but as active contributors.

That’s the real power of the web, and what we lose when we let companies like Google or Facebook change the nature of what the web is.

I’d like to end with another quote from Winer:

The web is not safe. That is correct. We don’t want every place to be safe. So people can be wild and experiment and try out new ideas. It’s why the web has been the proving ground for so much incredible stuff over its history.

Lots of things aren’t safe. Crossing the street. Bike riding in Manhattan. Falling in love. We do them anyway. You can’t be safe all the time. Life itself isn’t safe.

Occam’s Razor as it applies to DevOps

A client emailed me today about an unusual problem. The “Create an Account” link on their website was not pointing to a page of their site, but instead to an IP address. An IP address that, when I ran a whois on it, turned out to be owned by China Telecom.

That was disconcerting. I’m not passing any judgment on anyone in particular in any country in particular, but the fact is, a hugely disproportionate number of online attacks against U.S. sites come from a small number of foreign countries, China being one of them. So, I was alarmed.

My first guess, since I’ve seen WordPress sites get hacked… a few times (much less often since I started using Wordfence as standard practice on every site I build), was that hackers had somehow hijacked this link and were trying to route my client’s users over to their systems in some kind of spoofing/phishing/whatever attack.

Only, the link didn’t actually do anything. There’s no web server listening on that IP address. Hmm.

Next up I looked at the HTML source, since I wasn’t quite sure if the code in question was being generated by their theme (which I built) or by a plugin like WooCommerce, so I wanted to see the CSS classes on the wrapper. Sure enough, it was in code I had built.

When in doubt, always blame your own code first.

But the fact that it was my code wasn’t what really caught my attention. It was the fact that the URL in the HTML wasn’t the IP address at all. It was just a string of 8 digits.

Suddenly it was clear to me that this was not a hack attempt, and China Telecom (or anyone using its services) had precisely zero to do with whatever was going on. This was a peculiar code problem, and it was at least indirectly my fault.

That 8-digit number… it looked very familiar. I knew that, due to some of the peculiarities of this client’s site, the ID values in their wp_posts table are on that order of magnitude. Bingo. This wasn’t a URL at all. It was a WordPress post ID, being incorrectly inserted here because Advanced Custom Fields was outputting the raw ID value instead of using it to look up the corresponding post URL.

Why was that happening? Well, that was ultimately my fault too, having to do with some logic that was designed to tell ACF where to load my custom field groups. When the site was built, I had that code running (technically) too early, then ACF released an update that started throwing up admin notices if you did that, so I rewrote it to run later… only I didn’t realize that my change was causing my code to get applied to a hook after it had already run, so… it wasn’t working. It was a very isolated set of circumstances, so it went unnoticed for months. As far as I know, the only user-facing issue it created was this weird integer URL on the “Create an Account” link on a page few people ever visit.

The simplest explanation is the most likely.

Even if the details are anything but simple. Was someone in China trying to hack my client’s site to phish for their customers’ data, or did I just write some flawed code? Hmm.

On Apple products and the subjectivity of “expensive”

Until the Apple Watch came along, I had gone 20 years without wearing a watch. And before that, the most I had ever spent on one was $50. A watch was not an object I was willing to spend more money on than that. But then Apple released a very compelling product, and I went for it. (Even if, in retrospect, the original iteration of the Apple Watch was… underwhelming.)

I’ve owned three Apple Watches: the original (a.k.a. “Series 0”), a Series 3, and my current one, a Series 5. But after visiting a local Apple Store yesterday and looking at the latest models, I decided it was time to upgrade my Apple Watch experience once again, so today I ordered a Series 8… and for the first time, I sprung for the extra $100 to get one with cellular. Now I can finally go out running without bringing my phone. This will transform my running experience… once the snow melts and I’m back outside, that is. (But actually it will transform my experience on the indoor track too. I hate having my phone in my pocket when I run!)

Of course, running without my iPhone means that also means I need wireless earbuds. I may be willing to drop a lot of cash on a lot of Apple products, but AirPods are one area where I feel their options are way overpriced. Well… maybe not overpriced for what they offer, but more than I am willing to spend, for features I don’t really care about.

What’s worse, I can’t stand hard plastic earbuds, and Apple’s only option with silicone tips is the $250 “Pro” models. There’s no way I’m paying that much of a premium for something so easily lost. I’d rather stick with my tried-and-true $9 wired Panasonic earbuds. (But of course you can’t use wired earbuds with the watch!)

Anyway, I found these no-name Bluetooth earbuds on Amazon for $20. I’m going to give them a try before I go for anything higher-end. Hopefully they won’t explode while I’m wearing them!

Bootstrap 5 Carousel: position captions outside (i.e. below) the images

(If you want to get right to the point, a full code example is provided at the bottom of this post.)

I’m not a Bootstrap expert. During most of its evolution, I’ve mostly ignored it in favor of rolling my own… everything. I finally really embraced Bootstrap when I had a rush project in October 2022 that was way too precisely designed to work with WordPress, especially Gutenberg. (And the client didn’t need editing capabilities.) So I decided to hand-code it, but to use Bootstrap to… uh… bootstrap my HTML/CSS layouts.

I think Bootstrap 5 is excellent. I wish Gutenberg was built on top of it instead of the idiosyncratic house of cards it’s actually built on, but whatever.

As it happens, I’m actually now using Bootstrap 5 with Gutenberg for some custom blocks, specifically a Carousel block. One of the options I want to provide in my block is the ability to show the carousel’s captions and controls outside of the image, but apparently, at least with Bootstrap 5, that’s not an option.

I decided to Google for a quick solution before creating my own and I came across… this. I’m sure it gets the job done, but it seems severely over-engineered, so here I’m presenting my own comparatively simple, CSS-only solution.

Basically there are two things you need to do: 1) move the absolute-positioned caption text below the image, and 2) add padding to the bottom of the container, so the caption has somewhere to go instead of just overlapping the content below it.

Let’s start with the second item first:

.carousel { padding-bottom: 4rem; }

There may be some trial and error here, as you need to make sure you’re accommodating captions of varying length. I will admit this is not fully thought out here, and unlike the rest of what is about to follow, it may be a deal breaker under certain circumstances. But let’s assume your captions are a fairly consistent length, and you can determine how much padding you need.

Getting the caption pushed below the images is easy…

.carousel-caption { top: 100%; }

…except, oops, vertical overflow is hidden. Let’s fix that:

.carousel-inner { overflow: visible; }

Of course, if you have your transition effect set to slide (which is the default), that now spews stuff all over the page in an ugly way. But we can fix that by hiding overflow on the outer carousel element instead:

.carousel { overflow: hidden; }

You might, at this point, wonder why I didn’t just set overflow-y: visible on .carousel-inner which seems perfectly reasonable, and which, of course, I tried. But for reasons I couldn’t be bothered with investigating, that ended up causing .carousel-inner to just show a vertical scrollbar and not display the caption unless you scrolled it. Ugh. No matter, the above takes care of it.

That’s pretty much it, as far as the captions go. But if you’re using the controls (previous/next arrows) or indicators (dots/lines for the number of slides and current selection), you’ll notice there’s some weirdness to their placement, so let’s fix that too. The indicators just get shoved to the bottom of the container, so your bottom padding can accommodate that. But if you want to move them back up onto the image, you just need to offset that extra padding, like this:

.carousel-indicators { bottom: 4rem; }

Make that value the same as the bottom padding you added to .carousel itself.

As for the controls, since you’ve made the overall container taller, they’re now a bit too low rather than being vertically centered on the image. Guess what… setting their bottom value to match the extra bottom padding fixes their placement too!

.carousel-control-next, .carousel-control-prev { bottom: 4rem; }

So, putting it all together as concisely as possible, here’s what we have:

.carousel { overflow: hidden; padding-bottom: 4rem; }
.carousel-caption { top: 100%; }
.carousel-inner { overflow: visible; }
.carousel-control-next, .carousel-control-prev, .carousel-indicators { bottom: 4rem; }