Moving the Ant.tmbundle
February 10th, 2010
Initially I set out with the aim to switch from Subversion to Git before there was an official plan from the TextMate crew. This has now changed, and all bundles that show Github activity are being removed from the TextMate svn repository. Which means that the official bundles I mirrored now have a duplicate Github mirror, and one that is more central for TextMate users and should be the root of all development. The Apache bundle was easy to sort, as there were no forks I could simply delete my copy. The Ant bundle wasn’t so straightforward.
Theoretically there’s no reason why two mirrored repositories couldn’t be used as each can be
added as a remote. But because of their independent initialisation against the
svn repo their histories aren’t identical this doesn’t work correctly in practice. Even though the file contents are identical at each commit git still recognises separate commits because git-svn appends unique metadata. So you end up with a lot of messy duplication in the history tree.
The fastest solution is to rebase one mirror into the other. Public rebasing
isn’t the done thing as it’s bad practice to be changing the repository history
when others could be working against it. However in this case we are looking to
retire one history completely. I think, given that there’s only a little work
in the forks, and the file content is the same it is the right solution.
So here are the steps I took to merge my mirror into the official one
- Forked and cloned the official bundle on github
cd‘d to the root of the clone- Added new remote using
git remote add old-origin git@github.com:simongregory/ant-tmbundle.git - Fetch the remote data
git fetch old-origin - Created old-master branch from the old-origin/master with
git br old-master old-origin/master - Checked out old-master
git co old-master - Rebased old-master onto master using
git rebase master - Switched back to master
git co master - Merged master with old-master
git merge old-master - Deleted the old-master branch
git br -D old-master - Created new sg branch
git co -b sg - Cherry picked the one commit I needed
git cherry-pick 91f598 - Pushed the branch
git push origin sg - Removed the old-origin remote using
git remote rm old-origin
Then to linked to the official TextMate remote using
- git remote add tm git@github.com:textmate/ant.tmbundle.git
- Fetched the remote data
git fetch tm - Checked master out
git co master - Synced master branches by pushing
git push tm(only possible if you have write access)
One extra thing to note is the change from the old naming convention using a hyphen to a period.
There’s likely to be a better way of achieving this, but this is what worked for me. It won’t work if you have any private branches as you wouldn’t be able to pull them across. In this case I’d look at inverting the process and adding the new fork as a remote to the existing repository and merging from there.
Improved Auto Import for ActionScript 3 in TextMate
February 18th, 2009
The ActionScript 3 bundles had the ability to auto import a class for a long time, but the functionality has been limited to the area of the document between the package and class declarations. There have been some interesting solutions to improve this workflow, but ultimately it needed a more elegant solution.
If you grab the most recent version of the bundle you’ll now find that ⇧⌘I can be invoked from a wider scope and will present you with a list of possible classes to import based on the current word. Select one and an import statement for the class will be generated and injected into the document (or a tooltip saying the class is already imported).
I ought to stress that the importing is improved, but needs more work. The command is scoped to work within a public class, so any private classes hiding beneath your package block won’t benefit. You’re also likely, if you’re tidy, to want to organise the imports statements later on. But what is great about this is it let’s you skip a repetitive task and focus on higher level logic.
AS3 Autocompletion in TextMate
September 26th, 2008
Here’s a little teaser showing autocompletion for ActionScript 3 in action using TextMate.
It’s work in progress and I’m planning on releasing it for testing once Dialog 2 moves out of review. I also need to add the functionality to search multiple ancestors in interfaces to resolve the type of an item.
TextMate JavaScript Flash Bundle
July 31st, 2008
I’ve quickly put together a bundle for working with JSFL, or the Flash JavaScript API. If you’re not familiar with JSFL it is used to automate and extend the Flash IDE. The bundles language grammar relies on the JavaScript bundle being installed (which is one of TextMates default bundles) as it extends it and adds all of the JSFL objects, methods and properties. You also get:
Run (⌘R)
Runs the current document in Flash.
Documentation (⌃H)
Searches the documentation and presents a list of matches. As I only have access to machines with Flash CS3 installed I don’t know the alternative paths to the documentation previous (and later) versions of Flash use so please drop me a line and I’ll include them.
Auto Complete Method / Property (⌥⎋)
Provides a pop-up list of the available method and property completions based on the current word.
I’d recommend checking out the bundle from here for the most up to date version, otherwise you can download it as a zip here.
Apache Bundle Upgrade
February 11th, 2008
The Apache bundle, which I originally contributed in the early days of TextMate, was due an upgrade. So I’ve made a few improvements…
Start, Stop, Restart and Graceful commands (⌘R)
These commands, which all target apachectl, are now bound to ⌘R under the source.apache-config scope which makes it more convenient to directly control httpd from TextMate.
As apachectl requires sudo privileges I used applescript for authentication. For reasons only known to Apple the password request dialog would launch but not get focus – leaving you to reach for the mouse to target the input field. Moving away from the keyboard is slow so this was something that really annoyed me. I’ve now switched to using the excellent tm_dialog system which makes things much smoother.
It is also possible to store your admin password in your Keychain, this is done by selecting the “Add to Keychain” toggle in the password request dialog box. I’m more than happy with the security implications of this as I’m fairly good at keeping my machines locked. If you do choose to do this then the command line security app will have access to the keychain item and is the only way someone could gain access.
Documentation (⌃H)
This now searches a documentation index file for the current word/selection then redirects or presents a list of matches as appropriate. If you appear to have the documentation installed locally then the script favours it over the apache website.
Open Include (⇧⌘D)
The language definition has been improved to add a scope for Includes. Using the key combination apple-shift-D on this scope opens the file referenced by the inlcude, or directory if it is wild carded.
Open Config… (⇧⌘C)
Previously there were various commands to open the apache.conf files these have now been consolidated into one command which searches the apache install directory, either /etc/apache2 or /private/etc/httpd depending on your version of OS X and the /users, /extra and /other subdirectories. All the conf files found are presented in pop-up from which one can be choosen to open.
Bundle Configuration
It is now possible to override the default bundle behaviour by setting the following environmental variables. TMAPACHEDIRECTORY, TMAPACHEACCESSLOG, TMAPACHEERRORLOG and
TMAPACHEMANUAL_URI all allow the custom targeting of files and directories. See the bundle help for a detailed explanation.
Open Bundle as Project…
January 2nd, 2008
I’m often opening the bundles I develop – and nosing through the others – as projects, and doing so via the Finder or the File > Open menu is long winded. To speed up the process here’s a small command which searches the default bundle locations and presents all the bundles in a dialog. Pick the one you’re interested in and TextMate opens it as a project. That’s if it’s enabled, when it’s not the default behavior is to enable it, second time round it will open as a project.
HelvectorLight Theme
December 23rd, 2007
I’ve just updated the ActionScript 3 Bundle to include an ASDoc language definition. This is essentially a scope change of Luke Daley’s JavaDoc language definition. The result is that the following scopes within the documentation blocks are brought under new colour jurisdictions.
keyword.other
entity.name.tag
punctuation.definition.tag
For me, using my favourite theme – Twilight – the extra colour where I was so used to seeing grey wasn’t working. To combat it, and get things greyscale again, I added 3 new theme elements and applied them to the following scopes:
comment.block.documentation keyword.other
comment.block.documentation entity.name.tag
comment.block.documentation punctuation.definition.tag
The results are the HelvectorLight.tmTheme which calms things down again.
TextMate Ant Bundle
October 30th, 2007
TextMate ActionScript 3 and Flex Bundles
October 30th, 2007
As a Flash developer who’s been working with Flex and ActionScript 3 since late last year I found I couldn’t settle down and use the Flex Builder Eclipse plug-in. Previously I had acquired the habit of editing ActionScript using TextMate and compiled using the lightning fast MTASC, and although there were alternatives (FDT, Sepy), I’ve always preferred the lightweight flexibility and crisp feel that TextMate has. As a result I’m responsible for TextMate’s ActionScript 3 and Flex bundles.
At the moment the bundles are in the review section of the TextMate Repository. Once installed the bundle help covers how to set up (primarily to download the flex sdk) and outlines the non-obvious commands.
The main highlights of the bundles are:
- MXMLC and FCSH Build Commands.
- Function, Tag, Import Auto Completion.
- ActionScript 3 and Flex documentation search.
- Drag and Drop of imports, includes, embed assets, css, xml.
- ASDoc Support.
- MXML Validation.
- Manifest Generation.
- Class and Component Templates.
- Flex Builder compatible project creation.
- Unused Import statement removal.
- Shortcut Key Super Class, Code Behind and Import file opening.
Thanks to the following people who have all had a hand, although they may not know it, in the creation of the bundles:
- Daniel Parnell
- Theo Hultberg
- Mark Llobrera
- Joachim
- ChromaticRain
- Thomas Aylott
For those of you who don’t use subversion the following zip’s can be downloaded, but they won’t necessarily be the latest version :
Switching flash players on OS X
January 8th, 2006
I wrote the following shell script a while back for use with TextMate as part of my build process. TextMate’s great as it easily allows you to bind scripts to custom commands (and key combinations). However you’d easily be able to adapt it to your set up. It will allow you to cleanly change all the flash players available for OS X, as well as being able to Uninstall the player, and optionally restart open browsers (FireFox and Safari) afterwards.
You’ll need to download the players, install and move the files into archived folders the contents of which the script will copy to the default internet plug-ins folder. It shouldn’t be too difficult to work out how this happens and alter the script for your needs.
Download the script here
To install the FP 7.0.14 without restarting any open broswers:
changePlayer.sh 7.0.14 false
To uninstall the flash player:
changePlayer.sh uninstallflashplayer
To install FP 6.0.49, restarting open browsers:
changePlayer.sh 6.0.49
If there’s anyone out there using TextMate and would like a the above wrapped up in a bundle then please email me and I’ll send a copy over.



