go to post Brett Saviano · Apr 1 @Kurro Lopez The GET /api/atelier/ REST endpoint contains a lot of useful information about the server and it's been available since 2016.2. It does require %Development to call though.
go to post Brett Saviano · Mar 31 Hi @Dmitrii Baranov, you can use VS Code's multi-root workspace feature to add multiple local folders to a single workspace. There are some great client-side editing enhancements among the features that should be released later this week.
go to post Brett Saviano · Mar 28 You can use the $STACK system function: Write $STACK($STACK(-1),"PLACE") Note that this will only work if $ECODE is clear (the empty string).
go to post Brett Saviano · Mar 27 They're not in the preview builds. 2025.1 is now GA, so use the released build. Tags 2025.1 or latest-em should pull the released build (number 223).
go to post Brett Saviano · Mar 27 Thanks for this feedback Enrico. We will consider this for a future version.
go to post Brett Saviano · Mar 27 These new UIs are available in all IRIS-based products, including containers and the Community edition.
go to post Brett Saviano · Mar 27 The regex Route is the correct way to do this: Class User.REST Extends %CSP.REST { XData UrlMap [ XMLNamespace = "http://www.intersystems.com/urlmap" ] { <Routes> <Route Url="/(.*)" Method="GET" Call="test" /> </Routes> } ClassMethod test(path As %String) As %Status { Set %response.ContentType = ..#CONTENTTYPETEXT Write path Return $$$OK } }
go to post Brett Saviano · Mar 27 The two new apps (Production Configuration and DTL Editor) are opt-in at this time. You must open a Production or DTL in the old app, and then click the "Try the new UI" button to launch the new one. There is currently no way to set the new ones as a default like the Rule Editor since these are still in the early stages, but you can always bookmark them through your browser.
go to post Brett Saviano · Mar 21 VS Code supports editing a class that extends Ens.DataTransformDTL the same as any other. That error message is reporting that the contents of the DTL XData block are invalid. Did you make your edit the right place?
go to post Brett Saviano · Mar 18 The /api/monitor/alerts endpoint was created to allow for text-based alerts to be consumed by the now-discontinued System Alerting & Monitoring tool. It does not map to any concept related to Prometheus. For more information, see this documentation page.
go to post Brett Saviano · Mar 18 Thanks for the detailed explanation Mat. It makes sense that you would want to turn off VS Code's syncing since you've already implemented it via git hooks. I will think about the best way to implement these settings and will let you know when I have a proposal.
go to post Brett Saviano · Mar 18 Hi Michael, can you pleas explain what your git hooks are doing in more detail? If you don't want to share that publicly, feel free to send me a direct message.
go to post Brett Saviano · Mar 18 Hi Michael, I am convinced that a change should be made here. I'm going to always enable the code that fills in the ROUTINE and Class headers when a new file is created, because that scaffolding is valuable even if the user has to edit the generated name. However, I will leave the code that modifies existing files when they are moved guarded by the objectscript.autoAdjustName setting, which will remain false by default.
go to post Brett Saviano · Mar 12 Hi Michael, thanks for the feedback! The intention of that change was to not update the name of the document when you move it to another file location. However, it may be desirable for the extension to fill in the ROUTINE and Class headers, even if the generated name needs to be updated by the user.
go to post Brett Saviano · Feb 13 Of the three options presented already, concatenating with $LISTBUILD() is by far the most performant. Running the following method ClassMethod ListTest(l = 100000) { #; Concatenate with $LISTBUILD Set li="",zh=$ZHOROLOG For i=1:1:l Set li=li_$LISTBUILD(i) Write "Creating a list with length of ",$LISTLENGTH(li)," using $LISTBUILD() took ",$ZHOROLOG-zh," seconds",! #; Set $LIST Set li="",zh=$ZHOROLOG For i=1:1:l Set $LIST(li,i)=i Write "Creating a list with length of ",$LISTLENGTH(li)," using $LIST() took ",$ZHOROLOG-zh," seconds",! #; $LISTUPDATE Set li="",zh=$ZHOROLOG For i=1:1:l Set li=$LISTUPDATE(li,i,i) Write "Creating a list with length of ",$LISTLENGTH(li)," using $LISTUPDATE took ",$ZHOROLOG-zh," seconds" } on a recent version of IRIS produces these results: USER>d ##class(User.Test).ListTest() Creating a list with length of 100000 using $LISTBUILD() took .007244 seconds Creating a list with length of 100000 using $LIST() took 10.156168 seconds Creating a list with length of 100000 using $LISTUPDATE took 10.954107 seconds
go to post Brett Saviano · Feb 6 The issue is that I forgot to add the E/e flag to the list of flags for the Color() method, so empty lines were removed from the JSON output. I will edit the accepted answer.
go to post Brett Saviano · Feb 5 I'm glad you find this useful! Instead of looping through ^ROUTINE or ^rMAC to build the stream, you can open a %Routine object and pass that in as the first argument. That class implements the Stream interface. You can get a list of languages and attributes per language from a %SyntaxColor object using the Languages() and Attributes() methods.
go to post Brett Saviano · Feb 5 @Anna Golitsyna If you goal is to find all globals referenced in a document, you can use a modified version of the code I included in this comment. The code uses the %SyntaxColor class to get a JSON array of semantic tokens for a document, and then loops through them looking for global references. Note that this will only find literal references, not naked references or indirection. ClassMethod WriteAllGrefs() { Set syn = ##class(%SyntaxColor).%New(), in = ##class(%Stream.TmpCharacter).%New(), out = ##class(%Stream.TmpCharacter).%New() #; TODO Put your document's contents into "in" Do syn.Color(in,out,"COS" /* or "INT" or "CLS" */,"KE" /* K means JSON output, E means keep empty lines */) #; Format of the JSON output: #; [ #; #; One array for each source line #; [ #; { #; #; Language of the token. See Languages() in %Library.SyntaxColor. #; "l": %Integer, #; #; Attribute of the token. See Attributes() in %Library.SyntaxColor. #; "s": %Integer, #; #; Zero-indexed start position of the token on the line #; "p": %Integer, #; #; Length of the token in characters #; "c": %Integer #; } #; ] #; ] Set json = ##class(%DynamicArray).%FromJSON(out), lineIter = json.%GetIterator() While lineIter.%GetNext(.lineNum,.lineTokens) { Set tokensIter = lineTokens.%GetIterator() While tokensIter.%GetNext(,.token) { If ( #; COS (token.l = 1) && #; Global reference (token.s = 18) ) { Write "Gref starting in column ",token.p + 1," of line ",lineNum + 1,! } } } } You can combine this with the %Library.RoutineMgr_StudioOpenDialog query to make an index of all globals referenced in a subset of documents.