Existing ones are just better than nothing. The formater, go to definition, auto indentation etc. need completely new implementation.
Anyone interested to join?
What does VS require for the extension?
I've previously used NotePad++ as an extension, the definition files are from Chris here:
https://github.com/cjdinger/sas-npp
For complex projects, for example, syntax linting, go to definition, on the fly function, a language server is required. I would imagine this to be a lot of typescript programming.
Typescript is a strict syntactical superset of JavaScript.
Syntax highlighting and Indentation should be relatively easy, they can be directly edited from template:
https://code.visualstudio.com/api/language-extensions/language-configuration-guide
I see the power of VS Code editor as a modern editor. If the extension is made correctly with an API to run SAS service from command line, to view Dataset in a split tab, it can be better than SAS Base (DM).
Yes, that is exactly what I mean "Existing ones are just better than nothing."
Those two extensions are very basic (incomplete) syntax highlighting logic. I believe a better syntax highlighting can be made in a week from spare time by importing keywords into templates. They do not include any advance features such as on the fly function help, intellisense, go to definition, auto indentation, etc.
The advance features off course will require a lot of coding. Once finished, it can be in par, if not better, than SAS Studio.
And I believe it is much easier to implement it in VS Code than writting a brand new SAS version of Spyder, to an extent that can be achieved by open source community.
The SAS Base is stable. But it sucks.
The SAS EG is awesome. But the user sometimes only needs a text editor, a data viewer, and save scripts on the disk so that it can be opened through other editors or synced through Github.
The SAS Studio is awesome. But not everyone likes to edit a file in a browser. Browser also limits rich IDE features.
A good IDE with a good extension suits well for this situation.
So VS Code seems like a useful tool as it is. There is an extension for SAS that does a reasonable job of syntax highlighting. Better than the version in SAS 9.4 Enhanced Editor.
https://marketplace.visualstudio.com/itemdetails?itemName=77qingliu.sas-syntax
For the other enhancements it looks like VS Code could do a lot, depending on what you want to build.
For execution you could start simple and just build something to let you save and run SAS program files via command line call to base SAS and automatically open the LOG and LST files generated. Like the old ESS (Emacs Speaks Statistics) lisp code plug in for Emacs. A more complex solution would be one that could actually launch a workplace server instance of SAS and send code and retrieve results. Like the way the EG and SAS/Studio work. Then you could just send the code to run. You could highlight pieces of the code and run them, like in Display Manager or SAS/Studio. In that mode could you also build tools for discovering what objects (librefs, datasets, variables, macro variables, macros,etc.) that are defined in your current active SAS session, like in R/Studio?
I am a wary of lint/formatter tools because most of them do not have enough options. Can you make it place continuation keywords (commas, AND, OR, etc) at the BEGINNING of the overflow line where they are visible to humans instead of leaving them on the END of the line that is getting too long? But being able to craft a set that work well for SAS code would be nice.
I am also not that pleased with the autocomplete (intellesense) implementation in SAS/Studio. It is constantly trying to prompt me to fill in things I don't need any help with. Could we build an extension with user options to suppress it base on for example which PROC it is trying to help me with? I don't need help typing PROC PRINT code. PROC GLM or other procs that I use infrequently it might be nice. If it is able to interact with a live SAS session could you have a "file" that showed the variable definitions for a dataset and quickly grab and paste the variable name(s) into the command you are editing in your current window?
You could also build a lot of functionality just using the snippets feature without having to "program". You could build many things like the snippets/tasks that are in SAS/Studio.
One programming task might be a way to read source code from autocall macro library and generate snippets (or intellesense) to allow you to generate macro calls. So you could tell VS Code what folder in your project will be used as the autocall library in SAS and it could see that you are starting to type a call to %MYMACRO and automatically give the options for parameters that the macro takes. That could replace the command macro to generate macro call from source code that I have used for 20 years in Display Manager.
I see the power of VS Code editor as a modern editor. If the extension is made correctly with an API to run SAS service from command line, to view Dataset in a split tab, it can be better than SAS Base (DM).
The future of SAS is Viya and under Viya 4++ there isn't a SAS Base Windowing environment or even SAS EG anymore. The interface is SAS Studio.
I certainly haven't fully thought through what you're proposing to do but just consider it to be" future proof" - and the current "standard" is Viya 4 with data not only existing as physical SAS files but also as tables in CAS.
Basically, I am imagine the VS Code extension growing to something like the current python extension in VS Code with additional capability to view Dataset in a split tab. It compares to SAS Studio like the Spyder compares to Jupyter notebook.
Interesting. We use Visual Studio with the TFS add-in for version control of SAS programs, but Enterprise Guide for code development. We open our SAS programs in VS but link them to open with EG. The two work pretty well together.
What is VS? What is a VS Code extension?
Do you have explanations? Links? Documentation?
If the reader does not understand what the topic is, he/she definitely will not understand how to develop extension.
Thanks for your concern.
@anonymous_user wrote:
If the reader does not understand what the topic is, he/she definitely will not understand how to develop extension.
Thanks for your concern.
I don't know how to develop an extension at the moment, but I'm also fully confident I could figure it out if desired and the same goes for several other programmers on here, Tom included.
VS is Visual Studio, an IDE that works across multiple languages.
A code extension would allow a SAS programmer to use VS to develop programs with similar features to SAS EG or Studio. I'm quite happy with Studio but I understand the desire for a more programmer friendly interface.
Apparently it's built in either TypeScript or JavaScript - tutorial here.
https://code.visualstudio.com/api/get-started/your-first-extension
Quick clarification. VS is Visual Studio and normally refers to the full IDE which is much more powerful than VS Code. VS Code is an open source editor (and a darn good one) that supports a lot of languages. I use both, VS daily, VS Code every other week or so.
So, VS and VS Code are very separate entities. A VS extension, which I built many moons ago, is probably not the direction. However, VS Code should be the direction. If a VS extension is desired, i have developed one a long time ago and it involved C# and interface compliance.
Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.