News

Visual Basic Resurgence? Project Seeks to 'Bring the VBE into This Century!'

Is Visual Basic primed for a resurgence?

Well, no.

But there are signs of new life in the VB ecosystem, most recently on the Visual Basic for Applications (VBA) side of things.

This week saw a couple of improvements to Rubberduck, a project to upgrade the Visual Basic Editor (VBE) and "Bring the VBE into this century!"

VBA is based on the now-deprecated "classic" Visual Basic 6 and is associated with Microsoft Office applications, particularly Excel, where the VBE is a fundamental tool for scripting, automation and much more.

Visual Basic, especially "classic" VB, attracted a loyal following, with many projects emerging over the years devoted to keeping it alive despite Microsoft having moved on in 2002 with VB.NET.

VBA is still bundled with Office, however, and Mathieu Guindon started the Rubberduck project to improve its editor. The project is described as "a very active open-source COM add-in project that integrates with the Visual Basic Editor to enable the features every programmer wants to have in their IDE. From unit testing to code inspections and refactorings, programming in VBA will never be the same."

VBE in Excel
[Click on image for larger view.] VBE in Excel

The project's origin stemmed from a rewrite of VBA Excel add-in that output unit testing results to the debug/immediate window.

"Rubberduck simply emerged from the idea of rewriting that unit testing code in C# to deploy it as a COM extension/add-in specifically for the VBA IDE, the glorious VBE. We had code that could integrate with the IDE and read (write, too) the contents of code files, and do everything else the VBE API allows us to do. So we take the code in the IDE, parse it with ANTLR, and then make very cool things happen," the site says. "Rubberduck is first and foremost a project, aiming to make the VBA editor a professional-grade integrated development environment. We want to give professional VBA developers the tools they need to be professionals, the tools that are a standard part of the toolbox elsewhere in the software development community."

The project includes a Code Explorer, Smart Indenter and Unit Testing among other components, along with functionality for refactorings, GitHub/source control integration and more.

The Rubberduck Code Explorer
[Click on image for larger view.] The Rubberduck Code Explorer

Just today (Feb. 28), news of a an OSS milestone -- the Rubberduck GitHub project reaching 1,000 stars -- was announced on Twitter by Guindon, who has been tweeting about the project under the handle "Rubberduck VBIDE add-in" since at least December 2017.

This week also marked the 100th blog post about continuing work on the project, this one declaring "VBA isn't going anywhere" in the face of a YouTube video posted this month titled, "First Look: Excel VBA Killer - TypeScript Debuts in Excel."

This week also saw a Rubberduck post on Hacker News, where the project was met with some skepticism (as is common on that development-oriented social site).

"Add Javascript to VBA and allow users to use WebStorm or VS and we'd have something great," read one comment on the HN post. "I gave Rubberduck a go a few years ago and was rather underwhelmed when compared to a real IDE (which is understandable, as Rubberducks creators don't have $$$ behind them)."

A couple other readers compared it unfavorably to MZ-tools among speed and stability concerns.

Nevertheless, work is continuing on the project, which just hit version 2.5.0 a couple months ago.

As far as a classic VB resurgence, it's not likely. Microsoft has resisted all efforts to bring it back and has even abandoned its VB.NET co-evolution strategy with C# that was announced in 2010. "For VB to follow C# in its aggressive evolution would not only miss the mark, but would actively undermine the straightforward approachability that is one of VB's key strengths," said Microsoft's Mads Torgersen in a 2017 post about "The .NET Language Strategy" that announced the shift from VB/C# co-evolution.

That break has been borne out, as a look at Microsoft's development blog postings for C# and VB indicates. While C# post are published regularly, the most recent post from the VB team is from November 2018.

And the company clearly spelled out its VB plans in response to a Developer Community issue filed back in October 2018 to "Support VB6 programming and VBA programming."

"Hello, we don't plan on making changes to VB6 nor bringing it up to support modern platforms," said Microsoft's Phillip Carter.

About the Author

David Ramel is an editor and writer for Converge360.

comments powered by Disqus

Featured

  • AI for GitHub Collaboration? Maybe Not So Much

    No doubt GitHub Copilot has been a boon for developers, but AI might not be the best tool for collaboration, according to developers weighing in on a recent social media post from the GitHub team.

  • Visual Studio 2022 Getting VS Code 'Command Palette' Equivalent

    As any Visual Studio Code user knows, the editor's command palette is a powerful tool for getting things done quickly, without having to navigate through menus and dialogs. Now, we learn how an equivalent is coming for Microsoft's flagship Visual Studio IDE, invoked by the same familiar Ctrl+Shift+P keyboard shortcut.

  • .NET 9 Preview 3: 'I've Been Waiting 9 Years for This API!'

    Microsoft's third preview of .NET 9 sees a lot of minor tweaks and fixes with no earth-shaking new functionality, but little things can be important to individual developers.

  • Data Anomaly Detection Using a Neural Autoencoder with C#

    Dr. James McCaffrey of Microsoft Research tackles the process of examining a set of source data to find data items that are different in some way from the majority of the source items.

  • What's New for Python, Java in Visual Studio Code

    Microsoft announced March 2024 updates to its Python and Java extensions for Visual Studio Code, the open source-based, cross-platform code editor that has repeatedly been named the No. 1 tool in major development surveys.

Subscribe on YouTube