Need someone to lead product management at your software company? I build high-craft software and the teams that build it. I'm looking for my next opportunity. Check out my resume and get in touch.

This is the blog of Adam Kalsey. Unusual depth and complexity. Rich, full body with a hint of nutty earthiness.

Content Management

Expressions

Freshness Warning
This blog post is over 21 years old. It's possible that the information you read below isn't current and the links no longer work.

Expressions is a Movable Type (MT) plugin designed to be used by plugin developers. The plugin provides a method that allows plugins to support the use of Movable Type tag expressions in their tag attributes. When a plugin is using Expressions, MT tags like the following are allowed:

<MTFoo bar="[MTEntryBody encode_xml="1"]">

Download

Expressions.zip

Installation

Copy Expressions.pm into a directory called MTPlugins inside your Movable Type extlib directory. If you don’t already have a MTPlugins directory, create it first.

Your installation should look like this:
mtdirectory/extlib/MTPlugins/Expressions.pm

Usage

Unless you are developing plugins, you won’t find this plugin very useful. It doesn’t add any new tags. It doesn’t make your copy of MT do anything interesting. All it does is gives plugin authors an easy way to support tag expressions in their plugins.

If you are a plugin developer, well, that’s a different story. By using this plugin, you’ll find you sleep better at night, no longer get hangovers, and have the sudden urge to send me money by PayPal.

Okay, maybe not.

But you will be able to support tag expressions in your plugins.

To use, all you need to do is hand the plugin your MT object reference (commonly stored in $ctx) and your tag attributes (commonly stored in $args). The plugin will check all your attributes for tag expressions, run them through MT for processing, and hand them back to you, ready for use.

The plugin nesses with your token stash and your stashed builder object, so it’s very important to retreive these before you call this plugin. You can do that like so:

my $tokens = $ctx->stash('tokens');
my $builder = $ctx->stash('builder');
$args = MTPlugins::Expressions::process($ctx, $args);

Example

<MTMyPlugin input="[MTEntryTitle]">

Acknowledgements

This plugin was insired by an idea from Brad Choate. Brad also contributed a patch to MTAmazon that is now part of this plugin as well.

License

Like our other freeware, this plugin is released under the open-source MIT License. In plain English, that means you can do whatever you want with the software, including modifying it, selling it, or eating it, but we’re not responsible for anything that goes wrong. Read the license file included with the downloaded package for the complete license.

Revision History

1.0 - January 8, 2003
Initial release.

Recently Written

Building the Next Big Thing: A Framework for Your Second Product
Nov 19: You need a first product sooner than you think. Here's a framework for helping you identify a winner.
A Framework for Scaling product teams
Oct 9: The people, processes, and systems that make up a product organization change radically as you go through the stages of a company. This framework will guide that scaling.
My Networked Webcam Setup
Sep 25: A writeup of my network-powered conference call camera setup.
Roadmap Outcomes, not Features
Sep 4: Drive success by roadmapping the outcomes you'll create instead of the features you'll deliver.
Different roadmaps for different folks
Sep 2: The key to effective roadmapping? Different views for different needs.
Micromanaging and competence
Jul 2: Providing feedback or instruction can be seen as micromanagement unless you provide context.
My productivity operating system
Jun 24: A framework for super-charging productivity on the things that matter.
Great product managers own the outcomes
May 14: Being a product manager means never having to say, "that's not my job."

Older...

What I'm Reading