- Fix bug where a query is sometimes run before the file is saved. #947
- Fix broken contextual queries, including View AST. #949
- Add support for filename pattern in history view. #930
- Add an option View Results (CSV) to view the results of a non-alert query. The existing options for alert queries have been renamed to View Alerts to avoid confusion. #929
- Allow users to specify the number of paths to display for each alert. #931
- Adjust pagination controls in CodeQL Query Results to always be visible #936
- Fix bug where View AST fails due to recent refactoring in the standard library and query packs. #939
- Add a command CodeQL: Run Query on Multiple Databases, which lets users select multiple databases to run a query on. #898
- Autodetect what language a query targets. This refines the CodeQL: Run Query on Multiple Databases command to only show relevant databases. #915
- Adjust test log output to display diffs only when comparing failed test results with expected test results. #920
- Add the Add Database Source to Workspace command to the right-click context menu in the databases view. This lets users re-add a database's source folder to the workspace and browse the source code. #891
- Fix markdown rendering in the description of the
codeQL.cli.executablePath
setting. #908 - Fix the Open Query Results command in the query history view. #909
No user facing changes.
- Display CodeQL CLI version being downloaded during an upgrade. #862
- Display a helpful message and link to documentation when a query produces no results. #866
- Refresh test databases automatically after a test run. #868
- Allow users to specify a custom directory for storing query server logs (
codeQL.runningQueries.customLogDirectory
). The extension will not delete these logs automatically. #863 - Support the VS Code Workspace Trust feature. This extension is now enabled in untrusted workspaces, but it restricts commands that contain arbitrary paths. #861
- Allow the
codeQL.cli.executablePath
configuration setting to be set in workspace-scoped configuration files. This means that each workspace can now specify its own CodeQL CLI compiler, a feature that is unblocked due to implementing Workspace Trust. #861
- Copy version information to the clipboard when a user clicks the CodeQL section of the status bar. #845
- Ensure changes in directories that contain tests will be properly updated in the test explorer. #846
- Remind users to choose a language when downloading a database from LGTM. #852
- Fix a bug that prevented the results view from being loaded. #842
- Avoid showing an error popup when running a query with
@kind table
metadata. #814 - Add an option to jump from a .qlref file to the .ql file it references. #815
- Avoid opening the results panel when a database is deleted. #831
- Forward all query metadata to the CLI when interpreting results. #838
- Avoid showing an error popup when user runs a query without
@kind
metadata. #801 - Fix running of tests when the
ms-python
extension is installed. #803
- Introduce evaluator options for saving intermediate results to the disk cache (
codeQL.runningQueries.saveCache
) and for limiting the size of this cache (codeQL.runningQueries.cacheSize
). #778 - Respect the
codeQL.runningQueries.numberOfThreads
setting when creating SARIF files during result interpretation. #771 - Allow using raw LGTM project slugs for fetching LGTM databases. #769
- Better error messages when BQRS interpretation fails to produce SARIF. #770
- Implement sorting of the query history view by name, date, and results count. #777
- Add a configuration option to pass additional arguments to the CLI when running tests. #785
- Introduce option to view query results as CSV. #784
- Add some snippets for commonly used QL statements. #782
- More descriptive error messages on QL test failures. #788
- Avoid displaying an error when removing orphaned databases and the storage folder does not exist. #748
- Add better error messages when AST Viewer is unable to create an AST. #753
- Cache AST viewing operations so that subsequent calls to view the AST of a single file will be extremely fast. #753
- Ensure CodeQL version in status bar updates correctly when version changes. #754
- Avoid deleting the quick query file when it is re-opened. #747
- Add a status bar item for the CodeQL CLI to show the current version. #741
- Fix version constraint for flagging CLI support of non-destructive updates. #744
- Add a More Information button in the telemetry popup that opens the telemetry documentation in a browser tab. #742
- Reword the telemetry modal dialog box. #738
- Fix bug where databases are not reregistered when the query server restarts. #734
- Fix bug where upgrade requests were erroneously being marked as failed. #734
- On a strictly opt-in basis, collect anonymized usage data from the VS Code extension, helping improve CodeQL's usability and performance. See the telemetry documentation for more information on exactly what data is collected and what it is used for. #611
- Include the full stack in error log messages to help with debugging. #726
- No changes visible to end users.
- Ensure databases are unlocked when removing them from the workspace. This will ensure that after a database is removed from VS Code, queries can be run on it from the command line without restarting the IDE. Requires CodeQL CLI 2.4.1 or later. #681
- Fix bug when removing databases where sometimes the source folder would not also be removed from the workspace or the database files would not be deleted from the workspace storage location. #692
- Query results with no string representation will now be displayed with placeholder text in query results. Previously, they were omitted. #694
- Add a label for the language of a database in the databases view. This will only take effect for new databases created with the CodeQL CLI v2.4.1 or later. #697
- Add clearer error message when running a query using a missing or invalid qlpack. #702
- Add clearer error message when trying to run a command from the query history view if no item in the history is selected. #702
- Fix a bug where it is not possible to download some database archives. This fix specifically addresses large archives and archives whose central directories do not align with file headers. #700
- Avoid error dialogs when QL test discovery or database cleanup encounters a missing directory. #706
- Add descriptive text and a link in the results view. #711
- Fix the Set Label command in the query history view. #710
- Add the CodeQL: View AST command to the right-click context menu when a source file in a database source archive is open in the editor. #712
- Editors opened by navigating from the results view are no longer opened in preview mode. Now they are opened as a persistent editor. #630
- When comparing the results of a failed QL test run and the
.expected
file does not exist, an empty.expected
file is created and compared against the.actual
file. #669 - Alter structure of the Test Explorer tree. It now follows the structure of the filesystem instead of the QL Packs. #624
- Alter structure of the Test Explorer tree. It now follows the structure of the filesystem instead of the QL Packs. #624
- Add more structured output for tests. #626
- Whenever the extension restarts, orphaned databases will be cleaned up. These are databases whose files are located inside of the extension's storage area, but are not imported into the workspace.
- After renaming a database, the database list is re-sorted. #685
- Add a
codeQl.resultsDisplay.pageSize
setting to configure the number of results displayed in a single results view page. Increase the default page size from 100 to 200. #686 - Update the AST Viewer to include edge labels (if available) in addition to the target node labels. So far, only C/C++ databases take advantage of this change. #688
- Fix URI encoding for databases that were created with special characters in their paths. #648
- Disable CodeQL Test commands from the command palette #667
- Fix display of booleans in results view. #657
- Avoid recursive selection changes in AST Viewer. #668
- Fix a bug where archived source folders for databases were not showing any contents.
- Fix URI encoding for databases that were created with special characters in their paths.
- Add friendly welcome message when the databases view is empty.
- Add open query, open results, and remove query commands in the query history view title bar.
- The maximum number of simultaneous queries launchable by the
CodeQL: Run Queries in Selected Files
command is now configurable by changing thecodeQL.runningQueries.maxQueries
setting. - Allow simultaneously run queries to be canceled in a single-click.
- Prevent multiple upgrade dialogs from appearing when running simultaneous queries on upgradeable databases.
- Fix sorting of results. Some pages of results would have the wrong sort order and columns.
- Remember previous sort order when reloading query results.
- Fix proper escaping of backslashes in SARIF message strings.
- Allow setting
codeQL.runningQueries.numberOfThreads
andcodeQL.runningTests.numberOfThreads
to 0, (which is interpreted as 'use one thread per core on the machine'). - Clear the problems view of all CodeQL query results when a database is removed.
- Add a
View DIL
command on query history items. This opens a text editor containing the Datalog Intermediary Language representation of the compiled query. - Remove feature flag for the AST Viewer. For more information on how to use the AST Viewer, see the documentation.
- The
codeQL.runningTests.numberOfThreads
setting is now used correctly when running tests. - Alter structure of the Test Explorer tree. It now follows the structure of the filesystem instead of the qlpacks.
- Ensure output of CodeQL test runs includes compilation error messages and test failure messages.
- Fix display of raw results entities with label but no url.
- Fix bug where sort order is forgotten when changing raw results page.
- Avoid showing a location link in results view when a result item has an empty location.
- Fix error with choosing qlpack search path.
- Fix pagination when there are no results.
- Suppress database downloaded from URL message when action canceled.
- Fix QL test discovery to avoid showing duplicate tests in the test explorer.
- Enable pagination of query results
- Add experimental AST Viewer for Go and C++. To enable, add
"codeQL.experimentalAstViewer": true
to the user settings file.
- Fix unzipping of large files.
- Ensure compare order is consistent when selecting two queries to compare. The first query selected is always the from query and the query selected later is always the to query.
- Ensure added databases have zipped source locations for databases added as archives or downloaded from the internet.
- Fix bug where it is not possible to add databases starting with
db-*
. - Change styling of pagination section of the results page.
- Fix display of query text for stored quick queries.
- Report error when selecting invalid database.
- Add descriptive message for database archive import failure.
- Respect VS Code's i18n locale setting when formatting dates and sorting strings.
- Allow the opening of large SARIF files externally from VS Code.
- Add new 'CodeQL: Compare Query' command that shows the differences between two queries.
- Allow multiple items in the query history view to be removed in one operation.
- Allow multiple items in the databases view to be removed in one operation.
- Allow multiple items in the databases view to be upgraded in one operation.
- Allow multiple items in the databases view to have their external folders opened.
- Allow all selected queries to be run in one command from the file explorer.
- Fix auto-indentation rules.
- Add ability to download platform-specific releases of the CodeQL CLI if they are available.
- Fix handling of downloading prerelease versions of the CodeQL CLI.
- Add pagination for displaying non-interpreted results.
- Better formatting and autoindentation when adding QLDoc comments to
.ql
and.qll
files. - Allow for more flexibility when opening a database in the workspace. A user can now choose the actual database folder, or the nested
db-*
folder. - Add query history menu command for viewing corresponding SARIF file.
- Add ability for users to download databases directly from LGTM.com.
- Enable 'Go to Definition' and 'Go to References' on source archive files in CodeQL databases. This is handled by a CodeQL query.
- Fix adding database archive files on Windows.
- Enable adding remote and local database archive files from the command palette.
- Links in results are no longer underlined and monospaced.
- Add the ability to choose a database either from an archive, a folder, or from the internet.
- New icons for commands on the databases view.
- Add the ability to download and install databases archives from the internet.
- Add a suggestion in alerts view to view raw results, when there are raw results but no alerts.
- Add the ability to rename databases in the database view.
- Add the ability to open the directory in the filesystem of a database.
- Implement syntax highlighting for the new
unique
aggregate. - Implement XML syntax highlighting for
.qhelp
files. - Add option to auto save queries before running them.
- Add new command in query history to view the query text of the selected query (note that this may be different from the current contents of the query file if the file has been edited).
- Add ability to sort CodeQL databases by name or by date added.
- Fix quick evaluation in
.qll
files. - Add new command in query history view to view the log file of a query.
- Request user acknowledgment before updating the CodeQL binaries.
- Warn when using the deprecated
codeql.cmd
launcher on Windows.
- Add functionality for testing custom CodeQL queries by using the VS
Code Test Explorer extension and
codeql test
. See the documentation for more details. - Add a "Show log" button to all information, error, and warning popups that will display the CodeQL extension log.
- Display a message when a query times out.
- Show canceled queries in query history.
- Improve error messages when attempting to run non-query files.
- Add command to restart query server.
- Enable support for future minor upgrades to the CodeQL CLI.
- Add an icon next to any failed query runs in the query history view.
- Add the ability to sort alerts by alert message.
- Disable word-based autocomplete by default.
- Add command
CodeQL: Quick Query
for easy query creation without having to choose a place in the filesystem to store the query file.
- Reduce the frequency of CodeQL CLI update checks to help avoid hitting GitHub API limits of 60 requests per hour for unauthenticated IPs.
- Fix sorting of result sets with names containing special characters.
- Fix rendering of negative numbers in results.
- Allow customization of query history labels from settings and from query history view context menu.
- Show number of results in results view.
- Add commands
CodeQL: Show Next Step on Path
andCodeQL: Show Previous Step on Path
for navigating the steps on the currently shown path result.
- Change
codeQL.cli.executablePath
to a per-machine setting, so it can no longer be set at the user or workspace level. This helps prevent arbitrary code execution when using a VS Code workspace from an untrusted source. - Improve the highlighting of the selected query result within the source code.
- Improve the performance of switching between result tables in the CodeQL Query Results view.
- Fix the automatic upgrading of CodeQL databases when using upgrade scripts from the workspace.
- Allow removal of items from the CodeQL Query History view.
Initial release of CodeQL for Visual Studio Code.