..."
+ expected += "@" + Integer.toHexString(System.identityHashCode(expectedThrowable));
+ actual += "@" + Integer.toHexString(System.identityHashCode(actualThrowable));
+ }
+ String mismatchMessage = buildPrefix(message)
+ + format("unexpected exception type thrown;", expected, actual);
+
+ // The AssertionError(String, Throwable) ctor is only available on JDK7.
+ AssertionError assertionError = new AssertionError(mismatchMessage);
+ assertionError.initCause(actualThrown);
+ throw assertionError;
+ }
+ }
+ String notThrownMessage = buildPrefix(message) + String
+ .format("expected %s to be thrown, but nothing was thrown",
+ formatClass(expectedThrowable));
+ throw new AssertionError(notThrownMessage);
+ }
+
+ private static String buildPrefix(String message) {
+ return message != null && message.length() != 0 ? message + ": " : "";
+ }
+
+}
diff --git a/java/ql/test/stubs/junit-4.13/org/junit/Test.java b/java/ql/test/stubs/junit-4.13/org/junit/Test.java
new file mode 100644
index 00000000000..8356b546d79
--- /dev/null
+++ b/java/ql/test/stubs/junit-4.13/org/junit/Test.java
@@ -0,0 +1,28 @@
+/*
+ * Copyright 2015-2018 the original author or authors.
+ *
+ * All rights reserved. This program and the accompanying materials are
+ * made available under the terms of the Eclipse Public License v2.0 which
+ * accompanies this distribution and is available at
+ *
+ * http://www.eclipse.org/legal/epl-v20.html
+ */
+
+/*
+ * MODIFIED version of junit-jupiter-api 5.2.0 as available at
+ * https://search.maven.org/classic/remotecontent?filepath=org/junit/jupiter/junit-jupiter-api/5.2.0/junit-jupiter-api-5.2.0-sources.jar
+ * Only parts of this file have been retained for test purposes.
+ */
+
+package org.junit;
+
+import java.lang.annotation.Documented;
+import java.lang.annotation.ElementType;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+
+@Target({ElementType.ANNOTATION_TYPE, ElementType.METHOD})
+@Retention(RetentionPolicy.RUNTIME)
+@Documented
+public @interface Test {}
diff --git a/java/ql/test/stubs/junit-4.13/org/junit/function/ThrowingRunnable.java b/java/ql/test/stubs/junit-4.13/org/junit/function/ThrowingRunnable.java
new file mode 100644
index 00000000000..d0eb782ccd3
--- /dev/null
+++ b/java/ql/test/stubs/junit-4.13/org/junit/function/ThrowingRunnable.java
@@ -0,0 +1,14 @@
+package org.junit.function;
+
+/**
+ * This interface facilitates the use of
+ * {@link org.junit.Assert#assertThrows(Class, ThrowingRunnable)} from Java 8. It allows method
+ * references to void methods (that declare checked exceptions) to be passed directly into
+ * {@code assertThrows}
+ * without wrapping. It is not meant to be implemented directly.
+ *
+ * @since 4.13
+ */
+public interface ThrowingRunnable {
+ void run() throws Throwable;
+}
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/ArgumentMatchers.java b/java/ql/test/stubs/mockito-5.14/org/mockito/ArgumentMatchers.java
new file mode 100644
index 00000000000..84004de2ac3
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/ArgumentMatchers.java
@@ -0,0 +1,4 @@
+package org.mockito;
+
+public class ArgumentMatchers {
+}
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/MockSettings.java b/java/ql/test/stubs/mockito-5.14/org/mockito/MockSettings.java
new file mode 100644
index 00000000000..f6e46d610e7
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/MockSettings.java
@@ -0,0 +1,10 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito;
+
+import java.io.Serializable;
+
+public interface MockSettings extends Serializable {
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/Mockito.java b/java/ql/test/stubs/mockito-5.14/org/mockito/Mockito.java
new file mode 100644
index 00000000000..e4d5a06a247
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/Mockito.java
@@ -0,0 +1,216 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito;
+
+import org.mockito.ArgumentMatchers;
+import org.mockito.MockSettings;
+import org.mockito.internal.creation.MockSettingsImpl;
+import org.mockito.stubbing.Answer;
+import org.mockito.stubbing.OngoingStubbing;
+import org.mockito.internal.MockitoCore;
+import org.mockito.MockSettings;
+import org.mockito.stubbing.Stubber;
+
+public class Mockito extends ArgumentMatchers {
+ static final MockitoCore MOCKITO_CORE = new MockitoCore();
+
+ public static MockSettings withSettings() {
+ return new MockSettings() {
+ };
+ }
+
+ /**
+ * Creates a mock object of the requested class or interface.
+ *
+ * See examples in javadoc for the {@link Mockito} class.
+ *
+ * @param reified don't pass any values to it. It's a trick to detect the
+ * class/interface you
+ * want to mock.
+ * @return the mock object.
+ * @since 4.10.0
+ */
+ @SafeVarargs
+ public static T mock(T... reified) {
+ return mock(withSettings(), reified);
+ }
+
+ /**
+ * Creates a mock object of the requested class or interface with the given
+ * default answer.
+ *
+ * See examples in javadoc for the {@link Mockito} class.
+ *
+ * @param defaultAnswer the default answer to use.
+ * @param reified don't pass any values to it. It's a trick to detect the
+ * class/interface you
+ * want to mock.
+ * @return the mock object.
+ * @since 5.1.0
+ */
+ @SafeVarargs
+ public static T mock(@SuppressWarnings("rawtypes") Answer defaultAnswer, T... reified) {
+ return mock(new Answer() {
+ }, reified);
+ }
+
+ /**
+ * Creates a mock object of the requested class or interface with the given
+ * name.
+ *
+ * See examples in javadoc for the {@link Mockito} class.
+ *
+ * @param name the mock name to use.
+ * @param reified don't pass any values to it. It's a trick to detect the
+ * class/interface you
+ * want to mock.
+ * @return the mock object.
+ * @since 5.1.0
+ */
+ @SafeVarargs
+ public static T mock(String name, T... reified) {
+ return mock(withSettings(), reified);
+ }
+
+ /**
+ * Creates a mock object of the requested class or interface with the given
+ * settings.
+ *
+ * See examples in javadoc for the {@link Mockito} class.
+ *
+ * @param settings the mock settings to use.
+ * @param reified don't pass any values to it. It's a trick to detect the
+ * class/interface you
+ * want to mock.
+ * @return the mock object.
+ * @since 5.1.0
+ */
+ @SafeVarargs
+ public static T mock(MockSettings settings, T... reified) {
+ if (reified == null || reified.length > 0) {
+ throw new IllegalArgumentException(
+ "Please don't pass any values here. Java will detect class automagically.");
+ }
+
+ return mock(getClassOf(reified), settings);
+ }
+
+ /**
+ * Creates mock object of given class or interface.
+ *
+ * See examples in javadoc for {@link Mockito} class
+ *
+ * @param classToMock class or interface to mock
+ * @return mock object
+ */
+ public static T mock(Class classToMock) {
+ return mock(classToMock, withSettings());
+ }
+
+ /**
+ * Specifies mock name. Naming mocks can be helpful for debugging - the name is
+ * used in all verification errors.
+ *
+ * Beware that naming mocks is not a solution for complex code which uses too
+ * many mocks or collaborators.
+ * If you have too many mocks then refactor the code so that it's easy to
+ * test/debug without necessity of naming mocks.
+ *
+ * If you use @Mock annotation then you've got naming mocks
+ * for free! @Mock uses field name as mock name.
+ * {@link Mock Read more.}
+ *
+ *
+ * See examples in javadoc for {@link Mockito} class
+ *
+ * @param classToMock class or interface to mock
+ * @param name of the mock
+ * @return mock object
+ */
+ public static T mock(Class classToMock, String name) {
+ return mock(classToMock, new Answer() {
+ });
+ }
+
+ /**
+ * Creates mock with a specified strategy for its answers to interactions.
+ * It's quite an advanced feature and typically you don't need it to write
+ * decent tests.
+ * However it can be helpful when working with legacy systems.
+ *
+ * It is the default answer so it will be used only when you don't stub
+ * the method call.
+ *
+ *
+ *
+ * Foo mock = mock(Foo.class, RETURNS_SMART_NULLS);
+ * Foo mockTwo = mock(Foo.class, new YourOwnAnswer());
+ *
+ *
+ *
+ *
+ * See examples in javadoc for {@link Mockito} class
+ *
+ *
+ * @param classToMock class or interface to mock
+ * @param defaultAnswer default answer for un-stubbed methods
+ *
+ * @return mock object
+ */
+ public static T mock(Class classToMock, Answer defaultAnswer) {
+ return mock(classToMock, new Answer() {
+ });
+ }
+
+ /**
+ * Creates a mock with some non-standard settings.
+ *
+ * The number of configuration points for a mock will grow,
+ * so we need a fluent way to introduce new configuration without adding more
+ * and more overloaded Mockito.mock() methods.
+ * Hence {@link MockSettings}.
+ *
+ *
+ *
+ * Listener mock = mock(Listener.class, withSettings()
+ * .name("firstListner").defaultBehavior(RETURNS_SMART_NULLS));
+ * );
+ *
+ *
+ *
+ * Use it carefully and occasionally . What might be reason your test
+ * needs non-standard mocks?
+ * Is the code under test so complicated that it requires non-standard mocks?
+ * Wouldn't you prefer to refactor the code under test, so that it is testable
+ * in a simple way?
+ *
+ * See also {@link Mockito#withSettings()}
+ *
+ * See examples in javadoc for {@link Mockito} class
+ *
+ * @param classToMock class or interface to mock
+ * @param mockSettings additional mock settings
+ * @return mock object
+ */
+ public static T mock(Class classToMock, MockSettings mockSettings) {
+ return MOCKITO_CORE.mock(classToMock, mockSettings);
+ }
+
+ private static Class getClassOf(T[] array) {
+ return (Class) array.getClass().getComponentType();
+ }
+
+ public static OngoingStubbing when(T methodCall) {
+ return MOCKITO_CORE.when(methodCall);
+ }
+
+ public static Stubber doReturn(Object toBeReturned) {
+ return null;
+ }
+
+ public static Stubber doReturn(Object toBeReturned, Object... toBeReturnedNext) {
+ return null;
+ }
+}
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/internal/MockitoCore.java b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/MockitoCore.java
new file mode 100644
index 00000000000..0ae8790a6d3
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/MockitoCore.java
@@ -0,0 +1,28 @@
+package org.mockito.internal;
+
+import org.mockito.MockSettings;
+import org.mockito.internal.creation.MockSettingsImpl;
+import org.mockito.internal.progress.MockingProgress;
+import org.mockito.stubbing.OngoingStubbing;
+import org.mockito.mock.MockCreationSettings;
+import static org.mockito.internal.util.MockUtil.createMock;
+
+public class MockitoCore {
+ public T mock(Class typeToMock, MockSettings settings) {
+ MockSettingsImpl impl = (MockSettingsImpl) settings;
+ MockCreationSettings creationSettings = impl.build(typeToMock);
+ T mock = createMock(creationSettings);
+ return mock;
+ }
+
+ public OngoingStubbing when(T methodCall) {
+ MockingProgress mockingProgress = new MockingProgress() {
+ @Override
+ public OngoingStubbing> pullOngoingStubbing() {
+ return null;
+ }
+ };
+ OngoingStubbing stubbing = (OngoingStubbing) mockingProgress.pullOngoingStubbing();
+ return stubbing;
+ }
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/internal/creation/MockSettingsImpl.java b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/creation/MockSettingsImpl.java
new file mode 100644
index 00000000000..c1e9083f4de
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/creation/MockSettingsImpl.java
@@ -0,0 +1,14 @@
+package org.mockito.internal.creation;
+
+import org.mockito.MockSettings;
+import org.mockito.mock.MockCreationSettings;
+
+public class MockSettingsImpl implements MockSettings {
+ public MockCreationSettings build(Class typeToMock) {
+ return new MockCreationSettings() {
+ public String getMockMaker() {
+ return null;
+ }
+ };
+ }
+}
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/internal/handler/MockHandlerFactory.java b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/handler/MockHandlerFactory.java
new file mode 100644
index 00000000000..17dc3dcd618
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/handler/MockHandlerFactory.java
@@ -0,0 +1,14 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.internal.handler;
+
+import org.mockito.mock.MockCreationSettings;
+import org.mockito.invocation.MockHandler;
+
+public final class MockHandlerFactory {
+ public static MockHandler createMockHandler(MockCreationSettings settings) {
+ return new MockHandlerImpl();
+ }
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/internal/handler/MockHandlerImpl.java b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/handler/MockHandlerImpl.java
new file mode 100644
index 00000000000..dd1dfc68dc3
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/handler/MockHandlerImpl.java
@@ -0,0 +1,10 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.internal.handler;
+
+import org.mockito.invocation.MockHandler;
+
+public class MockHandlerImpl implements MockHandler {
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/internal/progress/MockingProgress.java b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/progress/MockingProgress.java
new file mode 100644
index 00000000000..d52a9631b68
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/progress/MockingProgress.java
@@ -0,0 +1,11 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.internal.progress;
+
+import org.mockito.stubbing.OngoingStubbing;
+
+public interface MockingProgress {
+ OngoingStubbing> pullOngoingStubbing();
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/internal/util/MockUtil.java b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/util/MockUtil.java
new file mode 100644
index 00000000000..8a975ffe119
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/internal/util/MockUtil.java
@@ -0,0 +1,18 @@
+package org.mockito.internal.util;
+
+import org.mockito.mock.MockCreationSettings;
+import org.mockito.plugins.MockMaker;
+import org.mockito.invocation.MockHandler;
+import static org.mockito.internal.handler.MockHandlerFactory.createMockHandler;
+
+public class MockUtil {
+ public static T createMock(MockCreationSettings settings) {
+ MockMaker mockMaker = getMockMaker(settings.getMockMaker());
+ MockHandler mockHandler = createMockHandler(settings);
+ return mockMaker.createMock(settings, mockHandler);
+ }
+
+ public static MockMaker getMockMaker(String mockMaker) {
+ return null;
+ }
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/invocation/MockHandler.java b/java/ql/test/stubs/mockito-5.14/org/mockito/invocation/MockHandler.java
new file mode 100644
index 00000000000..d667c375929
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/invocation/MockHandler.java
@@ -0,0 +1,10 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.invocation;
+
+import java.io.Serializable;
+
+public interface MockHandler extends Serializable {
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/mock/MockCreationSettings.java b/java/ql/test/stubs/mockito-5.14/org/mockito/mock/MockCreationSettings.java
new file mode 100644
index 00000000000..86788eda5f1
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/mock/MockCreationSettings.java
@@ -0,0 +1,9 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.mock;
+
+public interface MockCreationSettings {
+ String getMockMaker();
+}
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/plugins/MockMaker.java b/java/ql/test/stubs/mockito-5.14/org/mockito/plugins/MockMaker.java
new file mode 100644
index 00000000000..d7b06ab96f5
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/plugins/MockMaker.java
@@ -0,0 +1,8 @@
+package org.mockito.plugins;
+
+import org.mockito.mock.MockCreationSettings;
+import org.mockito.invocation.MockHandler;
+
+public interface MockMaker {
+ T createMock(MockCreationSettings settings, MockHandler handler);
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/Answer.java b/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/Answer.java
new file mode 100644
index 00000000000..60828a66c52
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/Answer.java
@@ -0,0 +1,7 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.stubbing;
+
+public interface Answer { }
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/OngoingStubbing.java b/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/OngoingStubbing.java
new file mode 100644
index 00000000000..3fb5e659f04
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/OngoingStubbing.java
@@ -0,0 +1,9 @@
+/*
+ * Copyright (c) 2007 Mockito contributors
+ * This program is made available under the terms of the MIT License.
+ */
+package org.mockito.stubbing;
+
+public interface OngoingStubbing {
+ OngoingStubbing thenReturn(T value);
+}
\ No newline at end of file
diff --git a/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/Stubber.java b/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/Stubber.java
new file mode 100644
index 00000000000..eccca0c2c38
--- /dev/null
+++ b/java/ql/test/stubs/mockito-5.14/org/mockito/stubbing/Stubber.java
@@ -0,0 +1,5 @@
+package org.mockito.stubbing;
+
+public interface Stubber {
+ T when(T mock);
+}
\ No newline at end of file
From 22caa584adbf6c0ab8f980545d9983e0f2fd798b Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Mon, 11 Aug 2025 11:20:35 +0200
Subject: [PATCH 071/298] Java: Add inline test expectations for
`MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.qlref`
---
.../MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.qlref | 3 ++-
.../TestORM.java | 4 ++--
2 files changed, 4 insertions(+), 3 deletions(-)
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.qlref b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.qlref
index de4f9a9055f..6d22c90940b 100644
--- a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.qlref
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.qlref
@@ -1 +1,2 @@
-Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
\ No newline at end of file
+query: Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
+postprocess: utils/test/InlineExpectationsTestQuery.ql
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
index 9cb0d4720c1..155414d0dbb 100644
--- a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
@@ -31,7 +31,7 @@ public class TestORM {
* Test of form `when(mockedObject.methodToBeMocked()).thenReturn(someVal)`.
*/
@Test
- public void nonCompliant1() {
+ public void nonCompliant1() { // $ Alert
Employee sampleEmployee = new Employee("John Doe");
EmployeeRecord employeeRecordMock = mock(EmployeeRecord.class); // NON_COMPLIANT: All public methods of the mocked object are used
when(employeeRecordMock.add(sampleEmployee)).thenReturn(0); // Mocked EmployeeRecord.add
@@ -44,7 +44,7 @@ public class TestORM {
* Test of form `doReturn(someVal).when(mockedObject).methodToBeMocked()`.
*/
@Test
- public void nonCompliant2() {
+ public void nonCompliant2() { // $ Alert
Employee sampleEmployee = new Employee("John Doe");
EmployeeRecord employeeRecordMock = mock(EmployeeRecord.class); // NON_COMPLIANT: All public methods of the mocked object are used
doReturn(0).when(employeeRecordMock).add(sampleEmployee); // Mocked EmployeeRecord.add
From a9e9a62439f3b176b57fc696181e34407605da19 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Mon, 11 Aug 2025 11:23:01 +0200
Subject: [PATCH 072/298] Java: add single-method class test case for mocking
rule
Classes with only one public method should be compliant when mocked.
---
.../EmployeeStatus.java | 9 +++++++++
...gAllNonPrivateMethodsMeansUnitTestIsTooBig.expected | 1 +
.../TestORM.java | 10 ++++++++++
3 files changed, 20 insertions(+)
create mode 100644 java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/EmployeeStatus.java
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/EmployeeStatus.java b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/EmployeeStatus.java
new file mode 100644
index 00000000000..3b581bb39ef
--- /dev/null
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/EmployeeStatus.java
@@ -0,0 +1,9 @@
+/**
+ * Simple class with a single public method to test the edge case.
+ * When this single method is mocked, it means ALL public methods are mocked.
+ */
+public class EmployeeStatus {
+ public String getStatus() {
+ return "active";
+ }
+}
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected
index d3e95329380..45ff81d46e6 100644
--- a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected
@@ -1,2 +1,3 @@
| TestORM.java:34:15:34:27 | nonCompliant1 | This test method mocks all public methods of a $@. | EmployeeRecord.java:4:14:4:27 | EmployeeRecord | class or an interface |
| TestORM.java:47:15:47:27 | nonCompliant2 | This test method mocks all public methods of a $@. | EmployeeRecord.java:4:14:4:27 | EmployeeRecord | class or an interface |
+| TestORM.java:61:15:61:35 | compliantSingleMethod | This test method mocks all public methods of a $@. | EmployeeStatus.java:5:14:5:27 | EmployeeStatus | class or an interface |
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
index 155414d0dbb..a961ab20c10 100644
--- a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
@@ -52,4 +52,14 @@ public class TestORM {
doReturn(0).when(employeeRecordMock).update(sampleEmployee, "Jane Doe"); // Mocked EmployeeRecord.update
doReturn(0).when(employeeRecordMock).delete(sampleEmployee); // Mocked EmployeeRecord.delete
}
+
+ /**
+ * Edge case: Class with single public method - should NOT be flagged.
+ * When there's only one public method, mocking it doesn't indicate a "too big" test.
+ */
+ @Test
+ public void compliantSingleMethod() { // $ SPURIOUS: Alert
+ EmployeeStatus statusMock = mock(EmployeeStatus.class); // COMPLIANT: Single public method, no choice but to mock it if needed
+ when(statusMock.getStatus()).thenReturn("inactive"); // Mocked EmployeeStatus.getStatus (the only public method, but that's OK)
+ }
}
From 53ccc56959dc56236ba3dc40b4cf95b8b17591b1 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Mon, 11 Aug 2025 11:25:30 +0200
Subject: [PATCH 073/298] Java: exclude single-method classes from mocking
---
.../JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql | 2 ++
.../MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected | 1 -
.../TestORM.java | 2 +-
3 files changed, 3 insertions(+), 2 deletions(-)
diff --git a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
index 817763494c6..2c6fca90fbc 100644
--- a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
+++ b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
@@ -62,6 +62,8 @@ where
exists(MockitoMockCall mockCall |
mockCall.getParent+().(Stmt) = testMethod.getBody().getAStmt() and
mockedClassOrInterface = mockCall.getMockedType() and
+ // Only flag classes with multiple public methods (2 or more)
+ count(Method m | m = mockedClassOrInterface.getAMethod() and m.isPublic()) > 1 and
forex(Method method | method = mockedClassOrInterface.getAMethod() and method.isPublic() |
exists(MockitoMockingMethodCall mockedMethod |
mockedMethod.getMockitoMockCall() = mockCall and
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected
index 45ff81d46e6..d3e95329380 100644
--- a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.expected
@@ -1,3 +1,2 @@
| TestORM.java:34:15:34:27 | nonCompliant1 | This test method mocks all public methods of a $@. | EmployeeRecord.java:4:14:4:27 | EmployeeRecord | class or an interface |
| TestORM.java:47:15:47:27 | nonCompliant2 | This test method mocks all public methods of a $@. | EmployeeRecord.java:4:14:4:27 | EmployeeRecord | class or an interface |
-| TestORM.java:61:15:61:35 | compliantSingleMethod | This test method mocks all public methods of a $@. | EmployeeStatus.java:5:14:5:27 | EmployeeStatus | class or an interface |
diff --git a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
index a961ab20c10..eadf0151506 100644
--- a/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
+++ b/java/ql/test/query-tests/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig/TestORM.java
@@ -58,7 +58,7 @@ public class TestORM {
* When there's only one public method, mocking it doesn't indicate a "too big" test.
*/
@Test
- public void compliantSingleMethod() { // $ SPURIOUS: Alert
+ public void compliantSingleMethod() {
EmployeeStatus statusMock = mock(EmployeeStatus.class); // COMPLIANT: Single public method, no choice but to mock it if needed
when(statusMock.getStatus()).thenReturn("inactive"); // Mocked EmployeeStatus.getStatus (the only public method, but that's OK)
}
From b56f8cca2df21b9eda64687f3f431e2cf11ffb7a Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Mon, 11 Aug 2025 13:21:20 +0200
Subject: [PATCH 074/298] Java: Fix QLDoc style compliance and qhelp for
mocking query
---
...llNonPrivateMethodsMeansUnitTestIsTooBig.md | 18 +++++++-----------
...llNonPrivateMethodsMeansUnitTestIsTooBig.ql | 13 ++++++++-----
2 files changed, 15 insertions(+), 16 deletions(-)
diff --git a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.md b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.md
index 80a0c7e00f0..b0f2f8d1aa7 100644
--- a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.md
+++ b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.md
@@ -1,14 +1,10 @@
-# J-T-001: Mocking all non-private methods of a class may indicate the unit test is testing too much
-
-Mocking too many non-private methods of a class may indicate that the test is too complicated, possibly because it is trying to test multiple things at once.
-
## Overview
-Mocking methods of a class is necessary for a unit test to run without overhead caused by expensive I/O operations necessary to compute their values. However, if a unit test ends up mocking all of them, it is likely a signal that the scope of the unit test is reaching beyond a single unit of functionality.
+Mocking methods of a class is necessary for unit tests to run without overhead caused by expensive I/O operations. However, when a unit test ends up mocking all non-private methods of a class, it may indicate that the test is too complicated, possibly because it is trying to test multiple things at once. Such extensive mocking is likely a signal that the scope of the unit test is reaching beyond a single unit of functionality.
## Recommendation
-It is best to contain the scope of a single unit test to a single unit of functionality. For example, a unit test may aim to test a series of data-transforming functions that depends on an ORM class. Even though the functions may be semantically related with one another, it is better to create a unit test for each function.
+It is best to contain the scope of a single unit test to a single unit of functionality. For example, a unit test may aim to test a series of data-transforming functions that depend on an ORM class. Even though the functions may be semantically related with one another, it is better to create a unit test for each function.
## Example
@@ -30,14 +26,14 @@ public class TestORM {
public void nonCompliant() {
Employee sampleEmployee = new Employee("John Doe");
EmployeeRecord employeeRecordMock = mock(EmployeeRecord.class); // NON_COMPLIANT: Mocked class has all of its public methods used in the test
- when(employeeRecordMock.add(Employee.class)).thenReturn(0); // Mocked EmployeeRecord.add
- when(employeeRecordMock.get(String.class)).thenReturn(sampleEmployee); // Mocked EmployeeRecord.get
- when(employeeRecordMock.update(Employee.class, String.class)).thenReturn(0); // Mocked EmployeeRecord.update
- when(employeeRecordMock.delete(Employee.class)).thenReturn(0); // Mocked EmployeeRecord.delete
+ when(employeeRecordMock.add(sampleEmployee)).thenReturn(0); // Mocked EmployeeRecord.add
+ when(employeeRecordMock.get("John Doe")).thenReturn(sampleEmployee); // Mocked EmployeeRecord.get
+ when(employeeRecordMock.update(sampleEmployee, "Jane Doe")).thenReturn(0); // Mocked EmployeeRecord.update
+ when(employeeRecordMock.delete(sampleEmployee)).thenReturn(0); // Mocked EmployeeRecord.delete
}
@Test
- public void compliant1() {
+ public void compliant() {
Employee sampleEmployee = new Employee("John Doe");
EmployeeRecord employeeRecordMock = mock(EmployeeRecord.class); // COMPLIANT: Only some of the public methods belonging to the mocked object are used
when(employeeRecordMock.add(sampleEmployee)).thenReturn(0); // Mocked EmployeeRecord.add
diff --git a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
index 2c6fca90fbc..d35d3bf6ec1 100644
--- a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
+++ b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
@@ -1,6 +1,6 @@
/**
* @id java/mocking-all-non-private-methods-means-unit-test-is-too-big
- * @name J-T-001: Mocking all non-private methods of a class may indicate the unit test is testing too much
+ * @name Mocking all non-private methods of a class may indicate the unit test is testing too much
* @description Mocking all non-private methods provided by a class might indicate the unit test
* aims to test too many things.
* @kind problem
@@ -12,12 +12,15 @@
import java
+/**
+ * A call to Mockito's `mock` method.
+ */
class MockitoMockCall extends MethodCall {
MockitoMockCall() { this.getMethod().hasQualifiedName("org.mockito", "Mockito", "mock") }
/**
- * Gets the type that this call intends to mock. e.g.
- * ``` java
+ * Gets the type that this call intends to mock. For example:
+ * ```java
* EmployeeRecord employeeRecordMock = mock(EmployeeRecord.class);
* ```
* This predicate gets the class `EmployeeRecord` in the above example.
@@ -26,8 +29,8 @@ class MockitoMockCall extends MethodCall {
}
/**
- * A method call that mocks a target method in a JUnit test. e.g.
- * ``` java
+ * A method call that mocks a target method in a JUnit test. For example:
+ * ```java
* EmployeeRecord employeeRecordMock = mock(EmployeeRecord.class);
* when(employeeRecordMock.add(sampleEmployee)).thenReturn(0); // Mocked EmployeeRecord.add
* doReturn(0).when(employeeRecordMock).add(sampleEmployee); // Mocked EmployeeRecord.add
From f41cb67a696c0b01aa404e45d2fa75e61ac4a032 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Mon, 11 Aug 2025 13:27:07 +0200
Subject: [PATCH 075/298] Java: Promote
`java/mocking-all-non-private-methods-means-unit-test-is-too-big` to quality
status
---
.../java/query-suite/java-code-quality-extended.qls.expected | 1 +
.../java/query-suite/java-code-quality.qls.expected | 1 +
.../JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql | 3 ++-
3 files changed, 4 insertions(+), 1 deletion(-)
diff --git a/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected b/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected
index 7a1a986b2aa..5de435a0e74 100644
--- a/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected
+++ b/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected
@@ -37,6 +37,7 @@ ql/java/ql/src/Likely Bugs/Concurrency/ScheduledThreadPoolExecutorZeroThread.ql
ql/java/ql/src/Likely Bugs/Concurrency/SynchOnBoxedType.ql
ql/java/ql/src/Likely Bugs/Concurrency/SynchSetUnsynchGet.ql
ql/java/ql/src/Likely Bugs/Frameworks/JUnit/JUnit5MissingNestedAnnotation.ql
+ql/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
ql/java/ql/src/Likely Bugs/Inheritance/NoNonFinalInConstructor.ql
ql/java/ql/src/Likely Bugs/Likely Typos/ContainerSizeCmpZero.ql
ql/java/ql/src/Likely Bugs/Likely Typos/ContradictoryTypeChecks.ql
diff --git a/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected b/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected
index 17253dbe0f8..791f64cd672 100644
--- a/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected
+++ b/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected
@@ -35,6 +35,7 @@ ql/java/ql/src/Likely Bugs/Concurrency/ScheduledThreadPoolExecutorZeroThread.ql
ql/java/ql/src/Likely Bugs/Concurrency/SynchOnBoxedType.ql
ql/java/ql/src/Likely Bugs/Concurrency/SynchSetUnsynchGet.ql
ql/java/ql/src/Likely Bugs/Frameworks/JUnit/JUnit5MissingNestedAnnotation.ql
+ql/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
ql/java/ql/src/Likely Bugs/Inheritance/NoNonFinalInConstructor.ql
ql/java/ql/src/Likely Bugs/Likely Typos/ContainerSizeCmpZero.ql
ql/java/ql/src/Likely Bugs/Likely Typos/ContradictoryTypeChecks.ql
diff --git a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
index d35d3bf6ec1..47320e9bbcc 100644
--- a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
+++ b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
@@ -6,7 +6,8 @@
* @kind problem
* @precision high
* @problem.severity recommendation
- * @tags maintainability
+ * @tags quality
+ * maintainability
* readability
*/
From ff648fcb277a76aca20e43a578cbe5a9f92e1c98 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Mon, 11 Aug 2025 13:40:25 +0200
Subject: [PATCH 076/298] Java: Removed redundant cast to Stmt
---
.../JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
index 47320e9bbcc..f7a75aa94fe 100644
--- a/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
+++ b/java/ql/src/Likely Bugs/Frameworks/JUnit/MockingAllNonPrivateMethodsMeansUnitTestIsTooBig.ql
@@ -64,7 +64,7 @@ class MockitoMockingMethodCall extends MethodCall {
from JUnit4TestMethod testMethod, ClassOrInterface mockedClassOrInterface
where
exists(MockitoMockCall mockCall |
- mockCall.getParent+().(Stmt) = testMethod.getBody().getAStmt() and
+ mockCall.getParent+() = testMethod.getBody().getAStmt() and
mockedClassOrInterface = mockCall.getMockedType() and
// Only flag classes with multiple public methods (2 or more)
count(Method m | m = mockedClassOrInterface.getAMethod() and m.isPublic()) > 1 and
From 6ad8af0ea9a979692f2d625c2f5d1fc9e86dde39 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 12 Aug 2025 16:46:29 +0200
Subject: [PATCH 077/298] Cargo: upgrade dependencies
---
Cargo.lock | 314 ++++++++++++------------
ruby/extractor/Cargo.toml | 2 +-
rust/ast-generator/Cargo.toml | 6 +-
rust/extractor/Cargo.toml | 42 ++--
shared/tree-sitter-extractor/Cargo.toml | 2 +-
5 files changed, 189 insertions(+), 177 deletions(-)
diff --git a/Cargo.lock b/Cargo.lock
index 80adcc3e270..b712c4f8d24 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -90,9 +90,9 @@ dependencies = [
[[package]]
name = "anyhow"
-version = "1.0.98"
+version = "1.0.99"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e16d2d3311acee920a9eb8d33b8cbc1787ce4a264e85f964c2404b969bdcd487"
+checksum = "b0674a1ddeecb70197781e945de4b3b8ffb61fa939a5597bcf48503737663100"
[[package]]
name = "argfile"
@@ -195,12 +195,6 @@ version = "1.21.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ef657dfab802224e671f5818e9a4935f9b1957ed18e58292690cc39e7a4092a3"
-[[package]]
-name = "byteorder"
-version = "1.5.0"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b"
-
[[package]]
name = "camino"
version = "1.1.10"
@@ -285,6 +279,18 @@ dependencies = [
"synstructure",
]
+[[package]]
+name = "chalk-derive"
+version = "0.104.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9ea9b1e80910f66ae87c772247591432032ef3f6a67367ff17f8343db05beafa"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn",
+ "synstructure",
+]
+
[[package]]
name = "chalk-ir"
version = "0.103.0"
@@ -292,7 +298,17 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "90a37d2ab99352b4caca135061e7b4ac67024b648c28ed0b787feec4bea4caed"
dependencies = [
"bitflags 2.9.1",
- "chalk-derive",
+ "chalk-derive 0.103.0",
+]
+
+[[package]]
+name = "chalk-ir"
+version = "0.104.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7047a516de16226cd17344d41a319d0ea1064bf9e60bd612ab341ab4a34bbfa8"
+dependencies = [
+ "bitflags 2.9.1",
+ "chalk-derive 0.104.0",
]
[[package]]
@@ -301,8 +317,8 @@ version = "0.103.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c855be60e646664bc37c2496d3dc81ca5ef60520930e5e0f0057a0575aff6c19"
dependencies = [
- "chalk-derive",
- "chalk-ir",
+ "chalk-derive 0.103.0",
+ "chalk-ir 0.103.0",
"chalk-solve",
"rustc-hash 1.1.0",
"tracing",
@@ -314,8 +330,8 @@ version = "0.103.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "477ac6cdfd2013e9f93b09b036c2b607a67b2e728f4777b8422d55a79e9e3a34"
dependencies = [
- "chalk-derive",
- "chalk-ir",
+ "chalk-derive 0.103.0",
+ "chalk-ir 0.103.0",
"ena",
"indexmap 2.10.0",
"itertools 0.12.1",
@@ -341,9 +357,9 @@ dependencies = [
[[package]]
name = "clap"
-version = "4.5.41"
+version = "4.5.44"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "be92d32e80243a54711e5d7ce823c35c41c9d929dc4ab58e1276f625841aadf9"
+checksum = "1c1f056bae57e3e54c3375c41ff79619ddd13460a17d7438712bd0d83fda4ff8"
dependencies = [
"clap_builder",
"clap_derive",
@@ -351,9 +367,9 @@ dependencies = [
[[package]]
name = "clap_builder"
-version = "4.5.41"
+version = "4.5.44"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "707eab41e9622f9139419d573eca0900137718000c517d47da73045f54331c3d"
+checksum = "b3e7f4214277f3c7aa526a59dd3fbe306a370daee1f8b7b8c987069cd8e888a8"
dependencies = [
"anstream",
"anstyle",
@@ -433,7 +449,7 @@ version = "0.1.0"
dependencies = [
"anyhow",
"argfile",
- "chalk-ir",
+ "chalk-ir 0.104.0",
"chrono",
"clap",
"codeql-extractor",
@@ -462,7 +478,7 @@ dependencies = [
"serde",
"serde_json",
"serde_with",
- "toml 0.9.2",
+ "toml 0.9.5",
"tracing",
"tracing-flame",
"tracing-subscriber",
@@ -817,21 +833,21 @@ checksum = "7ab85b9b05e3978cc9a9cf8fea7f01b494e1a09ed3037e16ba39edc7a29eb61a"
[[package]]
name = "getrandom"
-version = "0.3.1"
+version = "0.3.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "43a49c392881ce6d5c3b8cb70f98717b7c07aabbdff06687b9030dbfbe2725f8"
+checksum = "26145e563e54f2cadc477553f1ec5ee650b00862f0a58bcd12cbdc5f0ea2d2f4"
dependencies = [
"cfg-if",
"libc",
- "wasi 0.13.3+wasi-0.2.2",
- "windows-targets 0.52.6",
+ "r-efi",
+ "wasi 0.14.2+wasi-0.2.4",
]
[[package]]
name = "glob"
-version = "0.3.2"
+version = "0.3.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a8d1add55171497b4705a648c6b583acafb01d58050a51727785f0b2c8e0a2b2"
+checksum = "0cc23270f6e1808e30a928bdc84dea0b9b4136a8bc82338574f23baf47bbd280"
[[package]]
name = "globset"
@@ -1542,18 +1558,18 @@ checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391"
[[package]]
name = "ppv-lite86"
-version = "0.2.20"
+version = "0.2.21"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "77957b295656769bb8ad2b6a6b09d897d94f05c41b069aede1fcdaa675eaea04"
+checksum = "85eae3c4ed2f50dcfe72643da4befc30deadb458a9b590d720cde2f2b1e97da9"
dependencies = [
- "zerocopy 0.7.35",
+ "zerocopy",
]
[[package]]
name = "proc-macro2"
-version = "1.0.95"
+version = "1.0.97"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "02b3e5e68a3a1a02aad3ec490a98007cbc13c37cbe84a3cd7b8e406d76e7f778"
+checksum = "d61789d7719defeb74ea5fe81f2fdfdbd28a803847077cecce2ff14e1472f6f1"
dependencies = [
"unicode-ident",
]
@@ -1581,10 +1597,16 @@ dependencies = [
]
[[package]]
-name = "ra-ap-rustc_abi"
-version = "0.116.0"
+name = "r-efi"
+version = "5.3.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a967e3a9cd3e38b543f503978e0eccee461e3aea3f7b10e944959bff41dbe612"
+checksum = "69cdb34c158ceb288df11e18b4bd39de994f6657d83847bdffdbd7f346754b0f"
+
+[[package]]
+name = "ra-ap-rustc_abi"
+version = "0.123.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f18c877575c259d127072e9bfc41d985202262fb4d6bfdae3d1252147c2562c2"
dependencies = [
"bitflags 2.9.1",
"ra-ap-rustc_hashes",
@@ -1594,18 +1616,18 @@ dependencies = [
[[package]]
name = "ra-ap-rustc_hashes"
-version = "0.116.0"
+version = "0.123.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1ea4c755ecbbffa5743c251344f484ebe571ec7bc5b36d80b2a8ae775d1a7a40"
+checksum = "2439ed1df3472443133b66949f81080dff88089b42f825761455463709ee1cad"
dependencies = [
"rustc-stable-hash",
]
[[package]]
name = "ra-ap-rustc_index"
-version = "0.116.0"
+version = "0.123.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "aca7ad7cf911538c619caa2162339fe98637e9e46f11bb0484ef96735df4d64a"
+checksum = "57a24fe0be21be1f8ebc21dcb40129214fb4cefb0f2753f3d46b6dbe656a1a45"
dependencies = [
"ra-ap-rustc_index_macros",
"smallvec",
@@ -1613,9 +1635,9 @@ dependencies = [
[[package]]
name = "ra-ap-rustc_index_macros"
-version = "0.116.0"
+version = "0.123.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8767ba551c9355bc3031be072cc4bb0381106e5e7cd275e72b7a8c76051c4070"
+checksum = "844a27ddcad0116facae2df8e741fd788662cf93dc13029cd864f2b8013b81f9"
dependencies = [
"proc-macro2",
"quote",
@@ -1624,9 +1646,20 @@ dependencies = [
[[package]]
name = "ra-ap-rustc_lexer"
-version = "0.116.0"
+version = "0.121.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "6101374afb267e6c27e4e2eb0b1352e9f3504c1a8f716f619cd39244e2ed92ab"
+checksum = "22944e31fb91e9b3e75bcbc91e37d958b8c0825a6160927f2856831d2ce83b36"
+dependencies = [
+ "memchr",
+ "unicode-properties",
+ "unicode-xid",
+]
+
+[[package]]
+name = "ra-ap-rustc_lexer"
+version = "0.123.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2b734cfcb577d09877799a22742f1bd398be6c00bc428d9de56d48d11ece5771"
dependencies = [
"memchr",
"unicode-properties",
@@ -1635,19 +1668,19 @@ dependencies = [
[[package]]
name = "ra-ap-rustc_parse_format"
-version = "0.116.0"
+version = "0.121.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ecd88a19f00da4f43e6727d5013444cbc399804b5046dfa2bbcd28ebed3970ce"
+checksum = "81057891bc2063ad9e353f29462fbc47a0f5072560af34428ae9313aaa5e9d97"
dependencies = [
- "ra-ap-rustc_lexer",
- "rustc-literal-escaper 0.0.2",
+ "ra-ap-rustc_lexer 0.121.0",
+ "rustc-literal-escaper",
]
[[package]]
name = "ra-ap-rustc_pattern_analysis"
-version = "0.116.0"
+version = "0.123.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "bb332dd32d7850a799862533b1c021e6062558861a4ad57817bf522499fbb892"
+checksum = "75b0ee1f059b9dea0818c6c7267478926eee95ba4c7dcf89c8db32fa165d3904"
dependencies = [
"ra-ap-rustc_index",
"rustc-hash 2.1.1",
@@ -1658,9 +1691,9 @@ dependencies = [
[[package]]
name = "ra_ap_base_db"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "3daac3b2c8e4e3d02d47f177c75360c85f16f4f9e6d60ee358a47532ccb35647"
+checksum = "47cac371778785196064f1a347fbbac0aafb1053786f17378bb138be59e57fc2"
dependencies = [
"dashmap",
"indexmap 2.10.0",
@@ -1681,9 +1714,9 @@ dependencies = [
[[package]]
name = "ra_ap_cfg"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "bfcada4b644f965cf8972f31c28a343737c9c500c87d59d026a77bf5ce8ad76b"
+checksum = "6789ed14467e6625bef45b29555844d0168d8af1bea9edb0f1d44f0a9b69f398"
dependencies = [
"ra_ap_intern",
"ra_ap_tt",
@@ -1693,15 +1726,15 @@ dependencies = [
[[package]]
name = "ra_ap_edition"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "732efa3d4cd5edc1578be0a33fa0f8052a348e52e6b95e7e161199f7166445b7"
+checksum = "637b74c692dc9d9b44394f8c0f91c063e1b6223c6e54f4ee89c943db2f2ee26e"
[[package]]
name = "ra_ap_hir"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "6de0998ba9f6d4f2b70e6be16c7beeda661bdf25cdae932ed10c45b8b6cc6d8f"
+checksum = "a94c69a3830f0b6fbc36c1d098fcc9430f63c8d47ee6f93e3d6810c3bf440296"
dependencies = [
"arrayvec",
"either",
@@ -1725,9 +1758,9 @@ dependencies = [
[[package]]
name = "ra_ap_hir_def"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "af1a22912226cfbc1909c09f30896cbbfd9acb5c051db9d55e1c557b5d7aa6f4"
+checksum = "7d94fcf7743db2f4f7e2c2911563847eb8efe2b7fb9fa430c107f0ac05962254"
dependencies = [
"arrayvec",
"bitflags 2.9.1",
@@ -1763,9 +1796,9 @@ dependencies = [
[[package]]
name = "ra_ap_hir_expand"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "7ef269bd496048dd39288122ee05805c672df3a26cc9c05ce7bdde42f0656324"
+checksum = "67ea3f6a0ba0c1e8b63f4a41bc596c07aeb2db2f99b67fa077820cfb5fce58bd"
dependencies = [
"cov-mark",
"either",
@@ -1791,14 +1824,14 @@ dependencies = [
[[package]]
name = "ra_ap_hir_ty"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1d26605356ec9541148ce2dcf00e45b9bbe90424c9e04baeca3fb6c463ce2487"
+checksum = "eccf6c291a88892e59e7591e081da8b9158f8c0b1ed9cb9b73d02d29a0d3d6d9"
dependencies = [
"arrayvec",
"bitflags 2.9.1",
- "chalk-derive",
- "chalk-ir",
+ "chalk-derive 0.103.0",
+ "chalk-ir 0.103.0",
"chalk-recursive",
"chalk-solve",
"cov-mark",
@@ -1832,9 +1865,9 @@ dependencies = [
[[package]]
name = "ra_ap_ide_db"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "087858853882a6dc56a2bd1da01ab0fc15d9e0ba2afd613d22df69097acc47a9"
+checksum = "0bbbc97cc9837f91100711b65fb0d8ce9d7ed8da0dc418e08678d973d53da6a3"
dependencies = [
"arrayvec",
"bitflags 2.9.1",
@@ -1866,9 +1899,9 @@ dependencies = [
[[package]]
name = "ra_ap_intern"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5ec1af1e540f93cc4c9642454c1ad7aa155d54d1533804da771ff05f19bb57fa"
+checksum = "10f4785a674a41f9f52414fb7f19ab9a1d6886cad572e68721a883b0b85c256b"
dependencies = [
"dashmap",
"hashbrown 0.14.5",
@@ -1878,9 +1911,9 @@ dependencies = [
[[package]]
name = "ra_ap_load-cargo"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a3343d16dc4b0f3337d4654f9d0c41363be4197aaf6f62a02b711440fdb3eaae"
+checksum = "f3be9990782fd2c2d90b67e2e0b4a86e7412ec8a0719950d9a68292924e85691"
dependencies = [
"anyhow",
"crossbeam-channel",
@@ -1899,13 +1932,13 @@ dependencies = [
[[package]]
name = "ra_ap_mbe"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c2253eeeef2ee51d8a7b43f86fe43883654b8a3bb56c9cb801de1bf457ca24d6"
+checksum = "5b713f4d927f9d86391f66237019b8e5dbcad4ddbbe37c91c2e21adca258b9aa"
dependencies = [
"arrayvec",
"cov-mark",
- "ra-ap-rustc_lexer",
+ "ra-ap-rustc_lexer 0.123.0",
"ra_ap_intern",
"ra_ap_parser",
"ra_ap_span",
@@ -1918,31 +1951,31 @@ dependencies = [
[[package]]
name = "ra_ap_parser"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "df3bf4cde715c2343c24a39283534e7bd5498e29b6b938615ba0e02ba4e262b4"
+checksum = "0d3fb8a5891c1c1d6fba5e58caa86b88f831990c878e361c54c1c1ff44ca8401"
dependencies = [
"drop_bomb",
- "ra-ap-rustc_lexer",
+ "ra-ap-rustc_lexer 0.123.0",
"ra_ap_edition",
- "rustc-literal-escaper 0.0.4",
+ "rustc-literal-escaper",
"tracing",
]
[[package]]
name = "ra_ap_paths"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "c610195e29090ebc387061aa8d55c5d741004df2e15e11c62e34cf3037e61fe8"
+checksum = "9ccd5cfd0dae89ab2c70c4e5aa646f64bb8b5591622477342863c23a5f32dabc"
dependencies = [
"camino",
]
[[package]]
name = "ra_ap_proc_macro_api"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "537a1866f6e63a1405bac2aa9e32ae47ea2e38b0879d1e7ab00e53b03d787512"
+checksum = "dae43c707bfb78f1b841ffb3731cc7876550463306c3b3986c20abd31033e7a2"
dependencies = [
"indexmap 2.10.0",
"ra_ap_intern",
@@ -1959,9 +1992,9 @@ dependencies = [
[[package]]
name = "ra_ap_profile"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "4824370708bd413f38e697831d37878c44366ff18aa7dd95ab0af5e3a484c558"
+checksum = "95a7b93ca94cf0821e8bcac6bf8464cc94d7b3cbe63ffb74946a58ad03991fae"
dependencies = [
"cfg-if",
"libc",
@@ -1971,9 +2004,9 @@ dependencies = [
[[package]]
name = "ra_ap_project_model"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "d97b1f2d3d8b6cd838264624192c0dbded200d7b7944a4731ab20bb18fab79b9"
+checksum = "0751b9433a0dd49c6ae58c9572faf9557d2b53818370d72112b3adeaae5eabc4"
dependencies = [
"anyhow",
"cargo_metadata",
@@ -1991,15 +2024,16 @@ dependencies = [
"serde",
"serde_derive",
"serde_json",
+ "temp-dir",
"tracing",
"triomphe",
]
[[package]]
name = "ra_ap_query-group-macro"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "9d9c2a0a9519e59eeb2cc42991477e4cf4214c2e9e1ac29453d6bd6ccd05ed58"
+checksum = "5a82732eb8f5dc592d1d8d9bee23c1d66532e39293f02e23c7a546b60b35072b"
dependencies = [
"proc-macro2",
"quote",
@@ -2008,9 +2042,9 @@ dependencies = [
[[package]]
name = "ra_ap_span"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "a2a224089b92abb04b36fa9dbd3e348a41997917e155eb9598d686766b15b4e9"
+checksum = "c498ddf2d71705dcef9fb142269c0027c959a5eb17c435eea5466af7c3b9c47c"
dependencies = [
"hashbrown 0.14.5",
"la-arena",
@@ -2024,9 +2058,9 @@ dependencies = [
[[package]]
name = "ra_ap_stdx"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "b565a5d6e364b3c6f955a5b20e1633e5db15df9f804fba26615150524eeccb2c"
+checksum = "26ade567b0d692c7efd4ceb921cdbe182beca0b5af9a5cf05c07cf0e14db512a"
dependencies = [
"crossbeam-channel",
"crossbeam-utils",
@@ -2040,9 +2074,9 @@ dependencies = [
[[package]]
name = "ra_ap_syntax"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "092f544af4e1c974924417ec5d1864544d99329d26ecc72cded2c99a86e6f710"
+checksum = "dba62d25b0296eb095d9db77e56d096417a89db4f4de1956add0d472ebcaf922"
dependencies = [
"either",
"itertools 0.14.0",
@@ -2050,7 +2084,7 @@ dependencies = [
"ra_ap_stdx",
"rowan",
"rustc-hash 2.1.1",
- "rustc-literal-escaper 0.0.4",
+ "rustc-literal-escaper",
"smol_str",
"tracing",
"triomphe",
@@ -2058,9 +2092,9 @@ dependencies = [
[[package]]
name = "ra_ap_syntax-bridge"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "3dcebacacf0a3fa1eac8f8ae57260602652fe4b2dbc3a1931cd854855fc744b2"
+checksum = "664466f2e824e285b671366f81128aa4a91b501fedbf7956a6bfb1f13d8b0b39"
dependencies = [
"ra_ap_intern",
"ra_ap_parser",
@@ -2073,9 +2107,9 @@ dependencies = [
[[package]]
name = "ra_ap_toolchain"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "08f64f934312af8dde360d0327322452f14e772e6ddc5449629a3bd840127cdd"
+checksum = "2ef82cfc5eb8f9d4a3be9876ce019b78fbfdb8ff4f7e4dee9e384d65122096ab"
dependencies = [
"camino",
"home",
@@ -2083,12 +2117,12 @@ dependencies = [
[[package]]
name = "ra_ap_tt"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "48c511a2238fb0b8a1437ad99d8361f48d60ca5267faf457748d47657bddbf55"
+checksum = "cbc858f5208f0d00f8638d14ab5ffab5d1bc79ad7fe1db5c5e0d478b9a02155c"
dependencies = [
"arrayvec",
- "ra-ap-rustc_lexer",
+ "ra-ap-rustc_lexer 0.123.0",
"ra_ap_intern",
"ra_ap_stdx",
"text-size",
@@ -2096,9 +2130,9 @@ dependencies = [
[[package]]
name = "ra_ap_vfs"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "7b8a98fbdf277b873c08937c0d5357f44b33c6d689b96f331653c2df1bb82d29"
+checksum = "e065b27829f5281d2ffc41de72551a0e4c4f49a9989ba7721676f414100c8af2"
dependencies = [
"crossbeam-channel",
"fst",
@@ -2112,9 +2146,9 @@ dependencies = [
[[package]]
name = "ra_ap_vfs-notify"
-version = "0.0.294"
+version = "0.0.300"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "9e1c54fc0e6b8bc6204a160019c80a26d4ca26c99729387e12d06c0bc421acdd"
+checksum = "5a3c795e86c9b5fcdbb99145e401a0d6348ed471ac96f1b7de151c0abe07a5af"
dependencies = [
"crossbeam-channel",
"notify",
@@ -2129,9 +2163,9 @@ dependencies = [
[[package]]
name = "rand"
-version = "0.9.1"
+version = "0.9.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "9fbfd9d094a40bf3ae768db9361049ace4c0e04a4fd6b359518bd7b73a73dd97"
+checksum = "6db2770f06117d490610c7488547d543617b21bfa07796d7a12f6f1bd53850d1"
dependencies = [
"rand_chacha",
"rand_core",
@@ -2149,12 +2183,11 @@ dependencies = [
[[package]]
name = "rand_core"
-version = "0.9.2"
+version = "0.9.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "7a509b1a2ffbe92afab0e55c8fd99dea1c280e8171bd2d88682bb20bc41cbc2c"
+checksum = "99d9a13982dcf210057a8a78572b2217b667c3beacbf3a0d8b454f6f82837d38"
dependencies = [
"getrandom",
- "zerocopy 0.8.20",
]
[[package]]
@@ -2283,12 +2316,6 @@ version = "2.1.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "357703d41365b4b27c590e3ed91eabb1b663f07c4c084095e60cbed4362dff0d"
-[[package]]
-name = "rustc-literal-escaper"
-version = "0.0.2"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "0041b6238913c41fe704213a4a9329e2f685a156d1781998128b4149c230ad04"
-
[[package]]
name = "rustc-literal-escaper"
version = "0.0.4"
@@ -2473,9 +2500,9 @@ dependencies = [
[[package]]
name = "serde_json"
-version = "1.0.140"
+version = "1.0.142"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "20068b6e96dc6c9bd23e01df8827e6c7e1f2fddd43c21810382803c136b99373"
+checksum = "030fedb782600dcbd6f02d479bf0d817ac3bb40d644745b769d6a96bc3afc5a7"
dependencies = [
"itoa",
"memchr",
@@ -2617,6 +2644,12 @@ dependencies = [
"syn",
]
+[[package]]
+name = "temp-dir"
+version = "0.1.16"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "83176759e9416cf81ee66cb6508dbfe9c96f20b8b56265a39917551c23c70964"
+
[[package]]
name = "text-size"
version = "1.1.1"
@@ -2714,9 +2747,9 @@ dependencies = [
[[package]]
name = "toml"
-version = "0.9.2"
+version = "0.9.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "ed0aee96c12fa71097902e0bb061a5e1ebd766a6636bb605ba401c45c1650eac"
+checksum = "75129e1dc5000bfbaa9fee9d1b21f974f9fbad9daec557a521ee6e080825f6e8"
dependencies = [
"indexmap 2.10.0",
"serde",
@@ -2761,9 +2794,9 @@ dependencies = [
[[package]]
name = "toml_parser"
-version = "1.0.1"
+version = "1.0.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "97200572db069e74c512a14117b296ba0a80a30123fbbb5aa1f4a348f639ca30"
+checksum = "b551886f449aa90d4fe2bdaa9f4a2577ad2dde302c61ecf262d80b116db95c10"
dependencies = [
"winnow",
]
@@ -3025,9 +3058,9 @@ checksum = "ccf3ec651a847eb01de73ccad15eb7d99f80485de043efb2f370cd654f4ea44b"
[[package]]
name = "wasi"
-version = "0.13.3+wasi-0.2.2"
+version = "0.14.2+wasi-0.2.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "26816d2e1a4a36a2940b96c5296ce403917633dff8f3440e9b236ed6f6bacad2"
+checksum = "9683f9a5a998d873c0d21fcbe3c083009670149a8fab228644b8bd36b2c48cb3"
dependencies = [
"wit-bindgen-rt",
]
@@ -3412,9 +3445,9 @@ dependencies = [
[[package]]
name = "wit-bindgen-rt"
-version = "0.33.0"
+version = "0.39.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "3268f3d866458b787f390cf61f4bbb563b922d091359f9608842999eaee3943c"
+checksum = "6f42320e61fe2cfd34354ecb597f86f413484a798ba44a8ca1165c58d42da6c1"
dependencies = [
"bitflags 2.9.1",
]
@@ -3457,39 +3490,18 @@ dependencies = [
[[package]]
name = "zerocopy"
-version = "0.7.35"
+version = "0.8.26"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1b9b4fd18abc82b8136838da5d50bae7bdea537c574d8dc1a34ed098d6c166f0"
+checksum = "1039dd0d3c310cf05de012d8a39ff557cb0d23087fd44cad61df08fc31907a2f"
dependencies = [
- "byteorder",
- "zerocopy-derive 0.7.35",
-]
-
-[[package]]
-name = "zerocopy"
-version = "0.8.20"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "dde3bb8c68a8f3f1ed4ac9221aad6b10cece3e60a8e2ea54a6a2dec806d0084c"
-dependencies = [
- "zerocopy-derive 0.8.20",
+ "zerocopy-derive",
]
[[package]]
name = "zerocopy-derive"
-version = "0.7.35"
+version = "0.8.26"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e"
-dependencies = [
- "proc-macro2",
- "quote",
- "syn",
-]
-
-[[package]]
-name = "zerocopy-derive"
-version = "0.8.20"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "eea57037071898bf96a6da35fd626f4f27e9cee3ead2a6c703cf09d472b2e700"
+checksum = "9ecf5b4cc5364572d7f4c329661bcc82724222973f2cab6f050a4e5c22f75181"
dependencies = [
"proc-macro2",
"quote",
diff --git a/ruby/extractor/Cargo.toml b/ruby/extractor/Cargo.toml
index 16cdcca246c..63c6d16d53c 100644
--- a/ruby/extractor/Cargo.toml
+++ b/ruby/extractor/Cargo.toml
@@ -17,6 +17,6 @@ rayon = "1.10.0"
regex = "1.11.1"
encoding = "0.2"
lazy_static = "1.5.0"
-serde_json = "1.0.140"
+serde_json = "1.0.142"
codeql-extractor = { path = "../../shared/tree-sitter-extractor" }
diff --git a/rust/ast-generator/Cargo.toml b/rust/ast-generator/Cargo.toml
index 634c3c34fc8..1c079952f71 100644
--- a/rust/ast-generator/Cargo.toml
+++ b/rust/ast-generator/Cargo.toml
@@ -7,11 +7,11 @@ license = "MIT"
# When updating these dependencies, run `rust/update_cargo_deps.sh`
[dependencies]
ungrammar = "1.16.1"
-proc-macro2 = "1.0.95"
+proc-macro2 = "1.0.97"
quote = "1.0.40"
either = "1.15.0"
-stdx = {package = "ra_ap_stdx", version = "0.0.294"}
+stdx = {package = "ra_ap_stdx", version = "0.0.300"}
itertools = "0.14.0"
mustache = "0.9.0"
serde = { version = "1.0.219", features = ["derive"] }
-anyhow = "1.0.98"
+anyhow = "1.0.99"
diff --git a/rust/extractor/Cargo.toml b/rust/extractor/Cargo.toml
index 31a18ad15b3..ed9915b2877 100644
--- a/rust/extractor/Cargo.toml
+++ b/rust/extractor/Cargo.toml
@@ -6,25 +6,25 @@ license = "MIT"
# When updating these dependencies, run `rust/update_cargo_deps.sh`
[dependencies]
-anyhow = "1.0.98"
-clap = { version = "4.5.41", features = ["derive"] }
+anyhow = "1.0.99"
+clap = { version = "4.5.44", features = ["derive"] }
figment = { version = "0.10.19", features = ["env", "yaml"] }
num-traits = "0.2.19"
-ra_ap_base_db = "0.0.294"
-ra_ap_hir = "0.0.294"
-ra_ap_hir_def = "0.0.294"
-ra_ap_ide_db = "0.0.294"
-ra_ap_hir_ty = "0.0.294"
-ra_ap_hir_expand = "0.0.294"
-ra_ap_load-cargo = "0.0.294"
-ra_ap_paths = "0.0.294"
-ra_ap_project_model = "0.0.294"
-ra_ap_syntax = "0.0.294"
-ra_ap_vfs = "0.0.294"
-ra_ap_parser = "0.0.294"
-ra_ap_span = "0.0.294"
-ra_ap_cfg = "0.0.294"
-ra_ap_intern = "0.0.294"
+ra_ap_base_db = "0.0.300"
+ra_ap_hir = "0.0.300"
+ra_ap_hir_def = "0.0.300"
+ra_ap_ide_db = "0.0.300"
+ra_ap_hir_ty = "0.0.300"
+ra_ap_hir_expand = "0.0.300"
+ra_ap_load-cargo = "0.0.300"
+ra_ap_paths = "0.0.300"
+ra_ap_project_model = "0.0.300"
+ra_ap_syntax = "0.0.300"
+ra_ap_vfs = "0.0.300"
+ra_ap_parser = "0.0.300"
+ra_ap_span = "0.0.300"
+ra_ap_cfg = "0.0.300"
+ra_ap_intern = "0.0.300"
serde = "1.0.219"
serde_with = "3.14.0"
triomphe = "0.1.14"
@@ -32,13 +32,13 @@ argfile = "0.2.1"
codeql-extractor = { path = "../../shared/tree-sitter-extractor" }
rust-extractor-macros = { path = "macros" }
itertools = "0.14.0"
-glob = "0.3.2"
+glob = "0.3.3"
chrono = { version = "0.4.41", features = ["serde"] }
-serde_json = "1.0.140"
+serde_json = "1.0.142"
dunce = "1.0.5"
-toml = "0.9.2"
+toml = "0.9.5"
tracing = "0.1.41"
tracing-flame = "0.2.0"
tracing-subscriber = "0.3.19"
-chalk-ir = "0.103.0"
+chalk-ir = "0.104.0"
mustache = "0.9.0"
diff --git a/shared/tree-sitter-extractor/Cargo.toml b/shared/tree-sitter-extractor/Cargo.toml
index 4cfeae2801b..e47ef3577e2 100644
--- a/shared/tree-sitter-extractor/Cargo.toml
+++ b/shared/tree-sitter-extractor/Cargo.toml
@@ -24,4 +24,4 @@ zstd = "0.13.3"
[dev-dependencies]
tree-sitter-ql = "0.23.1"
tree-sitter-json = "0.24.8"
-rand = "0.9.1"
+rand = "0.9.2"
From 0a42b7aba3cb9a9d0557d1722b07954a65d92e46 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 12 Aug 2025 16:51:13 +0200
Subject: [PATCH 078/298] Bazel: regenerate vendored cargo dependencies
---
MODULE.bazel | 48 +-
.../BUILD.adler2-2.0.0.bazel | 9 +
.../BUILD.aho-corasick-1.1.3.bazel | 9 +
.../BUILD.allocator-api2-0.2.21.bazel | 9 +
.../BUILD.android-tzdata-0.1.1.bazel | 9 +
...UILD.android_system_properties-0.1.5.bazel | 9 +
.../BUILD.anstream-0.6.19.bazel | 9 +
.../BUILD.anstyle-1.0.11.bazel | 9 +
.../BUILD.anstyle-parse-0.2.7.bazel | 9 +
.../BUILD.anstyle-query-1.1.3.bazel | 9 +
.../BUILD.anstyle-wincon-3.0.9.bazel | 9 +
...1.0.98.bazel => BUILD.anyhow-1.0.99.bazel} | 23 +-
.../BUILD.argfile-0.2.1.bazel | 9 +
.../BUILD.arrayvec-0.7.6.bazel | 9 +
.../BUILD.atomic-0.6.0.bazel | 9 +
.../BUILD.autocfg-1.5.0.bazel | 9 +
.../BUILD.base64-0.22.1.bazel | 9 +
.../tree_sitter_extractors_deps/BUILD.bazel | 148 ++--
.../BUILD.bitflags-1.3.2.bazel | 9 +
.../BUILD.bitflags-2.9.1.bazel | 9 +
.../BUILD.borsh-1.5.7.bazel | 17 +-
.../BUILD.boxcar-0.2.13.bazel | 9 +
.../BUILD.bstr-1.11.3.bazel | 9 +
.../BUILD.bumpalo-3.19.0.bazel | 9 +
.../BUILD.bytemuck-1.21.0.bazel | 9 +
.../BUILD.byteorder-1.5.0.bazel | 83 ---
.../BUILD.camino-1.1.10.bazel | 17 +-
.../BUILD.cargo-platform-0.2.0.bazel | 9 +
.../BUILD.cargo-util-schemas-0.8.2.bazel | 9 +
.../BUILD.cargo_metadata-0.21.0.bazel | 11 +-
.../BUILD.cc-1.2.29.bazel | 9 +
.../BUILD.cfg-if-1.0.1.bazel | 9 +
.../BUILD.cfg_aliases-0.2.1.bazel | 9 +
.../BUILD.chalk-derive-0.103.0.bazel | 11 +-
...bazel => BUILD.chalk-derive-0.104.0.bazel} | 18 +-
.../BUILD.chalk-ir-0.103.0.bazel | 9 +
....35.bazel => BUILD.chalk-ir-0.104.0.bazel} | 26 +-
.../BUILD.chalk-recursive-0.103.0.bazel | 9 +
.../BUILD.chalk-solve-0.103.0.bazel | 9 +
.../BUILD.chrono-0.4.41.bazel | 9 +
...p-4.5.41.bazel => BUILD.clap-4.5.44.bazel} | 13 +-
....bazel => BUILD.clap_builder-4.5.44.bazel} | 11 +-
.../BUILD.clap_derive-4.5.41.bazel | 11 +-
.../BUILD.clap_lex-0.7.5.bazel | 9 +
.../BUILD.colorchoice-1.0.4.bazel | 9 +
.../BUILD.core-foundation-sys-0.8.7.bazel | 9 +
.../BUILD.countme-3.0.1.bazel | 9 +
.../BUILD.cov-mark-2.0.0.bazel | 9 +
.../BUILD.crc32fast-1.4.2.bazel | 9 +
.../BUILD.crossbeam-channel-0.5.15.bazel | 9 +
.../BUILD.crossbeam-deque-0.8.6.bazel | 9 +
.../BUILD.crossbeam-epoch-0.9.18.bazel | 9 +
.../BUILD.crossbeam-queue-0.3.12.bazel | 9 +
.../BUILD.crossbeam-utils-0.8.21.bazel | 17 +-
.../BUILD.darling-0.20.11.bazel | 9 +
.../BUILD.darling_core-0.20.11.bazel | 11 +-
.../BUILD.darling_macro-0.20.11.bazel | 9 +
.../BUILD.dashmap-6.1.0.bazel | 9 +
.../BUILD.deranged-0.4.0.bazel | 9 +
.../BUILD.displaydoc-0.2.5.bazel | 11 +-
.../BUILD.drop_bomb-0.1.5.bazel | 9 +
.../BUILD.dunce-1.0.5.bazel | 9 +
.../BUILD.dyn-clone-1.0.19.bazel | 9 +
.../BUILD.either-1.15.0.bazel | 9 +
.../BUILD.ena-0.14.3.bazel | 9 +
.../BUILD.encoding-0.2.33.bazel | 9 +
...encoding-index-japanese-1.20141219.5.bazel | 9 +
...D.encoding-index-korean-1.20141219.5.bazel | 9 +
...oding-index-simpchinese-1.20141219.5.bazel | 9 +
...coding-index-singlebyte-1.20141219.5.bazel | 9 +
...oding-index-tradchinese-1.20141219.5.bazel | 9 +
.../BUILD.encoding_index_tests-0.1.4.bazel | 9 +
.../BUILD.equivalent-1.0.2.bazel | 9 +
.../BUILD.erased-serde-0.4.6.bazel | 9 +
.../BUILD.figment-0.10.19.bazel | 17 +-
.../BUILD.filetime-0.2.25.bazel | 9 +
.../BUILD.fixedbitset-0.4.2.bazel | 9 +
.../BUILD.flate2-1.1.0.bazel | 9 +
.../BUILD.fnv-1.0.7.bazel | 9 +
.../BUILD.foldhash-0.1.5.bazel | 9 +
.../BUILD.form_urlencoded-1.2.1.bazel | 9 +
.../BUILD.fs-err-2.11.0.bazel | 17 +-
.../BUILD.fsevent-sys-4.1.0.bazel | 9 +
.../BUILD.fst-0.4.7.bazel | 17 +-
....3.1.bazel => BUILD.getrandom-0.3.3.bazel} | 62 +-
...lob-0.3.2.bazel => BUILD.glob-0.3.3.bazel} | 11 +-
.../BUILD.globset-0.4.15.bazel | 9 +
.../BUILD.hashbrown-0.12.3.bazel | 9 +
.../BUILD.hashbrown-0.14.5.bazel | 9 +
.../BUILD.hashbrown-0.15.4.bazel | 9 +
.../BUILD.hashlink-0.10.0.bazel | 9 +
.../BUILD.heck-0.5.0.bazel | 9 +
.../BUILD.hermit-abi-0.5.2.bazel | 9 +
.../BUILD.hex-0.4.3.bazel | 9 +
.../BUILD.home-0.5.11.bazel | 9 +
.../BUILD.iana-time-zone-0.1.63.bazel | 9 +
.../BUILD.iana-time-zone-haiku-0.1.2.bazel | 17 +-
.../BUILD.icu_collections-2.0.0.bazel | 9 +
.../BUILD.icu_locale_core-2.0.0.bazel | 9 +
.../BUILD.icu_normalizer-2.0.0.bazel | 9 +
.../BUILD.icu_normalizer_data-2.0.0.bazel | 17 +-
.../BUILD.icu_properties-2.0.1.bazel | 9 +
.../BUILD.icu_properties_data-2.0.1.bazel | 17 +-
.../BUILD.icu_provider-2.0.0.bazel | 9 +
.../BUILD.ident_case-1.0.1.bazel | 9 +
.../BUILD.idna-1.0.3.bazel | 9 +
.../BUILD.idna_adapter-1.2.1.bazel | 9 +
.../BUILD.indexmap-1.9.3.bazel | 17 +-
.../BUILD.indexmap-2.10.0.bazel | 9 +
.../BUILD.inlinable_string-0.1.15.bazel | 9 +
.../BUILD.inotify-0.11.0.bazel | 9 +
.../BUILD.inotify-sys-0.1.5.bazel | 9 +
.../BUILD.intrusive-collections-0.9.7.bazel | 9 +
.../BUILD.is_terminal_polyfill-1.70.1.bazel | 9 +
.../BUILD.itertools-0.12.1.bazel | 9 +
.../BUILD.itertools-0.14.0.bazel | 9 +
.../BUILD.itoa-1.0.15.bazel | 9 +
.../BUILD.jobserver-0.1.32.bazel | 9 +
.../BUILD.jod-thread-1.0.0.bazel | 9 +
.../BUILD.js-sys-0.3.77.bazel | 9 +
.../BUILD.kqueue-1.1.1.bazel | 9 +
.../BUILD.kqueue-sys-1.0.4.bazel | 9 +
.../BUILD.la-arena-0.3.1.bazel | 9 +
.../BUILD.lazy_static-1.5.0.bazel | 9 +
.../BUILD.libc-0.2.174.bazel | 17 +-
.../BUILD.libredox-0.1.4.bazel | 9 +
.../BUILD.line-index-0.1.2.bazel | 9 +
.../BUILD.litemap-0.8.0.bazel | 9 +
.../BUILD.lock_api-0.4.13.bazel | 17 +-
.../BUILD.log-0.3.9.bazel | 9 +
.../BUILD.log-0.4.27.bazel | 9 +
.../BUILD.matchers-0.1.0.bazel | 9 +
.../BUILD.memchr-2.7.5.bazel | 9 +
.../BUILD.memoffset-0.9.1.bazel | 17 +-
.../BUILD.miniz_oxide-0.8.5.bazel | 9 +
.../BUILD.mio-1.0.4.bazel | 9 +
.../BUILD.miow-0.6.0.bazel | 9 +
.../BUILD.mustache-0.9.0.bazel | 9 +
.../BUILD.nohash-hasher-0.2.0.bazel | 9 +
.../BUILD.notify-8.0.0.bazel | 9 +
.../BUILD.notify-types-2.0.0.bazel | 9 +
.../BUILD.nu-ansi-term-0.46.0.bazel | 9 +
.../BUILD.num-conv-0.1.0.bazel | 9 +
.../BUILD.num-traits-0.2.19.bazel | 17 +-
.../BUILD.num_cpus-1.17.0.bazel | 9 +
.../BUILD.once_cell-1.21.3.bazel | 9 +
.../BUILD.once_cell_polyfill-1.70.1.bazel | 9 +
.../BUILD.oorandom-11.1.5.bazel | 9 +
.../BUILD.ordered-float-2.10.1.bazel | 9 +
.../BUILD.os_str_bytes-7.0.0.bazel | 9 +
.../BUILD.overload-0.1.1.bazel | 9 +
.../BUILD.papaya-0.2.3.bazel | 9 +
.../BUILD.parking_lot-0.12.4.bazel | 9 +
.../BUILD.parking_lot_core-0.9.11.bazel | 17 +-
.../BUILD.pear-0.2.9.bazel | 9 +
.../BUILD.pear_codegen-0.2.9.bazel | 11 +-
.../BUILD.percent-encoding-2.3.1.bazel | 9 +
.../BUILD.perf-event-0.4.7.bazel | 9 +
.../BUILD.perf-event-open-sys-1.0.1.bazel | 9 +
.../BUILD.petgraph-0.6.5.bazel | 9 +
.../BUILD.pin-project-lite-0.2.16.bazel | 9 +
.../BUILD.pkg-config-0.3.32.bazel | 9 +
.../BUILD.portable-atomic-1.11.1.bazel | 17 +-
.../BUILD.potential_utf-0.1.2.bazel | 9 +
.../BUILD.powerfmt-0.2.0.bazel | 9 +
...20.bazel => BUILD.ppv-lite86-0.2.21.bazel} | 13 +-
...5.bazel => BUILD.proc-macro2-1.0.97.bazel} | 23 +-
...BUILD.proc-macro2-diagnostics-0.10.1.bazel | 19 +-
.../BUILD.quote-1.0.40.bazel | 11 +-
.../BUILD.r-efi-5.3.0.bazel | 92 +++
...el => BUILD.ra-ap-rustc_abi-0.123.0.bazel} | 19 +-
...=> BUILD.ra-ap-rustc_hashes-0.123.0.bazel} | 11 +-
... => BUILD.ra-ap-rustc_index-0.123.0.bazel} | 15 +-
...LD.ra-ap-rustc_index_macros-0.123.0.bazel} | 13 +-
... => BUILD.ra-ap-rustc_lexer-0.121.0.bazel} | 11 +-
.../BUILD.ra-ap-rustc_lexer-0.123.0.bazel | 97 +++
...LD.ra-ap-rustc_parse_format-0.121.0.bazel} | 17 +-
...a-ap-rustc_pattern_analysis-0.123.0.bazel} | 15 +-
...azel => BUILD.ra_ap_base_db-0.0.300.bazel} | 35 +-
...94.bazel => BUILD.ra_ap_cfg-0.0.300.bazel} | 19 +-
...azel => BUILD.ra_ap_edition-0.0.300.bazel} | 11 +-
...94.bazel => BUILD.ra_ap_hir-0.0.300.bazel} | 51 +-
...azel => BUILD.ra_ap_hir_def-0.0.300.bazel} | 55 +-
...l => BUILD.ra_ap_hir_expand-0.0.300.bazel} | 55 +-
...bazel => BUILD.ra_ap_hir_ty-0.0.300.bazel} | 49 +-
...bazel => BUILD.ra_ap_ide_db-0.0.300.bazel} | 47 +-
...bazel => BUILD.ra_ap_intern-0.0.300.bazel} | 11 +-
...l => BUILD.ra_ap_load-cargo-0.0.300.bazel} | 49 +-
...94.bazel => BUILD.ra_ap_mbe-0.0.300.bazel} | 37 +-
...bazel => BUILD.ra_ap_parser-0.0.300.bazel} | 17 +-
....bazel => BUILD.ra_ap_paths-0.0.300.bazel} | 11 +-
... BUILD.ra_ap_proc_macro_api-0.0.300.bazel} | 33 +-
...azel => BUILD.ra_ap_profile-0.0.300.bazel} | 11 +-
...> BUILD.ra_ap_project_model-0.0.300.bazel} | 44 +-
...ILD.ra_ap_query-group-macro-0.0.300.bazel} | 13 +-
...4.bazel => BUILD.ra_ap_span-0.0.300.bazel} | 23 +-
...4.bazel => BUILD.ra_ap_stdx-0.0.300.bazel} | 11 +-
...bazel => BUILD.ra_ap_syntax-0.0.300.bazel} | 19 +-
...> BUILD.ra_ap_syntax-bridge-0.0.300.bazel} | 35 +-
...el => BUILD.ra_ap_toolchain-0.0.300.bazel} | 11 +-
...294.bazel => BUILD.ra_ap_tt-0.0.300.bazel} | 21 +-
...94.bazel => BUILD.ra_ap_vfs-0.0.300.bazel} | 19 +-
...l => BUILD.ra_ap_vfs-notify-0.0.300.bazel} | 23 +-
...and-0.9.1.bazel => BUILD.rand-0.9.2.bazel} | 13 +-
.../BUILD.rand_chacha-0.9.0.bazel | 13 +-
....9.2.bazel => BUILD.rand_core-0.9.3.bazel} | 14 +-
.../BUILD.rayon-1.10.0.bazel | 9 +
.../BUILD.rayon-core-1.12.1.bazel | 17 +-
.../BUILD.redox_syscall-0.5.13.bazel | 9 +
.../BUILD.ref-cast-1.0.24.bazel | 17 +-
.../BUILD.ref-cast-impl-1.0.24.bazel | 11 +-
.../BUILD.regex-1.11.1.bazel | 9 +
.../BUILD.regex-automata-0.1.10.bazel | 9 +
.../BUILD.regex-automata-0.4.9.bazel | 9 +
.../BUILD.regex-syntax-0.6.29.bazel | 9 +
.../BUILD.regex-syntax-0.8.5.bazel | 9 +
.../BUILD.rowan-0.15.15.bazel | 9 +
.../BUILD.rustc-hash-1.1.0.bazel | 9 +
.../BUILD.rustc-hash-2.1.1.bazel | 9 +
.../BUILD.rustc-literal-escaper-0.0.2.bazel | 83 ---
.../BUILD.rustc-literal-escaper-0.0.4.bazel | 9 +
.../BUILD.rustc-stable-hash-0.1.2.bazel | 9 +
...ustc_apfloat-0.2.3+llvm-462a31f5a5ab.bazel | 17 +-
.../BUILD.rustversion-1.0.21.bazel | 17 +-
.../BUILD.ryu-1.0.20.bazel | 9 +
.../BUILD.salsa-0.23.0.bazel | 9 +
.../BUILD.salsa-macro-rules-0.23.0.bazel | 9 +
.../BUILD.salsa-macros-0.23.0.bazel | 11 +-
.../BUILD.same-file-1.0.6.bazel | 9 +
.../BUILD.schemars-0.9.0.bazel | 11 +-
.../BUILD.schemars-1.0.4.bazel | 11 +-
.../BUILD.scoped-tls-1.0.1.bazel | 9 +
.../BUILD.scopeguard-1.2.0.bazel | 9 +
.../BUILD.seize-0.5.0.bazel | 9 +
.../BUILD.semver-1.0.26.bazel | 17 +-
.../BUILD.serde-1.0.219.bazel | 17 +-
.../BUILD.serde-untagged-0.1.7.bazel | 9 +
.../BUILD.serde-value-0.7.0.bazel | 9 +
.../BUILD.serde_derive-1.0.219.bazel | 11 +-
...0.bazel => BUILD.serde_json-1.0.142.bazel} | 23 +-
.../BUILD.serde_spanned-0.6.9.bazel | 9 +
.../BUILD.serde_spanned-1.0.0.bazel | 9 +
.../BUILD.serde_with-3.14.0.bazel | 9 +
.../BUILD.serde_with_macros-3.14.0.bazel | 11 +-
.../BUILD.serde_yaml-0.9.34+deprecated.bazel | 9 +
.../BUILD.sharded-slab-0.1.7.bazel | 9 +
.../BUILD.shlex-1.3.0.bazel | 9 +
.../BUILD.smallvec-1.15.1.bazel | 9 +
.../BUILD.smol_str-0.3.2.bazel | 9 +
.../BUILD.stable_deref_trait-1.2.0.bazel | 9 +
.../BUILD.streaming-iterator-0.1.9.bazel | 9 +
.../BUILD.strsim-0.11.1.bazel | 9 +
.../BUILD.syn-2.0.104.bazel | 11 +-
.../BUILD.synstructure-0.13.2.bazel | 11 +-
....2.2.bazel => BUILD.temp-dir-0.1.16.bazel} | 18 +-
.../BUILD.text-size-1.1.1.bazel | 9 +
.../BUILD.thin-vec-0.2.14.bazel | 9 +
.../BUILD.thiserror-2.0.12.bazel | 17 +-
.../BUILD.thiserror-impl-2.0.12.bazel | 11 +-
.../BUILD.thread_local-1.1.8.bazel | 9 +
.../BUILD.time-0.3.41.bazel | 9 +
.../BUILD.time-core-0.1.4.bazel | 9 +
.../BUILD.time-macros-0.2.22.bazel | 9 +
.../BUILD.tinystr-0.8.1.bazel | 9 +
.../BUILD.toml-0.8.23.bazel | 9 +
...oml-0.9.2.bazel => BUILD.toml-0.9.5.bazel} | 13 +-
.../BUILD.toml_datetime-0.6.11.bazel | 9 +
.../BUILD.toml_datetime-0.7.0.bazel | 9 +
.../BUILD.toml_edit-0.22.27.bazel | 9 +
....1.bazel => BUILD.toml_parser-1.0.2.bazel} | 11 +-
.../BUILD.toml_write-0.1.2.bazel | 9 +
.../BUILD.toml_writer-1.0.2.bazel | 10 +-
.../BUILD.tracing-0.1.41.bazel | 9 +
.../BUILD.tracing-attributes-0.1.30.bazel | 11 +-
.../BUILD.tracing-core-0.1.34.bazel | 9 +
.../BUILD.tracing-flame-0.2.0.bazel | 9 +
.../BUILD.tracing-log-0.2.0.bazel | 9 +
.../BUILD.tracing-subscriber-0.3.19.bazel | 9 +
.../BUILD.tree-sitter-0.24.6.bazel | 17 +-
...tree-sitter-embedded-template-0.23.2.bazel | 17 +-
.../BUILD.tree-sitter-json-0.24.8.bazel | 17 +-
.../BUILD.tree-sitter-language-0.1.3.bazel | 9 +
.../BUILD.tree-sitter-ql-0.23.1.bazel | 17 +-
.../BUILD.tree-sitter-ruby-0.23.1.bazel | 17 +-
.../BUILD.triomphe-0.1.14.bazel | 9 +
.../BUILD.typed-arena-2.0.2.bazel | 9 +
.../BUILD.typeid-1.0.3.bazel | 17 +-
.../BUILD.uncased-0.9.10.bazel | 17 +-
.../BUILD.ungrammar-1.16.1.bazel | 9 +
.../BUILD.unicode-ident-1.0.18.bazel | 9 +
.../BUILD.unicode-properties-0.1.3.bazel | 9 +
.../BUILD.unicode-xid-0.2.6.bazel | 9 +
.../BUILD.unsafe-libyaml-0.2.11.bazel | 9 +
.../BUILD.url-2.5.4.bazel | 9 +
.../BUILD.utf8_iter-1.0.4.bazel | 9 +
.../BUILD.utf8parse-0.2.2.bazel | 9 +
.../BUILD.valuable-0.1.1.bazel | 17 +-
.../BUILD.version_check-0.9.5.bazel | 9 +
.../BUILD.walkdir-2.5.0.bazel | 9 +
...D.wasi-0.11.1+wasi-snapshot-preview1.bazel | 9 +
.../BUILD.wasi-0.14.2+wasi-0.2.4.bazel | 95 +++
.../BUILD.wasm-bindgen-0.2.100.bazel | 17 +-
.../BUILD.wasm-bindgen-backend-0.2.100.bazel | 11 +-
.../BUILD.wasm-bindgen-macro-0.2.100.bazel | 9 +
...D.wasm-bindgen-macro-support-0.2.100.bazel | 11 +-
.../BUILD.wasm-bindgen-shared-0.2.100.bazel | 17 +-
.../BUILD.winapi-0.3.9.bazel | 17 +-
...ILD.winapi-i686-pc-windows-gnu-0.4.0.bazel | 17 +-
.../BUILD.winapi-util-0.1.9.bazel | 9 +
...D.winapi-x86_64-pc-windows-gnu-0.4.0.bazel | 17 +-
.../BUILD.windows-core-0.61.2.bazel | 9 +
.../BUILD.windows-implement-0.60.0.bazel | 11 +-
.../BUILD.windows-interface-0.59.1.bazel | 11 +-
.../BUILD.windows-link-0.1.3.bazel | 9 +
.../BUILD.windows-result-0.3.4.bazel | 9 +
.../BUILD.windows-strings-0.4.2.bazel | 9 +
.../BUILD.windows-sys-0.48.0.bazel | 9 +
.../BUILD.windows-sys-0.52.0.bazel | 9 +
.../BUILD.windows-sys-0.59.0.bazel | 9 +
.../BUILD.windows-sys-0.60.2.bazel | 9 +
.../BUILD.windows-targets-0.48.5.bazel | 9 +
.../BUILD.windows-targets-0.52.6.bazel | 9 +
.../BUILD.windows-targets-0.53.2.bazel | 9 +
...BUILD.windows_aarch64_gnullvm-0.48.5.bazel | 17 +-
...BUILD.windows_aarch64_gnullvm-0.52.6.bazel | 17 +-
...BUILD.windows_aarch64_gnullvm-0.53.0.bazel | 17 +-
.../BUILD.windows_aarch64_msvc-0.48.5.bazel | 17 +-
.../BUILD.windows_aarch64_msvc-0.52.6.bazel | 17 +-
.../BUILD.windows_aarch64_msvc-0.53.0.bazel | 17 +-
.../BUILD.windows_i686_gnu-0.48.5.bazel | 17 +-
.../BUILD.windows_i686_gnu-0.52.6.bazel | 17 +-
.../BUILD.windows_i686_gnu-0.53.0.bazel | 17 +-
.../BUILD.windows_i686_gnullvm-0.52.6.bazel | 17 +-
.../BUILD.windows_i686_gnullvm-0.53.0.bazel | 17 +-
.../BUILD.windows_i686_msvc-0.48.5.bazel | 17 +-
.../BUILD.windows_i686_msvc-0.52.6.bazel | 17 +-
.../BUILD.windows_i686_msvc-0.53.0.bazel | 17 +-
.../BUILD.windows_x86_64_gnu-0.48.5.bazel | 17 +-
.../BUILD.windows_x86_64_gnu-0.52.6.bazel | 17 +-
.../BUILD.windows_x86_64_gnu-0.53.0.bazel | 17 +-
.../BUILD.windows_x86_64_gnullvm-0.48.5.bazel | 17 +-
.../BUILD.windows_x86_64_gnullvm-0.52.6.bazel | 17 +-
.../BUILD.windows_x86_64_gnullvm-0.53.0.bazel | 17 +-
.../BUILD.windows_x86_64_msvc-0.48.5.bazel | 17 +-
.../BUILD.windows_x86_64_msvc-0.52.6.bazel | 17 +-
.../BUILD.windows_x86_64_msvc-0.53.0.bazel | 17 +-
.../BUILD.winnow-0.7.11.bazel | 9 +
...azel => BUILD.wit-bindgen-rt-0.39.0.bazel} | 23 +-
.../BUILD.writeable-0.6.1.bazel | 9 +
.../BUILD.yansi-1.0.1.bazel | 9 +
.../BUILD.yoke-0.8.0.bazel | 9 +
.../BUILD.yoke-derive-0.8.0.bazel | 11 +-
...8.20.bazel => BUILD.zerocopy-0.8.26.bazel} | 29 +-
...zel => BUILD.zerocopy-derive-0.8.26.bazel} | 13 +-
.../BUILD.zerofrom-0.1.6.bazel | 9 +
.../BUILD.zerofrom-derive-0.1.6.bazel | 11 +-
.../BUILD.zerotrie-0.2.2.bazel | 9 +
.../BUILD.zerovec-0.11.2.bazel | 9 +
.../BUILD.zerovec-derive-0.11.1.bazel | 11 +-
.../BUILD.zstd-0.13.3.bazel | 9 +
.../BUILD.zstd-safe-7.2.4.bazel | 17 +-
.../BUILD.zstd-sys-2.0.15+zstd.1.5.7.bazel | 17 +-
.../tree_sitter_extractors_deps/defs.bzl | 682 +++++++++---------
363 files changed, 4755 insertions(+), 1037 deletions(-)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.anyhow-1.0.98.bazel => BUILD.anyhow-1.0.99.bazel} (92%)
delete mode 100644 misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.byteorder-1.5.0.bazel
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.zerocopy-derive-0.7.35.bazel => BUILD.chalk-derive-0.104.0.bazel} (89%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.zerocopy-0.7.35.bazel => BUILD.chalk-ir-0.104.0.bazel} (90%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.clap-4.5.41.bazel => BUILD.clap-4.5.44.bazel} (93%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.clap_builder-4.5.41.bazel => BUILD.clap_builder-4.5.44.bazel} (94%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.getrandom-0.3.1.bazel => BUILD.getrandom-0.3.3.bazel} (71%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.glob-0.3.2.bazel => BUILD.glob-0.3.3.bazel} (93%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ppv-lite86-0.2.20.bazel => BUILD.ppv-lite86-0.2.21.bazel} (92%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.proc-macro2-1.0.95.bazel => BUILD.proc-macro2-1.0.97.bazel} (92%)
create mode 100644 misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.r-efi-5.3.0.bazel
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_abi-0.116.0.bazel => BUILD.ra-ap-rustc_abi-0.123.0.bazel} (88%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_hashes-0.116.0.bazel => BUILD.ra-ap-rustc_hashes-0.123.0.bazel} (94%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_index-0.116.0.bazel => BUILD.ra-ap-rustc_index-0.123.0.bazel} (91%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_index_macros-0.116.0.bazel => BUILD.ra-ap-rustc_index_macros-0.123.0.bazel} (92%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_lexer-0.116.0.bazel => BUILD.ra-ap-rustc_lexer-0.121.0.bazel} (94%)
create mode 100644 misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.123.0.bazel
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_parse_format-0.116.0.bazel => BUILD.ra-ap-rustc_parse_format-0.121.0.bazel} (89%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra-ap-rustc_pattern_analysis-0.116.0.bazel => BUILD.ra-ap-rustc_pattern_analysis-0.123.0.bazel} (91%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_base_db-0.0.294.bazel => BUILD.ra_ap_base_db-0.0.300.bazel} (81%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_cfg-0.0.294.bazel => BUILD.ra_ap_cfg-0.0.300.bazel} (89%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_edition-0.0.294.bazel => BUILD.ra_ap_edition-0.0.300.bazel} (93%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_hir-0.0.294.bazel => BUILD.ra_ap_hir-0.0.300.bazel} (73%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_hir_def-0.0.294.bazel => BUILD.ra_ap_hir_def-0.0.300.bazel} (74%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_hir_expand-0.0.294.bazel => BUILD.ra_ap_hir_expand-0.0.300.bazel} (73%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_hir_ty-0.0.294.bazel => BUILD.ra_ap_hir_ty-0.0.300.bazel} (77%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_ide_db-0.0.294.bazel => BUILD.ra_ap_ide_db-0.0.300.bazel} (77%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_intern-0.0.294.bazel => BUILD.ra_ap_intern-0.0.300.bazel} (94%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_load-cargo-0.0.294.bazel => BUILD.ra_ap_load-cargo-0.0.300.bazel} (73%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_mbe-0.0.294.bazel => BUILD.ra_ap_mbe-0.0.300.bazel} (79%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_parser-0.0.294.bazel => BUILD.ra_ap_parser-0.0.300.bazel} (90%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_paths-0.0.294.bazel => BUILD.ra_ap_paths-0.0.300.bazel} (94%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_proc_macro_api-0.0.294.bazel => BUILD.ra_ap_proc_macro_api-0.0.300.bazel} (81%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_profile-0.0.294.bazel => BUILD.ra_ap_profile-0.0.300.bazel} (96%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_project_model-0.0.294.bazel => BUILD.ra_ap_project_model-0.0.300.bazel} (77%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_query-group-macro-0.0.294.bazel => BUILD.ra_ap_query-group-macro-0.0.300.bazel} (92%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_span-0.0.294.bazel => BUILD.ra_ap_span-0.0.300.bazel} (87%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_stdx-0.0.294.bazel => BUILD.ra_ap_stdx-0.0.300.bazel} (97%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_syntax-0.0.294.bazel => BUILD.ra_ap_syntax-0.0.300.bazel} (89%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_syntax-bridge-0.0.294.bazel => BUILD.ra_ap_syntax-bridge-0.0.300.bazel} (79%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_toolchain-0.0.294.bazel => BUILD.ra_ap_toolchain-0.0.300.bazel} (94%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_tt-0.0.294.bazel => BUILD.ra_ap_tt-0.0.300.bazel} (87%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_vfs-0.0.294.bazel => BUILD.ra_ap_vfs-0.0.300.bazel} (89%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.ra_ap_vfs-notify-0.0.294.bazel => BUILD.ra_ap_vfs-notify-0.0.300.bazel} (87%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.rand-0.9.1.bazel => BUILD.rand-0.9.2.bazel} (93%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.rand_core-0.9.2.bazel => BUILD.rand_core-0.9.3.bazel} (92%)
delete mode 100644 misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.2.bazel
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.serde_json-1.0.140.bazel => BUILD.serde_json-1.0.142.bazel} (92%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.wasi-0.13.3+wasi-0.2.2.bazel => BUILD.temp-dir-0.1.16.bazel} (92%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.toml-0.9.2.bazel => BUILD.toml-0.9.5.bazel} (93%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.toml_parser-1.0.1.bazel => BUILD.toml_parser-1.0.2.bazel} (94%)
create mode 100644 misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.14.2+wasi-0.2.4.bazel
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.wit-bindgen-rt-0.33.0.bazel => BUILD.wit-bindgen-rt-0.39.0.bazel} (91%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.zerocopy-0.8.20.bazel => BUILD.zerocopy-0.8.26.bazel} (90%)
rename misc/bazel/3rdparty/tree_sitter_extractors_deps/{BUILD.zerocopy-derive-0.8.20.bazel => BUILD.zerocopy-derive-0.8.26.bazel} (92%)
diff --git a/MODULE.bazel b/MODULE.bazel
index 65dc8d494be..e616f3e1fac 100644
--- a/MODULE.bazel
+++ b/MODULE.bazel
@@ -98,49 +98,49 @@ use_repo(
tree_sitter_extractors_deps = use_extension("//misc/bazel/3rdparty:tree_sitter_extractors_extension.bzl", "r")
use_repo(
tree_sitter_extractors_deps,
- "vendor_ts__anyhow-1.0.98",
+ "vendor_ts__anyhow-1.0.99",
"vendor_ts__argfile-0.2.1",
- "vendor_ts__chalk-ir-0.103.0",
+ "vendor_ts__chalk-ir-0.104.0",
"vendor_ts__chrono-0.4.41",
- "vendor_ts__clap-4.5.41",
+ "vendor_ts__clap-4.5.44",
"vendor_ts__dunce-1.0.5",
"vendor_ts__either-1.15.0",
"vendor_ts__encoding-0.2.33",
"vendor_ts__figment-0.10.19",
"vendor_ts__flate2-1.1.0",
- "vendor_ts__glob-0.3.2",
+ "vendor_ts__glob-0.3.3",
"vendor_ts__globset-0.4.15",
"vendor_ts__itertools-0.14.0",
"vendor_ts__lazy_static-1.5.0",
"vendor_ts__mustache-0.9.0",
"vendor_ts__num-traits-0.2.19",
"vendor_ts__num_cpus-1.17.0",
- "vendor_ts__proc-macro2-1.0.95",
+ "vendor_ts__proc-macro2-1.0.97",
"vendor_ts__quote-1.0.40",
- "vendor_ts__ra_ap_base_db-0.0.294",
- "vendor_ts__ra_ap_cfg-0.0.294",
- "vendor_ts__ra_ap_hir-0.0.294",
- "vendor_ts__ra_ap_hir_def-0.0.294",
- "vendor_ts__ra_ap_hir_expand-0.0.294",
- "vendor_ts__ra_ap_hir_ty-0.0.294",
- "vendor_ts__ra_ap_ide_db-0.0.294",
- "vendor_ts__ra_ap_intern-0.0.294",
- "vendor_ts__ra_ap_load-cargo-0.0.294",
- "vendor_ts__ra_ap_parser-0.0.294",
- "vendor_ts__ra_ap_paths-0.0.294",
- "vendor_ts__ra_ap_project_model-0.0.294",
- "vendor_ts__ra_ap_span-0.0.294",
- "vendor_ts__ra_ap_stdx-0.0.294",
- "vendor_ts__ra_ap_syntax-0.0.294",
- "vendor_ts__ra_ap_vfs-0.0.294",
- "vendor_ts__rand-0.9.1",
+ "vendor_ts__ra_ap_base_db-0.0.300",
+ "vendor_ts__ra_ap_cfg-0.0.300",
+ "vendor_ts__ra_ap_hir-0.0.300",
+ "vendor_ts__ra_ap_hir_def-0.0.300",
+ "vendor_ts__ra_ap_hir_expand-0.0.300",
+ "vendor_ts__ra_ap_hir_ty-0.0.300",
+ "vendor_ts__ra_ap_ide_db-0.0.300",
+ "vendor_ts__ra_ap_intern-0.0.300",
+ "vendor_ts__ra_ap_load-cargo-0.0.300",
+ "vendor_ts__ra_ap_parser-0.0.300",
+ "vendor_ts__ra_ap_paths-0.0.300",
+ "vendor_ts__ra_ap_project_model-0.0.300",
+ "vendor_ts__ra_ap_span-0.0.300",
+ "vendor_ts__ra_ap_stdx-0.0.300",
+ "vendor_ts__ra_ap_syntax-0.0.300",
+ "vendor_ts__ra_ap_vfs-0.0.300",
+ "vendor_ts__rand-0.9.2",
"vendor_ts__rayon-1.10.0",
"vendor_ts__regex-1.11.1",
"vendor_ts__serde-1.0.219",
- "vendor_ts__serde_json-1.0.140",
+ "vendor_ts__serde_json-1.0.142",
"vendor_ts__serde_with-3.14.0",
"vendor_ts__syn-2.0.104",
- "vendor_ts__toml-0.9.2",
+ "vendor_ts__toml-0.9.5",
"vendor_ts__tracing-0.1.41",
"vendor_ts__tracing-flame-0.2.0",
"vendor_ts__tracing-subscriber-0.3.19",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.adler2-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.adler2-2.0.0.bazel
index 81739eb2c5a..5ee0a08f4c7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.adler2-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.adler2-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "adler2",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.aho-corasick-1.1.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.aho-corasick-1.1.3.bazel
index 2132ca53645..6d911d0cd9f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.aho-corasick-1.1.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.aho-corasick-1.1.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "aho_corasick",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.allocator-api2-0.2.21.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.allocator-api2-0.2.21.bazel
index 4d4616ad049..043bb8717df 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.allocator-api2-0.2.21.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.allocator-api2-0.2.21.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "allocator_api2",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android-tzdata-0.1.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android-tzdata-0.1.1.bazel
index c8da7a4f6e9..8a7e7f71b1f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android-tzdata-0.1.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android-tzdata-0.1.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "android_tzdata",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android_system_properties-0.1.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android_system_properties-0.1.5.bazel
index 2063ae43393..0d633d276d5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android_system_properties-0.1.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.android_system_properties-0.1.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "android_system_properties",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstream-0.6.19.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstream-0.6.19.bazel
index be3ff03ea10..efabc537139 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstream-0.6.19.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstream-0.6.19.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "anstream",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-1.0.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-1.0.11.bazel
index e7bc9599432..0680166780b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-1.0.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-1.0.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "anstyle",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-parse-0.2.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-parse-0.2.7.bazel
index 5a872223e57..ac933291b6a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-parse-0.2.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-parse-0.2.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "anstyle_parse",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-query-1.1.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-query-1.1.3.bazel
index 9c8ca69c641..04bdb7d5536 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-query-1.1.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-query-1.1.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "anstyle_query",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-wincon-3.0.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-wincon-3.0.9.bazel
index 771e6b35222..acb0616902e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-wincon-3.0.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anstyle-wincon-3.0.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "anstyle_wincon",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anyhow-1.0.98.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anyhow-1.0.99.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anyhow-1.0.98.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anyhow-1.0.99.bazel
index a73766e27bb..cdcb7d554a2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anyhow-1.0.98.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.anyhow-1.0.99.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "anyhow",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,9 +96,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "1.0.98",
+ version = "1.0.99",
deps = [
- "@vendor_ts__anyhow-1.0.98//:build_script_build",
+ "@vendor_ts__anyhow-1.0.99//:build_script_build",
],
)
@@ -129,6 +141,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "anyhow",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -139,7 +154,7 @@ cargo_build_script(
"noclippy",
"norustfmt",
],
- version = "1.0.98",
+ version = "1.0.99",
visibility = ["//visibility:private"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.argfile-0.2.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.argfile-0.2.1.bazel
index b2fff86bc5d..c28444a73c1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.argfile-0.2.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.argfile-0.2.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "argfile",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.arrayvec-0.7.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.arrayvec-0.7.6.bazel
index 33d28adc8ff..92ffe37c58b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.arrayvec-0.7.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.arrayvec-0.7.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "arrayvec",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.atomic-0.6.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.atomic-0.6.0.bazel
index fb24bd230ee..4cb9d323813 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.atomic-0.6.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.atomic-0.6.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "atomic",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.autocfg-1.5.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.autocfg-1.5.0.bazel
index 2fb8648afd5..66631184b2f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.autocfg-1.5.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.autocfg-1.5.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "autocfg",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.base64-0.22.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.base64-0.22.1.bazel
index ccc362c006d..dc8e3b89124 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.base64-0.22.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.base64-0.22.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "base64",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bazel
index df3166a9673..df61c70b249 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bazel
@@ -32,14 +32,14 @@ filegroup(
# Workspace Member Dependencies
alias(
- name = "anyhow-1.0.98",
- actual = "@vendor_ts__anyhow-1.0.98//:anyhow",
+ name = "anyhow-1.0.99",
+ actual = "@vendor_ts__anyhow-1.0.99//:anyhow",
tags = ["manual"],
)
alias(
name = "anyhow",
- actual = "@vendor_ts__anyhow-1.0.98//:anyhow",
+ actual = "@vendor_ts__anyhow-1.0.99//:anyhow",
tags = ["manual"],
)
@@ -56,14 +56,14 @@ alias(
)
alias(
- name = "chalk-ir-0.103.0",
- actual = "@vendor_ts__chalk-ir-0.103.0//:chalk_ir",
+ name = "chalk-ir-0.104.0",
+ actual = "@vendor_ts__chalk-ir-0.104.0//:chalk_ir",
tags = ["manual"],
)
alias(
name = "chalk-ir",
- actual = "@vendor_ts__chalk-ir-0.103.0//:chalk_ir",
+ actual = "@vendor_ts__chalk-ir-0.104.0//:chalk_ir",
tags = ["manual"],
)
@@ -80,14 +80,14 @@ alias(
)
alias(
- name = "clap-4.5.41",
- actual = "@vendor_ts__clap-4.5.41//:clap",
+ name = "clap-4.5.44",
+ actual = "@vendor_ts__clap-4.5.44//:clap",
tags = ["manual"],
)
alias(
name = "clap",
- actual = "@vendor_ts__clap-4.5.41//:clap",
+ actual = "@vendor_ts__clap-4.5.44//:clap",
tags = ["manual"],
)
@@ -152,14 +152,14 @@ alias(
)
alias(
- name = "glob-0.3.2",
- actual = "@vendor_ts__glob-0.3.2//:glob",
+ name = "glob-0.3.3",
+ actual = "@vendor_ts__glob-0.3.3//:glob",
tags = ["manual"],
)
alias(
name = "glob",
- actual = "@vendor_ts__glob-0.3.2//:glob",
+ actual = "@vendor_ts__glob-0.3.3//:glob",
tags = ["manual"],
)
@@ -236,14 +236,14 @@ alias(
)
alias(
- name = "proc-macro2-1.0.95",
- actual = "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ name = "proc-macro2-1.0.97",
+ actual = "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
tags = ["manual"],
)
alias(
name = "proc-macro2",
- actual = "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ actual = "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
tags = ["manual"],
)
@@ -260,212 +260,212 @@ alias(
)
alias(
- name = "ra_ap_base_db-0.0.294",
- actual = "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
+ name = "ra_ap_base_db-0.0.300",
+ actual = "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
tags = ["manual"],
)
alias(
name = "ra_ap_base_db",
- actual = "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
+ actual = "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
tags = ["manual"],
)
alias(
- name = "ra_ap_cfg-0.0.294",
- actual = "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
+ name = "ra_ap_cfg-0.0.300",
+ actual = "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
tags = ["manual"],
)
alias(
name = "ra_ap_cfg",
- actual = "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
+ actual = "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
tags = ["manual"],
)
alias(
- name = "ra_ap_hir-0.0.294",
- actual = "@vendor_ts__ra_ap_hir-0.0.294//:ra_ap_hir",
+ name = "ra_ap_hir-0.0.300",
+ actual = "@vendor_ts__ra_ap_hir-0.0.300//:ra_ap_hir",
tags = ["manual"],
)
alias(
name = "ra_ap_hir",
- actual = "@vendor_ts__ra_ap_hir-0.0.294//:ra_ap_hir",
+ actual = "@vendor_ts__ra_ap_hir-0.0.300//:ra_ap_hir",
tags = ["manual"],
)
alias(
- name = "ra_ap_hir_def-0.0.294",
- actual = "@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def",
+ name = "ra_ap_hir_def-0.0.300",
+ actual = "@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def",
tags = ["manual"],
)
alias(
name = "ra_ap_hir_def",
- actual = "@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def",
+ actual = "@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def",
tags = ["manual"],
)
alias(
- name = "ra_ap_hir_expand-0.0.294",
- actual = "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand",
+ name = "ra_ap_hir_expand-0.0.300",
+ actual = "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand",
tags = ["manual"],
)
alias(
name = "ra_ap_hir_expand",
- actual = "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand",
+ actual = "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand",
tags = ["manual"],
)
alias(
- name = "ra_ap_hir_ty-0.0.294",
- actual = "@vendor_ts__ra_ap_hir_ty-0.0.294//:ra_ap_hir_ty",
+ name = "ra_ap_hir_ty-0.0.300",
+ actual = "@vendor_ts__ra_ap_hir_ty-0.0.300//:ra_ap_hir_ty",
tags = ["manual"],
)
alias(
name = "ra_ap_hir_ty",
- actual = "@vendor_ts__ra_ap_hir_ty-0.0.294//:ra_ap_hir_ty",
+ actual = "@vendor_ts__ra_ap_hir_ty-0.0.300//:ra_ap_hir_ty",
tags = ["manual"],
)
alias(
- name = "ra_ap_ide_db-0.0.294",
- actual = "@vendor_ts__ra_ap_ide_db-0.0.294//:ra_ap_ide_db",
+ name = "ra_ap_ide_db-0.0.300",
+ actual = "@vendor_ts__ra_ap_ide_db-0.0.300//:ra_ap_ide_db",
tags = ["manual"],
)
alias(
name = "ra_ap_ide_db",
- actual = "@vendor_ts__ra_ap_ide_db-0.0.294//:ra_ap_ide_db",
+ actual = "@vendor_ts__ra_ap_ide_db-0.0.300//:ra_ap_ide_db",
tags = ["manual"],
)
alias(
- name = "ra_ap_intern-0.0.294",
- actual = "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
+ name = "ra_ap_intern-0.0.300",
+ actual = "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
tags = ["manual"],
)
alias(
name = "ra_ap_intern",
- actual = "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
+ actual = "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
tags = ["manual"],
)
alias(
- name = "ra_ap_load-cargo-0.0.294",
- actual = "@vendor_ts__ra_ap_load-cargo-0.0.294//:ra_ap_load_cargo",
+ name = "ra_ap_load-cargo-0.0.300",
+ actual = "@vendor_ts__ra_ap_load-cargo-0.0.300//:ra_ap_load_cargo",
tags = ["manual"],
)
alias(
name = "ra_ap_load-cargo",
- actual = "@vendor_ts__ra_ap_load-cargo-0.0.294//:ra_ap_load_cargo",
+ actual = "@vendor_ts__ra_ap_load-cargo-0.0.300//:ra_ap_load_cargo",
tags = ["manual"],
)
alias(
- name = "ra_ap_parser-0.0.294",
- actual = "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
+ name = "ra_ap_parser-0.0.300",
+ actual = "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
tags = ["manual"],
)
alias(
name = "ra_ap_parser",
- actual = "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
+ actual = "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
tags = ["manual"],
)
alias(
- name = "ra_ap_paths-0.0.294",
- actual = "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths",
+ name = "ra_ap_paths-0.0.300",
+ actual = "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths",
tags = ["manual"],
)
alias(
name = "ra_ap_paths",
- actual = "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths",
+ actual = "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths",
tags = ["manual"],
)
alias(
- name = "ra_ap_project_model-0.0.294",
- actual = "@vendor_ts__ra_ap_project_model-0.0.294//:ra_ap_project_model",
+ name = "ra_ap_project_model-0.0.300",
+ actual = "@vendor_ts__ra_ap_project_model-0.0.300//:ra_ap_project_model",
tags = ["manual"],
)
alias(
name = "ra_ap_project_model",
- actual = "@vendor_ts__ra_ap_project_model-0.0.294//:ra_ap_project_model",
+ actual = "@vendor_ts__ra_ap_project_model-0.0.300//:ra_ap_project_model",
tags = ["manual"],
)
alias(
- name = "ra_ap_span-0.0.294",
- actual = "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
+ name = "ra_ap_span-0.0.300",
+ actual = "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
tags = ["manual"],
)
alias(
name = "ra_ap_span",
- actual = "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
+ actual = "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
tags = ["manual"],
)
alias(
- name = "ra_ap_stdx-0.0.294",
- actual = "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
+ name = "ra_ap_stdx-0.0.300",
+ actual = "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
tags = ["manual"],
)
alias(
- name = "stdx-0.0.294",
- actual = "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
+ name = "stdx-0.0.300",
+ actual = "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
tags = ["manual"],
)
alias(
name = "stdx",
- actual = "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
+ actual = "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
tags = ["manual"],
)
alias(
- name = "ra_ap_syntax-0.0.294",
- actual = "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
+ name = "ra_ap_syntax-0.0.300",
+ actual = "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
tags = ["manual"],
)
alias(
name = "ra_ap_syntax",
- actual = "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
+ actual = "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
tags = ["manual"],
)
alias(
- name = "ra_ap_vfs-0.0.294",
- actual = "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
+ name = "ra_ap_vfs-0.0.300",
+ actual = "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
tags = ["manual"],
)
alias(
name = "ra_ap_vfs",
- actual = "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
+ actual = "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
tags = ["manual"],
)
alias(
- name = "rand-0.9.1",
- actual = "@vendor_ts__rand-0.9.1//:rand",
+ name = "rand-0.9.2",
+ actual = "@vendor_ts__rand-0.9.2//:rand",
tags = ["manual"],
)
alias(
name = "rand",
- actual = "@vendor_ts__rand-0.9.1//:rand",
+ actual = "@vendor_ts__rand-0.9.2//:rand",
tags = ["manual"],
)
@@ -506,14 +506,14 @@ alias(
)
alias(
- name = "serde_json-1.0.140",
- actual = "@vendor_ts__serde_json-1.0.140//:serde_json",
+ name = "serde_json-1.0.142",
+ actual = "@vendor_ts__serde_json-1.0.142//:serde_json",
tags = ["manual"],
)
alias(
name = "serde_json",
- actual = "@vendor_ts__serde_json-1.0.140//:serde_json",
+ actual = "@vendor_ts__serde_json-1.0.142//:serde_json",
tags = ["manual"],
)
@@ -542,14 +542,14 @@ alias(
)
alias(
- name = "toml-0.9.2",
- actual = "@vendor_ts__toml-0.9.2//:toml",
+ name = "toml-0.9.5",
+ actual = "@vendor_ts__toml-0.9.5//:toml",
tags = ["manual"],
)
alias(
name = "toml",
- actual = "@vendor_ts__toml-0.9.2//:toml",
+ actual = "@vendor_ts__toml-0.9.5//:toml",
tags = ["manual"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-1.3.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-1.3.2.bazel
index 0746269ac7a..951fa2156eb 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-1.3.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-1.3.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "bitflags",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-2.9.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-2.9.1.bazel
index f3f2b4bd254..fbb0a5c3656 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-2.9.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bitflags-2.9.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "bitflags",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.borsh-1.5.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.borsh-1.5.7.bazel
index 7e848f9a02d..f1cef840bb8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.borsh-1.5.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.borsh-1.5.7.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "borsh",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "borsh",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.boxcar-0.2.13.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.boxcar-0.2.13.bazel
index 4c7c453d12b..ac24b2ad629 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.boxcar-0.2.13.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.boxcar-0.2.13.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "boxcar",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bstr-1.11.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bstr-1.11.3.bazel
index 052150604e8..1793e0d7dae 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bstr-1.11.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bstr-1.11.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "bstr",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bumpalo-3.19.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bumpalo-3.19.0.bazel
index 9cbb1677bb3..8b8e7285990 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bumpalo-3.19.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bumpalo-3.19.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "bumpalo",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bytemuck-1.21.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bytemuck-1.21.0.bazel
index 72df549196e..cf7710e627d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bytemuck-1.21.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.bytemuck-1.21.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "bytemuck",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.byteorder-1.5.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.byteorder-1.5.0.bazel
deleted file mode 100644
index d4e76414876..00000000000
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.byteorder-1.5.0.bazel
+++ /dev/null
@@ -1,83 +0,0 @@
-###############################################################################
-# @generated
-# DO NOT MODIFY: This file is auto-generated by a crate_universe tool. To
-# regenerate this file, run the following:
-#
-# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
-###############################################################################
-
-load("@rules_rust//rust:defs.bzl", "rust_library")
-
-package(default_visibility = ["//visibility:public"])
-
-rust_library(
- name = "byteorder",
- srcs = glob(
- include = ["**/*.rs"],
- allow_empty = True,
- ),
- compile_data = glob(
- include = ["**"],
- allow_empty = True,
- exclude = [
- "**/* *",
- ".tmp_git_root/**/*",
- "BUILD",
- "BUILD.bazel",
- "WORKSPACE",
- "WORKSPACE.bazel",
- ],
- ),
- crate_root = "src/lib.rs",
- edition = "2021",
- rustc_flags = [
- "--cap-lints=allow",
- ],
- tags = [
- "cargo-bazel",
- "crate-name=byteorder",
- "manual",
- "noclippy",
- "norustfmt",
- ],
- target_compatible_with = select({
- "@rules_rust//rust/platform:aarch64-apple-darwin": [],
- "@rules_rust//rust/platform:aarch64-apple-ios": [],
- "@rules_rust//rust/platform:aarch64-apple-ios-sim": [],
- "@rules_rust//rust/platform:aarch64-linux-android": [],
- "@rules_rust//rust/platform:aarch64-pc-windows-msvc": [],
- "@rules_rust//rust/platform:aarch64-unknown-fuchsia": [],
- "@rules_rust//rust/platform:aarch64-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu": [],
- "@rules_rust//rust/platform:aarch64-unknown-nto-qnx710": [],
- "@rules_rust//rust/platform:aarch64-unknown-uefi": [],
- "@rules_rust//rust/platform:arm-unknown-linux-gnueabi": [],
- "@rules_rust//rust/platform:armv7-linux-androideabi": [],
- "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi": [],
- "@rules_rust//rust/platform:i686-apple-darwin": [],
- "@rules_rust//rust/platform:i686-linux-android": [],
- "@rules_rust//rust/platform:i686-pc-windows-msvc": [],
- "@rules_rust//rust/platform:i686-unknown-freebsd": [],
- "@rules_rust//rust/platform:i686-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:powerpc-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:riscv32imc-unknown-none-elf": [],
- "@rules_rust//rust/platform:riscv64gc-unknown-none-elf": [],
- "@rules_rust//rust/platform:s390x-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:thumbv7em-none-eabi": [],
- "@rules_rust//rust/platform:thumbv8m.main-none-eabi": [],
- "@rules_rust//rust/platform:wasm32-unknown-unknown": [],
- "@rules_rust//rust/platform:wasm32-wasip1": [],
- "@rules_rust//rust/platform:x86_64-apple-darwin": [],
- "@rules_rust//rust/platform:x86_64-apple-ios": [],
- "@rules_rust//rust/platform:x86_64-linux-android": [],
- "@rules_rust//rust/platform:x86_64-pc-windows-msvc": [],
- "@rules_rust//rust/platform:x86_64-unknown-freebsd": [],
- "@rules_rust//rust/platform:x86_64-unknown-fuchsia": [],
- "@rules_rust//rust/platform:x86_64-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu": [],
- "@rules_rust//rust/platform:x86_64-unknown-none": [],
- "@rules_rust//rust/platform:x86_64-unknown-uefi": [],
- "//conditions:default": ["@platforms//:incompatible"],
- }),
- version = "1.5.0",
-)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.camino-1.1.10.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.camino-1.1.10.bazel
index 98c88b9375e..f7df381842e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.camino-1.1.10.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.camino-1.1.10.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "camino",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -130,6 +142,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "camino",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-platform-0.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-platform-0.2.0.bazel
index 884bfd80837..bde1a5698f5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-platform-0.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-platform-0.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cargo_platform",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-util-schemas-0.8.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-util-schemas-0.8.2.bazel
index f5646c65b51..a4d476d9ad9 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-util-schemas-0.8.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo-util-schemas-0.8.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cargo_util_schemas",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo_metadata-0.21.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo_metadata-0.21.0.bazel
index fc0229a7f84..37ecc0be0e0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo_metadata-0.21.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cargo_metadata-0.21.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cargo_metadata",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -89,7 +98,7 @@ rust_library(
"@vendor_ts__cargo-util-schemas-0.8.2//:cargo_util_schemas",
"@vendor_ts__semver-1.0.26//:semver",
"@vendor_ts__serde-1.0.219//:serde",
- "@vendor_ts__serde_json-1.0.140//:serde_json",
+ "@vendor_ts__serde_json-1.0.142//:serde_json",
"@vendor_ts__thiserror-2.0.12//:thiserror",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cc-1.2.29.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cc-1.2.29.bazel
index 51f4136d1a1..94f1085dc75 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cc-1.2.29.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cc-1.2.29.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cc",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg-if-1.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg-if-1.0.1.bazel
index ad6a15b046e..3c46f710630 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg-if-1.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg-if-1.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cfg_if",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg_aliases-0.2.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg_aliases-0.2.1.bazel
index 2ea050c6839..045b9c7d3e1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg_aliases-0.2.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cfg_aliases-0.2.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cfg_aliases",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.103.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.103.0.bazel
index 94432c0b330..43156f3cd95 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.103.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.103.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "chalk_derive",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.103.0",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
"@vendor_ts__synstructure-0.13.2//:synstructure",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.7.35.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.104.0.bazel
similarity index 89%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.7.35.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.104.0.bazel
index b6addfd7256..b37413cd6c0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.7.35.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-derive-0.104.0.bazel
@@ -6,12 +6,18 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
- name = "zerocopy_derive",
+ name = "chalk_derive",
srcs = glob(
include = ["**/*.rs"],
allow_empty = True,
@@ -30,12 +36,15 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
tags = [
"cargo-bazel",
- "crate-name=zerocopy-derive",
+ "crate-name=chalk-derive",
"manual",
"noclippy",
"norustfmt",
@@ -79,10 +88,11 @@ rust_proc_macro(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.7.35",
+ version = "0.104.0",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
+ "@vendor_ts__synstructure-0.13.2//:synstructure",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.103.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.103.0.bazel
index de782121b24..1e3c900ab90 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.103.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.103.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "chalk_ir",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__chalk-derive-0.103.0//:chalk_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.7.35.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.104.0.bazel
similarity index 90%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.7.35.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.104.0.bazel
index 04a723e7bd5..16b835996d6 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.7.35.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-ir-0.104.0.bazel
@@ -6,12 +6,18 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
- name = "zerocopy",
+ name = "chalk_ir",
srcs = glob(
include = ["**/*.rs"],
allow_empty = True,
@@ -28,24 +34,20 @@ rust_library(
"WORKSPACE.bazel",
],
),
- crate_features = [
- "byteorder",
- "default",
- "derive",
- "simd",
- "zerocopy-derive",
- ],
crate_root = "src/lib.rs",
edition = "2018",
proc_macro_deps = [
- "@vendor_ts__zerocopy-derive-0.7.35//:zerocopy_derive",
+ "@vendor_ts__chalk-derive-0.104.0//:chalk_derive",
+ ],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
],
rustc_flags = [
"--cap-lints=allow",
],
tags = [
"cargo-bazel",
- "crate-name=zerocopy",
+ "crate-name=chalk-ir",
"manual",
"noclippy",
"norustfmt",
@@ -89,8 +91,8 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.7.35",
+ version = "0.104.0",
deps = [
- "@vendor_ts__byteorder-1.5.0//:byteorder",
+ "@vendor_ts__bitflags-2.9.1//:bitflags",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-recursive-0.103.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-recursive-0.103.0.bazel
index fc517c41574..a8959b395ef 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-recursive-0.103.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-recursive-0.103.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "chalk_recursive",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__chalk-derive-0.103.0//:chalk_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-solve-0.103.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-solve-0.103.0.bazel
index dd409a748c8..4966053d4f3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-solve-0.103.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chalk-solve-0.103.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "chalk_solve",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__chalk-derive-0.103.0//:chalk_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chrono-0.4.41.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chrono-0.4.41.bazel
index 1e98ae71ac5..c96eee26669 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chrono-0.4.41.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.chrono-0.4.41.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "chrono",
srcs = glob(
@@ -46,6 +52,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap-4.5.41.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap-4.5.44.bazel
similarity index 93%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap-4.5.41.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap-4.5.44.bazel
index 80bdcb9866d..df9619c99ea 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap-4.5.41.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap-4.5.44.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "clap",
srcs = glob(
@@ -43,6 +49,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__clap_derive-4.5.41//:clap_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -92,8 +101,8 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "4.5.41",
+ version = "4.5.44",
deps = [
- "@vendor_ts__clap_builder-4.5.41//:clap_builder",
+ "@vendor_ts__clap_builder-4.5.44//:clap_builder",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_builder-4.5.41.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_builder-4.5.44.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_builder-4.5.41.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_builder-4.5.44.bazel
index 4ab8f147d5c..639d48d4637 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_builder-4.5.41.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_builder-4.5.44.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "clap_builder",
srcs = glob(
@@ -38,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -87,7 +96,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "4.5.41",
+ version = "4.5.44",
deps = [
"@vendor_ts__anstream-0.6.19//:anstream",
"@vendor_ts__anstyle-1.0.11//:anstyle",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_derive-4.5.41.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_derive-4.5.41.bazel
index 817a7c4c469..177f948947f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_derive-4.5.41.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_derive-4.5.41.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "clap_derive",
srcs = glob(
@@ -33,6 +39,9 @@ rust_proc_macro(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -85,7 +94,7 @@ rust_proc_macro(
version = "4.5.41",
deps = [
"@vendor_ts__heck-0.5.0//:heck",
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_lex-0.7.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_lex-0.7.5.bazel
index 452a009728f..1762f5e8514 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_lex-0.7.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.clap_lex-0.7.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "clap_lex",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.colorchoice-1.0.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.colorchoice-1.0.4.bazel
index 2c240f27082..19f14814c6b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.colorchoice-1.0.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.colorchoice-1.0.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "colorchoice",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.core-foundation-sys-0.8.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.core-foundation-sys-0.8.7.bazel
index 5f7d2dfb796..961ed6da5a7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.core-foundation-sys-0.8.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.core-foundation-sys-0.8.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "core_foundation_sys",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.countme-3.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.countme-3.0.1.bazel
index 1d1219daec5..3d52a6a65d2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.countme-3.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.countme-3.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "countme",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cov-mark-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cov-mark-2.0.0.bazel
index 795d6a6f377..3c562e624d0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cov-mark-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.cov-mark-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "cov_mark",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crc32fast-1.4.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crc32fast-1.4.2.bazel
index 02693983763..24f106b3eda 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crc32fast-1.4.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crc32fast-1.4.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "crc32fast",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-channel-0.5.15.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-channel-0.5.15.bazel
index cec59335032..8d06af4b20d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-channel-0.5.15.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-channel-0.5.15.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "crossbeam_channel",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-deque-0.8.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-deque-0.8.6.bazel
index 3bb0e6f18ea..275da3cb388 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-deque-0.8.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-deque-0.8.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "crossbeam_deque",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-epoch-0.9.18.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-epoch-0.9.18.bazel
index 76d404fae87..ca30e79b83e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-epoch-0.9.18.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-epoch-0.9.18.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "crossbeam_epoch",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-queue-0.3.12.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-queue-0.3.12.bazel
index 000ff3e1c07..2de25a15e6c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-queue-0.3.12.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-queue-0.3.12.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "crossbeam_queue",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-utils-0.8.21.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-utils-0.8.21.bazel
index 4c738272e68..5efee8b6bd1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-utils-0.8.21.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.crossbeam-utils-0.8.21.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "crossbeam_utils",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -129,6 +141,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "crossbeam-utils",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling-0.20.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling-0.20.11.bazel
index d95e83f5e2d..57a23dfb80e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling-0.20.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling-0.20.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "darling",
srcs = glob(
@@ -37,6 +43,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__darling_macro-0.20.11//:darling_macro",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_core-0.20.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_core-0.20.11.bazel
index 11b4c8a57d3..3f33e24ebe2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_core-0.20.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_core-0.20.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "darling_core",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -87,7 +96,7 @@ rust_library(
deps = [
"@vendor_ts__fnv-1.0.7//:fnv",
"@vendor_ts__ident_case-1.0.1//:ident_case",
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__strsim-0.11.1//:strsim",
"@vendor_ts__syn-2.0.104//:syn",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_macro-0.20.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_macro-0.20.11.bazel
index ea316fe5316..f4d01d9198e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_macro-0.20.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.darling_macro-0.20.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "darling_macro",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dashmap-6.1.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dashmap-6.1.0.bazel
index 51f50afa5a4..e4f933a3d51 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dashmap-6.1.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dashmap-6.1.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "dashmap",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.deranged-0.4.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.deranged-0.4.0.bazel
index 84300161e03..c25fab4a1ad 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.deranged-0.4.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.deranged-0.4.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "deranged",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.displaydoc-0.2.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.displaydoc-0.2.5.bazel
index 8bad701502d..7c6b8f96bbf 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.displaydoc-0.2.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.displaydoc-0.2.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "displaydoc",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.2.5",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.drop_bomb-0.1.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.drop_bomb-0.1.5.bazel
index c50dbdde29d..e1753384d51 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.drop_bomb-0.1.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.drop_bomb-0.1.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "drop_bomb",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dunce-1.0.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dunce-1.0.5.bazel
index 3324d8c9399..107c3ffebb5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dunce-1.0.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dunce-1.0.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "dunce",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dyn-clone-1.0.19.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dyn-clone-1.0.19.bazel
index da7eea4ee94..448bf06fc09 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dyn-clone-1.0.19.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.dyn-clone-1.0.19.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "dyn_clone",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.either-1.15.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.either-1.15.0.bazel
index d5f576edcb0..f0e4ed753a9 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.either-1.15.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.either-1.15.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "either",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ena-0.14.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ena-0.14.3.bazel
index ab0a896ca89..d006d25618c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ena-0.14.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ena-0.14.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ena",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-0.2.33.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-0.2.33.bazel
index 625e2e26216..a244aae188c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-0.2.33.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-0.2.33.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-japanese-1.20141219.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-japanese-1.20141219.5.bazel
index 13d487c632d..364bb52518b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-japanese-1.20141219.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-japanese-1.20141219.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding_index_japanese",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-korean-1.20141219.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-korean-1.20141219.5.bazel
index 97a7c7735c1..20bed276c3d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-korean-1.20141219.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-korean-1.20141219.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding_index_korean",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-simpchinese-1.20141219.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-simpchinese-1.20141219.5.bazel
index 1d849a7173a..d351a58ac13 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-simpchinese-1.20141219.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-simpchinese-1.20141219.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding_index_simpchinese",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-singlebyte-1.20141219.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-singlebyte-1.20141219.5.bazel
index c2abfe5614b..f5842e0a4ea 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-singlebyte-1.20141219.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-singlebyte-1.20141219.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding_index_singlebyte",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-tradchinese-1.20141219.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-tradchinese-1.20141219.5.bazel
index 60e931b095a..bbee3fd0412 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-tradchinese-1.20141219.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding-index-tradchinese-1.20141219.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding_index_tradchinese",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding_index_tests-0.1.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding_index_tests-0.1.4.bazel
index efde4215512..38f81f0a381 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding_index_tests-0.1.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.encoding_index_tests-0.1.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "encoding_index_tests",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "index_tests.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.equivalent-1.0.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.equivalent-1.0.2.bazel
index 2404a962610..0c774d24ada 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.equivalent-1.0.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.equivalent-1.0.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "equivalent",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.erased-serde-0.4.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.erased-serde-0.4.6.bazel
index 1bd7df32673..100d2f9727c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.erased-serde-0.4.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.erased-serde-0.4.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "erased_serde",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.figment-0.10.19.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.figment-0.10.19.bazel
index ed0c656449e..9569df15a02 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.figment-0.10.19.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.figment-0.10.19.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "figment",
srcs = glob(
@@ -38,6 +47,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -183,6 +195,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "figment",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.filetime-0.2.25.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.filetime-0.2.25.bazel
index 67efe6c549b..35820d594a5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.filetime-0.2.25.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.filetime-0.2.25.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "filetime",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fixedbitset-0.4.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fixedbitset-0.4.2.bazel
index 9a5e9225047..75630f1b6ff 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fixedbitset-0.4.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fixedbitset-0.4.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "fixedbitset",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.flate2-1.1.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.flate2-1.1.0.bazel
index 348b7df0274..47ffe2a16c7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.flate2-1.1.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.flate2-1.1.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "flate2",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fnv-1.0.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fnv-1.0.7.bazel
index 133e793ffa4..54f682b45eb 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fnv-1.0.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fnv-1.0.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "fnv",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.foldhash-0.1.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.foldhash-0.1.5.bazel
index af8c916a930..766dc7a15dc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.foldhash-0.1.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.foldhash-0.1.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "foldhash",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.form_urlencoded-1.2.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.form_urlencoded-1.2.1.bazel
index 3d002c1c1f6..be5dbcf148d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.form_urlencoded-1.2.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.form_urlencoded-1.2.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "form_urlencoded",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fs-err-2.11.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fs-err-2.11.0.bazel
index 7a912b77abe..ae8912b4340 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fs-err-2.11.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fs-err-2.11.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "fs_err",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "fs-err",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fsevent-sys-4.1.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fsevent-sys-4.1.0.bazel
index 64bc7d17284..f6e6c4fad54 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fsevent-sys-4.1.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fsevent-sys-4.1.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "fsevent_sys",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fst-0.4.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fst-0.4.7.bazel
index d0d00bc0992..4512e7e59c2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fst-0.4.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.fst-0.4.7.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "fst",
srcs = glob(
@@ -34,6 +43,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -127,6 +139,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "fst",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.getrandom-0.3.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.getrandom-0.3.3.bazel
similarity index 71%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.getrandom-0.3.1.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.getrandom-0.3.3.bazel
index e21141ad273..54516ab2d7a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.getrandom-0.3.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.getrandom-0.3.3.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "getrandom",
srcs = glob(
@@ -34,6 +43,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,10 +95,10 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.3.1",
+ version = "0.3.3",
deps = [
"@vendor_ts__cfg-if-1.0.1//:cfg_if",
- "@vendor_ts__getrandom-0.3.1//:build_script_build",
+ "@vendor_ts__getrandom-0.3.3//:build_script_build",
] + select({
"@rules_rust//rust/platform:aarch64-apple-darwin": [
"@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "macos", target_os = "openbsd", target_os = "vita", target_os = "emscripten"))
@@ -98,49 +110,43 @@ rust_library(
"@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "ios", target_os = "visionos", target_os = "watchos", target_os = "tvos"))
],
"@rules_rust//rust/platform:aarch64-linux-android": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
- ],
- "@rules_rust//rust/platform:aarch64-pc-windows-msvc": [
- "@vendor_ts__windows-targets-0.52.6//:windows_targets", # cfg(all(windows, not(target_vendor = "win7")))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:aarch64-unknown-linux-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:aarch64-unknown-nixos-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:aarch64-unknown-nto-qnx710": [
"@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "haiku", target_os = "redox", target_os = "nto", target_os = "aix"))
],
"@rules_rust//rust/platform:arm-unknown-linux-gnueabi": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:armv7-linux-androideabi": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:armv7-unknown-linux-gnueabi": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:i686-apple-darwin": [
"@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "macos", target_os = "openbsd", target_os = "vita", target_os = "emscripten"))
],
"@rules_rust//rust/platform:i686-linux-android": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
- ],
- "@rules_rust//rust/platform:i686-pc-windows-msvc": [
- "@vendor_ts__windows-targets-0.52.6//:windows_targets", # cfg(all(windows, not(target_vendor = "win7")))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:i686-unknown-freebsd": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "dragonfly", target_os = "freebsd", target_os = "hurd", target_os = "illumos", all(target_os = "horizon", target_arch = "arm")))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "dragonfly", target_os = "freebsd", target_os = "hurd", target_os = "illumos", target_os = "cygwin", all(target_os = "horizon", target_arch = "arm")))
],
"@rules_rust//rust/platform:i686-unknown-linux-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:powerpc-unknown-linux-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:s390x-unknown-linux-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:x86_64-apple-darwin": [
"@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "macos", target_os = "openbsd", target_os = "vita", target_os = "emscripten"))
@@ -149,19 +155,16 @@ rust_library(
"@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "ios", target_os = "visionos", target_os = "watchos", target_os = "tvos"))
],
"@rules_rust//rust/platform:x86_64-linux-android": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
- ],
- "@rules_rust//rust/platform:x86_64-pc-windows-msvc": [
- "@vendor_ts__windows-targets-0.52.6//:windows_targets", # cfg(all(windows, not(target_vendor = "win7")))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:x86_64-unknown-freebsd": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "dragonfly", target_os = "freebsd", target_os = "hurd", target_os = "illumos", all(target_os = "horizon", target_arch = "arm")))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(any(target_os = "dragonfly", target_os = "freebsd", target_os = "hurd", target_os = "illumos", target_os = "cygwin", all(target_os = "horizon", target_arch = "arm")))
],
"@rules_rust//rust/platform:x86_64-unknown-linux-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"@rules_rust//rust/platform:x86_64-unknown-nixos-gnu": [
- "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(getrandom_backend = "custom", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
+ "@vendor_ts__libc-0.2.174//:libc", # cfg(all(any(target_os = "linux", target_os = "android"), not(any(all(target_os = "linux", target_env = ""), getrandom_backend = "custom", getrandom_backend = "linux_raw", getrandom_backend = "rdrand", getrandom_backend = "rndr"))))
],
"//conditions:default": [],
}),
@@ -205,6 +208,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "getrandom",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -215,7 +221,7 @@ cargo_build_script(
"noclippy",
"norustfmt",
],
- version = "0.3.1",
+ version = "0.3.3",
visibility = ["//visibility:private"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.glob-0.3.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.glob-0.3.3.bazel
similarity index 93%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.glob-0.3.2.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.glob-0.3.3.bazel
index 3fe979fb02c..da1a7679109 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.glob-0.3.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.glob-0.3.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "glob",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,5 +88,5 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.3.2",
+ version = "0.3.3",
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.globset-0.4.15.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.globset-0.4.15.bazel
index 3a2a29d0ae4..23ffeea84c3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.globset-0.4.15.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.globset-0.4.15.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "globset",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.12.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.12.3.bazel
index afd1879f3b7..aa0a973bafe 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.12.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.12.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "hashbrown",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.14.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.14.5.bazel
index 4b6e47dfa32..ba496ad4471 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.14.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.14.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "hashbrown",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.15.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.15.4.bazel
index e1a32ac34e2..e787c0b73f3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.15.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashbrown-0.15.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "hashbrown",
srcs = glob(
@@ -38,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashlink-0.10.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashlink-0.10.0.bazel
index 65e211d7a82..cede17426a8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashlink-0.10.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hashlink-0.10.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "hashlink",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.heck-0.5.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.heck-0.5.0.bazel
index 314a0e6fce0..8332feb628b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.heck-0.5.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.heck-0.5.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "heck",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hermit-abi-0.5.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hermit-abi-0.5.2.bazel
index 3f12e75a518..a8ce19b7407 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hermit-abi-0.5.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hermit-abi-0.5.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "hermit_abi",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hex-0.4.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hex-0.4.3.bazel
index 9add778f802..c04fd290de8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hex-0.4.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.hex-0.4.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "hex",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.home-0.5.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.home-0.5.11.bazel
index 3908ba2dea4..8f5c82b71d0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.home-0.5.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.home-0.5.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "home",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-0.1.63.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-0.1.63.bazel
index eb60c95d310..19f17469001 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-0.1.63.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-0.1.63.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "iana_time_zone",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-haiku-0.1.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-haiku-0.1.2.bazel
index 77cfe795fab..ac8feaf79a2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-haiku-0.1.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.iana-time-zone-haiku-0.1.2.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "iana_time_zone_haiku",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "iana-time-zone-haiku",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_collections-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_collections-2.0.0.bazel
index c86d9eb2bd6..73ee415f9a1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_collections-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_collections-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_collections",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_locale_core-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_locale_core-2.0.0.bazel
index 817700476ce..91cf4cab296 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_locale_core-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_locale_core-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_locale_core",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer-2.0.0.bazel
index 889aede4064..f604cf034a9 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_normalizer",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer_data-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer_data-2.0.0.bazel
index 9a2a78fe541..1bc714152c0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer_data-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_normalizer_data-2.0.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_normalizer_data",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "icu_normalizer_data",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties-2.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties-2.0.1.bazel
index 6f4c34bd93e..cee332f06e1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties-2.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties-2.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_properties",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties_data-2.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties_data-2.0.1.bazel
index 017eafee027..4779fee40dd 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties_data-2.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_properties_data-2.0.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_properties_data",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "icu_properties_data",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_provider-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_provider-2.0.0.bazel
index 13581bbaeaf..0a9c998ee12 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_provider-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.icu_provider-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "icu_provider",
srcs = glob(
@@ -37,6 +43,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ident_case-1.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ident_case-1.0.1.bazel
index 9f3782f718c..e4bc23dc1af 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ident_case-1.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ident_case-1.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ident_case",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna-1.0.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna-1.0.3.bazel
index d040184d1d3..ca624309664 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna-1.0.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna-1.0.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "idna",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna_adapter-1.2.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna_adapter-1.2.1.bazel
index 8b0b2b1d9f5..ca74505a064 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna_adapter-1.2.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.idna_adapter-1.2.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "idna_adapter",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-1.9.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-1.9.3.bazel
index b7acfc279c8..9af800b92dc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-1.9.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-1.9.3.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "indexmap",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -122,6 +134,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "indexmap",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-2.10.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-2.10.0.bazel
index 66bf0b14704..110e79e3f12 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-2.10.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.indexmap-2.10.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "indexmap",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inlinable_string-0.1.15.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inlinable_string-0.1.15.bazel
index 92f9d90fe34..6a2221969bf 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inlinable_string-0.1.15.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inlinable_string-0.1.15.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "inlinable_string",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-0.11.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-0.11.0.bazel
index 3c870418142..455b1ada88b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-0.11.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-0.11.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "inotify",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-sys-0.1.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-sys-0.1.5.bazel
index a8710d62738..64a360cc60b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-sys-0.1.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.inotify-sys-0.1.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "inotify_sys",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.intrusive-collections-0.9.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.intrusive-collections-0.9.7.bazel
index c8d8fb2743e..42a92804c85 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.intrusive-collections-0.9.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.intrusive-collections-0.9.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "intrusive_collections",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.is_terminal_polyfill-1.70.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.is_terminal_polyfill-1.70.1.bazel
index 49ecc70ad2a..196b9d70b34 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.is_terminal_polyfill-1.70.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.is_terminal_polyfill-1.70.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "is_terminal_polyfill",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.12.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.12.1.bazel
index b31c648e60a..4a7838edb6f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.12.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.12.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "itertools",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.14.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.14.0.bazel
index 5449caa6efb..d0885a15d3d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.14.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itertools-0.14.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "itertools",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itoa-1.0.15.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itoa-1.0.15.bazel
index 0ed2975cf78..d0d13ab1a57 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itoa-1.0.15.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.itoa-1.0.15.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "itoa",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jobserver-0.1.32.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jobserver-0.1.32.bazel
index 42f7675b6e9..5e1bfd6978c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jobserver-0.1.32.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jobserver-0.1.32.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "jobserver",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jod-thread-1.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jod-thread-1.0.0.bazel
index 8b42813e871..46ed18db7c9 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jod-thread-1.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.jod-thread-1.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "jod_thread",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.js-sys-0.3.77.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.js-sys-0.3.77.bazel
index 924333e1964..c7cad35aed5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.js-sys-0.3.77.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.js-sys-0.3.77.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "js_sys",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-1.1.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-1.1.1.bazel
index 92c8ab02ced..d2fcbb68bae 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-1.1.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-1.1.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "kqueue",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-sys-1.0.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-sys-1.0.4.bazel
index 57d6a0a8414..ad1e457dfe6 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-sys-1.0.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.kqueue-sys-1.0.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "kqueue_sys",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.la-arena-0.3.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.la-arena-0.3.1.bazel
index e1e8f3fcf44..63ae48cb758 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.la-arena-0.3.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.la-arena-0.3.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "la_arena",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lazy_static-1.5.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lazy_static-1.5.0.bazel
index 881b54afc3b..8fdf1e161e9 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lazy_static-1.5.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lazy_static-1.5.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "lazy_static",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libc-0.2.174.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libc-0.2.174.bazel
index e133650ce78..55fe8a8115b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libc-0.2.174.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libc-0.2.174.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "libc",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -129,6 +141,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "libc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libredox-0.1.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libredox-0.1.4.bazel
index e1f40827124..606bd2a2595 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libredox-0.1.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.libredox-0.1.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "libredox",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.line-index-0.1.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.line-index-0.1.2.bazel
index 0606a147a5c..95a868e1ad3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.line-index-0.1.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.line-index-0.1.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "line_index",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.litemap-0.8.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.litemap-0.8.0.bazel
index 25a24590229..0e547980f69 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.litemap-0.8.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.litemap-0.8.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "litemap",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lock_api-0.4.13.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lock_api-0.4.13.bazel
index 529db737e58..e0bfa81b31f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lock_api-0.4.13.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.lock_api-0.4.13.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "lock_api",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -130,6 +142,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "lock_api",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.3.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.3.9.bazel
index 7ee9ca3cce2..cc061b625ca 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.3.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.3.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "log",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.4.27.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.4.27.bazel
index b36cd98285f..8e1f8897335 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.4.27.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.log-0.4.27.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "log",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.matchers-0.1.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.matchers-0.1.0.bazel
index 90227adce7e..9a3778fcabc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.matchers-0.1.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.matchers-0.1.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "matchers",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memchr-2.7.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memchr-2.7.5.bazel
index 93869ada24c..9af3cd4c572 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memchr-2.7.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memchr-2.7.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "memchr",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memoffset-0.9.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memoffset-0.9.1.bazel
index 2cc7640b300..41234413ee7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memoffset-0.9.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.memoffset-0.9.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "memoffset",
srcs = glob(
@@ -34,6 +43,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -127,6 +139,9 @@ cargo_build_script(
),
edition = "2015",
pkg_name = "memoffset",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miniz_oxide-0.8.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miniz_oxide-0.8.5.bazel
index 2d7b2e2a69f..bc02579b4ea 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miniz_oxide-0.8.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miniz_oxide-0.8.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "miniz_oxide",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mio-1.0.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mio-1.0.4.bazel
index d7ec807e4de..098fbb7173c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mio-1.0.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mio-1.0.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "mio",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miow-0.6.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miow-0.6.0.bazel
index 373f357ebb5..6f99dee0d2d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miow-0.6.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.miow-0.6.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "miow",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mustache-0.9.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mustache-0.9.0.bazel
index cc4f5c0bcba..ae043e0e2a1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mustache-0.9.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.mustache-0.9.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "mustache",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nohash-hasher-0.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nohash-hasher-0.2.0.bazel
index 02d54105d74..ed88ea3eebb 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nohash-hasher-0.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nohash-hasher-0.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "nohash_hasher",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-8.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-8.0.0.bazel
index 03c0fc1ab2f..70889e441f0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-8.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-8.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "notify",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-types-2.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-types-2.0.0.bazel
index 2a58d2dd573..4ec350cba96 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-types-2.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.notify-types-2.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "notify_types",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nu-ansi-term-0.46.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nu-ansi-term-0.46.0.bazel
index 96808381d75..b436335be0c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nu-ansi-term-0.46.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.nu-ansi-term-0.46.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "nu_ansi_term",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-conv-0.1.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-conv-0.1.0.bazel
index 74dbb8ec76d..ee85d2c2961 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-conv-0.1.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-conv-0.1.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "num_conv",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-traits-0.2.19.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-traits-0.2.19.bazel
index 48edd376679..3b7620f1e5a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-traits-0.2.19.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num-traits-0.2.19.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "num_traits",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -129,6 +141,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "num-traits",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num_cpus-1.17.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num_cpus-1.17.0.bazel
index 7af36eb0bf7..65ccdc7fd1a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num_cpus-1.17.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.num_cpus-1.17.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "num_cpus",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell-1.21.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell-1.21.3.bazel
index cdeee345efa..1611f8ad4e8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell-1.21.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell-1.21.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "once_cell",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell_polyfill-1.70.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell_polyfill-1.70.1.bazel
index 28c43629922..08819b64aa4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell_polyfill-1.70.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.once_cell_polyfill-1.70.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "once_cell_polyfill",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.oorandom-11.1.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.oorandom-11.1.5.bazel
index 7fda44d7d5f..a712daf3904 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.oorandom-11.1.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.oorandom-11.1.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "oorandom",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ordered-float-2.10.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ordered-float-2.10.1.bazel
index 95f7e39c15f..be67bf877f4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ordered-float-2.10.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ordered-float-2.10.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ordered_float",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.os_str_bytes-7.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.os_str_bytes-7.0.0.bazel
index 429c84ba0b8..5f68898f2b4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.os_str_bytes-7.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.os_str_bytes-7.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "os_str_bytes",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.overload-0.1.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.overload-0.1.1.bazel
index daf088871c1..047ca4a2489 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.overload-0.1.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.overload-0.1.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "overload",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.papaya-0.2.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.papaya-0.2.3.bazel
index 08d725ad912..214b3d3caab 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.papaya-0.2.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.papaya-0.2.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "papaya",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot-0.12.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot-0.12.4.bazel
index 21ca868e69a..60ff4d9e26d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot-0.12.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot-0.12.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "parking_lot",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot_core-0.9.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot_core-0.9.11.bazel
index 5ccbe980ef5..dd30b9a5bc1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot_core-0.9.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.parking_lot_core-0.9.11.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "parking_lot_core",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -206,6 +218,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "parking_lot_core",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear-0.2.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear-0.2.9.bazel
index 72d8ec29384..6a781ccec50 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear-0.2.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear-0.2.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "pear",
srcs = glob(
@@ -38,6 +44,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__pear_codegen-0.2.9//:pear_codegen",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear_codegen-0.2.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear_codegen-0.2.9.bazel
index 7639db0cadd..44f538367d3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear_codegen-0.2.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pear_codegen-0.2.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "pear_codegen",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.2.9",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__proc-macro2-diagnostics-0.10.1//:proc_macro2_diagnostics",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.percent-encoding-2.3.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.percent-encoding-2.3.1.bazel
index fdc7f4b8d86..dae967123fc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.percent-encoding-2.3.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.percent-encoding-2.3.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "percent_encoding",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-0.4.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-0.4.7.bazel
index 599061b7148..c6512969320 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-0.4.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-0.4.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "perf_event",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-open-sys-1.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-open-sys-1.0.1.bazel
index dd2ae1f69bf..2f975dbab22 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-open-sys-1.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.perf-event-open-sys-1.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "perf_event_open_sys",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.petgraph-0.6.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.petgraph-0.6.5.bazel
index 4adeb22a182..aec5d8e678d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.petgraph-0.6.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.petgraph-0.6.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "petgraph",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pin-project-lite-0.2.16.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pin-project-lite-0.2.16.bazel
index 9d8e6d21fb1..1c7ae29aa31 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pin-project-lite-0.2.16.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pin-project-lite-0.2.16.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "pin_project_lite",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pkg-config-0.3.32.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pkg-config-0.3.32.bazel
index 8fb981887a7..10e8e40e1f1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pkg-config-0.3.32.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.pkg-config-0.3.32.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "pkg_config",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.portable-atomic-1.11.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.portable-atomic-1.11.1.bazel
index 146cc410b04..c481da86e5d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.portable-atomic-1.11.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.portable-atomic-1.11.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "portable_atomic",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -129,6 +141,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "portable-atomic",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.potential_utf-0.1.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.potential_utf-0.1.2.bazel
index 33ae44b0bf4..2c1aa625c77 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.potential_utf-0.1.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.potential_utf-0.1.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "potential_utf",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.powerfmt-0.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.powerfmt-0.2.0.bazel
index b1e35f6f5bf..eee2906ed43 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.powerfmt-0.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.powerfmt-0.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "powerfmt",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ppv-lite86-0.2.20.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ppv-lite86-0.2.21.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ppv-lite86-0.2.20.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ppv-lite86-0.2.21.bazel
index 37a6586979a..1027543b5e7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ppv-lite86-0.2.20.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ppv-lite86-0.2.21.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ppv_lite86",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,8 +92,8 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.2.20",
+ version = "0.2.21",
deps = [
- "@vendor_ts__zerocopy-0.7.35//:zerocopy",
+ "@vendor_ts__zerocopy-0.8.26//:zerocopy",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-1.0.95.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-1.0.97.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-1.0.95.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-1.0.97.bazel
index 2045bcf6e0c..393ebc5392b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-1.0.95.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-1.0.97.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "proc_macro2",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,9 +96,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "1.0.95",
+ version = "1.0.97",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:build_script_build",
+ "@vendor_ts__proc-macro2-1.0.97//:build_script_build",
"@vendor_ts__unicode-ident-1.0.18//:unicode_ident",
],
)
@@ -130,6 +142,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "proc-macro2",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -140,7 +155,7 @@ cargo_build_script(
"noclippy",
"norustfmt",
],
- version = "1.0.95",
+ version = "1.0.97",
visibility = ["//visibility:private"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-diagnostics-0.10.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-diagnostics-0.10.1.bazel
index 5ea9654963f..7e1cf59384c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-diagnostics-0.10.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.proc-macro2-diagnostics-0.10.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "proc_macro2_diagnostics",
srcs = glob(
@@ -36,6 +45,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -87,7 +99,7 @@ rust_library(
}),
version = "0.10.1",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__proc-macro2-diagnostics-0.10.1//:build_script_build",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
@@ -135,6 +147,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "proc-macro2-diagnostics",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.quote-1.0.40.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.quote-1.0.40.bazel
index 8898a30228c..aa96a49c642 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.quote-1.0.40.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.quote-1.0.40.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "quote",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -85,6 +94,6 @@ rust_library(
}),
version = "1.0.40",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.r-efi-5.3.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.r-efi-5.3.0.bazel
new file mode 100644
index 00000000000..7a7f59d9f4c
--- /dev/null
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.r-efi-5.3.0.bazel
@@ -0,0 +1,92 @@
+###############################################################################
+# @generated
+# DO NOT MODIFY: This file is auto-generated by a crate_universe tool. To
+# regenerate this file, run the following:
+#
+# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
+###############################################################################
+
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
+load("@rules_rust//rust:defs.bzl", "rust_library")
+
+package(default_visibility = ["//visibility:public"])
+
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
+rust_library(
+ name = "r_efi",
+ srcs = glob(
+ include = ["**/*.rs"],
+ allow_empty = True,
+ ),
+ compile_data = glob(
+ include = ["**"],
+ allow_empty = True,
+ exclude = [
+ "**/* *",
+ ".tmp_git_root/**/*",
+ "BUILD",
+ "BUILD.bazel",
+ "WORKSPACE",
+ "WORKSPACE.bazel",
+ ],
+ ),
+ crate_root = "src/lib.rs",
+ edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
+ rustc_flags = [
+ "--cap-lints=allow",
+ ],
+ tags = [
+ "cargo-bazel",
+ "crate-name=r-efi",
+ "manual",
+ "noclippy",
+ "norustfmt",
+ ],
+ target_compatible_with = select({
+ "@rules_rust//rust/platform:aarch64-apple-darwin": [],
+ "@rules_rust//rust/platform:aarch64-apple-ios": [],
+ "@rules_rust//rust/platform:aarch64-apple-ios-sim": [],
+ "@rules_rust//rust/platform:aarch64-linux-android": [],
+ "@rules_rust//rust/platform:aarch64-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:aarch64-unknown-fuchsia": [],
+ "@rules_rust//rust/platform:aarch64-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu": [],
+ "@rules_rust//rust/platform:aarch64-unknown-nto-qnx710": [],
+ "@rules_rust//rust/platform:aarch64-unknown-uefi": [],
+ "@rules_rust//rust/platform:arm-unknown-linux-gnueabi": [],
+ "@rules_rust//rust/platform:armv7-linux-androideabi": [],
+ "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi": [],
+ "@rules_rust//rust/platform:i686-apple-darwin": [],
+ "@rules_rust//rust/platform:i686-linux-android": [],
+ "@rules_rust//rust/platform:i686-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:i686-unknown-freebsd": [],
+ "@rules_rust//rust/platform:i686-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:powerpc-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:riscv32imc-unknown-none-elf": [],
+ "@rules_rust//rust/platform:riscv64gc-unknown-none-elf": [],
+ "@rules_rust//rust/platform:s390x-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:thumbv7em-none-eabi": [],
+ "@rules_rust//rust/platform:thumbv8m.main-none-eabi": [],
+ "@rules_rust//rust/platform:wasm32-unknown-unknown": [],
+ "@rules_rust//rust/platform:wasm32-wasip1": [],
+ "@rules_rust//rust/platform:x86_64-apple-darwin": [],
+ "@rules_rust//rust/platform:x86_64-apple-ios": [],
+ "@rules_rust//rust/platform:x86_64-linux-android": [],
+ "@rules_rust//rust/platform:x86_64-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:x86_64-unknown-freebsd": [],
+ "@rules_rust//rust/platform:x86_64-unknown-fuchsia": [],
+ "@rules_rust//rust/platform:x86_64-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu": [],
+ "@rules_rust//rust/platform:x86_64-unknown-none": [],
+ "@rules_rust//rust/platform:x86_64-unknown-uefi": [],
+ "//conditions:default": ["@platforms//:incompatible"],
+ }),
+ version = "5.3.0",
+)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_abi-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_abi-0.123.0.bazel
similarity index 88%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_abi-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_abi-0.123.0.bazel
index 5c46fefc8be..df3ed9bebac 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_abi-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_abi-0.123.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_rustc_abi",
srcs = glob(
@@ -17,8 +23,8 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra-ap-rustc_hashes-0.116.0//:ra_ap_rustc_hashes": "rustc_hashes",
- "@vendor_ts__ra-ap-rustc_index-0.116.0//:ra_ap_rustc_index": "rustc_index",
+ "@vendor_ts__ra-ap-rustc_hashes-0.123.0//:ra_ap_rustc_hashes": "rustc_hashes",
+ "@vendor_ts__ra-ap-rustc_index-0.123.0//:ra_ap_rustc_index": "rustc_index",
},
compile_data = glob(
include = ["**"],
@@ -34,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,11 +92,11 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.123.0",
deps = [
"@vendor_ts__bitflags-2.9.1//:bitflags",
- "@vendor_ts__ra-ap-rustc_hashes-0.116.0//:ra_ap_rustc_hashes",
- "@vendor_ts__ra-ap-rustc_index-0.116.0//:ra_ap_rustc_index",
+ "@vendor_ts__ra-ap-rustc_hashes-0.123.0//:ra_ap_rustc_hashes",
+ "@vendor_ts__ra-ap-rustc_index-0.123.0//:ra_ap_rustc_index",
"@vendor_ts__tracing-0.1.41//:tracing",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_hashes-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_hashes-0.123.0.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_hashes-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_hashes-0.123.0.bazel
index beae7e9f947..65ca37ead02 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_hashes-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_hashes-0.123.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_rustc_hashes",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,7 +88,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.123.0",
deps = [
"@vendor_ts__rustc-stable-hash-0.1.2//:rustc_stable_hash",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index-0.123.0.bazel
similarity index 91%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index-0.123.0.bazel
index 4c9e6a2966d..d3b5c92abd2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index-0.123.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_rustc_index",
srcs = glob(
@@ -17,7 +23,7 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra-ap-rustc_index_macros-0.116.0//:ra_ap_rustc_index_macros": "rustc_index_macros",
+ "@vendor_ts__ra-ap-rustc_index_macros-0.123.0//:ra_ap_rustc_index_macros": "rustc_index_macros",
},
compile_data = glob(
include = ["**"],
@@ -34,7 +40,10 @@ rust_library(
crate_root = "src/lib.rs",
edition = "2024",
proc_macro_deps = [
- "@vendor_ts__ra-ap-rustc_index_macros-0.116.0//:ra_ap_rustc_index_macros",
+ "@vendor_ts__ra-ap-rustc_index_macros-0.123.0//:ra_ap_rustc_index_macros",
+ ],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
],
rustc_flags = [
"--cap-lints=allow",
@@ -85,7 +94,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.123.0",
deps = [
"@vendor_ts__smallvec-1.15.1//:smallvec",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index_macros-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index_macros-0.123.0.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index_macros-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index_macros-0.123.0.bazel
index 9185230c160..6bb6017e68d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index_macros-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_index_macros-0.123.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "ra_ap_rustc_index_macros",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,9 +88,9 @@ rust_proc_macro(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.123.0",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.121.0.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.121.0.bazel
index 41614a75b7f..8190270b487 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.121.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_rustc_lexer",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,7 +88,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.121.0",
deps = [
"@vendor_ts__memchr-2.7.5//:memchr",
"@vendor_ts__unicode-properties-0.1.3//:unicode_properties",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.123.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.123.0.bazel
new file mode 100644
index 00000000000..fe2f610ab25
--- /dev/null
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_lexer-0.123.0.bazel
@@ -0,0 +1,97 @@
+###############################################################################
+# @generated
+# DO NOT MODIFY: This file is auto-generated by a crate_universe tool. To
+# regenerate this file, run the following:
+#
+# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
+###############################################################################
+
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
+load("@rules_rust//rust:defs.bzl", "rust_library")
+
+package(default_visibility = ["//visibility:public"])
+
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
+rust_library(
+ name = "ra_ap_rustc_lexer",
+ srcs = glob(
+ include = ["**/*.rs"],
+ allow_empty = True,
+ ),
+ compile_data = glob(
+ include = ["**"],
+ allow_empty = True,
+ exclude = [
+ "**/* *",
+ ".tmp_git_root/**/*",
+ "BUILD",
+ "BUILD.bazel",
+ "WORKSPACE",
+ "WORKSPACE.bazel",
+ ],
+ ),
+ crate_root = "src/lib.rs",
+ edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
+ rustc_flags = [
+ "--cap-lints=allow",
+ ],
+ tags = [
+ "cargo-bazel",
+ "crate-name=ra-ap-rustc_lexer",
+ "manual",
+ "noclippy",
+ "norustfmt",
+ ],
+ target_compatible_with = select({
+ "@rules_rust//rust/platform:aarch64-apple-darwin": [],
+ "@rules_rust//rust/platform:aarch64-apple-ios": [],
+ "@rules_rust//rust/platform:aarch64-apple-ios-sim": [],
+ "@rules_rust//rust/platform:aarch64-linux-android": [],
+ "@rules_rust//rust/platform:aarch64-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:aarch64-unknown-fuchsia": [],
+ "@rules_rust//rust/platform:aarch64-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu": [],
+ "@rules_rust//rust/platform:aarch64-unknown-nto-qnx710": [],
+ "@rules_rust//rust/platform:aarch64-unknown-uefi": [],
+ "@rules_rust//rust/platform:arm-unknown-linux-gnueabi": [],
+ "@rules_rust//rust/platform:armv7-linux-androideabi": [],
+ "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi": [],
+ "@rules_rust//rust/platform:i686-apple-darwin": [],
+ "@rules_rust//rust/platform:i686-linux-android": [],
+ "@rules_rust//rust/platform:i686-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:i686-unknown-freebsd": [],
+ "@rules_rust//rust/platform:i686-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:powerpc-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:riscv32imc-unknown-none-elf": [],
+ "@rules_rust//rust/platform:riscv64gc-unknown-none-elf": [],
+ "@rules_rust//rust/platform:s390x-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:thumbv7em-none-eabi": [],
+ "@rules_rust//rust/platform:thumbv8m.main-none-eabi": [],
+ "@rules_rust//rust/platform:wasm32-unknown-unknown": [],
+ "@rules_rust//rust/platform:wasm32-wasip1": [],
+ "@rules_rust//rust/platform:x86_64-apple-darwin": [],
+ "@rules_rust//rust/platform:x86_64-apple-ios": [],
+ "@rules_rust//rust/platform:x86_64-linux-android": [],
+ "@rules_rust//rust/platform:x86_64-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:x86_64-unknown-freebsd": [],
+ "@rules_rust//rust/platform:x86_64-unknown-fuchsia": [],
+ "@rules_rust//rust/platform:x86_64-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu": [],
+ "@rules_rust//rust/platform:x86_64-unknown-none": [],
+ "@rules_rust//rust/platform:x86_64-unknown-uefi": [],
+ "//conditions:default": ["@platforms//:incompatible"],
+ }),
+ version = "0.123.0",
+ deps = [
+ "@vendor_ts__memchr-2.7.5//:memchr",
+ "@vendor_ts__unicode-properties-0.1.3//:unicode_properties",
+ "@vendor_ts__unicode-xid-0.2.6//:unicode_xid",
+ ],
+)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_parse_format-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_parse_format-0.121.0.bazel
similarity index 89%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_parse_format-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_parse_format-0.121.0.bazel
index c7306e8a7ed..7fedf84a619 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_parse_format-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_parse_format-0.121.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_rustc_parse_format",
srcs = glob(
@@ -17,7 +23,7 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra-ap-rustc_lexer-0.116.0//:ra_ap_rustc_lexer": "rustc_lexer",
+ "@vendor_ts__ra-ap-rustc_lexer-0.121.0//:ra_ap_rustc_lexer": "rustc_lexer",
},
compile_data = glob(
include = ["**"],
@@ -33,6 +39,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -82,9 +91,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.121.0",
deps = [
- "@vendor_ts__ra-ap-rustc_lexer-0.116.0//:ra_ap_rustc_lexer",
- "@vendor_ts__rustc-literal-escaper-0.0.2//:rustc_literal_escaper",
+ "@vendor_ts__ra-ap-rustc_lexer-0.121.0//:ra_ap_rustc_lexer",
+ "@vendor_ts__rustc-literal-escaper-0.0.4//:rustc_literal_escaper",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_pattern_analysis-0.116.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_pattern_analysis-0.123.0.bazel
similarity index 91%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_pattern_analysis-0.116.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_pattern_analysis-0.123.0.bazel
index f4ffd21c674..b21233957f3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_pattern_analysis-0.116.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra-ap-rustc_pattern_analysis-0.123.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_rustc_pattern_analysis",
srcs = glob(
@@ -17,7 +23,7 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra-ap-rustc_index-0.116.0//:ra_ap_rustc_index": "rustc_index",
+ "@vendor_ts__ra-ap-rustc_index-0.123.0//:ra_ap_rustc_index": "rustc_index",
},
compile_data = glob(
include = ["**"],
@@ -33,6 +39,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -82,9 +91,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.116.0",
+ version = "0.123.0",
deps = [
- "@vendor_ts__ra-ap-rustc_index-0.116.0//:ra_ap_rustc_index",
+ "@vendor_ts__ra-ap-rustc_index-0.123.0//:ra_ap_rustc_index",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__rustc_apfloat-0.2.3-llvm-462a31f5a5ab//:rustc_apfloat",
"@vendor_ts__smallvec-1.15.1//:smallvec",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_base_db-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_base_db-0.0.300.bazel
similarity index 81%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_base_db-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_base_db-0.0.300.bazel
index 925e2c41264..de5ec1e085d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_base_db-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_base_db-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_base_db",
srcs = glob(
@@ -17,12 +23,12 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg": "cfg",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro": "query_group",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs": "vfs",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg": "cfg",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro": "query_group",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs": "vfs",
},
compile_data = glob(
include = ["**"],
@@ -39,9 +45,12 @@ rust_library(
crate_root = "src/lib.rs",
edition = "2024",
proc_macro_deps = [
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro",
"@vendor_ts__salsa-macros-0.23.0//:salsa_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -91,16 +100,16 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__dashmap-6.1.0//:dashmap",
"@vendor_ts__indexmap-2.10.0//:indexmap",
"@vendor_ts__la-arena-0.3.1//:la_arena",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__salsa-0.23.0//:salsa",
"@vendor_ts__semver-1.0.26//:semver",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_cfg-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_cfg-0.0.300.bazel
similarity index 89%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_cfg-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_cfg-0.0.300.bazel
index 7e7adc784db..164407b7d4e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_cfg-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_cfg-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_cfg",
srcs = glob(
@@ -17,8 +23,8 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -37,6 +43,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -86,10 +95,10 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__tracing-0.1.41//:tracing",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_edition-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_edition-0.0.300.bazel
similarity index 93%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_edition-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_edition-0.0.300.bazel
index 682e6af5823..43ed08a0c63 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_edition-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_edition-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_edition",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,5 +88,5 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir-0.0.300.bazel
similarity index 73%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir-0.0.300.bazel
index 98321aa0bbe..8ddcf402e83 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_hir",
srcs = glob(
@@ -17,16 +23,16 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db": "base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg": "cfg",
- "@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def": "hir_def",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand": "hir_expand",
- "@vendor_ts__ra_ap_hir_ty-0.0.294//:ra_ap_hir_ty": "hir_ty",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db": "base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg": "cfg",
+ "@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def": "hir_def",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand": "hir_expand",
+ "@vendor_ts__ra_ap_hir_ty-0.0.300//:ra_ap_hir_ty": "hir_ty",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -42,6 +48,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -91,22 +100,22 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__arrayvec-0.7.6//:arrayvec",
"@vendor_ts__either-1.15.0//:either",
"@vendor_ts__indexmap-2.10.0//:indexmap",
"@vendor_ts__itertools-0.14.0//:itertools",
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
- "@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand",
- "@vendor_ts__ra_ap_hir_ty-0.0.294//:ra_ap_hir_ty",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
+ "@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand",
+ "@vendor_ts__ra_ap_hir_ty-0.0.300//:ra_ap_hir_ty",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__smallvec-1.15.1//:smallvec",
"@vendor_ts__tracing-0.1.41//:tracing",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_def-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_def-0.0.300.bazel
similarity index 74%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_def-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_def-0.0.300.bazel
index 86e3c2bef42..c44207c333d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_def-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_def-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_hir_def",
srcs = glob(
@@ -17,16 +23,16 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db": "base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg": "cfg",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand": "hir_expand",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_mbe-0.0.294//:ra_ap_mbe": "mbe",
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro": "query_group",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db": "base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg": "cfg",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand": "hir_expand",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_mbe-0.0.300//:ra_ap_mbe": "mbe",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro": "query_group",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -43,9 +49,12 @@ rust_library(
crate_root = "src/lib.rs",
edition = "2024",
proc_macro_deps = [
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro",
"@vendor_ts__salsa-macros-0.23.0//:salsa_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -95,7 +104,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__arrayvec-0.7.6//:arrayvec",
"@vendor_ts__bitflags-2.9.1//:bitflags",
@@ -106,17 +115,17 @@ rust_library(
"@vendor_ts__indexmap-2.10.0//:indexmap",
"@vendor_ts__itertools-0.14.0//:itertools",
"@vendor_ts__la-arena-0.3.1//:la_arena",
- "@vendor_ts__ra-ap-rustc_abi-0.116.0//:ra_ap_rustc_abi",
- "@vendor_ts__ra-ap-rustc_parse_format-0.116.0//:ra_ap_rustc_parse_format",
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_mbe-0.0.294//:ra_ap_mbe",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra-ap-rustc_abi-0.123.0//:ra_ap_rustc_abi",
+ "@vendor_ts__ra-ap-rustc_parse_format-0.121.0//:ra_ap_rustc_parse_format",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_mbe-0.0.300//:ra_ap_mbe",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__rustc_apfloat-0.2.3-llvm-462a31f5a5ab//:rustc_apfloat",
"@vendor_ts__salsa-0.23.0//:salsa",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_expand-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_expand-0.0.300.bazel
similarity index 73%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_expand-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_expand-0.0.300.bazel
index 1dd7396ce9d..af75f70ce67 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_expand-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_expand-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_hir_expand",
srcs = glob(
@@ -17,17 +23,17 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db": "base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg": "cfg",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_mbe-0.0.294//:ra_ap_mbe": "mbe",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser": "parser",
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro": "query_group",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_syntax-bridge-0.0.294//:ra_ap_syntax_bridge": "syntax_bridge",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db": "base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg": "cfg",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_mbe-0.0.300//:ra_ap_mbe": "mbe",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser": "parser",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro": "query_group",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_syntax-bridge-0.0.300//:ra_ap_syntax_bridge": "syntax_bridge",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -44,9 +50,12 @@ rust_library(
crate_root = "src/lib.rs",
edition = "2024",
proc_macro_deps = [
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro",
"@vendor_ts__salsa-macros-0.23.0//:salsa_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -96,21 +105,21 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__cov-mark-2.0.0//:cov_mark",
"@vendor_ts__either-1.15.0//:either",
"@vendor_ts__itertools-0.14.0//:itertools",
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_mbe-0.0.294//:ra_ap_mbe",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_syntax-bridge-0.0.294//:ra_ap_syntax_bridge",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_mbe-0.0.300//:ra_ap_mbe",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_syntax-bridge-0.0.300//:ra_ap_syntax_bridge",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__salsa-0.23.0//:salsa",
"@vendor_ts__smallvec-1.15.1//:smallvec",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_ty-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_ty-0.0.300.bazel
similarity index 77%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_ty-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_ty-0.0.300.bazel
index 1d10f88015c..689b518ccf3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_ty-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_hir_ty-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_hir_ty",
srcs = glob(
@@ -17,14 +23,14 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db": "base_db",
- "@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def": "hir_def",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand": "hir_expand",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro": "query_group",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db": "base_db",
+ "@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def": "hir_def",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand": "hir_expand",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro": "query_group",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
},
compile_data = glob(
include = ["**"],
@@ -42,9 +48,12 @@ rust_library(
edition = "2024",
proc_macro_deps = [
"@vendor_ts__chalk-derive-0.103.0//:chalk_derive",
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro",
"@vendor_ts__salsa-macros-0.23.0//:salsa_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -94,7 +103,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__arrayvec-0.7.6//:arrayvec",
"@vendor_ts__bitflags-2.9.1//:bitflags",
@@ -108,16 +117,16 @@ rust_library(
"@vendor_ts__itertools-0.14.0//:itertools",
"@vendor_ts__la-arena-0.3.1//:la_arena",
"@vendor_ts__oorandom-11.1.5//:oorandom",
- "@vendor_ts__ra-ap-rustc_abi-0.116.0//:ra_ap_rustc_abi",
- "@vendor_ts__ra-ap-rustc_index-0.116.0//:ra_ap_rustc_index",
- "@vendor_ts__ra-ap-rustc_pattern_analysis-0.116.0//:ra_ap_rustc_pattern_analysis",
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
- "@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
+ "@vendor_ts__ra-ap-rustc_abi-0.123.0//:ra_ap_rustc_abi",
+ "@vendor_ts__ra-ap-rustc_index-0.123.0//:ra_ap_rustc_index",
+ "@vendor_ts__ra-ap-rustc_pattern_analysis-0.123.0//:ra_ap_rustc_pattern_analysis",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
+ "@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__rustc_apfloat-0.2.3-llvm-462a31f5a5ab//:rustc_apfloat",
"@vendor_ts__salsa-0.23.0//:salsa",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_ide_db-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_ide_db-0.0.300.bazel
similarity index 77%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_ide_db-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_ide_db-0.0.300.bazel
index 4da4d9d21a9..af1e936dc0c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_ide_db-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_ide_db-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_ide_db",
srcs = glob(
@@ -17,15 +23,15 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db": "base_db",
- "@vendor_ts__ra_ap_hir-0.0.294//:ra_ap_hir": "hir",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser": "parser",
- "@vendor_ts__ra_ap_profile-0.0.294//:ra_ap_profile": "profile",
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro": "query_group",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs": "vfs",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db": "base_db",
+ "@vendor_ts__ra_ap_hir-0.0.300//:ra_ap_hir": "hir",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser": "parser",
+ "@vendor_ts__ra_ap_profile-0.0.300//:ra_ap_profile": "profile",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro": "query_group",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs": "vfs",
},
compile_data = glob(
include = ["**"],
@@ -42,9 +48,12 @@ rust_library(
crate_root = "src/lib.rs",
edition = "2024",
proc_macro_deps = [
- "@vendor_ts__ra_ap_query-group-macro-0.0.294//:ra_ap_query_group_macro",
+ "@vendor_ts__ra_ap_query-group-macro-0.0.300//:ra_ap_query_group_macro",
"@vendor_ts__salsa-macros-0.23.0//:salsa_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -94,7 +103,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__arrayvec-0.7.6//:arrayvec",
"@vendor_ts__bitflags-2.9.1//:bitflags",
@@ -107,14 +116,14 @@ rust_library(
"@vendor_ts__line-index-0.1.2//:line_index",
"@vendor_ts__memchr-2.7.5//:memchr",
"@vendor_ts__nohash-hasher-0.2.0//:nohash_hasher",
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
- "@vendor_ts__ra_ap_hir-0.0.294//:ra_ap_hir",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
- "@vendor_ts__ra_ap_profile-0.0.294//:ra_ap_profile",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
+ "@vendor_ts__ra_ap_hir-0.0.300//:ra_ap_hir",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
+ "@vendor_ts__ra_ap_profile-0.0.300//:ra_ap_profile",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
"@vendor_ts__rayon-1.10.0//:rayon",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__salsa-0.23.0//:salsa",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_intern-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_intern-0.0.300.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_intern-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_intern-0.0.300.bazel
index 8ebd7d782a0..27f7bab382c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_intern-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_intern-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_intern",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,7 +88,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__dashmap-6.1.0//:dashmap",
"@vendor_ts__hashbrown-0.14.5//:hashbrown",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_load-cargo-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_load-cargo-0.0.300.bazel
similarity index 73%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_load-cargo-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_load-cargo-0.0.300.bazel
index d05e5a8887f..946a2dc743f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_load-cargo-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_load-cargo-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_load_cargo",
srcs = glob(
@@ -17,15 +23,15 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand": "hir_expand",
- "@vendor_ts__ra_ap_ide_db-0.0.294//:ra_ap_ide_db": "ide_db",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_proc_macro_api-0.0.294//:ra_ap_proc_macro_api": "proc_macro_api",
- "@vendor_ts__ra_ap_project_model-0.0.294//:ra_ap_project_model": "project_model",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs": "vfs",
- "@vendor_ts__ra_ap_vfs-notify-0.0.294//:ra_ap_vfs_notify": "vfs_notify",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand": "hir_expand",
+ "@vendor_ts__ra_ap_ide_db-0.0.300//:ra_ap_ide_db": "ide_db",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_proc_macro_api-0.0.300//:ra_ap_proc_macro_api": "proc_macro_api",
+ "@vendor_ts__ra_ap_project_model-0.0.300//:ra_ap_project_model": "project_model",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs": "vfs",
+ "@vendor_ts__ra_ap_vfs-notify-0.0.300//:ra_ap_vfs_notify": "vfs_notify",
},
compile_data = glob(
include = ["**"],
@@ -41,6 +47,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -90,20 +99,20 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
- "@vendor_ts__anyhow-1.0.98//:anyhow",
+ "@vendor_ts__anyhow-1.0.99//:anyhow",
"@vendor_ts__crossbeam-channel-0.5.15//:crossbeam_channel",
"@vendor_ts__itertools-0.14.0//:itertools",
- "@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand",
- "@vendor_ts__ra_ap_ide_db-0.0.294//:ra_ap_ide_db",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_proc_macro_api-0.0.294//:ra_ap_proc_macro_api",
- "@vendor_ts__ra_ap_project_model-0.0.294//:ra_ap_project_model",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
- "@vendor_ts__ra_ap_vfs-notify-0.0.294//:ra_ap_vfs_notify",
+ "@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand",
+ "@vendor_ts__ra_ap_ide_db-0.0.300//:ra_ap_ide_db",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_proc_macro_api-0.0.300//:ra_ap_proc_macro_api",
+ "@vendor_ts__ra_ap_project_model-0.0.300//:ra_ap_project_model",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
+ "@vendor_ts__ra_ap_vfs-notify-0.0.300//:ra_ap_vfs_notify",
"@vendor_ts__tracing-0.1.41//:tracing",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_mbe-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_mbe-0.0.300.bazel
similarity index 79%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_mbe-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_mbe-0.0.300.bazel
index 81fe285a387..5417da2031a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_mbe-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_mbe-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_mbe",
srcs = glob(
@@ -17,12 +23,12 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser": "parser",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-bridge-0.0.294//:ra_ap_syntax_bridge": "syntax_bridge",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser": "parser",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-bridge-0.0.300//:ra_ap_syntax_bridge": "syntax_bridge",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -38,6 +44,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -87,17 +96,17 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__arrayvec-0.7.6//:arrayvec",
"@vendor_ts__cov-mark-2.0.0//:cov_mark",
- "@vendor_ts__ra-ap-rustc_lexer-0.116.0//:ra_ap_rustc_lexer",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-bridge-0.0.294//:ra_ap_syntax_bridge",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra-ap-rustc_lexer-0.123.0//:ra_ap_rustc_lexer",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-bridge-0.0.300//:ra_ap_syntax_bridge",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__smallvec-1.15.1//:smallvec",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_parser-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_parser-0.0.300.bazel
similarity index 90%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_parser-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_parser-0.0.300.bazel
index 10b7349d60b..8ed11d91495 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_parser-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_parser-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_parser",
srcs = glob(
@@ -17,7 +23,7 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_edition-0.0.294//:ra_ap_edition": "edition",
+ "@vendor_ts__ra_ap_edition-0.0.300//:ra_ap_edition": "edition",
},
compile_data = glob(
include = ["**"],
@@ -37,6 +43,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -86,11 +95,11 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__drop_bomb-0.1.5//:drop_bomb",
- "@vendor_ts__ra-ap-rustc_lexer-0.116.0//:ra_ap_rustc_lexer",
- "@vendor_ts__ra_ap_edition-0.0.294//:ra_ap_edition",
+ "@vendor_ts__ra-ap-rustc_lexer-0.123.0//:ra_ap_rustc_lexer",
+ "@vendor_ts__ra_ap_edition-0.0.300//:ra_ap_edition",
"@vendor_ts__rustc-literal-escaper-0.0.4//:rustc_literal_escaper",
"@vendor_ts__tracing-0.1.41//:tracing",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_paths-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_paths-0.0.300.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_paths-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_paths-0.0.300.bazel
index c832055d4b8..ecaa639c662 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_paths-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_paths-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_paths",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -82,7 +91,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__camino-1.1.10//:camino",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_proc_macro_api-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_proc_macro_api-0.0.300.bazel
similarity index 81%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_proc_macro_api-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_proc_macro_api-0.0.300.bazel
index 3d6e5b6ab15..332966ee749 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_proc_macro_api-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_proc_macro_api-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_proc_macro_api",
srcs = glob(
@@ -17,11 +23,11 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths": "paths",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths": "paths",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -40,6 +46,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__serde_derive-1.0.219//:serde_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -89,17 +98,17 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__indexmap-2.10.0//:indexmap",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__serde-1.0.219//:serde",
- "@vendor_ts__serde_json-1.0.140//:serde_json",
+ "@vendor_ts__serde_json-1.0.142//:serde_json",
"@vendor_ts__tracing-0.1.41//:tracing",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_profile-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_profile-0.0.300.bazel
similarity index 96%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_profile-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_profile-0.0.300.bazel
index cec0a2379d7..c897e7748da 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_profile-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_profile-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_profile",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,7 +88,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__cfg-if-1.0.1//:cfg_if",
] + select({
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_project_model-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_project_model-0.0.300.bazel
similarity index 77%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_project_model-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_project_model-0.0.300.bazel
index 4c29ac16ef2..fb930fafd0a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_project_model-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_project_model-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_project_model",
srcs = glob(
@@ -17,13 +23,13 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db": "base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg": "cfg",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths": "paths",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_toolchain-0.0.294//:ra_ap_toolchain": "toolchain",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db": "base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg": "cfg",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths": "paths",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_toolchain-0.0.300//:ra_ap_toolchain": "toolchain",
},
compile_data = glob(
include = ["**"],
@@ -42,6 +48,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__serde_derive-1.0.219//:serde_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -91,23 +100,24 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
- "@vendor_ts__anyhow-1.0.98//:anyhow",
+ "@vendor_ts__anyhow-1.0.99//:anyhow",
"@vendor_ts__cargo_metadata-0.21.0//:cargo_metadata",
"@vendor_ts__itertools-0.14.0//:itertools",
"@vendor_ts__la-arena-0.3.1//:la_arena",
- "@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db",
- "@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_toolchain-0.0.294//:ra_ap_toolchain",
+ "@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db",
+ "@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_toolchain-0.0.300//:ra_ap_toolchain",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__semver-1.0.26//:semver",
"@vendor_ts__serde-1.0.219//:serde",
- "@vendor_ts__serde_json-1.0.140//:serde_json",
+ "@vendor_ts__serde_json-1.0.142//:serde_json",
+ "@vendor_ts__temp-dir-0.1.16//:temp_dir",
"@vendor_ts__tracing-0.1.41//:tracing",
"@vendor_ts__triomphe-0.1.14//:triomphe",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_query-group-macro-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_query-group-macro-0.0.300.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_query-group-macro-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_query-group-macro-0.0.300.bazel
index 8c58bf7c2b2..a5444525a4a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_query-group-macro-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_query-group-macro-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "ra_ap_query_group_macro",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,9 +88,9 @@ rust_proc_macro(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_span-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_span-0.0.300.bazel
similarity index 87%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_span-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_span-0.0.300.bazel
index e09f30f75cf..888665c53d4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_span-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_span-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_span",
srcs = glob(
@@ -17,9 +23,9 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs": "vfs",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs": "vfs",
},
compile_data = glob(
include = ["**"],
@@ -39,6 +45,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -88,13 +97,13 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__hashbrown-0.14.5//:hashbrown",
"@vendor_ts__la-arena-0.3.1//:la_arena",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__salsa-0.23.0//:salsa",
"@vendor_ts__text-size-1.1.1//:text_size",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_stdx-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_stdx-0.0.300.bazel
similarity index 97%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_stdx-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_stdx-0.0.300.bazel
index 08348bbf5a3..0ec1196ed3f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_stdx-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_stdx-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_stdx",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,7 +88,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__crossbeam-channel-0.5.15//:crossbeam_channel",
"@vendor_ts__crossbeam-utils-0.8.21//:crossbeam_utils",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-0.0.300.bazel
similarity index 89%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-0.0.300.bazel
index 5ce9e4aabc8..77c147097a4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_syntax",
srcs = glob(
@@ -17,8 +23,8 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser": "parser",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser": "parser",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
},
compile_data = glob(
include = ["**"],
@@ -34,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,12 +92,12 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__either-1.15.0//:either",
"@vendor_ts__itertools-0.14.0//:itertools",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
"@vendor_ts__rowan-0.15.15//:rowan",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__rustc-literal-escaper-0.0.4//:rustc_literal_escaper",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-bridge-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-bridge-0.0.300.bazel
similarity index 79%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-bridge-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-bridge-0.0.300.bazel
index 6c96d665264..b9741a866e0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-bridge-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_syntax-bridge-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_syntax_bridge",
srcs = glob(
@@ -17,12 +23,12 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser": "parser",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span": "span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax": "syntax",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt": "tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser": "parser",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span": "span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax": "syntax",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt": "tt",
},
compile_data = glob(
include = ["**"],
@@ -38,6 +44,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -87,14 +96,14 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser",
- "@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax",
- "@vendor_ts__ra_ap_tt-0.0.294//:ra_ap_tt",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser",
+ "@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax",
+ "@vendor_ts__ra_ap_tt-0.0.300//:ra_ap_tt",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_toolchain-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_toolchain-0.0.300.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_toolchain-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_toolchain-0.0.300.bazel
index 4bd1b2112cd..b077ab9b1ef 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_toolchain-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_toolchain-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_toolchain",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,7 +88,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__camino-1.1.10//:camino",
"@vendor_ts__home-0.5.11//:home",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_tt-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_tt-0.0.300.bazel
similarity index 87%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_tt-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_tt-0.0.300.bazel
index 8fdeecdaa92..a9dc4cbb42f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_tt-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_tt-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_tt",
srcs = glob(
@@ -17,8 +23,8 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern": "intern",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern": "intern",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
},
compile_data = glob(
include = ["**"],
@@ -34,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,12 +92,12 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__arrayvec-0.7.6//:arrayvec",
- "@vendor_ts__ra-ap-rustc_lexer-0.116.0//:ra_ap_rustc_lexer",
- "@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
+ "@vendor_ts__ra-ap-rustc_lexer-0.123.0//:ra_ap_rustc_lexer",
+ "@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
"@vendor_ts__text-size-1.1.1//:text_size",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-0.0.300.bazel
similarity index 89%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-0.0.300.bazel
index c3ba38e79bb..1ddf26373e2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_vfs",
srcs = glob(
@@ -17,8 +23,8 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths": "paths",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths": "paths",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
},
compile_data = glob(
include = ["**"],
@@ -34,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,14 +92,14 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__crossbeam-channel-0.5.15//:crossbeam_channel",
"@vendor_ts__fst-0.4.7//:fst",
"@vendor_ts__indexmap-2.10.0//:indexmap",
"@vendor_ts__nohash-hasher-0.2.0//:nohash_hasher",
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__tracing-0.1.41//:tracing",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-notify-0.0.294.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-notify-0.0.300.bazel
similarity index 87%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-notify-0.0.294.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-notify-0.0.300.bazel
index 0a1edaedf3a..1c9c87f94bf 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-notify-0.0.294.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ra_ap_vfs-notify-0.0.300.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ra_ap_vfs_notify",
srcs = glob(
@@ -17,9 +23,9 @@ rust_library(
allow_empty = True,
),
aliases = {
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths": "paths",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx": "stdx",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs": "vfs",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths": "paths",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx": "stdx",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs": "vfs",
},
compile_data = glob(
include = ["**"],
@@ -35,6 +41,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2024",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,13 +93,13 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.0.294",
+ version = "0.0.300",
deps = [
"@vendor_ts__crossbeam-channel-0.5.15//:crossbeam_channel",
"@vendor_ts__notify-8.0.0//:notify",
- "@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths",
- "@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx",
- "@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs",
+ "@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths",
+ "@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx",
+ "@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs",
"@vendor_ts__rayon-1.10.0//:rayon",
"@vendor_ts__rustc-hash-2.1.1//:rustc_hash",
"@vendor_ts__tracing-0.1.41//:tracing",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand-0.9.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand-0.9.2.bazel
similarity index 93%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand-0.9.1.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand-0.9.2.bazel
index 0489a607dcc..76eee3e10fc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand-0.9.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand-0.9.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rand",
srcs = glob(
@@ -39,6 +45,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -88,9 +97,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.9.1",
+ version = "0.9.2",
deps = [
"@vendor_ts__rand_chacha-0.9.0//:rand_chacha",
- "@vendor_ts__rand_core-0.9.2//:rand_core",
+ "@vendor_ts__rand_core-0.9.3//:rand_core",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_chacha-0.9.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_chacha-0.9.0.bazel
index eb188225fa4..23a86fd3b81 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_chacha-0.9.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_chacha-0.9.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rand_chacha",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,7 +93,7 @@ rust_library(
}),
version = "0.9.0",
deps = [
- "@vendor_ts__ppv-lite86-0.2.20//:ppv_lite86",
- "@vendor_ts__rand_core-0.9.2//:rand_core",
+ "@vendor_ts__ppv-lite86-0.2.21//:ppv_lite86",
+ "@vendor_ts__rand_core-0.9.3//:rand_core",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_core-0.9.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_core-0.9.3.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_core-0.9.2.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_core-0.9.3.bazel
index 79af89a699e..7d2ea3945b8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_core-0.9.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rand_core-0.9.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rand_core",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,9 +92,8 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.9.2",
+ version = "0.9.3",
deps = [
- "@vendor_ts__getrandom-0.3.1//:getrandom",
- "@vendor_ts__zerocopy-0.8.20//:zerocopy",
+ "@vendor_ts__getrandom-0.3.3//:getrandom",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-1.10.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-1.10.0.bazel
index 98b7029f86a..54b0313af6f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-1.10.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-1.10.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rayon",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-core-1.12.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-core-1.12.1.bazel
index 53bd8e6fe3d..32592b58e8a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-core-1.12.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rayon-core-1.12.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rayon_core",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -124,6 +136,9 @@ cargo_build_script(
edition = "2021",
links = "rayon-core",
pkg_name = "rayon-core",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.redox_syscall-0.5.13.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.redox_syscall-0.5.13.bazel
index 2eb917c7923..2c22ff5a4c5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.redox_syscall-0.5.13.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.redox_syscall-0.5.13.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "syscall",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-1.0.24.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-1.0.24.bazel
index e517f976ad3..7db5ebf02c7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-1.0.24.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-1.0.24.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ref_cast",
srcs = glob(
@@ -34,6 +43,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__ref-cast-impl-1.0.24//:ref_cast_impl",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -124,6 +136,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "ref-cast",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-impl-1.0.24.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-impl-1.0.24.bazel
index ec0ae118e76..38fec2277f0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-impl-1.0.24.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ref-cast-impl-1.0.24.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "ref_cast_impl",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "1.0.24",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-1.11.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-1.11.1.bazel
index 7de7f698bd6..92e631bc957 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-1.11.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-1.11.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "regex",
srcs = glob(
@@ -49,6 +55,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.1.10.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.1.10.bazel
index 59e85402070..9b58dc74006 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.1.10.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.1.10.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "regex_automata",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.4.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.4.9.bazel
index 56e895f026c..bdfd5c10b87 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.4.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-automata-0.4.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "regex_automata",
srcs = glob(
@@ -56,6 +62,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.6.29.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.6.29.bazel
index 033b857d528..dbfafb2e61f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.6.29.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.6.29.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "regex_syntax",
srcs = glob(
@@ -41,6 +47,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.8.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.8.5.bazel
index 3f00ce48a2a..78a2a7ef6bc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.8.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.regex-syntax-0.8.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "regex_syntax",
srcs = glob(
@@ -42,6 +48,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rowan-0.15.15.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rowan-0.15.15.bazel
index f2f46f442a8..730dcab37ba 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rowan-0.15.15.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rowan-0.15.15.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rowan",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-1.1.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-1.1.0.bazel
index 3d2c449d7fb..b1c27aea91a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-1.1.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-1.1.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rustc_hash",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-2.1.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-2.1.1.bazel
index 4fef93e4632..5af0f94dc4b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-2.1.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-hash-2.1.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rustc_hash",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.2.bazel
deleted file mode 100644
index 280e35dd632..00000000000
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.2.bazel
+++ /dev/null
@@ -1,83 +0,0 @@
-###############################################################################
-# @generated
-# DO NOT MODIFY: This file is auto-generated by a crate_universe tool. To
-# regenerate this file, run the following:
-#
-# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
-###############################################################################
-
-load("@rules_rust//rust:defs.bzl", "rust_library")
-
-package(default_visibility = ["//visibility:public"])
-
-rust_library(
- name = "rustc_literal_escaper",
- srcs = glob(
- include = ["**/*.rs"],
- allow_empty = True,
- ),
- compile_data = glob(
- include = ["**"],
- allow_empty = True,
- exclude = [
- "**/* *",
- ".tmp_git_root/**/*",
- "BUILD",
- "BUILD.bazel",
- "WORKSPACE",
- "WORKSPACE.bazel",
- ],
- ),
- crate_root = "src/lib.rs",
- edition = "2021",
- rustc_flags = [
- "--cap-lints=allow",
- ],
- tags = [
- "cargo-bazel",
- "crate-name=rustc-literal-escaper",
- "manual",
- "noclippy",
- "norustfmt",
- ],
- target_compatible_with = select({
- "@rules_rust//rust/platform:aarch64-apple-darwin": [],
- "@rules_rust//rust/platform:aarch64-apple-ios": [],
- "@rules_rust//rust/platform:aarch64-apple-ios-sim": [],
- "@rules_rust//rust/platform:aarch64-linux-android": [],
- "@rules_rust//rust/platform:aarch64-pc-windows-msvc": [],
- "@rules_rust//rust/platform:aarch64-unknown-fuchsia": [],
- "@rules_rust//rust/platform:aarch64-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu": [],
- "@rules_rust//rust/platform:aarch64-unknown-nto-qnx710": [],
- "@rules_rust//rust/platform:aarch64-unknown-uefi": [],
- "@rules_rust//rust/platform:arm-unknown-linux-gnueabi": [],
- "@rules_rust//rust/platform:armv7-linux-androideabi": [],
- "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi": [],
- "@rules_rust//rust/platform:i686-apple-darwin": [],
- "@rules_rust//rust/platform:i686-linux-android": [],
- "@rules_rust//rust/platform:i686-pc-windows-msvc": [],
- "@rules_rust//rust/platform:i686-unknown-freebsd": [],
- "@rules_rust//rust/platform:i686-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:powerpc-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:riscv32imc-unknown-none-elf": [],
- "@rules_rust//rust/platform:riscv64gc-unknown-none-elf": [],
- "@rules_rust//rust/platform:s390x-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:thumbv7em-none-eabi": [],
- "@rules_rust//rust/platform:thumbv8m.main-none-eabi": [],
- "@rules_rust//rust/platform:wasm32-unknown-unknown": [],
- "@rules_rust//rust/platform:wasm32-wasip1": [],
- "@rules_rust//rust/platform:x86_64-apple-darwin": [],
- "@rules_rust//rust/platform:x86_64-apple-ios": [],
- "@rules_rust//rust/platform:x86_64-linux-android": [],
- "@rules_rust//rust/platform:x86_64-pc-windows-msvc": [],
- "@rules_rust//rust/platform:x86_64-unknown-freebsd": [],
- "@rules_rust//rust/platform:x86_64-unknown-fuchsia": [],
- "@rules_rust//rust/platform:x86_64-unknown-linux-gnu": [],
- "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu": [],
- "@rules_rust//rust/platform:x86_64-unknown-none": [],
- "@rules_rust//rust/platform:x86_64-unknown-uefi": [],
- "//conditions:default": ["@platforms//:incompatible"],
- }),
- version = "0.0.2",
-)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.4.bazel
index 07cfe4ebb32..6636618777f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-literal-escaper-0.0.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rustc_literal_escaper",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-stable-hash-0.1.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-stable-hash-0.1.2.bazel
index 3b8c86af30a..b087a116ce2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-stable-hash-0.1.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc-stable-hash-0.1.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rustc_stable_hash",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc_apfloat-0.2.3+llvm-462a31f5a5ab.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc_apfloat-0.2.3+llvm-462a31f5a5ab.bazel
index 7f9f680e306..c63cc2939ba 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc_apfloat-0.2.3+llvm-462a31f5a5ab.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustc_apfloat-0.2.3+llvm-462a31f5a5ab.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "rustc_apfloat",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -123,6 +135,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "rustc_apfloat",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustversion-1.0.21.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustversion-1.0.21.bazel
index 3f441b4bff7..53d7609768a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustversion-1.0.21.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.rustversion-1.0.21.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "rustversion",
srcs = glob(
@@ -31,6 +40,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "rustversion",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ryu-1.0.20.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ryu-1.0.20.bazel
index 088f53319a0..4a971256e83 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ryu-1.0.20.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ryu-1.0.20.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ryu",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-0.23.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-0.23.0.bazel
index d0683da74bc..949a19b9b1b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-0.23.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-0.23.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "salsa",
srcs = glob(
@@ -39,6 +45,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__salsa-macros-0.23.0//:salsa_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macro-rules-0.23.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macro-rules-0.23.0.bazel
index 11ba464b99d..d351f598b7b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macro-rules-0.23.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macro-rules-0.23.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "salsa_macro_rules",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macros-0.23.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macros-0.23.0.bazel
index 8e12c246c37..72f1a5b649a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macros-0.23.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.salsa-macros-0.23.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "salsa_macros",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.23.0",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
"@vendor_ts__synstructure-0.13.2//:synstructure",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.same-file-1.0.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.same-file-1.0.6.bazel
index 823e6471df3..12659c8d66c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.same-file-1.0.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.same-file-1.0.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "same_file",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-0.9.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-0.9.0.bazel
index ee2aee6f8c1..3f8b85b2448 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-0.9.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-0.9.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "schemars",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,6 +93,6 @@ rust_library(
"@vendor_ts__dyn-clone-1.0.19//:dyn_clone",
"@vendor_ts__ref-cast-1.0.24//:ref_cast",
"@vendor_ts__serde-1.0.219//:serde",
- "@vendor_ts__serde_json-1.0.140//:serde_json",
+ "@vendor_ts__serde_json-1.0.142//:serde_json",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-1.0.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-1.0.4.bazel
index 2c31879f82c..1197212d2bc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-1.0.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.schemars-1.0.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "schemars",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,6 +93,6 @@ rust_library(
"@vendor_ts__dyn-clone-1.0.19//:dyn_clone",
"@vendor_ts__ref-cast-1.0.24//:ref_cast",
"@vendor_ts__serde-1.0.219//:serde",
- "@vendor_ts__serde_json-1.0.140//:serde_json",
+ "@vendor_ts__serde_json-1.0.142//:serde_json",
],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scoped-tls-1.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scoped-tls-1.0.1.bazel
index 1f00d70bc71..b7ee6285790 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scoped-tls-1.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scoped-tls-1.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "scoped_tls",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scopeguard-1.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scopeguard-1.2.0.bazel
index e890853dcb5..268fe36a09b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scopeguard-1.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.scopeguard-1.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "scopeguard",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.seize-0.5.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.seize-0.5.0.bazel
index ed5f5d999e8..f7104958ace 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.seize-0.5.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.seize-0.5.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "seize",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.semver-1.0.26.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.semver-1.0.26.bazel
index 807edeb3644..1b139d7a87e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.semver-1.0.26.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.semver-1.0.26.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "semver",
srcs = glob(
@@ -36,6 +45,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -132,6 +144,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "semver",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-1.0.219.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-1.0.219.bazel
index 7ba89e09bb7..86cb23175ba 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-1.0.219.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-1.0.219.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde",
srcs = glob(
@@ -41,6 +50,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__serde_derive-1.0.219//:serde_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -138,6 +150,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "serde",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-untagged-0.1.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-untagged-0.1.7.bazel
index 2785cb20382..8336f37c318 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-untagged-0.1.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-untagged-0.1.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_untagged",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-value-0.7.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-value-0.7.0.bazel
index d9e7c56d284..f6b8e9a212a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-value-0.7.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde-value-0.7.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_value",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_derive-1.0.219.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_derive-1.0.219.bazel
index f2164040e12..54f67711a1e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_derive-1.0.219.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_derive-1.0.219.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "serde_derive",
srcs = glob(
@@ -33,6 +39,9 @@ rust_proc_macro(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -84,7 +93,7 @@ rust_proc_macro(
}),
version = "1.0.219",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_json-1.0.140.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_json-1.0.142.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_json-1.0.140.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_json-1.0.142.bazel
index 922f6268281..2da5ba551f1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_json-1.0.140.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_json-1.0.142.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_json",
srcs = glob(
@@ -36,6 +45,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -85,13 +97,13 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "1.0.140",
+ version = "1.0.142",
deps = [
"@vendor_ts__itoa-1.0.15//:itoa",
"@vendor_ts__memchr-2.7.5//:memchr",
"@vendor_ts__ryu-1.0.20//:ryu",
"@vendor_ts__serde-1.0.219//:serde",
- "@vendor_ts__serde_json-1.0.140//:build_script_build",
+ "@vendor_ts__serde_json-1.0.142//:build_script_build",
],
)
@@ -135,6 +147,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "serde_json",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -145,7 +160,7 @@ cargo_build_script(
"noclippy",
"norustfmt",
],
- version = "1.0.140",
+ version = "1.0.142",
visibility = ["//visibility:private"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-0.6.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-0.6.9.bazel
index 4efede2084d..ffb3bcf7240 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-0.6.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-0.6.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_spanned",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-1.0.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-1.0.0.bazel
index 9c0d30218a3..e0c6242de6f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-1.0.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_spanned-1.0.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_spanned",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with-3.14.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with-3.14.0.bazel
index 810a3b27684..08f8fdf3880 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with-3.14.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with-3.14.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_with",
srcs = glob(
@@ -40,6 +46,9 @@ rust_library(
"@vendor_ts__serde_derive-1.0.219//:serde_derive",
"@vendor_ts__serde_with_macros-3.14.0//:serde_with_macros",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with_macros-3.14.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with_macros-3.14.0.bazel
index 8ee77607d8f..e36f146513e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with_macros-3.14.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_with_macros-3.14.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "serde_with_macros",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -82,7 +91,7 @@ rust_proc_macro(
version = "3.14.0",
deps = [
"@vendor_ts__darling-0.20.11//:darling",
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_yaml-0.9.34+deprecated.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_yaml-0.9.34+deprecated.bazel
index 1e57e377bbf..9a4e6a30087 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_yaml-0.9.34+deprecated.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.serde_yaml-0.9.34+deprecated.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "serde_yaml",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.sharded-slab-0.1.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.sharded-slab-0.1.7.bazel
index e978ca25cd6..848d1e2a4e5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.sharded-slab-0.1.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.sharded-slab-0.1.7.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "sharded_slab",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.shlex-1.3.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.shlex-1.3.0.bazel
index 9ffa52da238..b9f77c42ca3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.shlex-1.3.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.shlex-1.3.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "shlex",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smallvec-1.15.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smallvec-1.15.1.bazel
index 62bb519baf4..baeaf39f21e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smallvec-1.15.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smallvec-1.15.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "smallvec",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smol_str-0.3.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smol_str-0.3.2.bazel
index 3d5f832aad8..93dd67a02aa 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smol_str-0.3.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.smol_str-0.3.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "smol_str",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.stable_deref_trait-1.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.stable_deref_trait-1.2.0.bazel
index e2b0eef1e61..38f9881b0b7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.stable_deref_trait-1.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.stable_deref_trait-1.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "stable_deref_trait",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.streaming-iterator-0.1.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.streaming-iterator-0.1.9.bazel
index 1f7b83ba864..595be8e1eaf 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.streaming-iterator-0.1.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.streaming-iterator-0.1.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "streaming_iterator",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.strsim-0.11.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.strsim-0.11.1.bazel
index 9b4f4f7535f..69afe594ca7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.strsim-0.11.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.strsim-0.11.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "strsim",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.syn-2.0.104.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.syn-2.0.104.bazel
index 4a821476537..d33a680bd2e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.syn-2.0.104.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.syn-2.0.104.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "syn",
srcs = glob(
@@ -43,6 +49,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -94,7 +103,7 @@ rust_library(
}),
version = "2.0.104",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__unicode-ident-1.0.18//:unicode_ident",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.synstructure-0.13.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.synstructure-0.13.2.bazel
index edeaa4404a3..5b31bf98d6f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.synstructure-0.13.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.synstructure-0.13.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "synstructure",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -85,7 +94,7 @@ rust_library(
}),
version = "0.13.2",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.13.3+wasi-0.2.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.temp-dir-0.1.16.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.13.3+wasi-0.2.2.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.temp-dir-0.1.16.bazel
index 62578b6a312..97833eecfaf 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.13.3+wasi-0.2.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.temp-dir-0.1.16.bazel
@@ -6,12 +6,18 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
- name = "wasi",
+ name = "temp_dir",
srcs = glob(
include = ["**/*.rs"],
allow_empty = True,
@@ -30,12 +36,15 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
tags = [
"cargo-bazel",
- "crate-name=wasi",
+ "crate-name=temp-dir",
"manual",
"noclippy",
"norustfmt",
@@ -79,8 +88,5 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.13.3+wasi-0.2.2",
- deps = [
- "@vendor_ts__wit-bindgen-rt-0.33.0//:wit_bindgen_rt",
- ],
+ version = "0.1.16",
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.text-size-1.1.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.text-size-1.1.1.bazel
index e6ee991c967..eb5ded13f06 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.text-size-1.1.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.text-size-1.1.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "text_size",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thin-vec-0.2.14.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thin-vec-0.2.14.bazel
index aff81c59413..5cae0f03c35 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thin-vec-0.2.14.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thin-vec-0.2.14.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "thin_vec",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-2.0.12.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-2.0.12.bazel
index 2b685a2cd3a..22a50f358c8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-2.0.12.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-2.0.12.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "thiserror",
srcs = glob(
@@ -38,6 +47,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__thiserror-impl-2.0.12//:thiserror_impl",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -132,6 +144,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "thiserror",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-impl-2.0.12.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-impl-2.0.12.bazel
index 1fde44d65d1..ff86a30bb1c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-impl-2.0.12.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thiserror-impl-2.0.12.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "thiserror_impl",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "2.0.12",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thread_local-1.1.8.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thread_local-1.1.8.bazel
index 1c97113bb0e..fdb1e3df88c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thread_local-1.1.8.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.thread_local-1.1.8.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "thread_local",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-0.3.41.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-0.3.41.bazel
index 1db3b72f846..1b720393766 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-0.3.41.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-0.3.41.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "time",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-core-0.1.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-core-0.1.4.bazel
index 7ce3b7e8c50..ba20cfd5d04 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-core-0.1.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-core-0.1.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "time_core",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-macros-0.2.22.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-macros-0.2.22.bazel
index a3677c9f586..97ace68543e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-macros-0.2.22.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.time-macros-0.2.22.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "time_macros",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tinystr-0.8.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tinystr-0.8.1.bazel
index 8e578270bfb..e59752c0787 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tinystr-0.8.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tinystr-0.8.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tinystr",
srcs = glob(
@@ -37,6 +43,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.8.23.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.8.23.bazel
index ce7632fc072..bca02cb3cec 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.8.23.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.8.23.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.9.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.9.5.bazel
similarity index 93%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.9.2.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.9.5.bazel
index 72a06f1955f..196f0c87a31 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.9.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml-0.9.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml",
srcs = glob(
@@ -37,6 +43,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -86,12 +95,12 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.9.2",
+ version = "0.9.5",
deps = [
"@vendor_ts__serde-1.0.219//:serde",
"@vendor_ts__serde_spanned-1.0.0//:serde_spanned",
"@vendor_ts__toml_datetime-0.7.0//:toml_datetime",
- "@vendor_ts__toml_parser-1.0.1//:toml_parser",
+ "@vendor_ts__toml_parser-1.0.2//:toml_parser",
"@vendor_ts__toml_writer-1.0.2//:toml_writer",
"@vendor_ts__winnow-0.7.11//:winnow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.6.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.6.11.bazel
index ee9d696b0a9..d0a8d2086cc 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.6.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.6.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml_datetime",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.7.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.7.0.bazel
index 1978e60b2cd..6d3a99fb0f6 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.7.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_datetime-0.7.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml_datetime",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_edit-0.22.27.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_edit-0.22.27.bazel
index f074b69481c..73e49a5bec1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_edit-0.22.27.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_edit-0.22.27.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml_edit",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_parser-1.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_parser-1.0.2.bazel
similarity index 94%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_parser-1.0.1.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_parser-1.0.2.bazel
index d4d53a70183..d5c30a26290 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_parser-1.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_parser-1.0.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml_parser",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,7 +92,7 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "1.0.1",
+ version = "1.0.2",
deps = [
"@vendor_ts__winnow-0.7.11//:winnow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_write-0.1.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_write-0.1.2.bazel
index dd661ef8d1a..d8562021086 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_write-0.1.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_write-0.1.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml_write",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_writer-1.0.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_writer-1.0.2.bazel
index 06dfde95267..4193266e6d0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_writer-1.0.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.toml_writer-1.0.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "toml_writer",
srcs = glob(
@@ -30,11 +36,13 @@ rust_library(
),
crate_features = [
"alloc",
- "default",
"std",
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-0.1.41.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-0.1.41.bazel
index 57cd9586c95..1e49c47fd1e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-0.1.41.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-0.1.41.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tracing",
srcs = glob(
@@ -39,6 +45,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__tracing-attributes-0.1.30//:tracing_attributes",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-attributes-0.1.30.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-attributes-0.1.30.bazel
index f33e141e5b7..fa6532ba1fd 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-attributes-0.1.30.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-attributes-0.1.30.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "tracing_attributes",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.1.30",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-core-0.1.34.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-core-0.1.34.bazel
index 0b65c9e2485..a1fb8f6e776 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-core-0.1.34.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-core-0.1.34.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tracing_core",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-flame-0.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-flame-0.2.0.bazel
index bda5915465a..7bc42503a2b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-flame-0.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-flame-0.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tracing_flame",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-log-0.2.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-log-0.2.0.bazel
index 9e5af0d1d03..afde86be945 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-log-0.2.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-log-0.2.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tracing_log",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-subscriber-0.3.19.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-subscriber-0.3.19.bazel
index b2a3103bcf6..b66d0003b2a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-subscriber-0.3.19.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tracing-subscriber-0.3.19.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tracing_subscriber",
srcs = glob(
@@ -48,6 +54,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-0.24.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-0.24.6.bazel
index 3fcdb2a9f7c..cfa7b65f205 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-0.24.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-0.24.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tree_sitter",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "binding_rust/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -134,6 +146,9 @@ cargo_build_script(
edition = "2021",
links = "tree-sitter",
pkg_name = "tree-sitter",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-embedded-template-0.23.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-embedded-template-0.23.2.bazel
index 046e08c1489..47d76515ad1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-embedded-template-0.23.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-embedded-template-0.23.2.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tree_sitter_embedded_template",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "bindings/rust/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -122,6 +134,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "tree-sitter-embedded-template",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-json-0.24.8.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-json-0.24.8.bazel
index 6d02526eac4..daedbc6cdb5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-json-0.24.8.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-json-0.24.8.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tree_sitter_json",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "bindings/rust/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -122,6 +134,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "tree-sitter-json",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-language-0.1.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-language-0.1.3.bazel
index 7540a2699f3..c714fc492e3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-language-0.1.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-language-0.1.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tree_sitter_language",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "language.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ql-0.23.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ql-0.23.1.bazel
index 3e467674ce2..d08108c5cc8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ql-0.23.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ql-0.23.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tree_sitter_ql",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "bindings/rust/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -122,6 +134,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "tree-sitter-ql",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ruby-0.23.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ruby-0.23.1.bazel
index b189b4bfa8c..6fb0fab3b2b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ruby-0.23.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.tree-sitter-ruby-0.23.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "tree_sitter_ruby",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "bindings/rust/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -122,6 +134,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "tree-sitter-ruby",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.triomphe-0.1.14.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.triomphe-0.1.14.bazel
index 5e2ddffce75..1ea48d5a72d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.triomphe-0.1.14.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.triomphe-0.1.14.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "triomphe",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typed-arena-2.0.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typed-arena-2.0.2.bazel
index 1fd5da51e0a..69e0c45ebd0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typed-arena-2.0.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typed-arena-2.0.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "typed_arena",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typeid-1.0.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typeid-1.0.3.bazel
index 74c33179202..10f66174bc2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typeid-1.0.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.typeid-1.0.3.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "typeid",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "typeid",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.uncased-0.9.10.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.uncased-0.9.10.bazel
index 9f9e8eaaf6a..bcd4e9b5123 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.uncased-0.9.10.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.uncased-0.9.10.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "uncased",
srcs = glob(
@@ -35,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -129,6 +141,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "uncased",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ungrammar-1.16.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ungrammar-1.16.1.bazel
index 0705a7d0db2..5472fc5dabb 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ungrammar-1.16.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.ungrammar-1.16.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "ungrammar",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-ident-1.0.18.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-ident-1.0.18.bazel
index b0ebc51ff78..39820863a2c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-ident-1.0.18.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-ident-1.0.18.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "unicode_ident",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-properties-0.1.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-properties-0.1.3.bazel
index 9d4bb1d88e1..fed0654f1c1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-properties-0.1.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-properties-0.1.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "unicode_properties",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-xid-0.2.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-xid-0.2.6.bazel
index 6734172ce0c..6776feb0210 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-xid-0.2.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unicode-xid-0.2.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "unicode_xid",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unsafe-libyaml-0.2.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unsafe-libyaml-0.2.11.bazel
index db994352126..9478c1cfe80 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unsafe-libyaml-0.2.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.unsafe-libyaml-0.2.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "unsafe_libyaml",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.url-2.5.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.url-2.5.4.bazel
index 69d9c4097f6..58f034d5353 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.url-2.5.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.url-2.5.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "url",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8_iter-1.0.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8_iter-1.0.4.bazel
index 54c69ad9a16..c4b2c4062c1 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8_iter-1.0.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8_iter-1.0.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "utf8_iter",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8parse-0.2.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8parse-0.2.2.bazel
index caf6625917c..df14dcb7e1f 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8parse-0.2.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.utf8parse-0.2.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "utf8parse",
srcs = glob(
@@ -33,6 +39,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.valuable-0.1.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.valuable-0.1.1.bazel
index bfebc76046d..10a3cc3548a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.valuable-0.1.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.valuable-0.1.1.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "valuable",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "valuable",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.version_check-0.9.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.version_check-0.9.5.bazel
index 0370a2fe403..ce51c79a218 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.version_check-0.9.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.version_check-0.9.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "version_check",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.walkdir-2.5.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.walkdir-2.5.0.bazel
index 6162d18a3cc..3ee13a3e6f7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.walkdir-2.5.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.walkdir-2.5.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "walkdir",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.11.1+wasi-snapshot-preview1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.11.1+wasi-snapshot-preview1.bazel
index 0f6d860867a..6a0e8f023c4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.11.1+wasi-snapshot-preview1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.11.1+wasi-snapshot-preview1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "wasi",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.14.2+wasi-0.2.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.14.2+wasi-0.2.4.bazel
new file mode 100644
index 00000000000..9fc7384facd
--- /dev/null
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasi-0.14.2+wasi-0.2.4.bazel
@@ -0,0 +1,95 @@
+###############################################################################
+# @generated
+# DO NOT MODIFY: This file is auto-generated by a crate_universe tool. To
+# regenerate this file, run the following:
+#
+# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
+###############################################################################
+
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
+load("@rules_rust//rust:defs.bzl", "rust_library")
+
+package(default_visibility = ["//visibility:public"])
+
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
+rust_library(
+ name = "wasi",
+ srcs = glob(
+ include = ["**/*.rs"],
+ allow_empty = True,
+ ),
+ compile_data = glob(
+ include = ["**"],
+ allow_empty = True,
+ exclude = [
+ "**/* *",
+ ".tmp_git_root/**/*",
+ "BUILD",
+ "BUILD.bazel",
+ "WORKSPACE",
+ "WORKSPACE.bazel",
+ ],
+ ),
+ crate_root = "src/lib.rs",
+ edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
+ rustc_flags = [
+ "--cap-lints=allow",
+ ],
+ tags = [
+ "cargo-bazel",
+ "crate-name=wasi",
+ "manual",
+ "noclippy",
+ "norustfmt",
+ ],
+ target_compatible_with = select({
+ "@rules_rust//rust/platform:aarch64-apple-darwin": [],
+ "@rules_rust//rust/platform:aarch64-apple-ios": [],
+ "@rules_rust//rust/platform:aarch64-apple-ios-sim": [],
+ "@rules_rust//rust/platform:aarch64-linux-android": [],
+ "@rules_rust//rust/platform:aarch64-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:aarch64-unknown-fuchsia": [],
+ "@rules_rust//rust/platform:aarch64-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu": [],
+ "@rules_rust//rust/platform:aarch64-unknown-nto-qnx710": [],
+ "@rules_rust//rust/platform:aarch64-unknown-uefi": [],
+ "@rules_rust//rust/platform:arm-unknown-linux-gnueabi": [],
+ "@rules_rust//rust/platform:armv7-linux-androideabi": [],
+ "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi": [],
+ "@rules_rust//rust/platform:i686-apple-darwin": [],
+ "@rules_rust//rust/platform:i686-linux-android": [],
+ "@rules_rust//rust/platform:i686-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:i686-unknown-freebsd": [],
+ "@rules_rust//rust/platform:i686-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:powerpc-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:riscv32imc-unknown-none-elf": [],
+ "@rules_rust//rust/platform:riscv64gc-unknown-none-elf": [],
+ "@rules_rust//rust/platform:s390x-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:thumbv7em-none-eabi": [],
+ "@rules_rust//rust/platform:thumbv8m.main-none-eabi": [],
+ "@rules_rust//rust/platform:wasm32-unknown-unknown": [],
+ "@rules_rust//rust/platform:wasm32-wasip1": [],
+ "@rules_rust//rust/platform:x86_64-apple-darwin": [],
+ "@rules_rust//rust/platform:x86_64-apple-ios": [],
+ "@rules_rust//rust/platform:x86_64-linux-android": [],
+ "@rules_rust//rust/platform:x86_64-pc-windows-msvc": [],
+ "@rules_rust//rust/platform:x86_64-unknown-freebsd": [],
+ "@rules_rust//rust/platform:x86_64-unknown-fuchsia": [],
+ "@rules_rust//rust/platform:x86_64-unknown-linux-gnu": [],
+ "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu": [],
+ "@rules_rust//rust/platform:x86_64-unknown-none": [],
+ "@rules_rust//rust/platform:x86_64-unknown-uefi": [],
+ "//conditions:default": ["@platforms//:incompatible"],
+ }),
+ version = "0.14.2+wasi-0.2.4",
+ deps = [
+ "@vendor_ts__wit-bindgen-rt-0.39.0//:wit_bindgen_rt",
+ ],
+)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-0.2.100.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-0.2.100.bazel
index ac4e42da6ed..c707d350e7a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-0.2.100.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-0.2.100.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "wasm_bindgen",
srcs = glob(
@@ -41,6 +50,9 @@ rust_library(
"@vendor_ts__rustversion-1.0.21//:rustversion",
"@vendor_ts__wasm-bindgen-macro-0.2.100//:wasm_bindgen_macro",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -139,6 +151,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "wasm-bindgen",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-backend-0.2.100.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-backend-0.2.100.bazel
index 3133d7c3c2f..5459cb63446 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-backend-0.2.100.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-backend-0.2.100.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "wasm_bindgen_backend",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -83,7 +92,7 @@ rust_library(
deps = [
"@vendor_ts__bumpalo-3.19.0//:bumpalo",
"@vendor_ts__log-0.4.27//:log",
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
"@vendor_ts__wasm-bindgen-shared-0.2.100//:wasm_bindgen_shared",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-0.2.100.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-0.2.100.bazel
index 7890f71fa78..f6fb33e15f0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-0.2.100.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-0.2.100.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "wasm_bindgen_macro",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-support-0.2.100.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-support-0.2.100.bazel
index e60d0ec189a..026a0784f83 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-support-0.2.100.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-macro-support-0.2.100.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "wasm_bindgen_macro_support",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_library(
}),
version = "0.2.100",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
"@vendor_ts__wasm-bindgen-backend-0.2.100//:wasm_bindgen_backend",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-shared-0.2.100.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-shared-0.2.100.bazel
index f0ec6b59aaa..0be6d5b0e33 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-shared-0.2.100.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wasm-bindgen-shared-0.2.100.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "wasm_bindgen_shared",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -123,6 +135,9 @@ cargo_build_script(
edition = "2021",
links = "wasm_bindgen",
pkg_name = "wasm-bindgen-shared",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-0.3.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-0.3.9.bazel
index d80dd87d690..bdfcc0a9347 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-0.3.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-0.3.9.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "winapi",
srcs = glob(
@@ -38,6 +47,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -135,6 +147,9 @@ cargo_build_script(
),
edition = "2015",
pkg_name = "winapi",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-i686-pc-windows-gnu-0.4.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-i686-pc-windows-gnu-0.4.0.bazel
index 2251d0123cd..45130211eb6 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-i686-pc-windows-gnu-0.4.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-i686-pc-windows-gnu-0.4.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "winapi_i686_pc_windows_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2015",
pkg_name = "winapi-i686-pc-windows-gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-util-0.1.9.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-util-0.1.9.bazel
index cdb2fccbf69..4699f73a72e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-util-0.1.9.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-util-0.1.9.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "winapi_util",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-x86_64-pc-windows-gnu-0.4.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-x86_64-pc-windows-gnu-0.4.0.bazel
index 4de908b9111..200e251f5bd 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-x86_64-pc-windows-gnu-0.4.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winapi-x86_64-pc-windows-gnu-0.4.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "winapi_x86_64_pc_windows_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2015",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2015",
pkg_name = "winapi-x86_64-pc-windows-gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-core-0.61.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-core-0.61.2.bazel
index dad6e83029c..7a76ed1b4fa 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-core-0.61.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-core-0.61.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_core",
srcs = glob(
@@ -34,6 +40,9 @@ rust_library(
"@vendor_ts__windows-implement-0.60.0//:windows_implement",
"@vendor_ts__windows-interface-0.59.1//:windows_interface",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-implement-0.60.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-implement-0.60.0.bazel
index 23ba997ba55..4c5780af7b7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-implement-0.60.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-implement-0.60.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "windows_implement",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.60.0",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-interface-0.59.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-interface-0.59.1.bazel
index 56416563070..ad3593fff25 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-interface-0.59.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-interface-0.59.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "windows_interface",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.59.1",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-link-0.1.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-link-0.1.3.bazel
index 51a9757202b..bce46b7307a 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-link-0.1.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-link-0.1.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_link",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-result-0.3.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-result-0.3.4.bazel
index 125aff0fb29..1e0a303b959 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-result-0.3.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-result-0.3.4.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_result",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-strings-0.4.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-strings-0.4.2.bazel
index 07f976d4711..cb5f79c5e8c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-strings-0.4.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-strings-0.4.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_strings",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.48.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.48.0.bazel
index 744659daedf..5517c53feda 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.48.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.48.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_sys",
srcs = glob(
@@ -44,6 +50,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.52.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.52.0.bazel
index 02fed93acd9..98dc28b5fcf 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.52.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.52.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_sys",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.59.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.59.0.bazel
index 289fee68e92..3c282e594c9 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.59.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.59.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_sys",
srcs = glob(
@@ -47,6 +53,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.60.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.60.2.bazel
index 46506a263b8..02aff274771 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.60.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-sys-0.60.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_sys",
srcs = glob(
@@ -38,6 +44,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.48.5.bazel
index f235fb732a5..ebe18b13d6e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.48.5.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_targets",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.52.6.bazel
index c979bc50d9d..ebc4d23015e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.52.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_targets",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.53.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.53.2.bazel
index 77c1c5144a6..6f9255ba423 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.53.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows-targets-0.53.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_targets",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.48.5.bazel
index 362ee515339..76ee4c4ac63 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_aarch64_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_aarch64_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.52.6.bazel
index d4a56f92680..d9528c09f76 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_aarch64_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_aarch64_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.53.0.bazel
index e727eacb52a..6d4e29a973d 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_gnullvm-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_aarch64_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_aarch64_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.48.5.bazel
index 7b60315c465..5d16d71c77e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_aarch64_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_aarch64_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.52.6.bazel
index 7aaf3e56924..81ac3184619 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_aarch64_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_aarch64_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.53.0.bazel
index 4b4438eaea5..7f892eceb07 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_aarch64_msvc-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_aarch64_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_aarch64_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.48.5.bazel
index 45cf7592d1a..4e9c211e2f8 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_i686_gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.52.6.bazel
index c31f565b76c..8946e3dae8c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_i686_gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.53.0.bazel
index d4809237b86..5421c3221b0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnu-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_i686_gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.52.6.bazel
index 7f37dcce306..7c6704de130 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_i686_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.53.0.bazel
index 3bad746ef58..ec895ba6728 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_gnullvm-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_i686_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.48.5.bazel
index 98eef82ece6..8057157574e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_i686_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.52.6.bazel
index d09383b2835..714cbd2a786 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_i686_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.53.0.bazel
index 2f0214cf347..442a155b5ef 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_i686_msvc-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_i686_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_i686_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.48.5.bazel
index 14508675b58..79ebf6c9ad7 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_x86_64_gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.52.6.bazel
index eb1219c681c..627d5812cfd 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_x86_64_gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.53.0.bazel
index 1d07c0d0250..5ed7b8685f4 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnu-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_gnu",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_x86_64_gnu",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.48.5.bazel
index 71285899742..4a8f3a92123 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_x86_64_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.52.6.bazel
index 678e71b4da5..a7d85c18b4e 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_x86_64_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.53.0.bazel
index 2cad4e3de6f..01065e2d820 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_gnullvm-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_gnullvm",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_x86_64_gnullvm",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.48.5.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.48.5.bazel
index 9d9664ccbd4..47c0fc5917b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.48.5.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.48.5.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2018",
pkg_name = "windows_x86_64_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.52.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.52.6.bazel
index df8d9024f53..6b5b8ea9385 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.52.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.52.6.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_x86_64_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.53.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.53.0.bazel
index 2733c677a91..8dac1ae2733 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.53.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.windows_x86_64_msvc-0.53.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "windows_x86_64_msvc",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "windows_x86_64_msvc",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winnow-0.7.11.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winnow-0.7.11.bazel
index 5221e7699ad..ad39ba9d121 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winnow-0.7.11.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.winnow-0.7.11.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "winnow",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wit-bindgen-rt-0.33.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wit-bindgen-rt-0.39.0.bazel
similarity index 91%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wit-bindgen-rt-0.33.0.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wit-bindgen-rt-0.39.0.bazel
index 01f119aef6f..44b325ec96c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wit-bindgen-rt-0.33.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.wit-bindgen-rt-0.39.0.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "wit_bindgen_rt",
srcs = glob(
@@ -31,6 +40,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -80,9 +92,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.33.0",
+ version = "0.39.0",
deps = [
- "@vendor_ts__wit-bindgen-rt-0.33.0//:build_script_build",
+ "@vendor_ts__wit-bindgen-rt-0.39.0//:build_script_build",
],
)
@@ -121,6 +133,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "wit-bindgen-rt",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -131,7 +146,7 @@ cargo_build_script(
"noclippy",
"norustfmt",
],
- version = "0.33.0",
+ version = "0.39.0",
visibility = ["//visibility:private"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.writeable-0.6.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.writeable-0.6.1.bazel
index 0c2e96ae012..4fcd2d17feb 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.writeable-0.6.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.writeable-0.6.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "writeable",
srcs = glob(
@@ -30,6 +36,9 @@ rust_library(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yansi-1.0.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yansi-1.0.1.bazel
index 500ced28448..bd4b2f2df67 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yansi-1.0.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yansi-1.0.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "yansi",
srcs = glob(
@@ -35,6 +41,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-0.8.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-0.8.0.bazel
index 83fc89ba717..94aab2f51b5 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-0.8.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-0.8.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "yoke",
srcs = glob(
@@ -38,6 +44,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__yoke-derive-0.8.0//:yoke_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-derive-0.8.0.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-derive-0.8.0.bazel
index ce3b63861ad..507697272f2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-derive-0.8.0.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.yoke-derive-0.8.0.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "yoke_derive",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.8.0",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
"@vendor_ts__synstructure-0.13.2//:synstructure",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.8.20.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.8.26.bazel
similarity index 90%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.8.20.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.8.26.bazel
index ddd5a21cc67..32d5cf2d5a3 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.8.20.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-0.8.26.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zerocopy",
srcs = glob(
@@ -29,8 +38,14 @@ rust_library(
"WORKSPACE.bazel",
],
),
+ crate_features = [
+ "simd",
+ ],
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -80,9 +95,9 @@ rust_library(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.8.20",
+ version = "0.8.26",
deps = [
- "@vendor_ts__zerocopy-0.8.20//:build_script_build",
+ "@vendor_ts__zerocopy-0.8.26//:build_script_build",
],
)
@@ -105,6 +120,9 @@ cargo_build_script(
"WORKSPACE.bazel",
],
),
+ crate_features = [
+ "simd",
+ ],
crate_name = "build_script_build",
crate_root = "build.rs",
data = glob(
@@ -121,6 +139,9 @@ cargo_build_script(
),
edition = "2021",
pkg_name = "zerocopy",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -131,7 +152,7 @@ cargo_build_script(
"noclippy",
"norustfmt",
],
- version = "0.8.20",
+ version = "0.8.26",
visibility = ["//visibility:private"],
)
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.8.20.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.8.26.bazel
similarity index 92%
rename from misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.8.20.bazel
rename to misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.8.26.bazel
index 6532a50eaa1..136da86dc00 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.8.20.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerocopy-derive-0.8.26.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "zerocopy_derive",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -79,9 +88,9 @@ rust_proc_macro(
"@rules_rust//rust/platform:x86_64-unknown-uefi": [],
"//conditions:default": ["@platforms//:incompatible"],
}),
- version = "0.8.20",
+ version = "0.8.26",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-0.1.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-0.1.6.bazel
index 365169ad3eb..ff66227ba59 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-0.1.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-0.1.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zerofrom",
srcs = glob(
@@ -37,6 +43,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__zerofrom-derive-0.1.6//:zerofrom_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-derive-0.1.6.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-derive-0.1.6.bazel
index 223de956266..516b57bbff0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-derive-0.1.6.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerofrom-derive-0.1.6.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "zerofrom_derive",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.1.6",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
"@vendor_ts__synstructure-0.13.2//:synstructure",
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerotrie-0.2.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerotrie-0.2.2.bazel
index 453e2f8d259..68bcc2fdf62 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerotrie-0.2.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerotrie-0.2.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zerotrie",
srcs = glob(
@@ -37,6 +43,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__displaydoc-0.2.5//:displaydoc",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-0.11.2.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-0.11.2.bazel
index 6969b46a518..5a3209f87c0 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-0.11.2.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-0.11.2.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zerovec",
srcs = glob(
@@ -38,6 +44,9 @@ rust_library(
proc_macro_deps = [
"@vendor_ts__zerovec-derive-0.11.1//:zerovec_derive",
],
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-derive-0.11.1.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-derive-0.11.1.bazel
index 2367041cbd7..2d416230e0c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-derive-0.11.1.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zerovec-derive-0.11.1.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_proc_macro")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_proc_macro(
name = "zerovec_derive",
srcs = glob(
@@ -30,6 +36,9 @@ rust_proc_macro(
),
crate_root = "src/lib.rs",
edition = "2021",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -81,7 +90,7 @@ rust_proc_macro(
}),
version = "0.11.1",
deps = [
- "@vendor_ts__proc-macro2-1.0.95//:proc_macro2",
+ "@vendor_ts__proc-macro2-1.0.97//:proc_macro2",
"@vendor_ts__quote-1.0.40//:quote",
"@vendor_ts__syn-2.0.104//:syn",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-0.13.3.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-0.13.3.bazel
index 2ba80632d93..587eab5d90b 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-0.13.3.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-0.13.3.bazel
@@ -6,10 +6,16 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
+load("@rules_rust//cargo:defs.bzl", "cargo_toml_env_vars")
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zstd",
srcs = glob(
@@ -36,6 +42,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-safe-7.2.4.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-safe-7.2.4.bazel
index 265b6514b70..449d88c74f2 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-safe-7.2.4.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-safe-7.2.4.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zstd_safe",
srcs = glob(
@@ -37,6 +46,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -137,6 +149,9 @@ cargo_build_script(
"@vendor_ts__zstd-sys-2.0.15-zstd.1.5.7//:zstd_sys",
],
pkg_name = "zstd-safe",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-sys-2.0.15+zstd.1.5.7.bazel b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-sys-2.0.15+zstd.1.5.7.bazel
index f29b4b091ae..0d8bdc16757 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-sys-2.0.15+zstd.1.5.7.bazel
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/BUILD.zstd-sys-2.0.15+zstd.1.5.7.bazel
@@ -6,11 +6,20 @@
# bazel run @@//misc/bazel/3rdparty:vendor_tree_sitter_extractors
###############################################################################
-load("@rules_rust//cargo:defs.bzl", "cargo_build_script")
+load(
+ "@rules_rust//cargo:defs.bzl",
+ "cargo_build_script",
+ "cargo_toml_env_vars",
+)
load("@rules_rust//rust:defs.bzl", "rust_library")
package(default_visibility = ["//visibility:public"])
+cargo_toml_env_vars(
+ name = "cargo_toml_env_vars",
+ src = "Cargo.toml",
+)
+
rust_library(
name = "zstd_sys",
srcs = glob(
@@ -36,6 +45,9 @@ rust_library(
],
crate_root = "src/lib.rs",
edition = "2018",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
@@ -132,6 +144,9 @@ cargo_build_script(
edition = "2018",
links = "zstd",
pkg_name = "zstd-sys",
+ rustc_env_files = [
+ ":cargo_toml_env_vars",
+ ],
rustc_flags = [
"--cap-lints=allow",
],
diff --git a/misc/bazel/3rdparty/tree_sitter_extractors_deps/defs.bzl b/misc/bazel/3rdparty/tree_sitter_extractors_deps/defs.bzl
index 75cbec05e35..1ac8707748c 100644
--- a/misc/bazel/3rdparty/tree_sitter_extractors_deps/defs.bzl
+++ b/misc/bazel/3rdparty/tree_sitter_extractors_deps/defs.bzl
@@ -295,12 +295,12 @@ def aliases(
_NORMAL_DEPENDENCIES = {
"ruby/extractor": {
_COMMON_CONDITION: {
- "clap": Label("@vendor_ts__clap-4.5.41//:clap"),
+ "clap": Label("@vendor_ts__clap-4.5.44//:clap"),
"encoding": Label("@vendor_ts__encoding-0.2.33//:encoding"),
"lazy_static": Label("@vendor_ts__lazy_static-1.5.0//:lazy_static"),
"rayon": Label("@vendor_ts__rayon-1.10.0//:rayon"),
"regex": Label("@vendor_ts__regex-1.11.1//:regex"),
- "serde_json": Label("@vendor_ts__serde_json-1.0.140//:serde_json"),
+ "serde_json": Label("@vendor_ts__serde_json-1.0.142//:serde_json"),
"tracing": Label("@vendor_ts__tracing-0.1.41//:tracing"),
"tracing-subscriber": Label("@vendor_ts__tracing-subscriber-0.3.19//:tracing_subscriber"),
"tree-sitter": Label("@vendor_ts__tree-sitter-0.24.6//:tree_sitter"),
@@ -310,14 +310,14 @@ _NORMAL_DEPENDENCIES = {
},
"rust/ast-generator": {
_COMMON_CONDITION: {
- "anyhow": Label("@vendor_ts__anyhow-1.0.98//:anyhow"),
+ "anyhow": Label("@vendor_ts__anyhow-1.0.99//:anyhow"),
"either": Label("@vendor_ts__either-1.15.0//:either"),
"itertools": Label("@vendor_ts__itertools-0.14.0//:itertools"),
"mustache": Label("@vendor_ts__mustache-0.9.0//:mustache"),
- "proc-macro2": Label("@vendor_ts__proc-macro2-1.0.95//:proc_macro2"),
+ "proc-macro2": Label("@vendor_ts__proc-macro2-1.0.97//:proc_macro2"),
"quote": Label("@vendor_ts__quote-1.0.40//:quote"),
"serde": Label("@vendor_ts__serde-1.0.219//:serde"),
- "stdx": Label("@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx"),
+ "stdx": Label("@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx"),
"ungrammar": Label("@vendor_ts__ungrammar-1.16.1//:ungrammar"),
},
},
@@ -325,36 +325,36 @@ _NORMAL_DEPENDENCIES = {
},
"rust/extractor": {
_COMMON_CONDITION: {
- "anyhow": Label("@vendor_ts__anyhow-1.0.98//:anyhow"),
+ "anyhow": Label("@vendor_ts__anyhow-1.0.99//:anyhow"),
"argfile": Label("@vendor_ts__argfile-0.2.1//:argfile"),
- "chalk-ir": Label("@vendor_ts__chalk-ir-0.103.0//:chalk_ir"),
+ "chalk-ir": Label("@vendor_ts__chalk-ir-0.104.0//:chalk_ir"),
"chrono": Label("@vendor_ts__chrono-0.4.41//:chrono"),
- "clap": Label("@vendor_ts__clap-4.5.41//:clap"),
+ "clap": Label("@vendor_ts__clap-4.5.44//:clap"),
"dunce": Label("@vendor_ts__dunce-1.0.5//:dunce"),
"figment": Label("@vendor_ts__figment-0.10.19//:figment"),
- "glob": Label("@vendor_ts__glob-0.3.2//:glob"),
+ "glob": Label("@vendor_ts__glob-0.3.3//:glob"),
"itertools": Label("@vendor_ts__itertools-0.14.0//:itertools"),
"mustache": Label("@vendor_ts__mustache-0.9.0//:mustache"),
"num-traits": Label("@vendor_ts__num-traits-0.2.19//:num_traits"),
- "ra_ap_base_db": Label("@vendor_ts__ra_ap_base_db-0.0.294//:ra_ap_base_db"),
- "ra_ap_cfg": Label("@vendor_ts__ra_ap_cfg-0.0.294//:ra_ap_cfg"),
- "ra_ap_hir": Label("@vendor_ts__ra_ap_hir-0.0.294//:ra_ap_hir"),
- "ra_ap_hir_def": Label("@vendor_ts__ra_ap_hir_def-0.0.294//:ra_ap_hir_def"),
- "ra_ap_hir_expand": Label("@vendor_ts__ra_ap_hir_expand-0.0.294//:ra_ap_hir_expand"),
- "ra_ap_hir_ty": Label("@vendor_ts__ra_ap_hir_ty-0.0.294//:ra_ap_hir_ty"),
- "ra_ap_ide_db": Label("@vendor_ts__ra_ap_ide_db-0.0.294//:ra_ap_ide_db"),
- "ra_ap_intern": Label("@vendor_ts__ra_ap_intern-0.0.294//:ra_ap_intern"),
- "ra_ap_load-cargo": Label("@vendor_ts__ra_ap_load-cargo-0.0.294//:ra_ap_load_cargo"),
- "ra_ap_parser": Label("@vendor_ts__ra_ap_parser-0.0.294//:ra_ap_parser"),
- "ra_ap_paths": Label("@vendor_ts__ra_ap_paths-0.0.294//:ra_ap_paths"),
- "ra_ap_project_model": Label("@vendor_ts__ra_ap_project_model-0.0.294//:ra_ap_project_model"),
- "ra_ap_span": Label("@vendor_ts__ra_ap_span-0.0.294//:ra_ap_span"),
- "ra_ap_syntax": Label("@vendor_ts__ra_ap_syntax-0.0.294//:ra_ap_syntax"),
- "ra_ap_vfs": Label("@vendor_ts__ra_ap_vfs-0.0.294//:ra_ap_vfs"),
+ "ra_ap_base_db": Label("@vendor_ts__ra_ap_base_db-0.0.300//:ra_ap_base_db"),
+ "ra_ap_cfg": Label("@vendor_ts__ra_ap_cfg-0.0.300//:ra_ap_cfg"),
+ "ra_ap_hir": Label("@vendor_ts__ra_ap_hir-0.0.300//:ra_ap_hir"),
+ "ra_ap_hir_def": Label("@vendor_ts__ra_ap_hir_def-0.0.300//:ra_ap_hir_def"),
+ "ra_ap_hir_expand": Label("@vendor_ts__ra_ap_hir_expand-0.0.300//:ra_ap_hir_expand"),
+ "ra_ap_hir_ty": Label("@vendor_ts__ra_ap_hir_ty-0.0.300//:ra_ap_hir_ty"),
+ "ra_ap_ide_db": Label("@vendor_ts__ra_ap_ide_db-0.0.300//:ra_ap_ide_db"),
+ "ra_ap_intern": Label("@vendor_ts__ra_ap_intern-0.0.300//:ra_ap_intern"),
+ "ra_ap_load-cargo": Label("@vendor_ts__ra_ap_load-cargo-0.0.300//:ra_ap_load_cargo"),
+ "ra_ap_parser": Label("@vendor_ts__ra_ap_parser-0.0.300//:ra_ap_parser"),
+ "ra_ap_paths": Label("@vendor_ts__ra_ap_paths-0.0.300//:ra_ap_paths"),
+ "ra_ap_project_model": Label("@vendor_ts__ra_ap_project_model-0.0.300//:ra_ap_project_model"),
+ "ra_ap_span": Label("@vendor_ts__ra_ap_span-0.0.300//:ra_ap_span"),
+ "ra_ap_syntax": Label("@vendor_ts__ra_ap_syntax-0.0.300//:ra_ap_syntax"),
+ "ra_ap_vfs": Label("@vendor_ts__ra_ap_vfs-0.0.300//:ra_ap_vfs"),
"serde": Label("@vendor_ts__serde-1.0.219//:serde"),
- "serde_json": Label("@vendor_ts__serde_json-1.0.140//:serde_json"),
+ "serde_json": Label("@vendor_ts__serde_json-1.0.142//:serde_json"),
"serde_with": Label("@vendor_ts__serde_with-3.14.0//:serde_with"),
- "toml": Label("@vendor_ts__toml-0.9.2//:toml"),
+ "toml": Label("@vendor_ts__toml-0.9.5//:toml"),
"tracing": Label("@vendor_ts__tracing-0.1.41//:tracing"),
"tracing-flame": Label("@vendor_ts__tracing-flame-0.2.0//:tracing_flame"),
"tracing-subscriber": Label("@vendor_ts__tracing-subscriber-0.3.19//:tracing_subscriber"),
@@ -378,7 +378,7 @@ _NORMAL_DEPENDENCIES = {
"rayon": Label("@vendor_ts__rayon-1.10.0//:rayon"),
"regex": Label("@vendor_ts__regex-1.11.1//:regex"),
"serde": Label("@vendor_ts__serde-1.0.219//:serde"),
- "serde_json": Label("@vendor_ts__serde_json-1.0.140//:serde_json"),
+ "serde_json": Label("@vendor_ts__serde_json-1.0.142//:serde_json"),
"tracing": Label("@vendor_ts__tracing-0.1.41//:tracing"),
"tracing-subscriber": Label("@vendor_ts__tracing-subscriber-0.3.19//:tracing_subscriber"),
"tree-sitter": Label("@vendor_ts__tree-sitter-0.24.6//:tree_sitter"),
@@ -394,7 +394,7 @@ _NORMAL_ALIASES = {
},
"rust/ast-generator": {
_COMMON_CONDITION: {
- Label("@vendor_ts__ra_ap_stdx-0.0.294//:ra_ap_stdx"): "stdx",
+ Label("@vendor_ts__ra_ap_stdx-0.0.300//:ra_ap_stdx"): "stdx",
},
},
"rust/autobuild": {
@@ -426,7 +426,7 @@ _NORMAL_DEV_DEPENDENCIES = {
},
"shared/tree-sitter-extractor": {
_COMMON_CONDITION: {
- "rand": Label("@vendor_ts__rand-0.9.1//:rand"),
+ "rand": Label("@vendor_ts__rand-0.9.2//:rand"),
"tree-sitter-json": Label("@vendor_ts__tree-sitter-json-0.24.8//:tree_sitter_json"),
"tree-sitter-ql": Label("@vendor_ts__tree-sitter-ql-0.23.1//:tree_sitter_ql"),
},
@@ -588,7 +588,7 @@ _CONDITIONS = {
"armv7-linux-androideabi": ["@rules_rust//rust/platform:armv7-linux-androideabi"],
"armv7-unknown-linux-gnueabi": ["@rules_rust//rust/platform:armv7-unknown-linux-gnueabi"],
"cfg(all(any(target_arch = \"x86_64\", target_arch = \"arm64ec\"), target_env = \"msvc\", not(windows_raw_dylib)))": ["@rules_rust//rust/platform:x86_64-pc-windows-msvc"],
- "cfg(all(any(target_os = \"linux\", target_os = \"android\"), not(any(getrandom_backend = \"custom\", getrandom_backend = \"rdrand\", getrandom_backend = \"rndr\"))))": ["@rules_rust//rust/platform:aarch64-linux-android", "@rules_rust//rust/platform:aarch64-unknown-linux-gnu", "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu", "@rules_rust//rust/platform:arm-unknown-linux-gnueabi", "@rules_rust//rust/platform:armv7-linux-androideabi", "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi", "@rules_rust//rust/platform:i686-linux-android", "@rules_rust//rust/platform:i686-unknown-linux-gnu", "@rules_rust//rust/platform:powerpc-unknown-linux-gnu", "@rules_rust//rust/platform:s390x-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-linux-android", "@rules_rust//rust/platform:x86_64-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu"],
+ "cfg(all(any(target_os = \"linux\", target_os = \"android\"), not(any(all(target_os = \"linux\", target_env = \"\"), getrandom_backend = \"custom\", getrandom_backend = \"linux_raw\", getrandom_backend = \"rdrand\", getrandom_backend = \"rndr\"))))": ["@rules_rust//rust/platform:aarch64-linux-android", "@rules_rust//rust/platform:aarch64-unknown-linux-gnu", "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu", "@rules_rust//rust/platform:arm-unknown-linux-gnueabi", "@rules_rust//rust/platform:armv7-linux-androideabi", "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi", "@rules_rust//rust/platform:i686-linux-android", "@rules_rust//rust/platform:i686-unknown-linux-gnu", "@rules_rust//rust/platform:powerpc-unknown-linux-gnu", "@rules_rust//rust/platform:s390x-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-linux-android", "@rules_rust//rust/platform:x86_64-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu"],
"cfg(all(target_arch = \"aarch64\", target_env = \"msvc\", not(windows_raw_dylib)))": ["@rules_rust//rust/platform:aarch64-pc-windows-msvc"],
"cfg(all(target_arch = \"wasm32\", target_os = \"unknown\"))": ["@rules_rust//rust/platform:wasm32-unknown-unknown"],
"cfg(all(target_arch = \"wasm32\", target_os = \"wasi\", target_env = \"p2\"))": [],
@@ -599,9 +599,9 @@ _CONDITIONS = {
"cfg(all(target_arch = \"x86_64\", target_env = \"msvc\", not(windows_raw_dylib)))": ["@rules_rust//rust/platform:x86_64-pc-windows-msvc"],
"cfg(all(target_os = \"linux\", not(target_env = \"ohos\")))": ["@rules_rust//rust/platform:aarch64-unknown-linux-gnu", "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu", "@rules_rust//rust/platform:arm-unknown-linux-gnueabi", "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi", "@rules_rust//rust/platform:i686-unknown-linux-gnu", "@rules_rust//rust/platform:powerpc-unknown-linux-gnu", "@rules_rust//rust/platform:s390x-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu"],
"cfg(all(target_os = \"linux\", target_env = \"gnu\"))": ["@rules_rust//rust/platform:aarch64-unknown-linux-gnu", "@rules_rust//rust/platform:aarch64-unknown-nixos-gnu", "@rules_rust//rust/platform:arm-unknown-linux-gnueabi", "@rules_rust//rust/platform:armv7-unknown-linux-gnueabi", "@rules_rust//rust/platform:i686-unknown-linux-gnu", "@rules_rust//rust/platform:powerpc-unknown-linux-gnu", "@rules_rust//rust/platform:s390x-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-unknown-linux-gnu", "@rules_rust//rust/platform:x86_64-unknown-nixos-gnu"],
- "cfg(all(windows, not(target_vendor = \"win7\")))": ["@rules_rust//rust/platform:aarch64-pc-windows-msvc", "@rules_rust//rust/platform:i686-pc-windows-msvc", "@rules_rust//rust/platform:x86_64-pc-windows-msvc"],
+ "cfg(all(target_os = \"uefi\", getrandom_backend = \"efi_rng\"))": [],
"cfg(any())": [],
- "cfg(any(target_os = \"dragonfly\", target_os = \"freebsd\", target_os = \"hurd\", target_os = \"illumos\", all(target_os = \"horizon\", target_arch = \"arm\")))": ["@rules_rust//rust/platform:i686-unknown-freebsd", "@rules_rust//rust/platform:x86_64-unknown-freebsd"],
+ "cfg(any(target_os = \"dragonfly\", target_os = \"freebsd\", target_os = \"hurd\", target_os = \"illumos\", target_os = \"cygwin\", all(target_os = \"horizon\", target_arch = \"arm\")))": ["@rules_rust//rust/platform:i686-unknown-freebsd", "@rules_rust//rust/platform:x86_64-unknown-freebsd"],
"cfg(any(target_os = \"freebsd\", target_os = \"openbsd\", target_os = \"netbsd\", target_os = \"dragonflybsd\", target_os = \"ios\"))": ["@rules_rust//rust/platform:aarch64-apple-ios", "@rules_rust//rust/platform:aarch64-apple-ios-sim", "@rules_rust//rust/platform:i686-unknown-freebsd", "@rules_rust//rust/platform:x86_64-apple-ios", "@rules_rust//rust/platform:x86_64-unknown-freebsd"],
"cfg(any(target_os = \"haiku\", target_os = \"redox\", target_os = \"nto\", target_os = \"aix\"))": ["@rules_rust//rust/platform:aarch64-unknown-nto-qnx710"],
"cfg(any(target_os = \"ios\", target_os = \"visionos\", target_os = \"watchos\", target_os = \"tvos\"))": ["@rules_rust//rust/platform:aarch64-apple-ios", "@rules_rust//rust/platform:aarch64-apple-ios-sim", "@rules_rust//rust/platform:x86_64-apple-ios"],
@@ -761,12 +761,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__anyhow-1.0.98",
- sha256 = "e16d2d3311acee920a9eb8d33b8cbc1787ce4a264e85f964c2404b969bdcd487",
+ name = "vendor_ts__anyhow-1.0.99",
+ sha256 = "b0674a1ddeecb70197781e945de4b3b8ffb61fa939a5597bcf48503737663100",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/anyhow/1.0.98/download"],
- strip_prefix = "anyhow-1.0.98",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.anyhow-1.0.98.bazel"),
+ urls = ["https://static.crates.io/crates/anyhow/1.0.99/download"],
+ strip_prefix = "anyhow-1.0.99",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.anyhow-1.0.99.bazel"),
)
maybe(
@@ -889,16 +889,6 @@ def crate_repositories():
build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.bytemuck-1.21.0.bazel"),
)
- maybe(
- http_archive,
- name = "vendor_ts__byteorder-1.5.0",
- sha256 = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b",
- type = "tar.gz",
- urls = ["https://static.crates.io/crates/byteorder/1.5.0/download"],
- strip_prefix = "byteorder-1.5.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.byteorder-1.5.0.bazel"),
- )
-
maybe(
http_archive,
name = "vendor_ts__camino-1.1.10",
@@ -979,6 +969,16 @@ def crate_repositories():
build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.chalk-derive-0.103.0.bazel"),
)
+ maybe(
+ http_archive,
+ name = "vendor_ts__chalk-derive-0.104.0",
+ sha256 = "9ea9b1e80910f66ae87c772247591432032ef3f6a67367ff17f8343db05beafa",
+ type = "tar.gz",
+ urls = ["https://static.crates.io/crates/chalk-derive/0.104.0/download"],
+ strip_prefix = "chalk-derive-0.104.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.chalk-derive-0.104.0.bazel"),
+ )
+
maybe(
http_archive,
name = "vendor_ts__chalk-ir-0.103.0",
@@ -989,6 +989,16 @@ def crate_repositories():
build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.chalk-ir-0.103.0.bazel"),
)
+ maybe(
+ http_archive,
+ name = "vendor_ts__chalk-ir-0.104.0",
+ sha256 = "7047a516de16226cd17344d41a319d0ea1064bf9e60bd612ab341ab4a34bbfa8",
+ type = "tar.gz",
+ urls = ["https://static.crates.io/crates/chalk-ir/0.104.0/download"],
+ strip_prefix = "chalk-ir-0.104.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.chalk-ir-0.104.0.bazel"),
+ )
+
maybe(
http_archive,
name = "vendor_ts__chalk-recursive-0.103.0",
@@ -1021,22 +1031,22 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__clap-4.5.41",
- sha256 = "be92d32e80243a54711e5d7ce823c35c41c9d929dc4ab58e1276f625841aadf9",
+ name = "vendor_ts__clap-4.5.44",
+ sha256 = "1c1f056bae57e3e54c3375c41ff79619ddd13460a17d7438712bd0d83fda4ff8",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/clap/4.5.41/download"],
- strip_prefix = "clap-4.5.41",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.clap-4.5.41.bazel"),
+ urls = ["https://static.crates.io/crates/clap/4.5.44/download"],
+ strip_prefix = "clap-4.5.44",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.clap-4.5.44.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__clap_builder-4.5.41",
- sha256 = "707eab41e9622f9139419d573eca0900137718000c517d47da73045f54331c3d",
+ name = "vendor_ts__clap_builder-4.5.44",
+ sha256 = "b3e7f4214277f3c7aa526a59dd3fbe306a370daee1f8b7b8c987069cd8e888a8",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/clap_builder/4.5.41/download"],
- strip_prefix = "clap_builder-4.5.41",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.clap_builder-4.5.41.bazel"),
+ urls = ["https://static.crates.io/crates/clap_builder/4.5.44/download"],
+ strip_prefix = "clap_builder-4.5.44",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.clap_builder-4.5.44.bazel"),
)
maybe(
@@ -1461,22 +1471,22 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__getrandom-0.3.1",
- sha256 = "43a49c392881ce6d5c3b8cb70f98717b7c07aabbdff06687b9030dbfbe2725f8",
+ name = "vendor_ts__getrandom-0.3.3",
+ sha256 = "26145e563e54f2cadc477553f1ec5ee650b00862f0a58bcd12cbdc5f0ea2d2f4",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/getrandom/0.3.1/download"],
- strip_prefix = "getrandom-0.3.1",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.getrandom-0.3.1.bazel"),
+ urls = ["https://static.crates.io/crates/getrandom/0.3.3/download"],
+ strip_prefix = "getrandom-0.3.3",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.getrandom-0.3.3.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__glob-0.3.2",
- sha256 = "a8d1add55171497b4705a648c6b583acafb01d58050a51727785f0b2c8e0a2b2",
+ name = "vendor_ts__glob-0.3.3",
+ sha256 = "0cc23270f6e1808e30a928bdc84dea0b9b4136a8bc82338574f23baf47bbd280",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/glob/0.3.2/download"],
- strip_prefix = "glob-0.3.2",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.glob-0.3.2.bazel"),
+ urls = ["https://static.crates.io/crates/glob/0.3.3/download"],
+ strip_prefix = "glob-0.3.3",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.glob-0.3.3.bazel"),
)
maybe(
@@ -2271,22 +2281,22 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__ppv-lite86-0.2.20",
- sha256 = "77957b295656769bb8ad2b6a6b09d897d94f05c41b069aede1fcdaa675eaea04",
+ name = "vendor_ts__ppv-lite86-0.2.21",
+ sha256 = "85eae3c4ed2f50dcfe72643da4befc30deadb458a9b590d720cde2f2b1e97da9",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ppv-lite86/0.2.20/download"],
- strip_prefix = "ppv-lite86-0.2.20",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ppv-lite86-0.2.20.bazel"),
+ urls = ["https://static.crates.io/crates/ppv-lite86/0.2.21/download"],
+ strip_prefix = "ppv-lite86-0.2.21",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ppv-lite86-0.2.21.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__proc-macro2-1.0.95",
- sha256 = "02b3e5e68a3a1a02aad3ec490a98007cbc13c37cbe84a3cd7b8e406d76e7f778",
+ name = "vendor_ts__proc-macro2-1.0.97",
+ sha256 = "d61789d7719defeb74ea5fe81f2fdfdbd28a803847077cecce2ff14e1472f6f1",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/proc-macro2/1.0.95/download"],
- strip_prefix = "proc-macro2-1.0.95",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.proc-macro2-1.0.95.bazel"),
+ urls = ["https://static.crates.io/crates/proc-macro2/1.0.97/download"],
+ strip_prefix = "proc-macro2-1.0.97",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.proc-macro2-1.0.97.bazel"),
)
maybe(
@@ -2311,332 +2321,352 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_abi-0.116.0",
- sha256 = "a967e3a9cd3e38b543f503978e0eccee461e3aea3f7b10e944959bff41dbe612",
+ name = "vendor_ts__r-efi-5.3.0",
+ sha256 = "69cdb34c158ceb288df11e18b4bd39de994f6657d83847bdffdbd7f346754b0f",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_abi/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_abi-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_abi-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/r-efi/5.3.0/download"],
+ strip_prefix = "r-efi-5.3.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.r-efi-5.3.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_hashes-0.116.0",
- sha256 = "1ea4c755ecbbffa5743c251344f484ebe571ec7bc5b36d80b2a8ae775d1a7a40",
+ name = "vendor_ts__ra-ap-rustc_abi-0.123.0",
+ sha256 = "f18c877575c259d127072e9bfc41d985202262fb4d6bfdae3d1252147c2562c2",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_hashes/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_hashes-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_hashes-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_abi/0.123.0/download"],
+ strip_prefix = "ra-ap-rustc_abi-0.123.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_abi-0.123.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_index-0.116.0",
- sha256 = "aca7ad7cf911538c619caa2162339fe98637e9e46f11bb0484ef96735df4d64a",
+ name = "vendor_ts__ra-ap-rustc_hashes-0.123.0",
+ sha256 = "2439ed1df3472443133b66949f81080dff88089b42f825761455463709ee1cad",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_index/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_index-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_index-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_hashes/0.123.0/download"],
+ strip_prefix = "ra-ap-rustc_hashes-0.123.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_hashes-0.123.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_index_macros-0.116.0",
- sha256 = "8767ba551c9355bc3031be072cc4bb0381106e5e7cd275e72b7a8c76051c4070",
+ name = "vendor_ts__ra-ap-rustc_index-0.123.0",
+ sha256 = "57a24fe0be21be1f8ebc21dcb40129214fb4cefb0f2753f3d46b6dbe656a1a45",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_index_macros/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_index_macros-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_index_macros-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_index/0.123.0/download"],
+ strip_prefix = "ra-ap-rustc_index-0.123.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_index-0.123.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_lexer-0.116.0",
- sha256 = "6101374afb267e6c27e4e2eb0b1352e9f3504c1a8f716f619cd39244e2ed92ab",
+ name = "vendor_ts__ra-ap-rustc_index_macros-0.123.0",
+ sha256 = "844a27ddcad0116facae2df8e741fd788662cf93dc13029cd864f2b8013b81f9",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_lexer/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_lexer-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_lexer-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_index_macros/0.123.0/download"],
+ strip_prefix = "ra-ap-rustc_index_macros-0.123.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_index_macros-0.123.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_parse_format-0.116.0",
- sha256 = "ecd88a19f00da4f43e6727d5013444cbc399804b5046dfa2bbcd28ebed3970ce",
+ name = "vendor_ts__ra-ap-rustc_lexer-0.121.0",
+ sha256 = "22944e31fb91e9b3e75bcbc91e37d958b8c0825a6160927f2856831d2ce83b36",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_parse_format/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_parse_format-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_parse_format-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_lexer/0.121.0/download"],
+ strip_prefix = "ra-ap-rustc_lexer-0.121.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_lexer-0.121.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra-ap-rustc_pattern_analysis-0.116.0",
- sha256 = "bb332dd32d7850a799862533b1c021e6062558861a4ad57817bf522499fbb892",
+ name = "vendor_ts__ra-ap-rustc_lexer-0.123.0",
+ sha256 = "2b734cfcb577d09877799a22742f1bd398be6c00bc428d9de56d48d11ece5771",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra-ap-rustc_pattern_analysis/0.116.0/download"],
- strip_prefix = "ra-ap-rustc_pattern_analysis-0.116.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_pattern_analysis-0.116.0.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_lexer/0.123.0/download"],
+ strip_prefix = "ra-ap-rustc_lexer-0.123.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_lexer-0.123.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_base_db-0.0.294",
- sha256 = "3daac3b2c8e4e3d02d47f177c75360c85f16f4f9e6d60ee358a47532ccb35647",
+ name = "vendor_ts__ra-ap-rustc_parse_format-0.121.0",
+ sha256 = "81057891bc2063ad9e353f29462fbc47a0f5072560af34428ae9313aaa5e9d97",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_base_db/0.0.294/download"],
- strip_prefix = "ra_ap_base_db-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_base_db-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_parse_format/0.121.0/download"],
+ strip_prefix = "ra-ap-rustc_parse_format-0.121.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_parse_format-0.121.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_cfg-0.0.294",
- sha256 = "bfcada4b644f965cf8972f31c28a343737c9c500c87d59d026a77bf5ce8ad76b",
+ name = "vendor_ts__ra-ap-rustc_pattern_analysis-0.123.0",
+ sha256 = "75b0ee1f059b9dea0818c6c7267478926eee95ba4c7dcf89c8db32fa165d3904",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_cfg/0.0.294/download"],
- strip_prefix = "ra_ap_cfg-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_cfg-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra-ap-rustc_pattern_analysis/0.123.0/download"],
+ strip_prefix = "ra-ap-rustc_pattern_analysis-0.123.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra-ap-rustc_pattern_analysis-0.123.0.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_edition-0.0.294",
- sha256 = "732efa3d4cd5edc1578be0a33fa0f8052a348e52e6b95e7e161199f7166445b7",
+ name = "vendor_ts__ra_ap_base_db-0.0.300",
+ sha256 = "47cac371778785196064f1a347fbbac0aafb1053786f17378bb138be59e57fc2",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_edition/0.0.294/download"],
- strip_prefix = "ra_ap_edition-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_edition-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_base_db/0.0.300/download"],
+ strip_prefix = "ra_ap_base_db-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_base_db-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_hir-0.0.294",
- sha256 = "6de0998ba9f6d4f2b70e6be16c7beeda661bdf25cdae932ed10c45b8b6cc6d8f",
+ name = "vendor_ts__ra_ap_cfg-0.0.300",
+ sha256 = "6789ed14467e6625bef45b29555844d0168d8af1bea9edb0f1d44f0a9b69f398",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_hir/0.0.294/download"],
- strip_prefix = "ra_ap_hir-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_cfg/0.0.300/download"],
+ strip_prefix = "ra_ap_cfg-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_cfg-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_hir_def-0.0.294",
- sha256 = "af1a22912226cfbc1909c09f30896cbbfd9acb5c051db9d55e1c557b5d7aa6f4",
+ name = "vendor_ts__ra_ap_edition-0.0.300",
+ sha256 = "637b74c692dc9d9b44394f8c0f91c063e1b6223c6e54f4ee89c943db2f2ee26e",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_hir_def/0.0.294/download"],
- strip_prefix = "ra_ap_hir_def-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir_def-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_edition/0.0.300/download"],
+ strip_prefix = "ra_ap_edition-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_edition-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_hir_expand-0.0.294",
- sha256 = "7ef269bd496048dd39288122ee05805c672df3a26cc9c05ce7bdde42f0656324",
+ name = "vendor_ts__ra_ap_hir-0.0.300",
+ sha256 = "a94c69a3830f0b6fbc36c1d098fcc9430f63c8d47ee6f93e3d6810c3bf440296",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_hir_expand/0.0.294/download"],
- strip_prefix = "ra_ap_hir_expand-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir_expand-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_hir/0.0.300/download"],
+ strip_prefix = "ra_ap_hir-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_hir_ty-0.0.294",
- sha256 = "1d26605356ec9541148ce2dcf00e45b9bbe90424c9e04baeca3fb6c463ce2487",
+ name = "vendor_ts__ra_ap_hir_def-0.0.300",
+ sha256 = "7d94fcf7743db2f4f7e2c2911563847eb8efe2b7fb9fa430c107f0ac05962254",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_hir_ty/0.0.294/download"],
- strip_prefix = "ra_ap_hir_ty-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir_ty-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_hir_def/0.0.300/download"],
+ strip_prefix = "ra_ap_hir_def-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir_def-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_ide_db-0.0.294",
- sha256 = "087858853882a6dc56a2bd1da01ab0fc15d9e0ba2afd613d22df69097acc47a9",
+ name = "vendor_ts__ra_ap_hir_expand-0.0.300",
+ sha256 = "67ea3f6a0ba0c1e8b63f4a41bc596c07aeb2db2f99b67fa077820cfb5fce58bd",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_ide_db/0.0.294/download"],
- strip_prefix = "ra_ap_ide_db-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_ide_db-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_hir_expand/0.0.300/download"],
+ strip_prefix = "ra_ap_hir_expand-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir_expand-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_intern-0.0.294",
- sha256 = "5ec1af1e540f93cc4c9642454c1ad7aa155d54d1533804da771ff05f19bb57fa",
+ name = "vendor_ts__ra_ap_hir_ty-0.0.300",
+ sha256 = "eccf6c291a88892e59e7591e081da8b9158f8c0b1ed9cb9b73d02d29a0d3d6d9",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_intern/0.0.294/download"],
- strip_prefix = "ra_ap_intern-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_intern-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_hir_ty/0.0.300/download"],
+ strip_prefix = "ra_ap_hir_ty-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_hir_ty-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_load-cargo-0.0.294",
- sha256 = "a3343d16dc4b0f3337d4654f9d0c41363be4197aaf6f62a02b711440fdb3eaae",
+ name = "vendor_ts__ra_ap_ide_db-0.0.300",
+ sha256 = "0bbbc97cc9837f91100711b65fb0d8ce9d7ed8da0dc418e08678d973d53da6a3",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_load-cargo/0.0.294/download"],
- strip_prefix = "ra_ap_load-cargo-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_load-cargo-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_ide_db/0.0.300/download"],
+ strip_prefix = "ra_ap_ide_db-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_ide_db-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_mbe-0.0.294",
- sha256 = "c2253eeeef2ee51d8a7b43f86fe43883654b8a3bb56c9cb801de1bf457ca24d6",
+ name = "vendor_ts__ra_ap_intern-0.0.300",
+ sha256 = "10f4785a674a41f9f52414fb7f19ab9a1d6886cad572e68721a883b0b85c256b",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_mbe/0.0.294/download"],
- strip_prefix = "ra_ap_mbe-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_mbe-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_intern/0.0.300/download"],
+ strip_prefix = "ra_ap_intern-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_intern-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_parser-0.0.294",
- sha256 = "df3bf4cde715c2343c24a39283534e7bd5498e29b6b938615ba0e02ba4e262b4",
+ name = "vendor_ts__ra_ap_load-cargo-0.0.300",
+ sha256 = "f3be9990782fd2c2d90b67e2e0b4a86e7412ec8a0719950d9a68292924e85691",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_parser/0.0.294/download"],
- strip_prefix = "ra_ap_parser-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_parser-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_load-cargo/0.0.300/download"],
+ strip_prefix = "ra_ap_load-cargo-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_load-cargo-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_paths-0.0.294",
- sha256 = "c610195e29090ebc387061aa8d55c5d741004df2e15e11c62e34cf3037e61fe8",
+ name = "vendor_ts__ra_ap_mbe-0.0.300",
+ sha256 = "5b713f4d927f9d86391f66237019b8e5dbcad4ddbbe37c91c2e21adca258b9aa",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_paths/0.0.294/download"],
- strip_prefix = "ra_ap_paths-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_paths-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_mbe/0.0.300/download"],
+ strip_prefix = "ra_ap_mbe-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_mbe-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_proc_macro_api-0.0.294",
- sha256 = "537a1866f6e63a1405bac2aa9e32ae47ea2e38b0879d1e7ab00e53b03d787512",
+ name = "vendor_ts__ra_ap_parser-0.0.300",
+ sha256 = "0d3fb8a5891c1c1d6fba5e58caa86b88f831990c878e361c54c1c1ff44ca8401",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_proc_macro_api/0.0.294/download"],
- strip_prefix = "ra_ap_proc_macro_api-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_proc_macro_api-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_parser/0.0.300/download"],
+ strip_prefix = "ra_ap_parser-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_parser-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_profile-0.0.294",
- sha256 = "4824370708bd413f38e697831d37878c44366ff18aa7dd95ab0af5e3a484c558",
+ name = "vendor_ts__ra_ap_paths-0.0.300",
+ sha256 = "9ccd5cfd0dae89ab2c70c4e5aa646f64bb8b5591622477342863c23a5f32dabc",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_profile/0.0.294/download"],
- strip_prefix = "ra_ap_profile-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_profile-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_paths/0.0.300/download"],
+ strip_prefix = "ra_ap_paths-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_paths-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_project_model-0.0.294",
- sha256 = "d97b1f2d3d8b6cd838264624192c0dbded200d7b7944a4731ab20bb18fab79b9",
+ name = "vendor_ts__ra_ap_proc_macro_api-0.0.300",
+ sha256 = "dae43c707bfb78f1b841ffb3731cc7876550463306c3b3986c20abd31033e7a2",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_project_model/0.0.294/download"],
- strip_prefix = "ra_ap_project_model-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_project_model-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_proc_macro_api/0.0.300/download"],
+ strip_prefix = "ra_ap_proc_macro_api-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_proc_macro_api-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_query-group-macro-0.0.294",
- sha256 = "9d9c2a0a9519e59eeb2cc42991477e4cf4214c2e9e1ac29453d6bd6ccd05ed58",
+ name = "vendor_ts__ra_ap_profile-0.0.300",
+ sha256 = "95a7b93ca94cf0821e8bcac6bf8464cc94d7b3cbe63ffb74946a58ad03991fae",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_query-group-macro/0.0.294/download"],
- strip_prefix = "ra_ap_query-group-macro-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_query-group-macro-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_profile/0.0.300/download"],
+ strip_prefix = "ra_ap_profile-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_profile-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_span-0.0.294",
- sha256 = "a2a224089b92abb04b36fa9dbd3e348a41997917e155eb9598d686766b15b4e9",
+ name = "vendor_ts__ra_ap_project_model-0.0.300",
+ sha256 = "0751b9433a0dd49c6ae58c9572faf9557d2b53818370d72112b3adeaae5eabc4",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_span/0.0.294/download"],
- strip_prefix = "ra_ap_span-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_span-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_project_model/0.0.300/download"],
+ strip_prefix = "ra_ap_project_model-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_project_model-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_stdx-0.0.294",
- sha256 = "b565a5d6e364b3c6f955a5b20e1633e5db15df9f804fba26615150524eeccb2c",
+ name = "vendor_ts__ra_ap_query-group-macro-0.0.300",
+ sha256 = "5a82732eb8f5dc592d1d8d9bee23c1d66532e39293f02e23c7a546b60b35072b",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_stdx/0.0.294/download"],
- strip_prefix = "ra_ap_stdx-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_stdx-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_query-group-macro/0.0.300/download"],
+ strip_prefix = "ra_ap_query-group-macro-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_query-group-macro-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_syntax-0.0.294",
- sha256 = "092f544af4e1c974924417ec5d1864544d99329d26ecc72cded2c99a86e6f710",
+ name = "vendor_ts__ra_ap_span-0.0.300",
+ sha256 = "c498ddf2d71705dcef9fb142269c0027c959a5eb17c435eea5466af7c3b9c47c",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_syntax/0.0.294/download"],
- strip_prefix = "ra_ap_syntax-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_syntax-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_span/0.0.300/download"],
+ strip_prefix = "ra_ap_span-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_span-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_syntax-bridge-0.0.294",
- sha256 = "3dcebacacf0a3fa1eac8f8ae57260602652fe4b2dbc3a1931cd854855fc744b2",
+ name = "vendor_ts__ra_ap_stdx-0.0.300",
+ sha256 = "26ade567b0d692c7efd4ceb921cdbe182beca0b5af9a5cf05c07cf0e14db512a",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_syntax-bridge/0.0.294/download"],
- strip_prefix = "ra_ap_syntax-bridge-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_syntax-bridge-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_stdx/0.0.300/download"],
+ strip_prefix = "ra_ap_stdx-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_stdx-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_toolchain-0.0.294",
- sha256 = "08f64f934312af8dde360d0327322452f14e772e6ddc5449629a3bd840127cdd",
+ name = "vendor_ts__ra_ap_syntax-0.0.300",
+ sha256 = "dba62d25b0296eb095d9db77e56d096417a89db4f4de1956add0d472ebcaf922",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_toolchain/0.0.294/download"],
- strip_prefix = "ra_ap_toolchain-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_toolchain-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_syntax/0.0.300/download"],
+ strip_prefix = "ra_ap_syntax-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_syntax-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_tt-0.0.294",
- sha256 = "48c511a2238fb0b8a1437ad99d8361f48d60ca5267faf457748d47657bddbf55",
+ name = "vendor_ts__ra_ap_syntax-bridge-0.0.300",
+ sha256 = "664466f2e824e285b671366f81128aa4a91b501fedbf7956a6bfb1f13d8b0b39",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_tt/0.0.294/download"],
- strip_prefix = "ra_ap_tt-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_tt-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_syntax-bridge/0.0.300/download"],
+ strip_prefix = "ra_ap_syntax-bridge-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_syntax-bridge-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_vfs-0.0.294",
- sha256 = "7b8a98fbdf277b873c08937c0d5357f44b33c6d689b96f331653c2df1bb82d29",
+ name = "vendor_ts__ra_ap_toolchain-0.0.300",
+ sha256 = "2ef82cfc5eb8f9d4a3be9876ce019b78fbfdb8ff4f7e4dee9e384d65122096ab",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_vfs/0.0.294/download"],
- strip_prefix = "ra_ap_vfs-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_vfs-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_toolchain/0.0.300/download"],
+ strip_prefix = "ra_ap_toolchain-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_toolchain-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__ra_ap_vfs-notify-0.0.294",
- sha256 = "9e1c54fc0e6b8bc6204a160019c80a26d4ca26c99729387e12d06c0bc421acdd",
+ name = "vendor_ts__ra_ap_tt-0.0.300",
+ sha256 = "cbc858f5208f0d00f8638d14ab5ffab5d1bc79ad7fe1db5c5e0d478b9a02155c",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/ra_ap_vfs-notify/0.0.294/download"],
- strip_prefix = "ra_ap_vfs-notify-0.0.294",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_vfs-notify-0.0.294.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_tt/0.0.300/download"],
+ strip_prefix = "ra_ap_tt-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_tt-0.0.300.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__rand-0.9.1",
- sha256 = "9fbfd9d094a40bf3ae768db9361049ace4c0e04a4fd6b359518bd7b73a73dd97",
+ name = "vendor_ts__ra_ap_vfs-0.0.300",
+ sha256 = "e065b27829f5281d2ffc41de72551a0e4c4f49a9989ba7721676f414100c8af2",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/rand/0.9.1/download"],
- strip_prefix = "rand-0.9.1",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.rand-0.9.1.bazel"),
+ urls = ["https://static.crates.io/crates/ra_ap_vfs/0.0.300/download"],
+ strip_prefix = "ra_ap_vfs-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_vfs-0.0.300.bazel"),
+ )
+
+ maybe(
+ http_archive,
+ name = "vendor_ts__ra_ap_vfs-notify-0.0.300",
+ sha256 = "5a3c795e86c9b5fcdbb99145e401a0d6348ed471ac96f1b7de151c0abe07a5af",
+ type = "tar.gz",
+ urls = ["https://static.crates.io/crates/ra_ap_vfs-notify/0.0.300/download"],
+ strip_prefix = "ra_ap_vfs-notify-0.0.300",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.ra_ap_vfs-notify-0.0.300.bazel"),
+ )
+
+ maybe(
+ http_archive,
+ name = "vendor_ts__rand-0.9.2",
+ sha256 = "6db2770f06117d490610c7488547d543617b21bfa07796d7a12f6f1bd53850d1",
+ type = "tar.gz",
+ urls = ["https://static.crates.io/crates/rand/0.9.2/download"],
+ strip_prefix = "rand-0.9.2",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.rand-0.9.2.bazel"),
)
maybe(
@@ -2651,12 +2681,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__rand_core-0.9.2",
- sha256 = "7a509b1a2ffbe92afab0e55c8fd99dea1c280e8171bd2d88682bb20bc41cbc2c",
+ name = "vendor_ts__rand_core-0.9.3",
+ sha256 = "99d9a13982dcf210057a8a78572b2217b667c3beacbf3a0d8b454f6f82837d38",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/rand_core/0.9.2/download"],
- strip_prefix = "rand_core-0.9.2",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.rand_core-0.9.2.bazel"),
+ urls = ["https://static.crates.io/crates/rand_core/0.9.3/download"],
+ strip_prefix = "rand_core-0.9.3",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.rand_core-0.9.3.bazel"),
)
maybe(
@@ -2789,16 +2819,6 @@ def crate_repositories():
build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.rustc-hash-2.1.1.bazel"),
)
- maybe(
- http_archive,
- name = "vendor_ts__rustc-literal-escaper-0.0.2",
- sha256 = "0041b6238913c41fe704213a4a9329e2f685a156d1781998128b4149c230ad04",
- type = "tar.gz",
- urls = ["https://static.crates.io/crates/rustc-literal-escaper/0.0.2/download"],
- strip_prefix = "rustc-literal-escaper-0.0.2",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.rustc-literal-escaper-0.0.2.bazel"),
- )
-
maybe(
http_archive,
name = "vendor_ts__rustc-literal-escaper-0.0.4",
@@ -2991,12 +3011,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__serde_json-1.0.140",
- sha256 = "20068b6e96dc6c9bd23e01df8827e6c7e1f2fddd43c21810382803c136b99373",
+ name = "vendor_ts__serde_json-1.0.142",
+ sha256 = "030fedb782600dcbd6f02d479bf0d817ac3bb40d644745b769d6a96bc3afc5a7",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/serde_json/1.0.140/download"],
- strip_prefix = "serde_json-1.0.140",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.serde_json-1.0.140.bazel"),
+ urls = ["https://static.crates.io/crates/serde_json/1.0.142/download"],
+ strip_prefix = "serde_json-1.0.142",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.serde_json-1.0.142.bazel"),
)
maybe(
@@ -3139,6 +3159,16 @@ def crate_repositories():
build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.synstructure-0.13.2.bazel"),
)
+ maybe(
+ http_archive,
+ name = "vendor_ts__temp-dir-0.1.16",
+ sha256 = "83176759e9416cf81ee66cb6508dbfe9c96f20b8b56265a39917551c23c70964",
+ type = "tar.gz",
+ urls = ["https://static.crates.io/crates/temp-dir/0.1.16/download"],
+ strip_prefix = "temp-dir-0.1.16",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.temp-dir-0.1.16.bazel"),
+ )
+
maybe(
http_archive,
name = "vendor_ts__text-size-1.1.1",
@@ -3241,12 +3271,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__toml-0.9.2",
- sha256 = "ed0aee96c12fa71097902e0bb061a5e1ebd766a6636bb605ba401c45c1650eac",
+ name = "vendor_ts__toml-0.9.5",
+ sha256 = "75129e1dc5000bfbaa9fee9d1b21f974f9fbad9daec557a521ee6e080825f6e8",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/toml/0.9.2/download"],
- strip_prefix = "toml-0.9.2",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.toml-0.9.2.bazel"),
+ urls = ["https://static.crates.io/crates/toml/0.9.5/download"],
+ strip_prefix = "toml-0.9.5",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.toml-0.9.5.bazel"),
)
maybe(
@@ -3281,12 +3311,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__toml_parser-1.0.1",
- sha256 = "97200572db069e74c512a14117b296ba0a80a30123fbbb5aa1f4a348f639ca30",
+ name = "vendor_ts__toml_parser-1.0.2",
+ sha256 = "b551886f449aa90d4fe2bdaa9f4a2577ad2dde302c61ecf262d80b116db95c10",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/toml_parser/1.0.1/download"],
- strip_prefix = "toml_parser-1.0.1",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.toml_parser-1.0.1.bazel"),
+ urls = ["https://static.crates.io/crates/toml_parser/1.0.2/download"],
+ strip_prefix = "toml_parser-1.0.2",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.toml_parser-1.0.2.bazel"),
)
maybe(
@@ -3591,12 +3621,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__wasi-0.13.3-wasi-0.2.2",
- sha256 = "26816d2e1a4a36a2940b96c5296ce403917633dff8f3440e9b236ed6f6bacad2",
+ name = "vendor_ts__wasi-0.14.2-wasi-0.2.4",
+ sha256 = "9683f9a5a998d873c0d21fcbe3c083009670149a8fab228644b8bd36b2c48cb3",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/wasi/0.13.3+wasi-0.2.2/download"],
- strip_prefix = "wasi-0.13.3+wasi-0.2.2",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.wasi-0.13.3+wasi-0.2.2.bazel"),
+ urls = ["https://static.crates.io/crates/wasi/0.14.2+wasi-0.2.4/download"],
+ strip_prefix = "wasi-0.14.2+wasi-0.2.4",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.wasi-0.14.2+wasi-0.2.4.bazel"),
)
maybe(
@@ -4061,12 +4091,12 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__wit-bindgen-rt-0.33.0",
- sha256 = "3268f3d866458b787f390cf61f4bbb563b922d091359f9608842999eaee3943c",
+ name = "vendor_ts__wit-bindgen-rt-0.39.0",
+ sha256 = "6f42320e61fe2cfd34354ecb597f86f413484a798ba44a8ca1165c58d42da6c1",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/wit-bindgen-rt/0.33.0/download"],
- strip_prefix = "wit-bindgen-rt-0.33.0",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.wit-bindgen-rt-0.33.0.bazel"),
+ urls = ["https://static.crates.io/crates/wit-bindgen-rt/0.39.0/download"],
+ strip_prefix = "wit-bindgen-rt-0.39.0",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.wit-bindgen-rt-0.39.0.bazel"),
)
maybe(
@@ -4111,42 +4141,22 @@ def crate_repositories():
maybe(
http_archive,
- name = "vendor_ts__zerocopy-0.7.35",
- sha256 = "1b9b4fd18abc82b8136838da5d50bae7bdea537c574d8dc1a34ed098d6c166f0",
+ name = "vendor_ts__zerocopy-0.8.26",
+ sha256 = "1039dd0d3c310cf05de012d8a39ff557cb0d23087fd44cad61df08fc31907a2f",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/zerocopy/0.7.35/download"],
- strip_prefix = "zerocopy-0.7.35",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.zerocopy-0.7.35.bazel"),
+ urls = ["https://static.crates.io/crates/zerocopy/0.8.26/download"],
+ strip_prefix = "zerocopy-0.8.26",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.zerocopy-0.8.26.bazel"),
)
maybe(
http_archive,
- name = "vendor_ts__zerocopy-0.8.20",
- sha256 = "dde3bb8c68a8f3f1ed4ac9221aad6b10cece3e60a8e2ea54a6a2dec806d0084c",
+ name = "vendor_ts__zerocopy-derive-0.8.26",
+ sha256 = "9ecf5b4cc5364572d7f4c329661bcc82724222973f2cab6f050a4e5c22f75181",
type = "tar.gz",
- urls = ["https://static.crates.io/crates/zerocopy/0.8.20/download"],
- strip_prefix = "zerocopy-0.8.20",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.zerocopy-0.8.20.bazel"),
- )
-
- maybe(
- http_archive,
- name = "vendor_ts__zerocopy-derive-0.7.35",
- sha256 = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e",
- type = "tar.gz",
- urls = ["https://static.crates.io/crates/zerocopy-derive/0.7.35/download"],
- strip_prefix = "zerocopy-derive-0.7.35",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.zerocopy-derive-0.7.35.bazel"),
- )
-
- maybe(
- http_archive,
- name = "vendor_ts__zerocopy-derive-0.8.20",
- sha256 = "eea57037071898bf96a6da35fd626f4f27e9cee3ead2a6c703cf09d472b2e700",
- type = "tar.gz",
- urls = ["https://static.crates.io/crates/zerocopy-derive/0.8.20/download"],
- strip_prefix = "zerocopy-derive-0.8.20",
- build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.zerocopy-derive-0.8.20.bazel"),
+ urls = ["https://static.crates.io/crates/zerocopy-derive/0.8.26/download"],
+ strip_prefix = "zerocopy-derive-0.8.26",
+ build_file = Label("//misc/bazel/3rdparty/tree_sitter_extractors_deps:BUILD.zerocopy-derive-0.8.26.bazel"),
)
maybe(
@@ -4230,48 +4240,48 @@ def crate_repositories():
)
return [
- struct(repo = "vendor_ts__anyhow-1.0.98", is_dev_dep = False),
+ struct(repo = "vendor_ts__anyhow-1.0.99", is_dev_dep = False),
struct(repo = "vendor_ts__argfile-0.2.1", is_dev_dep = False),
- struct(repo = "vendor_ts__chalk-ir-0.103.0", is_dev_dep = False),
+ struct(repo = "vendor_ts__chalk-ir-0.104.0", is_dev_dep = False),
struct(repo = "vendor_ts__chrono-0.4.41", is_dev_dep = False),
- struct(repo = "vendor_ts__clap-4.5.41", is_dev_dep = False),
+ struct(repo = "vendor_ts__clap-4.5.44", is_dev_dep = False),
struct(repo = "vendor_ts__dunce-1.0.5", is_dev_dep = False),
struct(repo = "vendor_ts__either-1.15.0", is_dev_dep = False),
struct(repo = "vendor_ts__encoding-0.2.33", is_dev_dep = False),
struct(repo = "vendor_ts__figment-0.10.19", is_dev_dep = False),
struct(repo = "vendor_ts__flate2-1.1.0", is_dev_dep = False),
- struct(repo = "vendor_ts__glob-0.3.2", is_dev_dep = False),
+ struct(repo = "vendor_ts__glob-0.3.3", is_dev_dep = False),
struct(repo = "vendor_ts__globset-0.4.15", is_dev_dep = False),
struct(repo = "vendor_ts__itertools-0.14.0", is_dev_dep = False),
struct(repo = "vendor_ts__lazy_static-1.5.0", is_dev_dep = False),
struct(repo = "vendor_ts__mustache-0.9.0", is_dev_dep = False),
struct(repo = "vendor_ts__num-traits-0.2.19", is_dev_dep = False),
struct(repo = "vendor_ts__num_cpus-1.17.0", is_dev_dep = False),
- struct(repo = "vendor_ts__proc-macro2-1.0.95", is_dev_dep = False),
+ struct(repo = "vendor_ts__proc-macro2-1.0.97", is_dev_dep = False),
struct(repo = "vendor_ts__quote-1.0.40", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_base_db-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_cfg-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_hir-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_hir_def-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_hir_expand-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_hir_ty-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_ide_db-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_intern-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_load-cargo-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_parser-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_paths-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_project_model-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_span-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_stdx-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_syntax-0.0.294", is_dev_dep = False),
- struct(repo = "vendor_ts__ra_ap_vfs-0.0.294", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_base_db-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_cfg-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_hir-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_hir_def-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_hir_expand-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_hir_ty-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_ide_db-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_intern-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_load-cargo-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_parser-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_paths-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_project_model-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_span-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_stdx-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_syntax-0.0.300", is_dev_dep = False),
+ struct(repo = "vendor_ts__ra_ap_vfs-0.0.300", is_dev_dep = False),
struct(repo = "vendor_ts__rayon-1.10.0", is_dev_dep = False),
struct(repo = "vendor_ts__regex-1.11.1", is_dev_dep = False),
struct(repo = "vendor_ts__serde-1.0.219", is_dev_dep = False),
- struct(repo = "vendor_ts__serde_json-1.0.140", is_dev_dep = False),
+ struct(repo = "vendor_ts__serde_json-1.0.142", is_dev_dep = False),
struct(repo = "vendor_ts__serde_with-3.14.0", is_dev_dep = False),
struct(repo = "vendor_ts__syn-2.0.104", is_dev_dep = False),
- struct(repo = "vendor_ts__toml-0.9.2", is_dev_dep = False),
+ struct(repo = "vendor_ts__toml-0.9.5", is_dev_dep = False),
struct(repo = "vendor_ts__tracing-0.1.41", is_dev_dep = False),
struct(repo = "vendor_ts__tracing-flame-0.2.0", is_dev_dep = False),
struct(repo = "vendor_ts__tracing-subscriber-0.3.19", is_dev_dep = False),
@@ -4281,7 +4291,7 @@ def crate_repositories():
struct(repo = "vendor_ts__triomphe-0.1.14", is_dev_dep = False),
struct(repo = "vendor_ts__ungrammar-1.16.1", is_dev_dep = False),
struct(repo = "vendor_ts__zstd-0.13.3", is_dev_dep = False),
- struct(repo = "vendor_ts__rand-0.9.1", is_dev_dep = True),
+ struct(repo = "vendor_ts__rand-0.9.2", is_dev_dep = True),
struct(repo = "vendor_ts__tree-sitter-json-0.24.8", is_dev_dep = True),
struct(repo = "vendor_ts__tree-sitter-ql-0.23.1", is_dev_dep = True),
]
From 338572f25661cdc6634a8d1dc05108d3b8021b5b Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 12 Aug 2025 17:04:26 +0200
Subject: [PATCH 079/298] Rust: run codegen again
---
rust/extractor/src/generated/.generated.list | 2 +-
rust/extractor/src/generated/top.rs | 122 +++++++++---------
rust/extractor/src/translate/generated.rs | 50 ++++---
rust/ql/.generated.list | 44 +++----
rust/ql/.gitattributes | 10 +-
rust/ql/lib/codeql/rust/elements.qll | 2 +-
.../lib/codeql/rust/elements/ClosureExpr.qll | 2 +-
.../{ClosureBinder.qll => ForBinder.qll} | 8 +-
.../lib/codeql/rust/elements/ForTypeRepr.qll | 2 +-
.../ql/lib/codeql/rust/elements/TypeBound.qll | 1 +
.../ql/lib/codeql/rust/elements/WherePred.qll | 2 +-
...nstructor.qll => ForBinderConstructor.qll} | 6 +-
...losureBinderImpl.qll => ForBinderImpl.qll} | 10 +-
.../internal/generated/ClosureExpr.qll | 14 +-
.../{ClosureBinder.qll => ForBinder.qll} | 20 +--
.../internal/generated/ForTypeRepr.qll | 14 +-
.../internal/generated/ParentChild.qll | 81 ++++++------
.../rust/elements/internal/generated/Raw.qll | 65 +++++-----
.../elements/internal/generated/Synth.qll | 44 +++----
.../internal/generated/SynthConstructors.qll | 2 +-
.../elements/internal/generated/TypeBound.qll | 16 +++
.../elements/internal/generated/WherePred.qll | 14 +-
rust/ql/lib/rust.dbscheme | 40 +++---
.../generated/.generated_tests.list | 2 +-
.../extractor-tests/generated/.gitattributes | 2 +-
.../generated/ClosureBinder/Cargo.lock | 7 -
.../ClosureBinder/ClosureBinder.expected | 4 -
.../generated/ClosureBinder/ClosureBinder.ql | 9 --
.../generated/ClosureExpr/ClosureExpr.ql | 4 +-
.../generated/ForBinder/ForBinder.ql | 9 ++
.../gen_for_binder.rs} | 4 +-
.../generated/ForTypeRepr/ForTypeRepr.ql | 4 +-
.../generated/TypeBound/TypeBound.ql | 4 +
.../generated/WherePred/WherePred.ql | 4 +-
rust/schema/annotations.py | 4 +-
rust/schema/ast.py | 13 +-
36 files changed, 328 insertions(+), 313 deletions(-)
rename rust/ql/lib/codeql/rust/elements/{ClosureBinder.qll => ForBinder.qll} (60%)
rename rust/ql/lib/codeql/rust/elements/internal/{ClosureBinderConstructor.qll => ForBinderConstructor.qll} (61%)
rename rust/ql/lib/codeql/rust/elements/internal/{ClosureBinderImpl.qll => ForBinderImpl.qll} (66%)
rename rust/ql/lib/codeql/rust/elements/internal/generated/{ClosureBinder.qll => ForBinder.qll} (58%)
delete mode 100644 rust/ql/test/extractor-tests/generated/ClosureBinder/Cargo.lock
delete mode 100644 rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.expected
delete mode 100644 rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.ql
create mode 100644 rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.ql
rename rust/ql/test/extractor-tests/generated/{ClosureBinder/gen_closure_binder.rs => ForBinder/gen_for_binder.rs} (68%)
diff --git a/rust/extractor/src/generated/.generated.list b/rust/extractor/src/generated/.generated.list
index 832ebc8a834..62fb59a50ca 100644
--- a/rust/extractor/src/generated/.generated.list
+++ b/rust/extractor/src/generated/.generated.list
@@ -1,2 +1,2 @@
mod.rs 4bcb9def847469aae9d8649461546b7c21ec97cf6e63d3cf394e339915ce65d7 4bcb9def847469aae9d8649461546b7c21ec97cf6e63d3cf394e339915ce65d7
-top.rs 0fc473b83d7cd550396b5c147829487fa7264121b6823fd371b78f55e48935b0 0fc473b83d7cd550396b5c147829487fa7264121b6823fd371b78f55e48935b0
+top.rs a2b836f6f4c1332cdc2bcf7a4201765f22635f976892725aa424d7b306b6b586 a2b836f6f4c1332cdc2bcf7a4201765f22635f976892725aa424d7b306b6b586
diff --git a/rust/extractor/src/generated/top.rs b/rust/extractor/src/generated/top.rs
index 0b658d2aebb..d8de082d024 100644
--- a/rust/extractor/src/generated/top.rs
+++ b/rust/extractor/src/generated/top.rs
@@ -835,56 +835,6 @@ impl From> for trap::Label {
}
}
-#[derive(Debug)]
-pub struct ClosureBinder {
- pub id: trap::TrapId,
- pub generic_param_list: Option>,
-}
-
-impl trap::TrapEntry for ClosureBinder {
- fn extract_id(&mut self) -> trap::TrapId {
- std::mem::replace(&mut self.id, trap::TrapId::Star)
- }
-
- fn emit(self, id: trap::Label, out: &mut trap::Writer) {
- out.add_tuple("closure_binders", vec![id.into()]);
- if let Some(v) = self.generic_param_list {
- out.add_tuple("closure_binder_generic_param_lists", vec![id.into(), v.into()]);
- }
- }
-}
-
-impl trap::TrapClass for ClosureBinder {
- fn class_name() -> &'static str { "ClosureBinder" }
-}
-
-impl From> for trap::Label {
- fn from(value: trap::Label) -> Self {
- // SAFETY: this is safe because in the dbscheme ClosureBinder is a subclass of AstNode
- unsafe {
- Self::from_untyped(value.as_untyped())
- }
- }
-}
-
-impl From> for trap::Label {
- fn from(value: trap::Label) -> Self {
- // SAFETY: this is safe because in the dbscheme ClosureBinder is a subclass of Locatable
- unsafe {
- Self::from_untyped(value.as_untyped())
- }
- }
-}
-
-impl From> for trap::Label {
- fn from(value: trap::Label) -> Self {
- // SAFETY: this is safe because in the dbscheme ClosureBinder is a subclass of Element
- unsafe {
- Self::from_untyped(value.as_untyped())
- }
- }
-}
-
#[derive(Debug)]
pub struct Expr {
_unused: ()
@@ -1011,6 +961,56 @@ impl From> for trap::Label {
}
}
+#[derive(Debug)]
+pub struct ForBinder {
+ pub id: trap::TrapId,
+ pub generic_param_list: Option>,
+}
+
+impl trap::TrapEntry for ForBinder {
+ fn extract_id(&mut self) -> trap::TrapId {
+ std::mem::replace(&mut self.id, trap::TrapId::Star)
+ }
+
+ fn emit(self, id: trap::Label, out: &mut trap::Writer) {
+ out.add_tuple("for_binders", vec![id.into()]);
+ if let Some(v) = self.generic_param_list {
+ out.add_tuple("for_binder_generic_param_lists", vec![id.into(), v.into()]);
+ }
+ }
+}
+
+impl trap::TrapClass for ForBinder {
+ fn class_name() -> &'static str { "ForBinder" }
+}
+
+impl From> for trap::Label {
+ fn from(value: trap::Label) -> Self {
+ // SAFETY: this is safe because in the dbscheme ForBinder is a subclass of AstNode
+ unsafe {
+ Self::from_untyped(value.as_untyped())
+ }
+ }
+}
+
+impl From> for trap::Label {
+ fn from(value: trap::Label) -> Self {
+ // SAFETY: this is safe because in the dbscheme ForBinder is a subclass of Locatable
+ unsafe {
+ Self::from_untyped(value.as_untyped())
+ }
+ }
+}
+
+impl From> for trap::Label {
+ fn from(value: trap::Label) -> Self {
+ // SAFETY: this is safe because in the dbscheme ForBinder is a subclass of Element
+ unsafe {
+ Self::from_untyped(value.as_untyped())
+ }
+ }
+}
+
#[derive(Debug)]
pub struct FormatArgsArg {
pub id: trap::TrapId,
@@ -2808,6 +2808,7 @@ impl From> for trap::Label {
#[derive(Debug)]
pub struct TypeBound {
pub id: trap::TrapId,
+ pub for_binder: Option>,
pub is_async: bool,
pub is_const: bool,
pub lifetime: Option>,
@@ -2822,6 +2823,9 @@ impl trap::TrapEntry for TypeBound {
fn emit(self, id: trap::Label, out: &mut trap::Writer) {
out.add_tuple("type_bounds", vec![id.into()]);
+ if let Some(v) = self.for_binder {
+ out.add_tuple("type_bound_for_binders", vec![id.into(), v.into()]);
+ }
if self.is_async {
out.add_tuple("type_bound_is_async", vec![id.into()]);
}
@@ -3308,7 +3312,7 @@ impl From> for trap::Label {
#[derive(Debug)]
pub struct WherePred {
pub id: trap::TrapId,
- pub generic_param_list: Option>,
+ pub for_binder: Option>,
pub lifetime: Option>,
pub type_repr: Option>,
pub type_bound_list: Option>,
@@ -3321,8 +3325,8 @@ impl trap::TrapEntry for WherePred {
fn emit(self, id: trap::Label, out: &mut trap::Writer) {
out.add_tuple("where_preds", vec![id.into()]);
- if let Some(v) = self.generic_param_list {
- out.add_tuple("where_pred_generic_param_lists", vec![id.into(), v.into()]);
+ if let Some(v) = self.for_binder {
+ out.add_tuple("where_pred_for_binders", vec![id.into(), v.into()]);
}
if let Some(v) = self.lifetime {
out.add_tuple("where_pred_lifetimes", vec![id.into(), v.into()]);
@@ -4450,7 +4454,7 @@ pub struct ClosureExpr {
pub param_list: Option>,
pub attrs: Vec>,
pub body: Option>,
- pub closure_binder: Option>,
+ pub for_binder: Option>,
pub is_async: bool,
pub is_const: bool,
pub is_gen: bool,
@@ -4475,8 +4479,8 @@ impl trap::TrapEntry for ClosureExpr {
if let Some(v) = self.body {
out.add_tuple("closure_expr_bodies", vec![id.into(), v.into()]);
}
- if let Some(v) = self.closure_binder {
- out.add_tuple("closure_expr_closure_binders", vec![id.into(), v.into()]);
+ if let Some(v) = self.for_binder {
+ out.add_tuple("closure_expr_for_binders", vec![id.into(), v.into()]);
}
if self.is_async {
out.add_tuple("closure_expr_is_async", vec![id.into()]);
@@ -5132,7 +5136,7 @@ impl From> for trap::Label {
#[derive(Debug)]
pub struct ForTypeRepr {
pub id: trap::TrapId,
- pub generic_param_list: Option>,
+ pub for_binder: Option>,
pub type_repr: Option>,
}
@@ -5143,8 +5147,8 @@ impl trap::TrapEntry for ForTypeRepr {
fn emit(self, id: trap::Label, out: &mut trap::Writer) {
out.add_tuple("for_type_reprs", vec![id.into()]);
- if let Some(v) = self.generic_param_list {
- out.add_tuple("for_type_repr_generic_param_lists", vec![id.into(), v.into()]);
+ if let Some(v) = self.for_binder {
+ out.add_tuple("for_type_repr_for_binders", vec![id.into(), v.into()]);
}
if let Some(v) = self.type_repr {
out.add_tuple("for_type_repr_type_reprs", vec![id.into(), v.into()]);
diff --git a/rust/extractor/src/translate/generated.rs b/rust/extractor/src/translate/generated.rs
index 3b9be2e1915..cbcb6f28c7b 100644
--- a/rust/extractor/src/translate/generated.rs
+++ b/rust/extractor/src/translate/generated.rs
@@ -688,21 +688,6 @@ impl Translator<'_> {
self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
Some(label)
}
- pub(crate) fn emit_closure_binder(
- &mut self,
- node: &ast::ClosureBinder,
- ) -> Option> {
- let generic_param_list = node
- .generic_param_list()
- .and_then(|x| self.emit_generic_param_list(&x));
- let label = self.trap.emit(generated::ClosureBinder {
- id: TrapId::Star,
- generic_param_list,
- });
- self.emit_location(label, node);
- self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
- Some(label)
- }
pub(crate) fn emit_closure_expr(
&mut self,
node: &ast::ClosureExpr,
@@ -712,9 +697,7 @@ impl Translator<'_> {
}
let attrs = node.attrs().filter_map(|x| self.emit_attr(&x)).collect();
let body = node.body().and_then(|x| self.emit_expr(&x));
- let closure_binder = node
- .closure_binder()
- .and_then(|x| self.emit_closure_binder(&x));
+ let for_binder = node.for_binder().and_then(|x| self.emit_for_binder(&x));
let is_async = node.async_token().is_some();
let is_const = node.const_token().is_some();
let is_gen = node.gen_token().is_some();
@@ -726,7 +709,7 @@ impl Translator<'_> {
id: TrapId::Star,
attrs,
body,
- closure_binder,
+ for_binder,
is_async,
is_const,
is_gen,
@@ -1064,6 +1047,21 @@ impl Translator<'_> {
self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
Some(label)
}
+ pub(crate) fn emit_for_binder(
+ &mut self,
+ node: &ast::ForBinder,
+ ) -> Option> {
+ let generic_param_list = node
+ .generic_param_list()
+ .and_then(|x| self.emit_generic_param_list(&x));
+ let label = self.trap.emit(generated::ForBinder {
+ id: TrapId::Star,
+ generic_param_list,
+ });
+ self.emit_location(label, node);
+ self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
+ Some(label)
+ }
pub(crate) fn emit_for_expr(
&mut self,
node: &ast::ForExpr,
@@ -1092,13 +1090,11 @@ impl Translator<'_> {
&mut self,
node: &ast::ForType,
) -> Option> {
- let generic_param_list = node
- .generic_param_list()
- .and_then(|x| self.emit_generic_param_list(&x));
+ let for_binder = node.for_binder().and_then(|x| self.emit_for_binder(&x));
let type_repr = node.ty().and_then(|x| self.emit_type(&x));
let label = self.trap.emit(generated::ForTypeRepr {
id: TrapId::Star,
- generic_param_list,
+ for_binder,
type_repr,
});
self.emit_location(label, node);
@@ -2805,6 +2801,7 @@ impl Translator<'_> {
&mut self,
node: &ast::TypeBound,
) -> Option> {
+ let for_binder = node.for_binder().and_then(|x| self.emit_for_binder(&x));
let is_async = node.async_token().is_some();
let is_const = node.const_token().is_some();
let lifetime = node.lifetime().and_then(|x| self.emit_lifetime(&x));
@@ -2814,6 +2811,7 @@ impl Translator<'_> {
.and_then(|x| self.emit_use_bound_generic_args(&x));
let label = self.trap.emit(generated::TypeBound {
id: TrapId::Star,
+ for_binder,
is_async,
is_const,
lifetime,
@@ -3058,9 +3056,7 @@ impl Translator<'_> {
&mut self,
node: &ast::WherePred,
) -> Option> {
- let generic_param_list = node
- .generic_param_list()
- .and_then(|x| self.emit_generic_param_list(&x));
+ let for_binder = node.for_binder().and_then(|x| self.emit_for_binder(&x));
let lifetime = node.lifetime().and_then(|x| self.emit_lifetime(&x));
let type_repr = node.ty().and_then(|x| self.emit_type(&x));
let type_bound_list = node
@@ -3068,7 +3064,7 @@ impl Translator<'_> {
.and_then(|x| self.emit_type_bound_list(&x));
let label = self.trap.emit(generated::WherePred {
id: TrapId::Star,
- generic_param_list,
+ for_binder,
lifetime,
type_repr,
type_bound_list,
diff --git a/rust/ql/.generated.list b/rust/ql/.generated.list
index 93680bc6a4a..2e88869bd68 100644
--- a/rust/ql/.generated.list
+++ b/rust/ql/.generated.list
@@ -36,8 +36,7 @@ lib/codeql/rust/elements/CallExpr.qll f336500ca7a611b164d48b90e80edb0c0d3816792b
lib/codeql/rust/elements/CallExprBase.qll 2846202b5208b541977500286951d96487bf555838c6c16cdd006a71e383745a c789d412bf099c624329379e0c7d94fa0d23ae2edea7a25a2ea0f3c0042ccf62
lib/codeql/rust/elements/Callable.qll 0f7f78c3bfabbe24962f6232b0440d27e51f06d2b8d341fc623ffbfbff173f47 5fd13aaa0eaf76ea0b47fa0641bd23eea20a069f0b3cbc1ee4e290e88321008a
lib/codeql/rust/elements/CastExpr.qll 2fe1f36ba31fa29de309baf0a665cfcae67b61c73345e8f9bbd41e8c235fec45 c5b4c1e9dc24eb2357799defcb2df25989075e3a80e8663b74204a1c1b70e29a
-lib/codeql/rust/elements/ClosureBinder.qll 02c8e83bf07deaf7bf0233b76623ec7f1837be8b77fe7e1c23544edc7d85e3c4 2b114d9a6dede694324aebe3dac80a802d139cfacd39beb0f12b5b0a46ee6390
-lib/codeql/rust/elements/ClosureExpr.qll 67e2a106e9154c90367b129987e574d2a9ecf5b297536627e43706675d35eaed d6a381132ddd589c5a7ce174f50f9620041ddf690e15a65ebfb05ff7e7c02de7
+lib/codeql/rust/elements/ClosureExpr.qll d122c769abc6c832dd1ad1b55d00aabc2f9029dd786f30905ac019e9e18517c0 56288c841c5e88cb603acb0d078ddeab8166f435b9545598293c0a59e9e84457
lib/codeql/rust/elements/Comment.qll fedad50575125e9a64a8a8776a8c1dbf1e76df990f01849d9f0955f9d74cb2a6 8eb1afad1e1007a4f0090fdac65d81726b23eda6517d067fd0185f70f17635ab
lib/codeql/rust/elements/Const.qll 5f4d11e01162a06127ba56519efd66d1ecfb5de7c1792fc1c283a56cf2127373 8c618ac774267d25db70cc05a080f8a408dc23ab7e88c0fc543eda8b4d4cb995
lib/codeql/rust/elements/ConstArg.qll 01865b3be4790c627a062c59ea608462931abcb2f94a132cf265318664fd1251 a2c6bbf63dbfa999e511b6941143a51c9392477d8ccd25e081f85475936ff558
@@ -57,8 +56,9 @@ lib/codeql/rust/elements/ExternItemList.qll eceb0fcd3a6f9d87fa044da1da112ce96b75
lib/codeql/rust/elements/FieldExpr.qll 8102cd659f9059cf6af2a22033cfcd2aae9c35204b86f7d219a05f1f8de54b3b f818169dddf5102095ae1410583615f80031376a08b5307d0c464e79953c3975
lib/codeql/rust/elements/FieldList.qll 72f3eace2f0c0600b1ad059819ae756f1feccd15562e0449a3f039a680365462 50e4c01df7b801613688b06bb47ccc36e6c8c7fa2e50cc62cb4705c9abf5ee31
lib/codeql/rust/elements/FnPtrTypeRepr.qll d4586ac5ee2382b5ef9daafa77c7b3c1b7564647aa20d1efb1626299cde87ba9 48d9b63725c9cd89d79f9806fa5d5f22d7815e70bbd78d8da40a2359ac53fef5
+lib/codeql/rust/elements/ForBinder.qll ee29b55cb4c1fa5180cc4ee1236ac089fe9f67ffa9e5a1474003b717f1ac6e0f 5b811c8cf9550cb675034315e03c5cbbfa7544ad3a696988e04d780037d434bf
lib/codeql/rust/elements/ForExpr.qll a050f60cf6fcc3ce66f5042be1b8096e5207fe2674d7477f9e299091ca99a4bd d7198495139649778894e930163add2d16b5588dd12bd6e094a9aec6863cb16f
-lib/codeql/rust/elements/ForTypeRepr.qll b3ba3a7f74f092397f7986542e59020bd7ea63eb8abc154d0f66f1415e1eaf6e a04750567cf85e11698a6b93674a651245537d08bf8aabf303a3626e190a4977
+lib/codeql/rust/elements/ForTypeRepr.qll 0315e6850eb09d9debdd6843e4ce0cfa15a4b9502f1b81dbaafcd263efc62511 e0e612a9686502f3ff48321fea28be6f0720dfd22aad929b446b573ae70297d4
lib/codeql/rust/elements/Format.qll 1b186730710e7e29ea47594998f0b359ad308927f84841adae0c0cb35fc8aeda d6f7bfdda60a529fb9e9a1975628d5bd11aa28a45e295c7526692ac662fd19f8
lib/codeql/rust/elements/FormatArgsArg.qll a2c23cd512d44dd60b7d65eba52cc3adf6e2fbbcd0588be375daa16002cd7741 d9c5fe183fb228375223d83f857b7a9ee686f1d3e341bcf323d7c6f39652f88b
lib/codeql/rust/elements/FormatArgsExpr.qll 8127cbe4082f7acc3d8a05298c2c9bea302519b8a6cd2d158a83c516d18fc487 88cf9b3bedd69a1150968f9a465c904bbb6805da0e0b90cfd1fc0dab1f6d9319
@@ -168,7 +168,7 @@ lib/codeql/rust/elements/TupleStructPat.qll da398a23eb616bf7dd586b2a87f4ab00f286
lib/codeql/rust/elements/TupleTypeRepr.qll 1ac5abf6281ea31680a4098407fbe55459d08f92a50dec20d1f8b93d498eee41 6d9625cce4e4abf6b6e6c22e47880fbd23740d07b621137bd7fa0a2ee13badd9
lib/codeql/rust/elements/TypeAlias.qll b59f24488f0d7de8d4046a9e0ca1e1f54d1d5c11e035898b11ab97e151fc600f 7b25c9e14c8bb310cec796824904fcefced2cc486d55e981b80b7620e73dd2d7
lib/codeql/rust/elements/TypeArg.qll e91dbb399d2ab7cf7af9dd5f743a551d0bf91dba3cfb76cea9e2d42ada0f9f2e c67d64e20e35a9bba5092651e0f82c75ba53b8c165e823bc81d67975107ae375
-lib/codeql/rust/elements/TypeBound.qll a1645f31a789995af85b1db236caece180013cc2e28e1c50b792dc0d4ab0854e 14a68ebef2149bc657ba1f18606ef8cf9b7cc3e6113b50bc038c168eb6cfd11c
+lib/codeql/rust/elements/TypeBound.qll d5b2a904e497ba1899fb9e19547a6dfa7716c8aabe1e6e19070cbb58af32321b eabb16616afe3e88a25db4519174828a7ead1eb69ec7f98ef4abf4b3ead1c220
lib/codeql/rust/elements/TypeBoundList.qll 61a861e89b3de23801c723531cd3331a61214817a230aaae74d91cb60f0e096f d54e3d830bb550c5ba082ccd09bc0dc4e6e44e8d11066a7afba5a7172aa687a8
lib/codeql/rust/elements/TypeParam.qll 0787c1cc0c121e5b46f7d8e25153fd1b181bd3432eb040cf3b4ae3ed9ac2f28c 50092950f52a4e3bfd961dff4ffd8a719ef66ca1a0914bd33e26fed538321999
lib/codeql/rust/elements/TypeRepr.qll ea41b05ef0aaac71da460f9a6a8331cf98166f2c388526068ddacbd67488c892 11a01e42dab9183bac14de1ca49131788ede99e75b0ef759efcbc7cf08524184
@@ -185,7 +185,7 @@ lib/codeql/rust/elements/Variant.qll 7895461fa728f6c3a7293799c5e6b965b413b679566
lib/codeql/rust/elements/VariantList.qll 39803fbb873d48202c2a511c00c8eafede06e519894e0fd050c2a85bf5f4aa73 1735f89b2b8f6d5960a276b87ea10e4bb8c848c24a5d5fad7f3add7a4d94b7da
lib/codeql/rust/elements/Visibility.qll aa69e8a3fd3b01f6fea0ae2d841a2adc51f4e46dcfc9f8f03c34fbe96f7e24e7 0d475e97e07b73c8da2b53555085b8309d8dc69c113bcb396fc901361dbfe6b8
lib/codeql/rust/elements/WhereClause.qll 4e28e11ceec835a093e469854a4b615e698309cdcbc39ed83810e2e4e7c5953f 4736baf689b87dd6669cb0ef9e27eb2c0f2776ce7f29d7693670bbcea06eb4e4
-lib/codeql/rust/elements/WherePred.qll 490395b468c87d5c623f6741dc28512ee371cbf479ea77aee7e61b20544f5732 782f74b101d374a71908069be3db23755ab1473ffe879b368be73a5fdc6eac3a
+lib/codeql/rust/elements/WherePred.qll 35ef2580d20ffa6fadb05ea38152b5e4953b4dc827326e96969cd86d2dfdbfdc 6b8f7abf81bfeff7a16539f6a18746e02daedad42145b1c5a0b8cfa33676cbf8
lib/codeql/rust/elements/WhileExpr.qll 4a37e3ecd37c306a9b93b610a0e45e18adc22fcd4ce955a519b679e9f89b97e8 82026faa73b94390544e61ed2f3aaeaabd3e457439bb76d2fb06b0d1edd63f49
lib/codeql/rust/elements/WildcardPat.qll 4f941afc5f9f8d319719312399a8f787c75a0dbb709ec7cf488f019339635aab a9140a86da752f9126e586ddb9424b23b3fb4841a5420bac48108c38bb218930
lib/codeql/rust/elements/YeetExpr.qll 4172bf70de31cab17639da6eed4a12a7afcefd7aa9182216c3811c822d3d6b17 88223aab1bef696f508e0605615d6b83e1eaef755314e6a651ae977edd3757c3
@@ -241,8 +241,6 @@ lib/codeql/rust/elements/internal/BoxPatConstructor.qll 153f110ba25fd6c889092bfd
lib/codeql/rust/elements/internal/BreakExprConstructor.qll 356be043c28e0b34fdf925a119c945632ee883c6f5ebb9a27003c6a8d250afd9 bb77e66b04bb9489340e7506931559b94285c6904b6f9d2f83b214cba4f3cfd5
lib/codeql/rust/elements/internal/CallExprConstructor.qll 742b38e862e2cf82fd1ecc4d4fc5b4782a9c7c07f031452b2bae7aa59d5aa13a cad6e0a8be21d91b20ac2ec16cab9c30eae810b452c0f1992ed87d5c7f4144dc
lib/codeql/rust/elements/internal/CastExprConstructor.qll f3d6e10c4731f38a384675aeab3fba47d17b9e15648293787092bb3247ed808d d738a7751dbadb70aa1dcffcf8af7fa61d4cf8029798369a7e8620013afff4ed
-lib/codeql/rust/elements/internal/ClosureBinderConstructor.qll 6e376ab9d40308e95bcdaf1cc892472c92099d477720192cd382d2c4e0d9c8a1 60a0efe50203ad5bb97bdfc06d602182edcc48ac9670f2d27a9675bd9fd8e19f
-lib/codeql/rust/elements/internal/ClosureBinderImpl.qll 9f6ce7068b5c17df44f00037ebb42e6c8fdbbbd09bf89951221fb04f378fbdf1 6e6e372e151fe0b0f17a5ea0ed774553b6ed0bf53e1d377e5ed24a0f98529735
lib/codeql/rust/elements/internal/ClosureExprConstructor.qll a348229d2b25c7ebd43b58461830b7915e92d31ae83436ec831e0c4873f6218a 70a1d2ac33db3ac4da5826b0e8628f2f29a8f9cdfd8e4fd0e488d90ce0031a38
lib/codeql/rust/elements/internal/CommentConstructor.qll 0b4a6a976d667bf7595500dfb91b9cfc87460a501837ba5382d9a8d8321d7736 7d02d8c94a319dc48e7978d5270e33fc5c308d443768ff96b618236d250123f1
lib/codeql/rust/elements/internal/ConstArgConstructor.qll f63021dc1ca2276786da3a981d06c18d7a360b5e75c08bca5d1afece4f7c4a83 487a870cbf5ed6554d671a8e159edd9261d853eba2d28ce2bd459759f47f11f2
@@ -273,6 +271,8 @@ lib/codeql/rust/elements/internal/FieldExprConstructor.qll b3be2c4ccaf2c8a1283f3
lib/codeql/rust/elements/internal/FieldListImpl.qll 6b80b573989ee85389c4485729a40c92c7e0a5b8a96a4385e812c74fb63c894f d333bcb043616b95ffefed4d216f94e5b07541f8153e4fb8084f4e793947b023
lib/codeql/rust/elements/internal/FnPtrTypeReprConstructor.qll 61d8808ea027a6e04d5304c880974332a0195451f6b4474f84b3695ec907d865 0916c63a02b01a839fe23ec8b189d37dc1b8bc4e1ba753cbf6d6f5067a46965a
lib/codeql/rust/elements/internal/FnPtrTypeReprImpl.qll 6b66f9bda1b5deba50a02b6ac7deb8e922da04cf19d6ed9834141bc97074bf14 b0a07d7b9204256a85188fda2deaf14e18d24e8a881727fd6e5b571bf9debdc8
+lib/codeql/rust/elements/internal/ForBinderConstructor.qll 98f16b0106a19210713404f4be8b1b9f70c88efb0b88bdf2f9ea9c8fbd129842 a7af9e75f11d824a60c367924542a31a0f46f7b1f88d3ee330d4dd26b2f29df5
+lib/codeql/rust/elements/internal/ForBinderImpl.qll 62e957e4e8a68816defed494e706a37a83ad30a455ded913b48c2c3d9c51d728 e38e1b93963513704efebec2c63e5f9a9eae372fe88e1dc8c480885e21528121
lib/codeql/rust/elements/internal/ForExprConstructor.qll d79b88dac19256300b758ba0f37ce3f07e9f848d6ae0c1fdb87bd348e760aa3e 62123b11858293429aa609ea77d2f45cb8c8eebae80a1d81da6f3ad7d1dbc19b
lib/codeql/rust/elements/internal/ForTypeReprConstructor.qll eae141dbe9256ab0eb812a926ebf226075d150f6506dfecb56c85eb169cdc76b 721c2272193a6f9504fb780d40e316a93247ebfb1f302bb0a0222af689300245
lib/codeql/rust/elements/internal/ForTypeReprImpl.qll 75747779312b3f3ffdd02188053ba3f46b8922f02630711902f7a27eecced31a 71a900f014758d1473ef198c71892d42e20dd96e934d4bedb74581964c4d1503
@@ -492,8 +492,7 @@ lib/codeql/rust/elements/internal/generated/CallExpr.qll f1b8dae487077cc9d1dccf8
lib/codeql/rust/elements/internal/generated/CallExprBase.qll 2268e01d65015014c05166161bb28e5a1e78164d525ca16fc1e3106866cf231d b2f9b912153ba4d3e3612df4f74ac0e83077c31d5b31383bd277974081417a56
lib/codeql/rust/elements/internal/generated/Callable.qll 9a8661aa018fd90a21529760c1dbc46c1ad3649e17b030e59ced0683fbf83f8a 8b573adfc23ec0ac91949da415e6a0c988fa02cbce9534d45ac98a5512d7b1ca
lib/codeql/rust/elements/internal/generated/CastExpr.qll ddc20054b0b339ad4d40298f3461490d25d00af87c876da5ffbc6a11c0832295 f4247307afcd74d80e926f29f8c57e78c50800984483e6b6003a44681e4a71f3
-lib/codeql/rust/elements/internal/generated/ClosureBinder.qll ab199df96f525a083a0762fd654cd098802033c79700a593bb204a9a0c69ec01 86b33543e0886715830cfcdaca43b555a242a4f12a4caa18b88732d5afb584bd
-lib/codeql/rust/elements/internal/generated/ClosureExpr.qll 34149bf82f107591e65738221e1407ec1dc9cc0dfb10ae7f761116fda45162de fd2fbc9a87fc0773c940db64013cf784d5e4137515cc1020e2076da329f5a952
+lib/codeql/rust/elements/internal/generated/ClosureExpr.qll d5deef5d257b313e3fa3ad292c8af26db32f45446dc88009515435344aed1efc eb8d0394255e7dc005ef5c729ae851b78b4a0d838c3ac2460b4e715bbdb5e97f
lib/codeql/rust/elements/internal/generated/Comment.qll cd1ef861e3803618f9f78a4ac00516d50ecfecdca1c1d14304dc5327cbe07a3b 8b67345aeb15beb5895212228761ea3496297846c93fd2127b417406ae87c201
lib/codeql/rust/elements/internal/generated/Const.qll 3e606f0198b6461a94964dba7a4d386408f01651d75378eeab251dfceccf49c8 20fe276cded4764bdb1cd50de956bea88d7cd731909c0b84b4abb972b3094959
lib/codeql/rust/elements/internal/generated/ConstArg.qll c52bf746f2dc89b8d71b8419736707bfcbb09cca424c3ba76e888e2add415bf6 89309a9df4fde23cfd3d8492908ccec4d90cc8457d35c507ef81371a369941b4
@@ -514,8 +513,9 @@ lib/codeql/rust/elements/internal/generated/ExtractorStep.qll 61cd504a1aab98b1c9
lib/codeql/rust/elements/internal/generated/FieldExpr.qll d6077fcc563702bb8d626d2fda60df171023636f98b4a345345e131da1a03dfc 03f9eb65abfab778e6d2c7090c08fe75c38c967302f5a9fa96ab0c24e954929d
lib/codeql/rust/elements/internal/generated/FieldList.qll 35bb72a673c02afafc1f6128aeb26853d3a1cdbaea246332affa17a023ece70e b7012dd214788de9248e9ab6eea1a896329d5731fa0b39e23df1b39df2b7eb9c
lib/codeql/rust/elements/internal/generated/FnPtrTypeRepr.qll f218fa57a01ecc39b58fa15893d6499c15ff8ab8fd9f4ed3078f0ca8b3f15c7e 2d1a7325cf2bd0174ce6fc15e0cbe39c7c1d8b40db5f91e5329acb339a1ad1e8
+lib/codeql/rust/elements/internal/generated/ForBinder.qll 7be6b8e3934db8cd4ac326625cf637dda4b175fd7573a52d2feb147769c4c6a1 234484b9b4cf3a20c97334417700db5029da65313410b3c9e929512c509e5c27
lib/codeql/rust/elements/internal/generated/ForExpr.qll 7c497d2c612fd175069037d6d7ff9339e8aec63259757bb56269e9ca8b0114ea dc48c0ad3945868d6bd5e41ca34a41f8ee74d8ba0adc62b440256f59c7f21096
-lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll 36ea243bd5ada10c586d9430464761849506b91754cf045c59f4ae194e78a456 cc65dc72c87d0ad7be3263bbdd1c515a057e62e97b0a28f9c4b0f689ac3566b7
+lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll a8fcdff13e30cce9c30fc3ae81db9ee7160b3028872cb3a60db78523a3ffe771 d3dda40fd2547bd1acd2eeb4d1bc72a4487400bb0752e9679bbb6aea0debf35a
lib/codeql/rust/elements/internal/generated/Format.qll 934351f8a8ffd914cc3fd88aca8e81bf646236fe34d15e0df7aeeb0b942b203f da9f146e6f52bafd67dcfd3b916692cf8f66031e0b1d5d17fc8dda5eefb99ca0
lib/codeql/rust/elements/internal/generated/FormatArgsArg.qll c762a4af8609472e285dd1b1aec8251421aec49f8d0e5ce9df2cc5e2722326f8 c8c226b94b32447634b445c62bd9af7e11b93a706f8fa35d2de4fda3ce951926
lib/codeql/rust/elements/internal/generated/FormatArgsExpr.qll 8aed8715a27d3af3de56ded4610c6792a25216b1544eb7e57c8b0b37c14bd9c1 590a2b0063d2ecd00bbbd1ce29603c8fd69972e34e6daddf309c915ce4ec1375
@@ -575,7 +575,7 @@ lib/codeql/rust/elements/internal/generated/ParamList.qll eaa0cd4402d3665013d47e
lib/codeql/rust/elements/internal/generated/ParenExpr.qll 812d2ff65079277f39f15c084657a955a960a7c1c0e96dd60472a58d56b945eb eb8c607f43e1fcbb41f37a10de203a1db806690e10ff4f04d48ed874189cb0eb
lib/codeql/rust/elements/internal/generated/ParenPat.qll 24f9dc7fce75827d6fddb856cd48f80168143151b27295c0bab6db5a06567a09 ebadbc6f5498e9ed754b39893ce0763840409a0721036a25b56e1ead7dcc09aa
lib/codeql/rust/elements/internal/generated/ParenTypeRepr.qll 03f5c5b96a37adeb845352d7fcea3e098da9050e534972d14ac0f70d60a2d776 ed3d6e5d02086523087adebce4e89e35461eb95f2a66d1d4100fe23fc691b126
-lib/codeql/rust/elements/internal/generated/ParentChild.qll c7958f4e110f4afb810b06946309bf766305cc4d92c92695ae8f06b3f321ddcd 8150b0550b639cffc7c989c32fc3951fad32ec82ad838f359527a473bdb95a3f
+lib/codeql/rust/elements/internal/generated/ParentChild.qll 389ee1eea791f9d2a5eb9ae49d2aa61607f8cdb3f3d5752d5c067122029de66a 50875ace3751c001acc11fa596ea1cd8c8b17dd925344c2d91d338b3f864df0d
lib/codeql/rust/elements/internal/generated/ParenthesizedArgList.qll d901fdc8142a5b8847cc98fc2afcfd16428b8ace4fbffb457e761b5fd3901a77 5dbb0aea5a13f937da666ccb042494af8f11e776ade1459d16b70a4dd193f9fb
lib/codeql/rust/elements/internal/generated/Pat.qll 3605ac062be2f294ee73336e9669027b8b655f4ad55660e1eab35266275154ee 7f9400db2884d336dd1d21df2a8093759c2a110be9bf6482ce8e80ae0fd74ed4
lib/codeql/rust/elements/internal/generated/Path.qll 9b12afb46fc5a9ad3a811b05472621bbecccb900c47504feb7f29d96b28421ca bcacbffc36fb3e0c9b26523b5963af0ffa9fd6b19f00a2a31bdb2316071546bd
@@ -590,7 +590,7 @@ lib/codeql/rust/elements/internal/generated/PtrTypeRepr.qll 8d0ea4f6c7f8203340bf
lib/codeql/rust/elements/internal/generated/PureSynthConstructors.qll e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f
lib/codeql/rust/elements/internal/generated/RangeExpr.qll 23cca03bf43535f33b22a38894f70d669787be4e4f5b8fe5c8f7b964d30e9027 18624cef6c6b679eeace2a98737e472432e0ead354cca02192b4d45330f047c9
lib/codeql/rust/elements/internal/generated/RangePat.qll 80826a6a6868a803aa2372e31c52a03e1811a3f1f2abdb469f91ca0bfdd9ecb6 34ee1e208c1690cba505dff2c588837c0cd91e185e2a87d1fe673191962276a9
-lib/codeql/rust/elements/internal/generated/Raw.qll 7448186873413f4aa7762c990c1c699e3a379280f0260bc76524386aefe567f1 07acbe3eabaa87147757989e8616046fff218669677e7d3d6465fbda639519e1
+lib/codeql/rust/elements/internal/generated/Raw.qll 3c38cd761b847ba5744810479901692fe1a28759d8305f828ff535c034f21f97 56f75a0589112d66f234c99b0c3798ed928b3a808ebb7d37590cf5868aad9c10
lib/codeql/rust/elements/internal/generated/RefExpr.qll 7d995884e3dc1c25fc719f5d7253179344d63650e217e9ff6530285fe7a57f64 f2c3c12551deea4964b66553fb9b6423ee16fec53bd63db4796191aa60dc6c66
lib/codeql/rust/elements/internal/generated/RefPat.qll 456ede39837463ee22a630ec7ab6c8630d3664a8ea206fcc6e4f199e92fa564c 5622062765f32930465ba6b170e986706f159f6070f48adee3c20e24e8df4e05
lib/codeql/rust/elements/internal/generated/RefTypeRepr.qll 5b0663a6d234572fb3e467e276d019415caa95ef006438cc59b7af4e1783161e 0e27c8a8f0e323c0e4d6db01fca821bf07c0864d293cdf96fa891b10820c1e4b
@@ -616,8 +616,8 @@ lib/codeql/rust/elements/internal/generated/StructFieldList.qll 5da528a51a6a5db9
lib/codeql/rust/elements/internal/generated/StructPat.qll c76fa005c2fd0448a8803233e1e8818c4123301eb66ac5cf69d0b9eaafc61e98 6e0dffccdce24bca20e87d5ba0f0995c9a1ae8983283e71e7dbfcf6fffc67a58
lib/codeql/rust/elements/internal/generated/StructPatField.qll 5b5c7302dbc4a902ca8e69ff31875c867e295a16a626ba3cef29cd0aa248f179 4e192a0df79947f5cb0d47fdbbba7986137a6a40a1be92ae119873e2fad67edf
lib/codeql/rust/elements/internal/generated/StructPatFieldList.qll 1a95a1bd9f64fb18e9571657cf2d02a8b13c747048a1f0f74baf31b91f0392ad fc274e414ff4ed54386046505920de92755ad0b4d39a7523cdffa4830bd53b37
-lib/codeql/rust/elements/internal/generated/Synth.qll 39bd329c2efef8691106070107356da0c336d10cb395aa2129ceb6108db27357 5369b56fe14c1961b38af4288b512dfaf09fc4264efced468af5fc6da403ac04
-lib/codeql/rust/elements/internal/generated/SynthConstructors.qll bcc7f617b775ac0c7f04b1cc333ed7cc0bd91f1fabc8baa03c824d1df03f6076 bcc7f617b775ac0c7f04b1cc333ed7cc0bd91f1fabc8baa03c824d1df03f6076
+lib/codeql/rust/elements/internal/generated/Synth.qll e1f47da257976aa7689461ee3ea9022fc0d27494a556f14f1086f8149b885d5c 59b979f378be6ce75ecfd3430887bff747c273d1536c686f90def9e6c4ed2c12
+lib/codeql/rust/elements/internal/generated/SynthConstructors.qll f41abfc73415b7accb38da7c107faebfe6843c270ad54e0e54a96e930dfe479a f41abfc73415b7accb38da7c107faebfe6843c270ad54e0e54a96e930dfe479a
lib/codeql/rust/elements/internal/generated/Token.qll 77a91a25ca5669703cf3a4353b591cef4d72caa6b0b9db07bb9e005d69c848d1 2fdffc4882ed3a6ca9ac6d1fb5f1ac5a471ca703e2ffdc642885fa558d6e373b
lib/codeql/rust/elements/internal/generated/TokenTree.qll 1a3c4f5f30659738641abdd28cb793dab3cfde484196b59656fc0a2767e53511 de2ebb210c7759ef7a6f7ee9f805e1cac879221287281775fc80ba34a5492edf
lib/codeql/rust/elements/internal/generated/Trait.qll 8fa41b50fa0f68333534f2b66bb4ec8e103ff09ac8fa5c2cc64bc04beafec205 ce1c9aa6d0e2f05d28aab8e1165c3b9fb8e24681ade0cf6a9df2e8617abeae7e
@@ -631,7 +631,7 @@ lib/codeql/rust/elements/internal/generated/TupleStructPat.qll 6539d0edbdc16e7df
lib/codeql/rust/elements/internal/generated/TupleTypeRepr.qll 1756cdbad56d634bf4726bc39c768386754e62650492d7d6344012038236a05b 3ac0997a47f95f28cc70c782173ce345fcb5b073be10f3c0b414d1df8443e04c
lib/codeql/rust/elements/internal/generated/TypeAlias.qll 0d0c97d9e9213b8f0390b3456737d4611701a570b9943bb20b348c4efc8e4693 a83c701c0d8914e01517dfa9253a12be962f0a7ed2f75fbaae25a13432db403f
lib/codeql/rust/elements/internal/generated/TypeArg.qll 80245e4b52bef30e5033d4c765c72531324385deea1435dc623290271ff05b1d 097926e918dcd897ea1609010c5490dbf45d4d8f4cffb9166bcadf316a2f1558
-lib/codeql/rust/elements/internal/generated/TypeBound.qll fa5cf5370c3f69e687b5fc888d2ca29d0a45bd0824d1159a202eafae29e70601 e3bc6a1e5c0af374c60e83396c5b0ceda499fabd300c25017ae7d4d5b234b264
+lib/codeql/rust/elements/internal/generated/TypeBound.qll 15e118049bb5aae24bce580e3dff62b7e73dcce9f7c6bc8dfd59d2c25ed64244 f18a35749f8fc003221e8f4315160756be592406637441929eda919ac493e835
lib/codeql/rust/elements/internal/generated/TypeBoundList.qll c5d43dc27075a0d5370ba4bc56b4e247357af5d2989625deff284e7846a3a48b c33c87d080e6eb6df01e98b8b0031d780472fcaf3a1ed156a038669c0e05bf0a
lib/codeql/rust/elements/internal/generated/TypeParam.qll 81a8d39f1e227de031187534e5d8e2c34f42ad3433061d686cadfbdd0df54285 893795d62b5b89997574e9057701d308bea2c4dca6053042c5308c512137e697
lib/codeql/rust/elements/internal/generated/TypeRepr.qll 1e7b9d2ddab86e35dad7c31a6453a2a60747420f8bc2e689d5163cab4fec71bb eb80e3947649e511e7f3555ffc1fd87199e7a32624449ca80ffad996cdf9e2f3
@@ -648,12 +648,12 @@ lib/codeql/rust/elements/internal/generated/Variant.qll fa6909715133049b3dba4622
lib/codeql/rust/elements/internal/generated/VariantList.qll 3f70bfde982e5c5e8ee45da6ebe149286214f8d40377d5bc5e25df6ae8f3e2d1 22e5f428bf64fd3fd21c537bfa69a46089aad7c363d72c6566474fbe1d75859e
lib/codeql/rust/elements/internal/generated/Visibility.qll af1069733c0120fae8610b3ebbcdcebe4b4c9ce4c3e3d9be3f82a93541873625 266106bdff4d7041d017871d755c011e7dd396c5999803d9e46725b6a03a2458
lib/codeql/rust/elements/internal/generated/WhereClause.qll aec72d358689d99741c769b6e8e72b92c1458138c097ec2380e917aa68119ff0 81bb9d303bc0c8d2513dc7a2b8802ec15345b364e6c1e8b300f7860aac219c36
-lib/codeql/rust/elements/internal/generated/WherePred.qll 9aa63abdf1202ee4708e7413401811d481eac55ba576a4950653395f931d1e90 ebb9f2883f811ea101220eac13d02d2893d2ec0231a29826a32b77cb2c88a5f8
+lib/codeql/rust/elements/internal/generated/WherePred.qll 6826373cede8b4ac5d4719a183c6b30f840d48266f0e0c8e400574476f5a2f15 a82dcc24efac562d5b6247f9a105465ebafc9bebb4fc3648518bf9166e300dbd
lib/codeql/rust/elements/internal/generated/WhileExpr.qll 0353aab87c49569e1fbf5828b8f44457230edfa6b408fb5ec70e3d9b70f2e277 e1ba7c9c41ff150b9aaa43642c0714def4407850f2149232260c1a2672dd574a
lib/codeql/rust/elements/internal/generated/WildcardPat.qll d74b70b57a0a66bfae017a329352a5b27a6b9e73dd5521d627f680e810c6c59e 4b913b548ba27ff3c82fcd32cf996ff329cb57d176d3bebd0fcef394486ea499
lib/codeql/rust/elements/internal/generated/YeetExpr.qll cac328200872a35337b4bcb15c851afb4743f82c080f9738d295571eb01d7392 94af734eea08129b587fed849b643e7572800e8330c0b57d727d41abda47930b
lib/codeql/rust/elements/internal/generated/YieldExpr.qll 37e5f0c1e373a22bbc53d8b7f2c0e1f476e5be5080b8437c5e964f4e83fad79a 4a9a68643401637bf48e5c2b2f74a6bf0ddcb4ff76f6bffb61d436b685621e85
-lib/codeql/rust/elements.qll 6ebcf16ef214075bc43562c246c11f8b90c089ff1b5041ab1b39ab9f4a40e9b3 6ebcf16ef214075bc43562c246c11f8b90c089ff1b5041ab1b39ab9f4a40e9b3
+lib/codeql/rust/elements.qll 49df59c1b9574135b6ff2b0480b645f7303e81df042714b22b1070351d0076b9 49df59c1b9574135b6ff2b0480b645f7303e81df042714b22b1070351d0076b9
test/extractor-tests/generated/Abi/Abi.ql 086ed104ab1a7e7fe5c1ed29e03f1719a797c7096c738868bf6ebe872ab8fdaa fe23fe67ab0d9201e1177ea3f844b18ed428e13e3ce77381bf2b6910adfa3a0e
test/extractor-tests/generated/ArgList/ArgList.ql da97b5b25418b2aa8cb8df793f48870c89fa00759cdade8ddba60d7f1f4bbc01 acfd5d2caf67282ad2d57b961068472100482d0f770a52a3c00214c647d18c75
test/extractor-tests/generated/ArrayListExpr/ArrayListExpr.ql 42b365276aa43e2cad588338463542d3ce1dd0db3a428621554584b07a1431d5 08a66a8b69af35ee3bc64c35c453a19a6c9881cc6cc7e65275d1fff056121270
@@ -681,8 +681,7 @@ test/extractor-tests/generated/BoxPat/BoxPat.ql 854c9ba4e045dbe7ea1666866c1c443a
test/extractor-tests/generated/BreakExpr/BreakExpr.ql c2181211da3dfe983cfca93ead32d5d211e91181899b9477152c58124eaa846d 57e57b926e14db2efb2e88e04699608b2ba9797ee4f6c4f710135b6858982256
test/extractor-tests/generated/CallExpr/CallExpr.ql 2a1cd4485ccd8d4eb24a75889e832612adef9bb7feae414c90572796380bc6d7 95060b92aa04d7ad1fc6603c5ec14a275a5788ecb5a19932732e28105607a3b7
test/extractor-tests/generated/CastExpr/CastExpr.ql 3480ec51072399409b7553ab6139c832db6ed4ca991f3a7a2282a39afe07c6f2 614c8ea7a2fe30d57583dbf84ed7a12743c2aba49d8c6252d31af3ed10853a39
-test/extractor-tests/generated/ClosureBinder/ClosureBinder.ql b68285fec6224b156754f51ee75a9b7ed32edaa16527e6f657a73bf6dd97eba3 d02b1b6d66dea1da892447d7b309f9b6e4eda0dd02055d71706d52aa73b5b9c4
-test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql 849c874de45781b8491cee428cc00fefc8cdc76f87de8a373a181b16ce930ab1 5e570193befae7bfe6c21ce91e20afd52bb94f234e2be89d0974bd6337221508
+test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql f9002cc327769edff05ae428d0c01ba80e18a217057d4d2c3a31eb24ab659ed6 8af2986890d0f3dd77c72023d992d5e587c9922b6f3ea378a6e268a51cfbbda5
test/extractor-tests/generated/Comment/Comment.ql 0e0454911d2cf2e7ef5c6d860b84c57b9d490090914ebcf4fa0e8a70f777f066 cbd1c195276ef163f8d3c122344738c884dc9fb70eb2f9b7067829d735d48c4c
test/extractor-tests/generated/Const/Const.ql 28a0f2debbf73ae867fc2d08d8e54d9e96fea69522b7180a48495c9b7fce9367 54d4a68a2b67db95ceb856535a8b27860ce2b502da17a7eeea3bb554d7fb5e43
test/extractor-tests/generated/ConstArg/ConstArg.ql 21c7caf1939ff9fcc1bf0fe6dec5c6a6929f714cf1e17faf7a2f4a31c910194b 61eac00f4727f7269f926c53f53a62b5fae82ce7a02b42d23b9de6337b6f9d6e
@@ -698,8 +697,9 @@ test/extractor-tests/generated/ExternCrate/ExternCrate.ql 7cd54aa65300453fc031e6
test/extractor-tests/generated/ExternItemList/ExternItemList.ql 7f4d538d8878a0166b1868f391abf34df1d5e986a7a2e9ceaddb36d95bc7f46c 37072596f5a1e28ad98cc87dbfed00afadd83fa007f03d5b17d4dee8922b100f
test/extractor-tests/generated/FieldExpr/FieldExpr.ql 2a04baaf57a22b65bd5b9e142e59cc2b7d3dd3174910ddc0c2510094f2dd32b1 d8e4fb4384aade1770c907d16795a4af9884051390a5a05935ad4b4df2e757a0
test/extractor-tests/generated/FnPtrTypeRepr/FnPtrTypeRepr.ql 1501730f1e02e9d22b07b18bb42a5372e1d327bda62bdc81d75f9966946cb97d 28625f0b7ee4d7ab37fc13206585961e89a5e509a93215c16136d2382418b7af
+test/extractor-tests/generated/ForBinder/ForBinder.ql c95fd006eaddb9535eda0d527d71cdd5d3745fe464fd809a8d58b8c4dfc8790e 1d8b38059b8a25965eab9a8a1286384aa994d7cac7414b70b63c6a3d6bcf3c39
test/extractor-tests/generated/ForExpr/ForExpr.ql 3bac38bf33e140ae9f88371ec90409f7de867e39cdea46f02b15519b236b57cb aade1baf6e6081b3b9bce5b7e95fe4b7ffe00ea9450fd6e1d6692ad97cf93fe9
-test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql b74c0034bf5d1bb4a1a73ab822daca4572e80983a0c88620abe92bb794dd9cd8 a18f9a6d95b46b808c3a25e11fc54d2564ace67fb98d0c76632c5d5894b31030
+test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql 5961055988b3a7749fb80e24d924bf1b67b0c52a6c895379beedd66a34bad04f d8ab72fac742314ead1aa0e1fed2535cc6597d278f3eef017bc9f8fd8cde83e7
test/extractor-tests/generated/FormatArgsExpr/Format.ql 237ed2e01d9a75ee8521d6578333a7b1d566f09ef2102c4efcbb34ea58f2f9e8 09007ce4de701c0d1c0967f4f728ea9e627d9db19431bd9caebbf28ee51a1f36
test/extractor-tests/generated/FormatArgsExpr/FormatArgsArg.ql 5abcb565dcd2822e2ea142d19b8c92194ee17c71c3db7595248690034559d174 1ffa743fc678701ffeefff6c14c1414bb9158e6756f32380dd590ff44b19ca5a
test/extractor-tests/generated/FormatArgsExpr/FormatArgsExpr.ql 243c2f9d830f1eae915749e81ac78d3c140280385b0002d10fcc4d2feaf14711 72b90a99a8b1c16baf1e254e1e3463c3ce5409624a2a90829122717d4e5a2b74
@@ -796,7 +796,7 @@ test/extractor-tests/generated/TupleStructPat/TupleStructPat.ql d00b185013bb4e5f
test/extractor-tests/generated/TupleTypeRepr/TupleTypeRepr.ql 2f1503734d272cd0616e5885cd344659cbd0ae7309a375c8351f57f2b86c3302 276a4fe91b8dc64cdca4467343e2bb2e240c66ec1e4e11bf8cba73819c6532cc
test/extractor-tests/generated/TypeAlias/TypeAlias.ql 2b120c7fe640b233540f6982153fddf50ddc089b8284dca321b4c48eecf93dfd 6d40a0d8c927dd499fd92fd95638c50eeca8f956aa1706c17913dbf83f0f500c
test/extractor-tests/generated/TypeArg/TypeArg.ql e1ca286c03bd2d44054f5dd75aac250382037f243046c49ec752ad8d65e4c0ba f316d5fa84a721427c0aadf6bfa0ed4cfd86e4d318cfb0fe82efc52e65c4733b
-test/extractor-tests/generated/TypeBound/TypeBound.ql 4f5a2a49075c01c982988e66759f61c5285343d78cda94e228e17593d16fee6e 7aae320e881d6ea969e31b1e8fe586feb07b1db43c65da684cbac66157354851
+test/extractor-tests/generated/TypeBound/TypeBound.ql 41d0a7b6538de12797c5aa4152ea701517abe685b1160615f2d74203e7a00d34 f57128c66df37791f93db269451b1c617c991d8723ecb9efe4b8ff8b2559472c
test/extractor-tests/generated/TypeBoundList/TypeBoundList.ql 6827529eca62f5e7be87538af6231099f5932f39d8694f7a76369273b93f28ea 539dac4ccda7e51b7ae1a9e05d8a56a98176d9de25d5ed4347ebe2fbea8adeb1
test/extractor-tests/generated/TypeParam/TypeParam.ql c5f8f62f2877c719c3cf069f9d0ca83cebc14f7611c6c2dce86c85114ea2635c 751c630986f35a8d0d32fbeb61ca6ff801c96cd1829dbccc874fbf5f5158e98d
test/extractor-tests/generated/UnderscoreExpr/UnderscoreExpr.ql a7b7a93104fff28515154cf8e79045d3eea2494b5c46f1caf36639c53b1c64a7 070ee2e1664e3291646ea56681b5c93331f94dcc519deb28622beca3e26e16f3
@@ -809,7 +809,7 @@ test/extractor-tests/generated/Variant/Variant.ql 9405704e9192cac4838dcba8625261
test/extractor-tests/generated/VariantList/VariantList.ql 1c1d82ce3ecfa7daaae1920662510e81892ed899a3c2f785e2ff3670245a03cd 29d4c5ab2b737a92c7525789e10a4aa9848f1a327e34f4e9543018021106b303
test/extractor-tests/generated/Visibility/Visibility.ql 725d47d7444332133df603f9b06592dc40b0f83bf5e21ad4781c5658e001a3aa 2d65a30702a8bb5bc91caf6ae2d0e4c769b3eeb0d72ffbd9cdb81048be4061ad
test/extractor-tests/generated/WhereClause/WhereClause.ql a6f0e69ffa6b997cac04d4da442eb8bde517a576840c953abcc40863b9099ba1 7ce888fffc3038d5b18f8c94d3b045815cd45500e1bb3849c05fc874edbeb695
-test/extractor-tests/generated/WherePred/WherePred.ql 504d00a40e418542c3e0ff30d43c4d2d0e7218b2a31fcf32c9310d705d97b9fe 61c53dde539a9e1e3d6bf13ca1d0dab8af6ea6b54ab698a0a5a5f49bf627934b
+test/extractor-tests/generated/WherePred/WherePred.ql 8f73500a04f8748221b181bb9a51bef6c09d5ddf046488303594821e3191b370 8fb51d095a3c39b51ec8b4515fc02474ba36067ca4dfd48dff7e14d1c3881ea3
test/extractor-tests/generated/WhileExpr/WhileExpr.ql dcfe1ed375514a7b7513272767ed195cdbf339b56e00e62d207ca1eee080f164 f067283510655f0cf810cae834ac29ad2c6007ba312d027ebcdf695a23ec33e4
test/extractor-tests/generated/WildcardPat/WildcardPat.ql d36f52a1d00d338b43894b6f8e198ad0c409542f436e3e57d527205c3dfee38c 4e1321e714cedb606e0d84f10ed37c72da61b3a1616754b967f721ff0bc0e4ee
test/extractor-tests/generated/YeetExpr/YeetExpr.ql 5c552b490ccf5b123f7a2fa3e73d03d008e4df5928ffa0bd503dc6bd7736462c 09a4f413ae045051abe392f29949d6feab1a808d666c6b8dac0901f84a8a4740
diff --git a/rust/ql/.gitattributes b/rust/ql/.gitattributes
index 4fc300e48cc..d7dbdaa982e 100644
--- a/rust/ql/.gitattributes
+++ b/rust/ql/.gitattributes
@@ -38,7 +38,6 @@
/lib/codeql/rust/elements/CallExprBase.qll linguist-generated
/lib/codeql/rust/elements/Callable.qll linguist-generated
/lib/codeql/rust/elements/CastExpr.qll linguist-generated
-/lib/codeql/rust/elements/ClosureBinder.qll linguist-generated
/lib/codeql/rust/elements/ClosureExpr.qll linguist-generated
/lib/codeql/rust/elements/Comment.qll linguist-generated
/lib/codeql/rust/elements/Const.qll linguist-generated
@@ -59,6 +58,7 @@
/lib/codeql/rust/elements/FieldExpr.qll linguist-generated
/lib/codeql/rust/elements/FieldList.qll linguist-generated
/lib/codeql/rust/elements/FnPtrTypeRepr.qll linguist-generated
+/lib/codeql/rust/elements/ForBinder.qll linguist-generated
/lib/codeql/rust/elements/ForExpr.qll linguist-generated
/lib/codeql/rust/elements/ForTypeRepr.qll linguist-generated
/lib/codeql/rust/elements/Format.qll linguist-generated
@@ -243,8 +243,6 @@
/lib/codeql/rust/elements/internal/BreakExprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/CallExprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/CastExprConstructor.qll linguist-generated
-/lib/codeql/rust/elements/internal/ClosureBinderConstructor.qll linguist-generated
-/lib/codeql/rust/elements/internal/ClosureBinderImpl.qll linguist-generated
/lib/codeql/rust/elements/internal/ClosureExprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/CommentConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/ConstArgConstructor.qll linguist-generated
@@ -275,6 +273,8 @@
/lib/codeql/rust/elements/internal/FieldListImpl.qll linguist-generated
/lib/codeql/rust/elements/internal/FnPtrTypeReprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/FnPtrTypeReprImpl.qll linguist-generated
+/lib/codeql/rust/elements/internal/ForBinderConstructor.qll linguist-generated
+/lib/codeql/rust/elements/internal/ForBinderImpl.qll linguist-generated
/lib/codeql/rust/elements/internal/ForExprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/ForTypeReprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll linguist-generated
@@ -494,7 +494,6 @@
/lib/codeql/rust/elements/internal/generated/CallExprBase.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/Callable.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/CastExpr.qll linguist-generated
-/lib/codeql/rust/elements/internal/generated/ClosureBinder.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/Comment.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/Const.qll linguist-generated
@@ -516,6 +515,7 @@
/lib/codeql/rust/elements/internal/generated/FieldExpr.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/FieldList.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/FnPtrTypeRepr.qll linguist-generated
+/lib/codeql/rust/elements/internal/generated/ForBinder.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/ForExpr.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll linguist-generated
/lib/codeql/rust/elements/internal/generated/Format.qll linguist-generated
@@ -683,7 +683,6 @@
/test/extractor-tests/generated/BreakExpr/BreakExpr.ql linguist-generated
/test/extractor-tests/generated/CallExpr/CallExpr.ql linguist-generated
/test/extractor-tests/generated/CastExpr/CastExpr.ql linguist-generated
-/test/extractor-tests/generated/ClosureBinder/ClosureBinder.ql linguist-generated
/test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql linguist-generated
/test/extractor-tests/generated/Comment/Comment.ql linguist-generated
/test/extractor-tests/generated/Const/Const.ql linguist-generated
@@ -700,6 +699,7 @@
/test/extractor-tests/generated/ExternItemList/ExternItemList.ql linguist-generated
/test/extractor-tests/generated/FieldExpr/FieldExpr.ql linguist-generated
/test/extractor-tests/generated/FnPtrTypeRepr/FnPtrTypeRepr.ql linguist-generated
+/test/extractor-tests/generated/ForBinder/ForBinder.ql linguist-generated
/test/extractor-tests/generated/ForExpr/ForExpr.ql linguist-generated
/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql linguist-generated
/test/extractor-tests/generated/FormatArgsExpr/Format.ql linguist-generated
diff --git a/rust/ql/lib/codeql/rust/elements.qll b/rust/ql/lib/codeql/rust/elements.qll
index cd44985675f..64e497000a0 100644
--- a/rust/ql/lib/codeql/rust/elements.qll
+++ b/rust/ql/lib/codeql/rust/elements.qll
@@ -41,7 +41,6 @@ import codeql.rust.elements.CallExpr
import codeql.rust.elements.CallExprBase
import codeql.rust.elements.Callable
import codeql.rust.elements.CastExpr
-import codeql.rust.elements.ClosureBinder
import codeql.rust.elements.ClosureExpr
import codeql.rust.elements.Comment
import codeql.rust.elements.Const
@@ -62,6 +61,7 @@ import codeql.rust.elements.ExternItemList
import codeql.rust.elements.FieldExpr
import codeql.rust.elements.FieldList
import codeql.rust.elements.FnPtrTypeRepr
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.ForExpr
import codeql.rust.elements.ForTypeRepr
import codeql.rust.elements.Format
diff --git a/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll b/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll
index d1f73bfaadb..63fb8ccf53a 100644
--- a/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll
+++ b/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll
@@ -5,8 +5,8 @@
private import internal.ClosureExprImpl
import codeql.rust.elements.Callable
-import codeql.rust.elements.ClosureBinder
import codeql.rust.elements.Expr
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.RetTypeRepr
/**
diff --git a/rust/ql/lib/codeql/rust/elements/ClosureBinder.qll b/rust/ql/lib/codeql/rust/elements/ForBinder.qll
similarity index 60%
rename from rust/ql/lib/codeql/rust/elements/ClosureBinder.qll
rename to rust/ql/lib/codeql/rust/elements/ForBinder.qll
index 0bf9579b2f0..3dfff62d1e6 100644
--- a/rust/ql/lib/codeql/rust/elements/ClosureBinder.qll
+++ b/rust/ql/lib/codeql/rust/elements/ForBinder.qll
@@ -1,14 +1,14 @@
// generated by codegen, do not edit
/**
- * This module provides the public class `ClosureBinder`.
+ * This module provides the public class `ForBinder`.
*/
-private import internal.ClosureBinderImpl
+private import internal.ForBinderImpl
import codeql.rust.elements.AstNode
import codeql.rust.elements.GenericParamList
/**
- * A closure binder, specifying lifetime or type parameters for a closure.
+ * A for binder, specifying lifetime or type parameters for a closure or a type.
*
* For example:
* ```rust
@@ -21,4 +21,4 @@ import codeql.rust.elements.GenericParamList
* print_any("hello");
* ```
*/
-final class ClosureBinder = Impl::ClosureBinder;
+final class ForBinder = Impl::ForBinder;
diff --git a/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll b/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
index c52c92197bb..bf4627783ed 100644
--- a/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
+++ b/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
@@ -4,7 +4,7 @@
*/
private import internal.ForTypeReprImpl
-import codeql.rust.elements.GenericParamList
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.TypeRepr
/**
diff --git a/rust/ql/lib/codeql/rust/elements/TypeBound.qll b/rust/ql/lib/codeql/rust/elements/TypeBound.qll
index c49d8e5be06..03e0afa8cd3 100644
--- a/rust/ql/lib/codeql/rust/elements/TypeBound.qll
+++ b/rust/ql/lib/codeql/rust/elements/TypeBound.qll
@@ -5,6 +5,7 @@
private import internal.TypeBoundImpl
import codeql.rust.elements.AstNode
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.Lifetime
import codeql.rust.elements.TypeRepr
import codeql.rust.elements.UseBoundGenericArgs
diff --git a/rust/ql/lib/codeql/rust/elements/WherePred.qll b/rust/ql/lib/codeql/rust/elements/WherePred.qll
index 16e1e586570..c08334fb1b9 100644
--- a/rust/ql/lib/codeql/rust/elements/WherePred.qll
+++ b/rust/ql/lib/codeql/rust/elements/WherePred.qll
@@ -5,7 +5,7 @@
private import internal.WherePredImpl
import codeql.rust.elements.AstNode
-import codeql.rust.elements.GenericParamList
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.Lifetime
import codeql.rust.elements.TypeBoundList
import codeql.rust.elements.TypeRepr
diff --git a/rust/ql/lib/codeql/rust/elements/internal/ClosureBinderConstructor.qll b/rust/ql/lib/codeql/rust/elements/internal/ForBinderConstructor.qll
similarity index 61%
rename from rust/ql/lib/codeql/rust/elements/internal/ClosureBinderConstructor.qll
rename to rust/ql/lib/codeql/rust/elements/internal/ForBinderConstructor.qll
index 0213547728f..1dfea8c72ab 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/ClosureBinderConstructor.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/ForBinderConstructor.qll
@@ -1,14 +1,14 @@
// generated by codegen, remove this comment if you wish to edit this file
/**
* This module defines the hook used internally to tweak the characteristic predicate of
- * `ClosureBinder` synthesized instances.
+ * `ForBinder` synthesized instances.
* INTERNAL: Do not use.
*/
private import codeql.rust.elements.internal.generated.Raw
/**
- * The characteristic predicate of `ClosureBinder` synthesized instances.
+ * The characteristic predicate of `ForBinder` synthesized instances.
* INTERNAL: Do not use.
*/
-predicate constructClosureBinder(Raw::ClosureBinder id) { any() }
+predicate constructForBinder(Raw::ForBinder id) { any() }
diff --git a/rust/ql/lib/codeql/rust/elements/internal/ClosureBinderImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll
similarity index 66%
rename from rust/ql/lib/codeql/rust/elements/internal/ClosureBinderImpl.qll
rename to rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll
index 095a5a269e0..8281a549b29 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/ClosureBinderImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll
@@ -1,19 +1,19 @@
// generated by codegen, remove this comment if you wish to edit this file
/**
- * This module provides a hand-modifiable wrapper around the generated class `ClosureBinder`.
+ * This module provides a hand-modifiable wrapper around the generated class `ForBinder`.
*
* INTERNAL: Do not use.
*/
-private import codeql.rust.elements.internal.generated.ClosureBinder
+private import codeql.rust.elements.internal.generated.ForBinder
/**
- * INTERNAL: This module contains the customizable definition of `ClosureBinder` and should not
+ * INTERNAL: This module contains the customizable definition of `ForBinder` and should not
* be referenced directly.
*/
module Impl {
/**
- * A closure binder, specifying lifetime or type parameters for a closure.
+ * A for binder, specifying lifetime or type parameters for a closure or a type.
*
* For example:
* ```rust
@@ -26,5 +26,5 @@ module Impl {
* print_any("hello");
* ```
*/
- class ClosureBinder extends Generated::ClosureBinder { }
+ class ForBinder extends Generated::ForBinder { }
}
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll
index 70a3c374e0d..8341226d6e2 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll
@@ -7,9 +7,9 @@
private import codeql.rust.elements.internal.generated.Synth
private import codeql.rust.elements.internal.generated.Raw
import codeql.rust.elements.internal.CallableImpl::Impl as CallableImpl
-import codeql.rust.elements.ClosureBinder
import codeql.rust.elements.Expr
import codeql.rust.elements.internal.ExprImpl::Impl as ExprImpl
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.RetTypeRepr
/**
@@ -48,19 +48,19 @@ module Generated {
final predicate hasBody() { exists(this.getBody()) }
/**
- * Gets the closure binder of this closure expression, if it exists.
+ * Gets the for binder of this closure expression, if it exists.
*/
- ClosureBinder getClosureBinder() {
+ ForBinder getForBinder() {
result =
- Synth::convertClosureBinderFromRaw(Synth::convertClosureExprToRaw(this)
+ Synth::convertForBinderFromRaw(Synth::convertClosureExprToRaw(this)
.(Raw::ClosureExpr)
- .getClosureBinder())
+ .getForBinder())
}
/**
- * Holds if `getClosureBinder()` exists.
+ * Holds if `getForBinder()` exists.
*/
- final predicate hasClosureBinder() { exists(this.getClosureBinder()) }
+ final predicate hasForBinder() { exists(this.getForBinder()) }
/**
* Holds if this closure expression is async.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureBinder.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ForBinder.qll
similarity index 58%
rename from rust/ql/lib/codeql/rust/elements/internal/generated/ClosureBinder.qll
rename to rust/ql/lib/codeql/rust/elements/internal/generated/ForBinder.qll
index 9bd04fd3581..38512084e39 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureBinder.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ForBinder.qll
@@ -1,6 +1,6 @@
// generated by codegen, do not edit
/**
- * This module provides the generated definition of `ClosureBinder`.
+ * This module provides the generated definition of `ForBinder`.
* INTERNAL: Do not import directly.
*/
@@ -10,12 +10,12 @@ import codeql.rust.elements.internal.AstNodeImpl::Impl as AstNodeImpl
import codeql.rust.elements.GenericParamList
/**
- * INTERNAL: This module contains the fully generated definition of `ClosureBinder` and should not
+ * INTERNAL: This module contains the fully generated definition of `ForBinder` and should not
* be referenced directly.
*/
module Generated {
/**
- * A closure binder, specifying lifetime or type parameters for a closure.
+ * A for binder, specifying lifetime or type parameters for a closure or a type.
*
* For example:
* ```rust
@@ -27,19 +27,19 @@ module Generated {
* print_any(42);
* print_any("hello");
* ```
- * INTERNAL: Do not reference the `Generated::ClosureBinder` class directly.
- * Use the subclass `ClosureBinder`, where the following predicates are available.
+ * INTERNAL: Do not reference the `Generated::ForBinder` class directly.
+ * Use the subclass `ForBinder`, where the following predicates are available.
*/
- class ClosureBinder extends Synth::TClosureBinder, AstNodeImpl::AstNode {
- override string getAPrimaryQlClass() { result = "ClosureBinder" }
+ class ForBinder extends Synth::TForBinder, AstNodeImpl::AstNode {
+ override string getAPrimaryQlClass() { result = "ForBinder" }
/**
- * Gets the generic parameter list of this closure binder, if it exists.
+ * Gets the generic parameter list of this for binder, if it exists.
*/
GenericParamList getGenericParamList() {
result =
- Synth::convertGenericParamListFromRaw(Synth::convertClosureBinderToRaw(this)
- .(Raw::ClosureBinder)
+ Synth::convertGenericParamListFromRaw(Synth::convertForBinderToRaw(this)
+ .(Raw::ForBinder)
.getGenericParamList())
}
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
index cbe2975bf50..f52af334108 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
@@ -6,7 +6,7 @@
private import codeql.rust.elements.internal.generated.Synth
private import codeql.rust.elements.internal.generated.Raw
-import codeql.rust.elements.GenericParamList
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.TypeRepr
import codeql.rust.elements.internal.TypeReprImpl::Impl as TypeReprImpl
@@ -35,19 +35,19 @@ module Generated {
override string getAPrimaryQlClass() { result = "ForTypeRepr" }
/**
- * Gets the generic parameter list of this for type representation, if it exists.
+ * Gets the for binder of this for type representation, if it exists.
*/
- GenericParamList getGenericParamList() {
+ ForBinder getForBinder() {
result =
- Synth::convertGenericParamListFromRaw(Synth::convertForTypeReprToRaw(this)
+ Synth::convertForBinderFromRaw(Synth::convertForTypeReprToRaw(this)
.(Raw::ForTypeRepr)
- .getGenericParamList())
+ .getForBinder())
}
/**
- * Holds if `getGenericParamList()` exists.
+ * Holds if `getForBinder()` exists.
*/
- final predicate hasGenericParamList() { exists(this.getGenericParamList()) }
+ final predicate hasForBinder() { exists(this.getForBinder()) }
/**
* Gets the type representation of this for type representation, if it exists.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll
index d0b9c397a77..3011eccbee4 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll
@@ -152,22 +152,6 @@ private module Impl {
)
}
- private Element getImmediateChildOfClosureBinder(
- ClosureBinder e, int index, string partialPredicateCall
- ) {
- exists(int n, int nGenericParamList |
- n = 0 and
- nGenericParamList = n + 1 and
- (
- none()
- or
- index = n and
- result = e.getGenericParamList() and
- partialPredicateCall = "GenericParamList()"
- )
- )
- }
-
private Element getImmediateChildOfExternItemList(
ExternItemList e, int index, string partialPredicateCall
) {
@@ -187,6 +171,20 @@ private module Impl {
)
}
+ private Element getImmediateChildOfForBinder(ForBinder e, int index, string partialPredicateCall) {
+ exists(int n, int nGenericParamList |
+ n = 0 and
+ nGenericParamList = n + 1 and
+ (
+ none()
+ or
+ index = n and
+ result = e.getGenericParamList() and
+ partialPredicateCall = "GenericParamList()"
+ )
+ )
+ }
+
private Element getImmediateChildOfFormatArgsArg(
FormatArgsArg e, int index, string partialPredicateCall
) {
@@ -656,15 +654,18 @@ private module Impl {
}
private Element getImmediateChildOfTypeBound(TypeBound e, int index, string partialPredicateCall) {
- exists(int n, int nLifetime, int nTypeRepr, int nUseBoundGenericArgs |
+ exists(int n, int nForBinder, int nLifetime, int nTypeRepr, int nUseBoundGenericArgs |
n = 0 and
- nLifetime = n + 1 and
+ nForBinder = n + 1 and
+ nLifetime = nForBinder + 1 and
nTypeRepr = nLifetime + 1 and
nUseBoundGenericArgs = nTypeRepr + 1 and
(
none()
or
- index = n and result = e.getLifetime() and partialPredicateCall = "Lifetime()"
+ index = n and result = e.getForBinder() and partialPredicateCall = "ForBinder()"
+ or
+ index = nForBinder and result = e.getLifetime() and partialPredicateCall = "Lifetime()"
or
index = nLifetime and result = e.getTypeRepr() and partialPredicateCall = "TypeRepr()"
or
@@ -781,22 +782,18 @@ private module Impl {
}
private Element getImmediateChildOfWherePred(WherePred e, int index, string partialPredicateCall) {
- exists(int n, int nGenericParamList, int nLifetime, int nTypeRepr, int nTypeBoundList |
+ exists(int n, int nForBinder, int nLifetime, int nTypeRepr, int nTypeBoundList |
n = 0 and
- nGenericParamList = n + 1 and
- nLifetime = nGenericParamList + 1 and
+ nForBinder = n + 1 and
+ nLifetime = nForBinder + 1 and
nTypeRepr = nLifetime + 1 and
nTypeBoundList = nTypeRepr + 1 and
(
none()
or
- index = n and
- result = e.getGenericParamList() and
- partialPredicateCall = "GenericParamList()"
+ index = n and result = e.getForBinder() and partialPredicateCall = "ForBinder()"
or
- index = nGenericParamList and
- result = e.getLifetime() and
- partialPredicateCall = "Lifetime()"
+ index = nForBinder and result = e.getLifetime() and partialPredicateCall = "Lifetime()"
or
index = nLifetime and result = e.getTypeRepr() and partialPredicateCall = "TypeRepr()"
or
@@ -1095,13 +1092,13 @@ private module Impl {
private Element getImmediateChildOfClosureExpr(
ClosureExpr e, int index, string partialPredicateCall
) {
- exists(int n, int nParamList, int nAttr, int nBody, int nClosureBinder, int nRetType |
+ exists(int n, int nParamList, int nAttr, int nBody, int nForBinder, int nRetType |
n = 0 and
nParamList = n + 1 and
nAttr = nParamList + 1 + max(int i | i = -1 or exists(e.getAttr(i)) | i) and
nBody = nAttr + 1 and
- nClosureBinder = nBody + 1 and
- nRetType = nClosureBinder + 1 and
+ nForBinder = nBody + 1 and
+ nRetType = nForBinder + 1 and
(
none()
or
@@ -1112,9 +1109,9 @@ private module Impl {
or
index = nAttr and result = e.getBody() and partialPredicateCall = "Body()"
or
- index = nBody and result = e.getClosureBinder() and partialPredicateCall = "ClosureBinder()"
+ index = nBody and result = e.getForBinder() and partialPredicateCall = "ForBinder()"
or
- index = nClosureBinder and result = e.getRetType() and partialPredicateCall = "RetType()"
+ index = nForBinder and result = e.getRetType() and partialPredicateCall = "RetType()"
)
)
}
@@ -1257,20 +1254,16 @@ private module Impl {
private Element getImmediateChildOfForTypeRepr(
ForTypeRepr e, int index, string partialPredicateCall
) {
- exists(int n, int nGenericParamList, int nTypeRepr |
+ exists(int n, int nForBinder, int nTypeRepr |
n = 0 and
- nGenericParamList = n + 1 and
- nTypeRepr = nGenericParamList + 1 and
+ nForBinder = n + 1 and
+ nTypeRepr = nForBinder + 1 and
(
none()
or
- index = n and
- result = e.getGenericParamList() and
- partialPredicateCall = "GenericParamList()"
+ index = n and result = e.getForBinder() and partialPredicateCall = "ForBinder()"
or
- index = nGenericParamList and
- result = e.getTypeRepr() and
- partialPredicateCall = "TypeRepr()"
+ index = nForBinder and result = e.getTypeRepr() and partialPredicateCall = "TypeRepr()"
)
)
}
@@ -3072,10 +3065,10 @@ private module Impl {
or
result = getImmediateChildOfAttr(e, index, partialAccessor)
or
- result = getImmediateChildOfClosureBinder(e, index, partialAccessor)
- or
result = getImmediateChildOfExternItemList(e, index, partialAccessor)
or
+ result = getImmediateChildOfForBinder(e, index, partialAccessor)
+ or
result = getImmediateChildOfFormatArgsArg(e, index, partialAccessor)
or
result = getImmediateChildOfGenericArgList(e, index, partialAccessor)
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
index 38798573712..019e0c08e16 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
@@ -319,30 +319,6 @@ module Raw {
Attr getAttr(int index) { callable_attrs(this, index, result) }
}
- /**
- * INTERNAL: Do not use.
- * A closure binder, specifying lifetime or type parameters for a closure.
- *
- * For example:
- * ```rust
- * let print_any = for |x: T| {
- * // ^^^^^^^^^^^^^^^^^^^^^^^
- * println!("{:?}", x);
- * };
- *
- * print_any(42);
- * print_any("hello");
- * ```
- */
- class ClosureBinder extends @closure_binder, AstNode {
- override string toString() { result = "ClosureBinder" }
-
- /**
- * Gets the generic parameter list of this closure binder, if it exists.
- */
- GenericParamList getGenericParamList() { closure_binder_generic_param_lists(this, result) }
- }
-
/**
* INTERNAL: Do not use.
* The base class for expressions.
@@ -389,6 +365,30 @@ module Raw {
*/
class FieldList extends @field_list, AstNode { }
+ /**
+ * INTERNAL: Do not use.
+ * A for binder, specifying lifetime or type parameters for a closure or a type.
+ *
+ * For example:
+ * ```rust
+ * let print_any = for |x: T| {
+ * // ^^^^^^^^^^^^^^^^^^^^^^^
+ * println!("{:?}", x);
+ * };
+ *
+ * print_any(42);
+ * print_any("hello");
+ * ```
+ */
+ class ForBinder extends @for_binder, AstNode {
+ override string toString() { result = "ForBinder" }
+
+ /**
+ * Gets the generic parameter list of this for binder, if it exists.
+ */
+ GenericParamList getGenericParamList() { for_binder_generic_param_lists(this, result) }
+ }
+
/**
* INTERNAL: Do not use.
* A FormatArgsArg. For example the `"world"` in:
@@ -1209,6 +1209,11 @@ module Raw {
class TypeBound extends @type_bound, AstNode {
override string toString() { result = "TypeBound" }
+ /**
+ * Gets the for binder of this type bound, if it exists.
+ */
+ ForBinder getForBinder() { type_bound_for_binders(this, result) }
+
/**
* Holds if this type bound is async.
*/
@@ -1415,9 +1420,9 @@ module Raw {
override string toString() { result = "WherePred" }
/**
- * Gets the generic parameter list of this where pred, if it exists.
+ * Gets the for binder of this where pred, if it exists.
*/
- GenericParamList getGenericParamList() { where_pred_generic_param_lists(this, result) }
+ ForBinder getForBinder() { where_pred_for_binders(this, result) }
/**
* Gets the lifetime of this where pred, if it exists.
@@ -1912,9 +1917,9 @@ module Raw {
Expr getBody() { closure_expr_bodies(this, result) }
/**
- * Gets the closure binder of this closure expression, if it exists.
+ * Gets the for binder of this closure expression, if it exists.
*/
- ClosureBinder getClosureBinder() { closure_expr_closure_binders(this, result) }
+ ForBinder getForBinder() { closure_expr_for_binders(this, result) }
/**
* Holds if this closure expression is async.
@@ -2209,9 +2214,9 @@ module Raw {
override string toString() { result = "ForTypeRepr" }
/**
- * Gets the generic parameter list of this for type representation, if it exists.
+ * Gets the for binder of this for type representation, if it exists.
*/
- GenericParamList getGenericParamList() { for_type_repr_generic_param_lists(this, result) }
+ ForBinder getForBinder() { for_type_repr_for_binders(this, result) }
/**
* Gets the type representation of this for type representation, if it exists.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/Synth.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/Synth.qll
index 3c8b1e87f57..42d5c99eb0a 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/Synth.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/Synth.qll
@@ -130,10 +130,6 @@ module Synth {
* INTERNAL: Do not use.
*/
TCastExpr(Raw::CastExpr id) { constructCastExpr(id) } or
- /**
- * INTERNAL: Do not use.
- */
- TClosureBinder(Raw::ClosureBinder id) { constructClosureBinder(id) } or
/**
* INTERNAL: Do not use.
*/
@@ -202,6 +198,10 @@ module Synth {
* INTERNAL: Do not use.
*/
TFnPtrTypeRepr(Raw::FnPtrTypeRepr id) { constructFnPtrTypeRepr(id) } or
+ /**
+ * INTERNAL: Do not use.
+ */
+ TForBinder(Raw::ForBinder id) { constructForBinder(id) } or
/**
* INTERNAL: Do not use.
*/
@@ -718,8 +718,8 @@ module Synth {
*/
class TAstNode =
TAbi or TAddressable or TArgList or TAsmDirSpec or TAsmOperand or TAsmOperandExpr or
- TAsmOption or TAsmPiece or TAsmRegSpec or TAssocItemList or TAttr or TCallable or
- TClosureBinder or TExpr or TExternItemList or TFieldList or TFormatArgsArg or TGenericArg or
+ TAsmOption or TAsmPiece or TAsmRegSpec or TAssocItemList or TAttr or TCallable or TExpr or
+ TExternItemList or TFieldList or TForBinder or TFormatArgsArg or TGenericArg or
TGenericArgList or TGenericParam or TGenericParamList or TItemList or TLabel or TLetElse or
TMacroItems or TMatchArm or TMatchArmList or TMatchGuard or TMeta or TName or TParamBase or
TParamList or TParenthesizedArgList or TPat or TPath or TPathSegment or TRename or
@@ -1024,12 +1024,6 @@ module Synth {
*/
TCastExpr convertCastExprFromRaw(Raw::Element e) { result = TCastExpr(e) }
- /**
- * INTERNAL: Do not use.
- * Converts a raw element to a synthesized `TClosureBinder`, if possible.
- */
- TClosureBinder convertClosureBinderFromRaw(Raw::Element e) { result = TClosureBinder(e) }
-
/**
* INTERNAL: Do not use.
* Converts a raw element to a synthesized `TClosureExpr`, if possible.
@@ -1132,6 +1126,12 @@ module Synth {
*/
TFnPtrTypeRepr convertFnPtrTypeReprFromRaw(Raw::Element e) { result = TFnPtrTypeRepr(e) }
+ /**
+ * INTERNAL: Do not use.
+ * Converts a raw element to a synthesized `TForBinder`, if possible.
+ */
+ TForBinder convertForBinderFromRaw(Raw::Element e) { result = TForBinder(e) }
+
/**
* INTERNAL: Do not use.
* Converts a raw element to a synthesized `TForExpr`, if possible.
@@ -1953,14 +1953,14 @@ module Synth {
or
result = convertCallableFromRaw(e)
or
- result = convertClosureBinderFromRaw(e)
- or
result = convertExprFromRaw(e)
or
result = convertExternItemListFromRaw(e)
or
result = convertFieldListFromRaw(e)
or
+ result = convertForBinderFromRaw(e)
+ or
result = convertFormatArgsArgFromRaw(e)
or
result = convertGenericArgFromRaw(e)
@@ -2612,12 +2612,6 @@ module Synth {
*/
Raw::Element convertCastExprToRaw(TCastExpr e) { e = TCastExpr(result) }
- /**
- * INTERNAL: Do not use.
- * Converts a synthesized `TClosureBinder` to a raw DB element, if possible.
- */
- Raw::Element convertClosureBinderToRaw(TClosureBinder e) { e = TClosureBinder(result) }
-
/**
* INTERNAL: Do not use.
* Converts a synthesized `TClosureExpr` to a raw DB element, if possible.
@@ -2720,6 +2714,12 @@ module Synth {
*/
Raw::Element convertFnPtrTypeReprToRaw(TFnPtrTypeRepr e) { e = TFnPtrTypeRepr(result) }
+ /**
+ * INTERNAL: Do not use.
+ * Converts a synthesized `TForBinder` to a raw DB element, if possible.
+ */
+ Raw::Element convertForBinderToRaw(TForBinder e) { e = TForBinder(result) }
+
/**
* INTERNAL: Do not use.
* Converts a synthesized `TForExpr` to a raw DB element, if possible.
@@ -3539,14 +3539,14 @@ module Synth {
or
result = convertCallableToRaw(e)
or
- result = convertClosureBinderToRaw(e)
- or
result = convertExprToRaw(e)
or
result = convertExternItemListToRaw(e)
or
result = convertFieldListToRaw(e)
or
+ result = convertForBinderToRaw(e)
+ or
result = convertFormatArgsArgToRaw(e)
or
result = convertGenericArgToRaw(e)
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/SynthConstructors.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/SynthConstructors.qll
index e6ff3af4715..d701fa09d76 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/SynthConstructors.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/SynthConstructors.qll
@@ -32,7 +32,6 @@ import codeql.rust.elements.internal.BoxPatConstructor
import codeql.rust.elements.internal.BreakExprConstructor
import codeql.rust.elements.internal.CallExprConstructor
import codeql.rust.elements.internal.CastExprConstructor
-import codeql.rust.elements.internal.ClosureBinderConstructor
import codeql.rust.elements.internal.ClosureExprConstructor
import codeql.rust.elements.internal.CommentConstructor
import codeql.rust.elements.internal.ConstConstructor
@@ -50,6 +49,7 @@ import codeql.rust.elements.internal.ExternItemListConstructor
import codeql.rust.elements.internal.ExtractorStepConstructor
import codeql.rust.elements.internal.FieldExprConstructor
import codeql.rust.elements.internal.FnPtrTypeReprConstructor
+import codeql.rust.elements.internal.ForBinderConstructor
import codeql.rust.elements.internal.ForExprConstructor
import codeql.rust.elements.internal.ForTypeReprConstructor
import codeql.rust.elements.internal.FormatConstructor
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll
index c1e349511be..48089b82083 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll
@@ -7,6 +7,7 @@
private import codeql.rust.elements.internal.generated.Synth
private import codeql.rust.elements.internal.generated.Raw
import codeql.rust.elements.internal.AstNodeImpl::Impl as AstNodeImpl
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.Lifetime
import codeql.rust.elements.TypeRepr
import codeql.rust.elements.UseBoundGenericArgs
@@ -30,6 +31,21 @@ module Generated {
class TypeBound extends Synth::TTypeBound, AstNodeImpl::AstNode {
override string getAPrimaryQlClass() { result = "TypeBound" }
+ /**
+ * Gets the for binder of this type bound, if it exists.
+ */
+ ForBinder getForBinder() {
+ result =
+ Synth::convertForBinderFromRaw(Synth::convertTypeBoundToRaw(this)
+ .(Raw::TypeBound)
+ .getForBinder())
+ }
+
+ /**
+ * Holds if `getForBinder()` exists.
+ */
+ final predicate hasForBinder() { exists(this.getForBinder()) }
+
/**
* Holds if this type bound is async.
*/
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll
index cd835e33850..dc007f3aa21 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll
@@ -7,7 +7,7 @@
private import codeql.rust.elements.internal.generated.Synth
private import codeql.rust.elements.internal.generated.Raw
import codeql.rust.elements.internal.AstNodeImpl::Impl as AstNodeImpl
-import codeql.rust.elements.GenericParamList
+import codeql.rust.elements.ForBinder
import codeql.rust.elements.Lifetime
import codeql.rust.elements.TypeBoundList
import codeql.rust.elements.TypeRepr
@@ -32,19 +32,19 @@ module Generated {
override string getAPrimaryQlClass() { result = "WherePred" }
/**
- * Gets the generic parameter list of this where pred, if it exists.
+ * Gets the for binder of this where pred, if it exists.
*/
- GenericParamList getGenericParamList() {
+ ForBinder getForBinder() {
result =
- Synth::convertGenericParamListFromRaw(Synth::convertWherePredToRaw(this)
+ Synth::convertForBinderFromRaw(Synth::convertWherePredToRaw(this)
.(Raw::WherePred)
- .getGenericParamList())
+ .getForBinder())
}
/**
- * Holds if `getGenericParamList()` exists.
+ * Holds if `getForBinder()` exists.
*/
- final predicate hasGenericParamList() { exists(this.getGenericParamList()) }
+ final predicate hasForBinder() { exists(this.getForBinder()) }
/**
* Gets the lifetime of this where pred, if it exists.
diff --git a/rust/ql/lib/rust.dbscheme b/rust/ql/lib/rust.dbscheme
index 4adb57ee525..3c1990e7f1d 100644
--- a/rust/ql/lib/rust.dbscheme
+++ b/rust/ql/lib/rust.dbscheme
@@ -177,10 +177,10 @@ named_crates(
| @assoc_item_list
| @attr
| @callable
-| @closure_binder
| @expr
| @extern_item_list
| @field_list
+| @for_binder
| @format_args_arg
| @generic_arg
| @generic_arg_list
@@ -403,16 +403,6 @@ callable_attrs(
int attr: @attr ref
);
-closure_binders(
- unique int id: @closure_binder
-);
-
-#keyset[id]
-closure_binder_generic_param_lists(
- int id: @closure_binder ref,
- int generic_param_list: @generic_param_list ref
-);
-
@expr =
@array_expr_internal
| @asm_expr
@@ -472,6 +462,16 @@ extern_item_list_extern_items(
| @tuple_field_list
;
+for_binders(
+ unique int id: @for_binder
+);
+
+#keyset[id]
+for_binder_generic_param_lists(
+ int id: @for_binder ref,
+ int generic_param_list: @generic_param_list ref
+);
+
format_args_args(
unique int id: @format_args_arg
);
@@ -1044,6 +1044,12 @@ type_bounds(
unique int id: @type_bound
);
+#keyset[id]
+type_bound_for_binders(
+ int id: @type_bound ref,
+ int for_binder: @for_binder ref
+);
+
#keyset[id]
type_bound_is_async(
int id: @type_bound ref
@@ -1191,9 +1197,9 @@ where_preds(
);
#keyset[id]
-where_pred_generic_param_lists(
+where_pred_for_binders(
int id: @where_pred ref,
- int generic_param_list: @generic_param_list ref
+ int for_binder: @for_binder ref
);
#keyset[id]
@@ -1541,9 +1547,9 @@ closure_expr_bodies(
);
#keyset[id]
-closure_expr_closure_binders(
+closure_expr_for_binders(
int id: @closure_expr ref,
- int closure_binder: @closure_binder ref
+ int for_binder: @for_binder ref
);
#keyset[id]
@@ -1744,9 +1750,9 @@ for_type_reprs(
);
#keyset[id]
-for_type_repr_generic_param_lists(
+for_type_repr_for_binders(
int id: @for_type_repr ref,
- int generic_param_list: @generic_param_list ref
+ int for_binder: @for_binder ref
);
#keyset[id]
diff --git a/rust/ql/test/extractor-tests/generated/.generated_tests.list b/rust/ql/test/extractor-tests/generated/.generated_tests.list
index a4fab823b03..616aa6525bf 100644
--- a/rust/ql/test/extractor-tests/generated/.generated_tests.list
+++ b/rust/ql/test/extractor-tests/generated/.generated_tests.list
@@ -25,7 +25,6 @@ BoxPat/gen_box_pat.rs 1493e24b732370b577ade38c47db17fa157df19f5390606a67a6040e49
BreakExpr/gen_break_expr.rs aacdf9df7fc51d19742b9e813835c0bd0913017e8d62765960e06b27d58b9031 aacdf9df7fc51d19742b9e813835c0bd0913017e8d62765960e06b27d58b9031
CallExpr/gen_call_expr.rs 013a7c878996aefb25b94b68eebc4f0b1bb74ccd09e91c491980817a383e2401 013a7c878996aefb25b94b68eebc4f0b1bb74ccd09e91c491980817a383e2401
CastExpr/gen_cast_expr.rs c3892211fbae4fed7cb1f25ff1679fd79d2878bf0bf2bd4b7982af23d00129f5 c3892211fbae4fed7cb1f25ff1679fd79d2878bf0bf2bd4b7982af23d00129f5
-ClosureBinder/gen_closure_binder.rs 14b5e2deb2bbba164f1aee378be18e99e3c5a926628e964dcc2fbb349ff3b672 14b5e2deb2bbba164f1aee378be18e99e3c5a926628e964dcc2fbb349ff3b672
ClosureExpr/gen_closure_expr.rs 15bd9abdb8aaffabb8bb335f8ebd0571eb5f29115e1dc8d11837aa988702cd80 15bd9abdb8aaffabb8bb335f8ebd0571eb5f29115e1dc8d11837aa988702cd80
Comment/gen_comment.rs 1e1f9f43161a79c096c2056e8b7f5346385ab7addcdec68c2d53b383dd3debe6 1e1f9f43161a79c096c2056e8b7f5346385ab7addcdec68c2d53b383dd3debe6
Const/gen_const.rs a3b971134a4204d0da12563fcefa9ab72f3f2f2e957e82b70c8548b5807f375f a3b971134a4204d0da12563fcefa9ab72f3f2f2e957e82b70c8548b5807f375f
@@ -41,6 +40,7 @@ ExternCrate/gen_extern_crate.rs 8d6bfd8d993a8e3a95ae9ccb576bd55be0c6a1d0893cfe15
ExternItemList/gen_extern_item_list.rs f9a03ddf20387871b96994915c9a725feb333d061544c0fb6d2e6b1a1961d6ed f9a03ddf20387871b96994915c9a725feb333d061544c0fb6d2e6b1a1961d6ed
FieldExpr/gen_field_expr.rs 9a70500d592e0a071b03d974a55558b3bc0df531ff11bce5898feb36e17ffd8b 9a70500d592e0a071b03d974a55558b3bc0df531ff11bce5898feb36e17ffd8b
FnPtrTypeRepr/gen_fn_ptr_type_repr.rs c154ec0cc43236d133f6b946374f3063b89e5cbf9e96d9ee66877be4f948888e c154ec0cc43236d133f6b946374f3063b89e5cbf9e96d9ee66877be4f948888e
+ForBinder/gen_for_binder.rs e3c9e5ffd3f2a5a546af9ab6e2a2ed733baf9cf609e05850b70feb31478a0bae e3c9e5ffd3f2a5a546af9ab6e2a2ed733baf9cf609e05850b70feb31478a0bae
ForExpr/gen_for_expr.rs 003dc36e3dc4db6e3a4accd410c316f14334ba5b3d5d675c851a91dcd5185122 003dc36e3dc4db6e3a4accd410c316f14334ba5b3d5d675c851a91dcd5185122
ForTypeRepr/gen_for_type_repr.rs 86f2f11f399d8072add3d3109a186d82d95d141660b18986bce738b7e9ec81a2 86f2f11f399d8072add3d3109a186d82d95d141660b18986bce738b7e9ec81a2
FormatArgsExpr/gen_format.rs e9d8e7b98d0050ad6053c2459cb21faab00078e74245336a5962438336f76d33 e9d8e7b98d0050ad6053c2459cb21faab00078e74245336a5962438336f76d33
diff --git a/rust/ql/test/extractor-tests/generated/.gitattributes b/rust/ql/test/extractor-tests/generated/.gitattributes
index dd1c891195e..2679395b34f 100644
--- a/rust/ql/test/extractor-tests/generated/.gitattributes
+++ b/rust/ql/test/extractor-tests/generated/.gitattributes
@@ -27,7 +27,6 @@
/BreakExpr/gen_break_expr.rs linguist-generated
/CallExpr/gen_call_expr.rs linguist-generated
/CastExpr/gen_cast_expr.rs linguist-generated
-/ClosureBinder/gen_closure_binder.rs linguist-generated
/ClosureExpr/gen_closure_expr.rs linguist-generated
/Comment/gen_comment.rs linguist-generated
/Const/gen_const.rs linguist-generated
@@ -43,6 +42,7 @@
/ExternItemList/gen_extern_item_list.rs linguist-generated
/FieldExpr/gen_field_expr.rs linguist-generated
/FnPtrTypeRepr/gen_fn_ptr_type_repr.rs linguist-generated
+/ForBinder/gen_for_binder.rs linguist-generated
/ForExpr/gen_for_expr.rs linguist-generated
/ForTypeRepr/gen_for_type_repr.rs linguist-generated
/FormatArgsExpr/gen_format.rs linguist-generated
diff --git a/rust/ql/test/extractor-tests/generated/ClosureBinder/Cargo.lock b/rust/ql/test/extractor-tests/generated/ClosureBinder/Cargo.lock
deleted file mode 100644
index b9856cfaf77..00000000000
--- a/rust/ql/test/extractor-tests/generated/ClosureBinder/Cargo.lock
+++ /dev/null
@@ -1,7 +0,0 @@
-# This file is automatically @generated by Cargo.
-# It is not intended for manual editing.
-version = 4
-
-[[package]]
-name = "test"
-version = "0.0.1"
diff --git a/rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.expected b/rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.expected
deleted file mode 100644
index dfd2bd58d07..00000000000
--- a/rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.expected
+++ /dev/null
@@ -1,4 +0,0 @@
-instances
-| gen_closure_binder.rs:7:21:7:43 | ClosureBinder |
-getGenericParamList
-| gen_closure_binder.rs:7:21:7:43 | ClosureBinder | gen_closure_binder.rs:7:24:7:43 | <...> |
diff --git a/rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.ql b/rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.ql
deleted file mode 100644
index d204c5fbde1..00000000000
--- a/rust/ql/test/extractor-tests/generated/ClosureBinder/ClosureBinder.ql
+++ /dev/null
@@ -1,9 +0,0 @@
-// generated by codegen, do not edit
-import codeql.rust.elements
-import TestUtils
-
-query predicate instances(ClosureBinder x) { toBeTested(x) and not x.isUnknown() }
-
-query predicate getGenericParamList(ClosureBinder x, GenericParamList getGenericParamList) {
- toBeTested(x) and not x.isUnknown() and getGenericParamList = x.getGenericParamList()
-}
diff --git a/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql b/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql
index acf3b130677..296eae11485 100644
--- a/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql
+++ b/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.ql
@@ -37,8 +37,8 @@ query predicate getBody(ClosureExpr x, Expr getBody) {
toBeTested(x) and not x.isUnknown() and getBody = x.getBody()
}
-query predicate getClosureBinder(ClosureExpr x, ClosureBinder getClosureBinder) {
- toBeTested(x) and not x.isUnknown() and getClosureBinder = x.getClosureBinder()
+query predicate getForBinder(ClosureExpr x, ForBinder getForBinder) {
+ toBeTested(x) and not x.isUnknown() and getForBinder = x.getForBinder()
}
query predicate getRetType(ClosureExpr x, RetTypeRepr getRetType) {
diff --git a/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.ql b/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.ql
new file mode 100644
index 00000000000..7e577cb1be2
--- /dev/null
+++ b/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.ql
@@ -0,0 +1,9 @@
+// generated by codegen, do not edit
+import codeql.rust.elements
+import TestUtils
+
+query predicate instances(ForBinder x) { toBeTested(x) and not x.isUnknown() }
+
+query predicate getGenericParamList(ForBinder x, GenericParamList getGenericParamList) {
+ toBeTested(x) and not x.isUnknown() and getGenericParamList = x.getGenericParamList()
+}
diff --git a/rust/ql/test/extractor-tests/generated/ClosureBinder/gen_closure_binder.rs b/rust/ql/test/extractor-tests/generated/ForBinder/gen_for_binder.rs
similarity index 68%
rename from rust/ql/test/extractor-tests/generated/ClosureBinder/gen_closure_binder.rs
rename to rust/ql/test/extractor-tests/generated/ForBinder/gen_for_binder.rs
index 6328368c5e1..c37e16793f2 100644
--- a/rust/ql/test/extractor-tests/generated/ClosureBinder/gen_closure_binder.rs
+++ b/rust/ql/test/extractor-tests/generated/ForBinder/gen_for_binder.rs
@@ -1,7 +1,7 @@
// generated by codegen, do not edit
-fn test_closure_binder() -> () {
- // A closure binder, specifying lifetime or type parameters for a closure.
+fn test_for_binder() -> () {
+ // A for binder, specifying lifetime or type parameters for a closure or a type.
//
// For example:
let print_any = for |x: T| {
diff --git a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql
index 398a317a3dd..9a485ca6d74 100644
--- a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql
+++ b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.ql
@@ -4,8 +4,8 @@ import TestUtils
query predicate instances(ForTypeRepr x) { toBeTested(x) and not x.isUnknown() }
-query predicate getGenericParamList(ForTypeRepr x, GenericParamList getGenericParamList) {
- toBeTested(x) and not x.isUnknown() and getGenericParamList = x.getGenericParamList()
+query predicate getForBinder(ForTypeRepr x, ForBinder getForBinder) {
+ toBeTested(x) and not x.isUnknown() and getForBinder = x.getForBinder()
}
query predicate getTypeRepr(ForTypeRepr x, TypeRepr getTypeRepr) {
diff --git a/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.ql b/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.ql
index e4b2b6127dc..40d44dff8c8 100644
--- a/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.ql
+++ b/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.ql
@@ -13,6 +13,10 @@ query predicate instances(
if x.isConst() then isConst = "yes" else isConst = "no"
}
+query predicate getForBinder(TypeBound x, ForBinder getForBinder) {
+ toBeTested(x) and not x.isUnknown() and getForBinder = x.getForBinder()
+}
+
query predicate getLifetime(TypeBound x, Lifetime getLifetime) {
toBeTested(x) and not x.isUnknown() and getLifetime = x.getLifetime()
}
diff --git a/rust/ql/test/extractor-tests/generated/WherePred/WherePred.ql b/rust/ql/test/extractor-tests/generated/WherePred/WherePred.ql
index 3d1ecb7339d..957c2b45edf 100644
--- a/rust/ql/test/extractor-tests/generated/WherePred/WherePred.ql
+++ b/rust/ql/test/extractor-tests/generated/WherePred/WherePred.ql
@@ -4,8 +4,8 @@ import TestUtils
query predicate instances(WherePred x) { toBeTested(x) and not x.isUnknown() }
-query predicate getGenericParamList(WherePred x, GenericParamList getGenericParamList) {
- toBeTested(x) and not x.isUnknown() and getGenericParamList = x.getGenericParamList()
+query predicate getForBinder(WherePred x, ForBinder getForBinder) {
+ toBeTested(x) and not x.isUnknown() and getForBinder = x.getForBinder()
}
query predicate getLifetime(WherePred x, Lifetime getLifetime) {
diff --git a/rust/schema/annotations.py b/rust/schema/annotations.py
index 8295cd5860b..67e3610e8a2 100644
--- a/rust/schema/annotations.py
+++ b/rust/schema/annotations.py
@@ -967,10 +967,10 @@ class _:
"""
-@annotate(ClosureBinder)
+@annotate(ForBinder)
class _:
"""
- A closure binder, specifying lifetime or type parameters for a closure.
+ A for binder, specifying lifetime or type parameters for a closure or a type.
For example:
```rust
diff --git a/rust/schema/ast.py b/rust/schema/ast.py
index d5b99753f11..e527d318b66 100644
--- a/rust/schema/ast.py
+++ b/rust/schema/ast.py
@@ -162,13 +162,10 @@ class CastExpr(Expr, ):
expr: optional["Expr"] | child
type_repr: optional["TypeRepr"] | child
-class ClosureBinder(AstNode, ):
- generic_param_list: optional["GenericParamList"] | child
-
class ClosureExpr(Expr, ):
attrs: list["Attr"] | child
body: optional["Expr"] | child
- closure_binder: optional["ClosureBinder"] | child
+ for_binder: optional["ForBinder"] | child
is_async: predicate
is_const: predicate
is_gen: predicate
@@ -265,6 +262,9 @@ class FnPtrTypeRepr(TypeRepr, ):
param_list: optional["ParamList"] | child
ret_type: optional["RetTypeRepr"] | child
+class ForBinder(AstNode, ):
+ generic_param_list: optional["GenericParamList"] | child
+
class ForExpr(Expr, ):
attrs: list["Attr"] | child
iterable: optional["Expr"] | child
@@ -273,7 +273,7 @@ class ForExpr(Expr, ):
pat: optional["Pat"] | child
class ForTypeRepr(TypeRepr, ):
- generic_param_list: optional["GenericParamList"] | child
+ for_binder: optional["ForBinder"] | child
type_repr: optional["TypeRepr"] | child
class FormatArgsArg(AstNode, ):
@@ -697,6 +697,7 @@ class TypeArg(GenericArg, ):
type_repr: optional["TypeRepr"] | child
class TypeBound(AstNode, ):
+ for_binder: optional["ForBinder"] | child
is_async: predicate
is_const: predicate
lifetime: optional["Lifetime"] | child
@@ -757,7 +758,7 @@ class WhereClause(AstNode, ):
predicates: list["WherePred"] | child
class WherePred(AstNode, ):
- generic_param_list: optional["GenericParamList"] | child
+ for_binder: optional["ForBinder"] | child
lifetime: optional["Lifetime"] | child
type_repr: optional["TypeRepr"] | child
type_bound_list: optional["TypeBoundList"] | child
From fbc81cbb1886f0318ed24c007d5569acf8ecc7f3 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 12 Aug 2025 17:10:02 +0200
Subject: [PATCH 080/298] Rust: fix compilation errors
---
rust/extractor/src/rust_analyzer.rs | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/rust/extractor/src/rust_analyzer.rs b/rust/extractor/src/rust_analyzer.rs
index d477b13b5d0..ce9d763db4d 100644
--- a/rust/extractor/src/rust_analyzer.rs
+++ b/rust/extractor/src/rust_analyzer.rs
@@ -95,7 +95,7 @@ impl<'a> RustAnalyzer<'a> {
ParseResult {
ast: source_file,
- text: input.text(semantics.db),
+ text: input.text(semantics.db).clone(),
errors,
semantics_info: Ok(FileSemanticInformation { file_id, semantics }),
}
From 92e94695e7183265a17e814d60464938b2c14b5d Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 12 Aug 2025 17:29:11 +0200
Subject: [PATCH 081/298] Rust: add `ForBinder` case in `ClosureExpr` and
accept test changes
---
rust/ql/.generated.list | 6 ++---
.../lib/codeql/rust/elements/ClosureExpr.qll | 9 ++++---
.../elements/internal/ClosureExprImpl.qll | 9 ++++---
.../internal/generated/ClosureExpr.qll | 9 ++++---
.../rust/elements/internal/generated/Raw.qll | 9 ++++---
.../generated/.generated_tests.list | 2 +-
.../generated/AsmExpr/AsmExpr.expected | 3 +++
.../ClosureExpr/ClosureExpr.expected | 27 +++++++++++--------
.../generated/ClosureExpr/gen_closure_expr.rs | 9 ++++---
.../generated/ForBinder/ForBinder.expected | 4 +++
.../ForTypeRepr/ForTypeRepr.expected | 5 +---
.../generated/TypeBound/TypeBound.expected | 1 +
.../generated/WherePred/WherePred.expected | 2 +-
rust/schema/annotations.py | 9 ++++---
14 files changed, 66 insertions(+), 38 deletions(-)
create mode 100644 rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected
diff --git a/rust/ql/.generated.list b/rust/ql/.generated.list
index 2e88869bd68..2a093c83953 100644
--- a/rust/ql/.generated.list
+++ b/rust/ql/.generated.list
@@ -36,7 +36,7 @@ lib/codeql/rust/elements/CallExpr.qll f336500ca7a611b164d48b90e80edb0c0d3816792b
lib/codeql/rust/elements/CallExprBase.qll 2846202b5208b541977500286951d96487bf555838c6c16cdd006a71e383745a c789d412bf099c624329379e0c7d94fa0d23ae2edea7a25a2ea0f3c0042ccf62
lib/codeql/rust/elements/Callable.qll 0f7f78c3bfabbe24962f6232b0440d27e51f06d2b8d341fc623ffbfbff173f47 5fd13aaa0eaf76ea0b47fa0641bd23eea20a069f0b3cbc1ee4e290e88321008a
lib/codeql/rust/elements/CastExpr.qll 2fe1f36ba31fa29de309baf0a665cfcae67b61c73345e8f9bbd41e8c235fec45 c5b4c1e9dc24eb2357799defcb2df25989075e3a80e8663b74204a1c1b70e29a
-lib/codeql/rust/elements/ClosureExpr.qll d122c769abc6c832dd1ad1b55d00aabc2f9029dd786f30905ac019e9e18517c0 56288c841c5e88cb603acb0d078ddeab8166f435b9545598293c0a59e9e84457
+lib/codeql/rust/elements/ClosureExpr.qll 69e0b7a7c7a4c348fcada5ad4da22dd2f51747109f856be239cede315a56d695 93400650282e2d4e682b826e9f5f844aa893dda126548e41ea1c703d2bf209ca
lib/codeql/rust/elements/Comment.qll fedad50575125e9a64a8a8776a8c1dbf1e76df990f01849d9f0955f9d74cb2a6 8eb1afad1e1007a4f0090fdac65d81726b23eda6517d067fd0185f70f17635ab
lib/codeql/rust/elements/Const.qll 5f4d11e01162a06127ba56519efd66d1ecfb5de7c1792fc1c283a56cf2127373 8c618ac774267d25db70cc05a080f8a408dc23ab7e88c0fc543eda8b4d4cb995
lib/codeql/rust/elements/ConstArg.qll 01865b3be4790c627a062c59ea608462931abcb2f94a132cf265318664fd1251 a2c6bbf63dbfa999e511b6941143a51c9392477d8ccd25e081f85475936ff558
@@ -492,7 +492,7 @@ lib/codeql/rust/elements/internal/generated/CallExpr.qll f1b8dae487077cc9d1dccf8
lib/codeql/rust/elements/internal/generated/CallExprBase.qll 2268e01d65015014c05166161bb28e5a1e78164d525ca16fc1e3106866cf231d b2f9b912153ba4d3e3612df4f74ac0e83077c31d5b31383bd277974081417a56
lib/codeql/rust/elements/internal/generated/Callable.qll 9a8661aa018fd90a21529760c1dbc46c1ad3649e17b030e59ced0683fbf83f8a 8b573adfc23ec0ac91949da415e6a0c988fa02cbce9534d45ac98a5512d7b1ca
lib/codeql/rust/elements/internal/generated/CastExpr.qll ddc20054b0b339ad4d40298f3461490d25d00af87c876da5ffbc6a11c0832295 f4247307afcd74d80e926f29f8c57e78c50800984483e6b6003a44681e4a71f3
-lib/codeql/rust/elements/internal/generated/ClosureExpr.qll d5deef5d257b313e3fa3ad292c8af26db32f45446dc88009515435344aed1efc eb8d0394255e7dc005ef5c729ae851b78b4a0d838c3ac2460b4e715bbdb5e97f
+lib/codeql/rust/elements/internal/generated/ClosureExpr.qll 1f77ea8ec01366f8027fa36793f7de5a74f562a1af1bf6954410e68670e6f68a bd61457093dcfc3985e6e526d4582299f29421bc7d3e9818e530152ac8ad8bed
lib/codeql/rust/elements/internal/generated/Comment.qll cd1ef861e3803618f9f78a4ac00516d50ecfecdca1c1d14304dc5327cbe07a3b 8b67345aeb15beb5895212228761ea3496297846c93fd2127b417406ae87c201
lib/codeql/rust/elements/internal/generated/Const.qll 3e606f0198b6461a94964dba7a4d386408f01651d75378eeab251dfceccf49c8 20fe276cded4764bdb1cd50de956bea88d7cd731909c0b84b4abb972b3094959
lib/codeql/rust/elements/internal/generated/ConstArg.qll c52bf746f2dc89b8d71b8419736707bfcbb09cca424c3ba76e888e2add415bf6 89309a9df4fde23cfd3d8492908ccec4d90cc8457d35c507ef81371a369941b4
@@ -590,7 +590,7 @@ lib/codeql/rust/elements/internal/generated/PtrTypeRepr.qll 8d0ea4f6c7f8203340bf
lib/codeql/rust/elements/internal/generated/PureSynthConstructors.qll e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f
lib/codeql/rust/elements/internal/generated/RangeExpr.qll 23cca03bf43535f33b22a38894f70d669787be4e4f5b8fe5c8f7b964d30e9027 18624cef6c6b679eeace2a98737e472432e0ead354cca02192b4d45330f047c9
lib/codeql/rust/elements/internal/generated/RangePat.qll 80826a6a6868a803aa2372e31c52a03e1811a3f1f2abdb469f91ca0bfdd9ecb6 34ee1e208c1690cba505dff2c588837c0cd91e185e2a87d1fe673191962276a9
-lib/codeql/rust/elements/internal/generated/Raw.qll 3c38cd761b847ba5744810479901692fe1a28759d8305f828ff535c034f21f97 56f75a0589112d66f234c99b0c3798ed928b3a808ebb7d37590cf5868aad9c10
+lib/codeql/rust/elements/internal/generated/Raw.qll 5de291e604fbeb5a4536eeb2a417f95b227a600bb589f7aab075971cd1cbfc67 22e5b41fba360781f354edb72dbc8f53b9d7434c30d3e3bac4c22f1faa72b8ed
lib/codeql/rust/elements/internal/generated/RefExpr.qll 7d995884e3dc1c25fc719f5d7253179344d63650e217e9ff6530285fe7a57f64 f2c3c12551deea4964b66553fb9b6423ee16fec53bd63db4796191aa60dc6c66
lib/codeql/rust/elements/internal/generated/RefPat.qll 456ede39837463ee22a630ec7ab6c8630d3664a8ea206fcc6e4f199e92fa564c 5622062765f32930465ba6b170e986706f159f6070f48adee3c20e24e8df4e05
lib/codeql/rust/elements/internal/generated/RefTypeRepr.qll 5b0663a6d234572fb3e467e276d019415caa95ef006438cc59b7af4e1783161e 0e27c8a8f0e323c0e4d6db01fca821bf07c0864d293cdf96fa891b10820c1e4b
diff --git a/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll b/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll
index 63fb8ccf53a..e2e2c067e46 100644
--- a/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll
+++ b/rust/ql/lib/codeql/rust/elements/ClosureExpr.qll
@@ -15,10 +15,13 @@ import codeql.rust.elements.RetTypeRepr
* |x| x + 1;
* move |x: i32| -> i32 { x + 1 };
* async |x: i32, y| x + y;
- * #[coroutine]
+ * #[coroutine]
* |x| yield x;
- * #[coroutine]
- * static |x| yield x;
+ * #[coroutine]
+ * static |x| yield x;
+ * for |x: T| {
+ * println!("{:?}", x);
+ * };
* ```
*/
final class ClosureExpr = Impl::ClosureExpr;
diff --git a/rust/ql/lib/codeql/rust/elements/internal/ClosureExprImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/ClosureExprImpl.qll
index e96ae47e301..960a91e9ee5 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/ClosureExprImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/ClosureExprImpl.qll
@@ -18,10 +18,13 @@ module Impl {
* |x| x + 1;
* move |x: i32| -> i32 { x + 1 };
* async |x: i32, y| x + y;
- * #[coroutine]
+ * #[coroutine]
* |x| yield x;
- * #[coroutine]
- * static |x| yield x;
+ * #[coroutine]
+ * static |x| yield x;
+ * for |x: T| {
+ * println!("{:?}", x);
+ * };
* ```
*/
class ClosureExpr extends Generated::ClosureExpr {
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll
index 8341226d6e2..99e494a6000 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ClosureExpr.qll
@@ -23,10 +23,13 @@ module Generated {
* |x| x + 1;
* move |x: i32| -> i32 { x + 1 };
* async |x: i32, y| x + y;
- * #[coroutine]
+ * #[coroutine]
* |x| yield x;
- * #[coroutine]
- * static |x| yield x;
+ * #[coroutine]
+ * static |x| yield x;
+ * for |x: T| {
+ * println!("{:?}", x);
+ * };
* ```
* INTERNAL: Do not reference the `Generated::ClosureExpr` class directly.
* Use the subclass `ClosureExpr`, where the following predicates are available.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
index 019e0c08e16..dbb1ae77237 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
@@ -1902,10 +1902,13 @@ module Raw {
* |x| x + 1;
* move |x: i32| -> i32 { x + 1 };
* async |x: i32, y| x + y;
- * #[coroutine]
+ * #[coroutine]
* |x| yield x;
- * #[coroutine]
- * static |x| yield x;
+ * #[coroutine]
+ * static |x| yield x;
+ * for |x: T| {
+ * println!("{:?}", x);
+ * };
* ```
*/
class ClosureExpr extends @closure_expr, Expr, Callable {
diff --git a/rust/ql/test/extractor-tests/generated/.generated_tests.list b/rust/ql/test/extractor-tests/generated/.generated_tests.list
index 616aa6525bf..952b93b3339 100644
--- a/rust/ql/test/extractor-tests/generated/.generated_tests.list
+++ b/rust/ql/test/extractor-tests/generated/.generated_tests.list
@@ -25,7 +25,7 @@ BoxPat/gen_box_pat.rs 1493e24b732370b577ade38c47db17fa157df19f5390606a67a6040e49
BreakExpr/gen_break_expr.rs aacdf9df7fc51d19742b9e813835c0bd0913017e8d62765960e06b27d58b9031 aacdf9df7fc51d19742b9e813835c0bd0913017e8d62765960e06b27d58b9031
CallExpr/gen_call_expr.rs 013a7c878996aefb25b94b68eebc4f0b1bb74ccd09e91c491980817a383e2401 013a7c878996aefb25b94b68eebc4f0b1bb74ccd09e91c491980817a383e2401
CastExpr/gen_cast_expr.rs c3892211fbae4fed7cb1f25ff1679fd79d2878bf0bf2bd4b7982af23d00129f5 c3892211fbae4fed7cb1f25ff1679fd79d2878bf0bf2bd4b7982af23d00129f5
-ClosureExpr/gen_closure_expr.rs 15bd9abdb8aaffabb8bb335f8ebd0571eb5f29115e1dc8d11837aa988702cd80 15bd9abdb8aaffabb8bb335f8ebd0571eb5f29115e1dc8d11837aa988702cd80
+ClosureExpr/gen_closure_expr.rs bd95408103b7f2084e526e6d35cf3319b2e9d7219aff4c80e4e6691180c549b4 bd95408103b7f2084e526e6d35cf3319b2e9d7219aff4c80e4e6691180c549b4
Comment/gen_comment.rs 1e1f9f43161a79c096c2056e8b7f5346385ab7addcdec68c2d53b383dd3debe6 1e1f9f43161a79c096c2056e8b7f5346385ab7addcdec68c2d53b383dd3debe6
Const/gen_const.rs a3b971134a4204d0da12563fcefa9ab72f3f2f2e957e82b70c8548b5807f375f a3b971134a4204d0da12563fcefa9ab72f3f2f2e957e82b70c8548b5807f375f
ConstArg/gen_const_arg.rs 6a15d099c61ffa814e8e0e0fca2d8ff481d73ad81959064e0a214d3172a9d49e 6a15d099c61ffa814e8e0e0fca2d8ff481d73ad81959064e0a214d3172a9d49e
diff --git a/rust/ql/test/extractor-tests/generated/AsmExpr/AsmExpr.expected b/rust/ql/test/extractor-tests/generated/AsmExpr/AsmExpr.expected
index 2091c3814d5..d4cc7cbe67c 100644
--- a/rust/ql/test/extractor-tests/generated/AsmExpr/AsmExpr.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmExpr/AsmExpr.expected
@@ -1,5 +1,8 @@
instances
| gen_asm_expr.rs:6:9:7:59 | AsmExpr |
+getExtendedCanonicalPath
+getCrateOrigin
+getAttributeMacroExpansion
getAsmPiece
| gen_asm_expr.rs:6:9:7:59 | AsmExpr | 0 | gen_asm_expr.rs:7:39:7:47 | AsmOperandNamed |
| gen_asm_expr.rs:6:9:7:59 | AsmExpr | 1 | gen_asm_expr.rs:7:50:7:58 | AsmOperandNamed |
diff --git a/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected b/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected
index 041669861b9..1c3f489930b 100644
--- a/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected
+++ b/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected
@@ -2,30 +2,35 @@ instances
| gen_closure_expr.rs:5:5:5:13 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | no | isStatic: | no |
| gen_closure_expr.rs:6:5:6:34 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | yes | isStatic: | no |
| gen_closure_expr.rs:7:5:7:27 | \|...\| ... | isAsync: | yes | isConst: | no | isGen: | no | isMove: | no | isStatic: | no |
-| gen_closure_expr.rs:8:6:9:15 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | no | isStatic: | no |
-| gen_closure_expr.rs:10:6:11:23 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | no | isStatic: | yes |
+| gen_closure_expr.rs:8:5:9:15 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | no | isStatic: | no |
+| gen_closure_expr.rs:10:5:11:22 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | no | isStatic: | yes |
+| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | isAsync: | no | isConst: | no | isGen: | no | isMove: | no | isStatic: | no |
getParamList
| gen_closure_expr.rs:5:5:5:13 | \|...\| ... | gen_closure_expr.rs:5:5:5:7 | ParamList |
| gen_closure_expr.rs:6:5:6:34 | \|...\| ... | gen_closure_expr.rs:6:10:6:17 | ParamList |
| gen_closure_expr.rs:7:5:7:27 | \|...\| ... | gen_closure_expr.rs:7:11:7:21 | ParamList |
-| gen_closure_expr.rs:8:6:9:15 | \|...\| ... | gen_closure_expr.rs:9:5:9:7 | ParamList |
-| gen_closure_expr.rs:10:6:11:23 | \|...\| ... | gen_closure_expr.rs:11:13:11:15 | ParamList |
+| gen_closure_expr.rs:8:5:9:15 | \|...\| ... | gen_closure_expr.rs:9:5:9:7 | ParamList |
+| gen_closure_expr.rs:10:5:11:22 | \|...\| ... | gen_closure_expr.rs:11:12:11:14 | ParamList |
+| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | gen_closure_expr.rs:12:29:12:34 | ParamList |
getAttr
-| gen_closure_expr.rs:8:6:9:15 | \|...\| ... | 0 | gen_closure_expr.rs:8:6:8:17 | Attr |
-| gen_closure_expr.rs:10:6:11:23 | \|...\| ... | 0 | gen_closure_expr.rs:10:6:10:17 | Attr |
+| gen_closure_expr.rs:8:5:9:15 | \|...\| ... | 0 | gen_closure_expr.rs:8:5:8:16 | Attr |
+| gen_closure_expr.rs:10:5:11:22 | \|...\| ... | 0 | gen_closure_expr.rs:10:5:10:16 | Attr |
getParam
| gen_closure_expr.rs:5:5:5:13 | \|...\| ... | 0 | gen_closure_expr.rs:5:6:5:6 | ... |
| gen_closure_expr.rs:6:5:6:34 | \|...\| ... | 0 | gen_closure_expr.rs:6:11:6:16 | ...: i32 |
| gen_closure_expr.rs:7:5:7:27 | \|...\| ... | 0 | gen_closure_expr.rs:7:12:7:17 | ...: i32 |
| gen_closure_expr.rs:7:5:7:27 | \|...\| ... | 1 | gen_closure_expr.rs:7:20:7:20 | ... |
-| gen_closure_expr.rs:8:6:9:15 | \|...\| ... | 0 | gen_closure_expr.rs:9:6:9:6 | ... |
-| gen_closure_expr.rs:10:6:11:23 | \|...\| ... | 0 | gen_closure_expr.rs:11:14:11:14 | ... |
+| gen_closure_expr.rs:8:5:9:15 | \|...\| ... | 0 | gen_closure_expr.rs:9:6:9:6 | ... |
+| gen_closure_expr.rs:10:5:11:22 | \|...\| ... | 0 | gen_closure_expr.rs:11:13:11:13 | ... |
+| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | 0 | gen_closure_expr.rs:12:30:12:33 | ...: T |
getBody
| gen_closure_expr.rs:5:5:5:13 | \|...\| ... | gen_closure_expr.rs:5:9:5:13 | ... + ... |
| gen_closure_expr.rs:6:5:6:34 | \|...\| ... | gen_closure_expr.rs:6:26:6:34 | { ... } |
| gen_closure_expr.rs:7:5:7:27 | \|...\| ... | gen_closure_expr.rs:7:23:7:27 | ... + ... |
-| gen_closure_expr.rs:8:6:9:15 | \|...\| ... | gen_closure_expr.rs:9:9:9:15 | YieldExpr |
-| gen_closure_expr.rs:10:6:11:23 | \|...\| ... | gen_closure_expr.rs:11:17:11:23 | YieldExpr |
-getClosureBinder
+| gen_closure_expr.rs:8:5:9:15 | \|...\| ... | gen_closure_expr.rs:9:9:9:15 | YieldExpr |
+| gen_closure_expr.rs:10:5:11:22 | \|...\| ... | gen_closure_expr.rs:11:16:11:22 | YieldExpr |
+| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | gen_closure_expr.rs:12:36:14:5 | { ... } |
+getForBinder
+| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | gen_closure_expr.rs:12:5:12:27 | ForBinder |
getRetType
| gen_closure_expr.rs:6:5:6:34 | \|...\| ... | gen_closure_expr.rs:6:19:6:24 | RetTypeRepr |
diff --git a/rust/ql/test/extractor-tests/generated/ClosureExpr/gen_closure_expr.rs b/rust/ql/test/extractor-tests/generated/ClosureExpr/gen_closure_expr.rs
index 4c0c6067aac..a9d1c5a2aea 100644
--- a/rust/ql/test/extractor-tests/generated/ClosureExpr/gen_closure_expr.rs
+++ b/rust/ql/test/extractor-tests/generated/ClosureExpr/gen_closure_expr.rs
@@ -5,8 +5,11 @@ fn test_closure_expr() -> () {
|x| x + 1;
move |x: i32| -> i32 { x + 1 };
async |x: i32, y| x + y;
- #[coroutine]
+ #[coroutine]
|x| yield x;
- #[coroutine]
- static |x| yield x;
+ #[coroutine]
+ static |x| yield x;
+ for |x: T| {
+ println!("{:?}", x);
+ };
}
diff --git a/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected b/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected
new file mode 100644
index 00000000000..3607f89a6dd
--- /dev/null
+++ b/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected
@@ -0,0 +1,4 @@
+instances
+| gen_for_binder.rs:7:21:7:43 | ForBinder |
+getGenericParamList
+| gen_for_binder.rs:7:21:7:43 | ForBinder | gen_for_binder.rs:7:24:7:43 | <...> |
diff --git a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
index 8f5ac12ec36..450d0b6c754 100644
--- a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
+++ b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
@@ -1,6 +1,3 @@
instances
-| gen_for_type_repr.rs:9:12:9:41 | ForTypeRepr |
-getGenericParamList
-| gen_for_type_repr.rs:9:12:9:41 | ForTypeRepr | gen_for_type_repr.rs:9:15:9:18 | <...> |
+getForBinder
getTypeRepr
-| gen_for_type_repr.rs:9:12:9:41 | ForTypeRepr | gen_for_type_repr.rs:9:20:9:41 | Fn |
diff --git a/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected b/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected
index e0ed9fcdd6c..f294d646676 100644
--- a/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected
+++ b/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected
@@ -1,5 +1,6 @@
instances
| gen_type_bound.rs:7:15:7:19 | TypeBound | isAsync: | no | isConst: | no |
+getForBinder
getLifetime
getTypeRepr
| gen_type_bound.rs:7:15:7:19 | TypeBound | gen_type_bound.rs:7:15:7:19 | Debug |
diff --git a/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected b/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected
index 4980b912b86..18fd13987c3 100644
--- a/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected
+++ b/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected
@@ -1,7 +1,7 @@
instances
| gen_where_pred.rs:7:36:7:43 | WherePred |
| gen_where_pred.rs:7:46:7:53 | WherePred |
-getGenericParamList
+getForBinder
getLifetime
getTypeRepr
| gen_where_pred.rs:7:36:7:43 | WherePred | gen_where_pred.rs:7:36:7:36 | T |
diff --git a/rust/schema/annotations.py b/rust/schema/annotations.py
index 67e3610e8a2..3c17ec99756 100644
--- a/rust/schema/annotations.py
+++ b/rust/schema/annotations.py
@@ -547,10 +547,13 @@ class _:
|x| x + 1;
move |x: i32| -> i32 { x + 1 };
async |x: i32, y| x + y;
- #[coroutine]
+ #[coroutine]
|x| yield x;
- #[coroutine]
- static |x| yield x;
+ #[coroutine]
+ static |x| yield x;
+ for |x: T| {
+ println!("{:?}", x);
+ };
```
"""
From 0924d795b4b9e314ed4467c64440036b634bfeb9 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Fri, 15 Aug 2025 10:12:12 +0200
Subject: [PATCH 082/298] Rust: accept test changes
---
.../AsmClobberAbi/AsmClobberAbi.expected | 1 +
.../generated/AsmConst/AsmConst.expected | 2 +
.../generated/AsmDirSpec/AsmDirSpec.expected | 2 +
.../generated/AsmLabel/AsmLabel.expected | 2 +
.../AsmOperandExpr/AsmOperandExpr.expected | 6 +
.../AsmOperandNamed/AsmOperandNamed.expected | 5 +
.../generated/AsmOption/AsmOption.expected | 2 +
.../AsmOptionsList/AsmOptionsList.expected | 3 +
.../AsmRegOperand/AsmRegOperand.expected | 8 +
.../generated/AsmRegSpec/AsmRegSpec.expected | 3 +
.../generated/AsmSym/AsmSym.expected | 2 +
.../generated/MacroCall/MacroCall.expected | 2 +-
.../generated/MacroItems/MacroItems.expected | 6 +-
.../NeverTypeRepr/NeverTypeRepr.expected | 2 +-
.../PathResolutionConsistency.expected | 12 +-
.../macro-expansion/test.expected | 12 +-
.../controlflow/BasicBlocks.expected | 70 ++--
.../library-tests/controlflow/Cfg.expected | 88 ++---
.../dataflow/local/DataFlowStep.expected | 4 +-
.../strings/inline-taint-flow.expected | 12 +-
.../PathResolutionConsistency.expected | 2 +-
.../test/library-tests/variables/Cfg.expected | 40 +-
.../test/library-tests/variables/Ssa.expected | 16 +-
.../variables/variables.expected | 16 +-
.../security/CWE-020/RegexInjection.expected | 6 +-
.../TypeInferenceConsistency.expected | 4 +-
.../security/CWE-089/SqlInjection.expected | 6 +-
.../CWE-311/CleartextTransmission.expected | 30 +-
.../PathResolutionConsistency.expected | 128 +++----
.../CWE-312/CleartextLogging.expected | 358 +++++++++---------
.../CWE-825/AccessAfterLifetime.expected | 18 +-
.../PathResolutionConsistency.expected | 2 +-
32 files changed, 453 insertions(+), 417 deletions(-)
diff --git a/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected b/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected
index 10f3409cc79..3fa93611a58 100644
--- a/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected
@@ -1 +1,2 @@
| gen_asm_clobber_abi.rs:8:14:8:29 | AsmClobberAbi |
+| gen_asm_clobber_abi.rs:8:14:8:29 | AsmClobberAbi |
diff --git a/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected b/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected
index 30ed42e46f9..f87adbca9bd 100644
--- a/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected
@@ -1,4 +1,6 @@
instances
| gen_asm_const.rs:8:30:8:37 | AsmConst | isConst: | yes |
+| gen_asm_const.rs:8:30:8:37 | AsmConst | isConst: | yes |
getExpr
| gen_asm_const.rs:8:30:8:37 | AsmConst | gen_asm_const.rs:8:36:8:37 | 42 |
+| gen_asm_const.rs:8:30:8:37 | AsmConst | gen_asm_const.rs:8:36:8:37 | 42 |
diff --git a/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected b/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected
index 977c8504c0e..dc6fb69446b 100644
--- a/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected
@@ -1,2 +1,4 @@
| gen_asm_dir_spec.rs:8:47:8:49 | AsmDirSpec |
+| gen_asm_dir_spec.rs:8:47:8:49 | AsmDirSpec |
+| gen_asm_dir_spec.rs:8:67:8:68 | AsmDirSpec |
| gen_asm_dir_spec.rs:8:67:8:68 | AsmDirSpec |
diff --git a/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected b/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected
index cbd9eac398a..cdc2abe7bed 100644
--- a/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected
@@ -1,4 +1,6 @@
instances
| gen_asm_label.rs:10:9:10:47 | AsmLabel |
+| gen_asm_label.rs:10:9:10:47 | AsmLabel |
getBlockExpr
| gen_asm_label.rs:10:9:10:47 | AsmLabel | gen_asm_label.rs:10:15:10:47 | { ... } |
+| gen_asm_label.rs:10:9:10:47 | AsmLabel | gen_asm_label.rs:10:15:10:47 | { ... } |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected b/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected
index 262ca3ada57..f252705d0d9 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected
@@ -1,9 +1,15 @@
instances
| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr |
+| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr |
+| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr |
| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr |
getInExpr
| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
+| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
+| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
getOutExpr
| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
+| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
+| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected b/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected
index c8aec731ff8..66dcd7eb7d0 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected
@@ -1,8 +1,13 @@
instances
| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed |
+| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed |
+| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed |
| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed |
getAsmOperand
| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed | gen_asm_operand_named.rs:8:34:8:43 | AsmRegOperand |
+| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed | gen_asm_operand_named.rs:8:34:8:43 | AsmRegOperand |
+| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:54:8:62 | AsmRegOperand |
| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:54:8:62 | AsmRegOperand |
getName
| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:46:8:50 | input |
+| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:46:8:50 | input |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected b/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected
index ddd5bc880b9..4bb6ff00140 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected
@@ -1,2 +1,4 @@
| gen_asm_option.rs:8:22:8:28 | AsmOption | isRaw: | no |
+| gen_asm_option.rs:8:22:8:28 | AsmOption | isRaw: | no |
+| gen_asm_option.rs:8:31:8:35 | AsmOption | isRaw: | no |
| gen_asm_option.rs:8:31:8:35 | AsmOption | isRaw: | no |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected b/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected
index cf9ec35d070..db19616d779 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected
@@ -1,5 +1,8 @@
instances
| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList |
+| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList |
getAsmOption
| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 0 | gen_asm_options_list.rs:8:22:8:28 | AsmOption |
+| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 0 | gen_asm_options_list.rs:8:22:8:28 | AsmOption |
+| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 1 | gen_asm_options_list.rs:8:31:8:35 | AsmOption |
| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 1 | gen_asm_options_list.rs:8:31:8:35 | AsmOption |
diff --git a/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected b/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected
index a141f1a25c2..62aa617aa8d 100644
--- a/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected
@@ -1,12 +1,20 @@
instances
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand |
+| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand |
+| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand |
getAsmDirSpec
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:26:8:28 | AsmDirSpec |
+| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:26:8:28 | AsmDirSpec |
+| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:38:8:39 | AsmDirSpec |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:38:8:39 | AsmDirSpec |
getAsmOperandExpr
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:35:8:35 | AsmOperandExpr |
+| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:35:8:35 | AsmOperandExpr |
+| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:46:8:46 | AsmOperandExpr |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:46:8:46 | AsmOperandExpr |
getAsmRegSpec
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:30:8:32 | AsmRegSpec |
+| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:30:8:32 | AsmRegSpec |
+| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:41:8:43 | AsmRegSpec |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:41:8:43 | AsmRegSpec |
diff --git a/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected b/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected
index 120ba8d2093..31fb38d585f 100644
--- a/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected
@@ -1,5 +1,8 @@
instances
| gen_asm_reg_spec.rs:8:30:8:34 | AsmRegSpec |
+| gen_asm_reg_spec.rs:8:30:8:34 | AsmRegSpec |
+| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec |
| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec |
getIdentifier
| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec | gen_asm_reg_spec.rs:8:43:8:45 | EBX |
+| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec | gen_asm_reg_spec.rs:8:43:8:45 | EBX |
diff --git a/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected b/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected
index e3f8fbc9ec7..688d38c5ac6 100644
--- a/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected
@@ -1,4 +1,6 @@
instances
| gen_asm_sym.rs:8:30:8:44 | AsmSym |
+| gen_asm_sym.rs:8:30:8:44 | AsmSym |
getPath
| gen_asm_sym.rs:8:30:8:44 | AsmSym | gen_asm_sym.rs:8:34:8:44 | my_function |
+| gen_asm_sym.rs:8:30:8:44 | AsmSym | gen_asm_sym.rs:8:34:8:44 | my_function |
diff --git a/rust/ql/test/extractor-tests/generated/MacroCall/MacroCall.expected b/rust/ql/test/extractor-tests/generated/MacroCall/MacroCall.expected
index 0fae1d5e49d..dc076731def 100644
--- a/rust/ql/test/extractor-tests/generated/MacroCall/MacroCall.expected
+++ b/rust/ql/test/extractor-tests/generated/MacroCall/MacroCall.expected
@@ -7,7 +7,7 @@ getAttributeMacroExpansion
getAttr
getPath
| gen_macro_call.rs:7:5:7:29 | println!... | gen_macro_call.rs:7:5:7:11 | println |
-| gen_macro_call.rs:7:14:7:28 | ...::format_args_nl!... | gen_macro_call.rs:7:5:7:29 | ...::format_args_nl |
+| gen_macro_call.rs:7:14:7:28 | ...::format_args_nl!... | gen_macro_call.rs:7:5:7:12 | ...::format_args_nl |
getTokenTree
| gen_macro_call.rs:7:5:7:29 | println!... | gen_macro_call.rs:7:13:7:29 | TokenTree |
| gen_macro_call.rs:7:14:7:28 | ...::format_args_nl!... | gen_macro_call.rs:7:14:7:28 | TokenTree |
diff --git a/rust/ql/test/extractor-tests/generated/MacroItems/MacroItems.expected b/rust/ql/test/extractor-tests/generated/MacroItems/MacroItems.expected
index 90daafd5817..156893a07eb 100644
--- a/rust/ql/test/extractor-tests/generated/MacroItems/MacroItems.expected
+++ b/rust/ql/test/extractor-tests/generated/MacroItems/MacroItems.expected
@@ -1,7 +1,7 @@
instances
-| gen_macro_items.rs:5:5:5:38 | MacroItems |
+| gen_macro_items.rs:5:5:5:12 | MacroItems |
| gen_macro_items.rs:13:12:13:14 | MacroItems |
getItem
-| gen_macro_items.rs:5:5:5:38 | MacroItems | 0 | gen_macro_items.rs:5:5:5:38 | use ...::Path |
-| gen_macro_items.rs:5:5:5:38 | MacroItems | 1 | gen_macro_items.rs:5:5:5:38 | fn get_parent |
+| gen_macro_items.rs:5:5:5:12 | MacroItems | 0 | gen_macro_items.rs:5:5:5:38 | use ...::Path |
+| gen_macro_items.rs:5:5:5:12 | MacroItems | 1 | gen_macro_items.rs:5:5:5:38 | fn get_parent |
| gen_macro_items.rs:13:12:13:14 | MacroItems | 0 | gen_macro_items.rs:13:12:13:14 | impl ...::Debug for Bar::<...> { ... } |
diff --git a/rust/ql/test/extractor-tests/generated/NeverTypeRepr/NeverTypeRepr.expected b/rust/ql/test/extractor-tests/generated/NeverTypeRepr/NeverTypeRepr.expected
index e3e1a8d3900..7e8d7f8718b 100644
--- a/rust/ql/test/extractor-tests/generated/NeverTypeRepr/NeverTypeRepr.expected
+++ b/rust/ql/test/extractor-tests/generated/NeverTypeRepr/NeverTypeRepr.expected
@@ -1,2 +1,2 @@
| gen_never_type_repr.rs:7:17:7:17 | ! |
-| gen_never_type_repr.rs:7:21:7:28 | ! |
+| gen_never_type_repr.rs:7:21:7:26 | ! |
diff --git a/rust/ql/test/extractor-tests/macro-expansion/CONSISTENCY/PathResolutionConsistency.expected b/rust/ql/test/extractor-tests/macro-expansion/CONSISTENCY/PathResolutionConsistency.expected
index 675d607c9fd..ec99962b9b0 100644
--- a/rust/ql/test/extractor-tests/macro-expansion/CONSISTENCY/PathResolutionConsistency.expected
+++ b/rust/ql/test/extractor-tests/macro-expansion/CONSISTENCY/PathResolutionConsistency.expected
@@ -1,10 +1,10 @@
multipleCallTargets
-| proc_macro.rs:15:5:17:5 | ...::new(...) |
-| proc_macro.rs:25:5:28:5 | ...::new(...) |
-| proc_macro.rs:41:5:49:5 | ...::new(...) |
-| proc_macro.rs:41:5:49:5 | ...::new(...) |
-| proc_macro.rs:41:5:49:5 | ...::new(...) |
-| proc_macro.rs:41:5:49:5 | ...::new(...) |
+| proc_macro.rs:15:5:15:10 | ...::new(...) |
+| proc_macro.rs:25:5:25:10 | ...::new(...) |
+| proc_macro.rs:41:5:41:10 | ...::new(...) |
+| proc_macro.rs:41:5:41:10 | ...::new(...) |
+| proc_macro.rs:41:5:41:10 | ...::new(...) |
+| proc_macro.rs:41:5:41:10 | ...::new(...) |
| proc_macro.rs:44:27:44:30 | ...::to_tokens(...) |
multiplePathResolutions
| macro_expansion.rs:1:5:1:14 | proc_macro |
diff --git a/rust/ql/test/extractor-tests/macro-expansion/test.expected b/rust/ql/test/extractor-tests/macro-expansion/test.expected
index ad2cfe5a9b8..5001751e5c3 100644
--- a/rust/ql/test/extractor-tests/macro-expansion/test.expected
+++ b/rust/ql/test/extractor-tests/macro-expansion/test.expected
@@ -32,18 +32,18 @@ macro_calls
| macro_expansion.rs:33:9:33:15 | hello!... | macro_expansion.rs:31:5:31:16 | MacroBlockExpr |
| macro_expansion.rs:33:9:33:15 | hello!... | macro_expansion.rs:31:5:31:16 | MacroBlockExpr |
| macro_expansion.rs:33:9:33:15 | hello!... | macro_expansion.rs:31:5:31:16 | MacroBlockExpr |
-| macro_expansion.rs:44:5:44:13 | def_x!... | macro_expansion.rs:44:5:44:13 | MacroItems |
+| macro_expansion.rs:44:5:44:13 | def_x!... | macro_expansion.rs:44:5:44:10 | MacroItems |
| macro_expansion.rs:53:9:53:25 | concat!... | macro_expansion.rs:53:17:53:24 | "xy" |
| macro_expansion.rs:55:9:58:5 | my_macro!... | macro_expansion.rs:56:9:57:13 | MacroExpr |
| macro_expansion.rs:56:9:57:13 | ...::format_args!... | macro_expansion.rs:56:9:57:13 | FormatArgsExpr |
| macro_expansion.rs:56:9:57:13 | format!... | macro_expansion.rs:56:9:57:13 | ...::must_use(...) |
| macro_expansion.rs:61:1:61:33 | concat!... | macro_expansion.rs:61:1:61:33 | "Hello world!" |
| macro_expansion.rs:61:1:61:33 | include!... | macro_expansion.rs:61:1:61:33 | MacroItems |
-| macro_expansion.rs:70:16:70:24 | my_int!... | macro_expansion.rs:70:16:70:24 | i32 |
-| macro_expansion.rs:71:12:71:20 | my_int!... | macro_expansion.rs:71:12:71:20 | i32 |
-| macro_expansion.rs:72:10:72:18 | my_int!... | macro_expansion.rs:72:10:72:18 | i32 |
-| macro_expansion.rs:76:14:76:22 | my_int!... | macro_expansion.rs:76:14:76:22 | i32 |
-| macro_expansion.rs:79:12:79:20 | my_int!... | macro_expansion.rs:79:12:79:20 | i32 |
+| macro_expansion.rs:70:16:70:24 | my_int!... | macro_expansion.rs:70:16:70:22 | i32 |
+| macro_expansion.rs:71:12:71:20 | my_int!... | macro_expansion.rs:71:12:71:18 | i32 |
+| macro_expansion.rs:72:10:72:18 | my_int!... | macro_expansion.rs:72:10:72:16 | i32 |
+| macro_expansion.rs:76:14:76:22 | my_int!... | macro_expansion.rs:76:14:76:20 | i32 |
+| macro_expansion.rs:79:12:79:20 | my_int!... | macro_expansion.rs:79:12:79:18 | i32 |
unexpanded_macro_calls
| included/included.rs:2:9:2:39 | concat!... |
| macro_expansion.rs:5:9:5:35 | concat!... |
diff --git a/rust/ql/test/library-tests/controlflow/BasicBlocks.expected b/rust/ql/test/library-tests/controlflow/BasicBlocks.expected
index 1b4b770c130..8ada702c93f 100644
--- a/rust/ql/test/library-tests/controlflow/BasicBlocks.expected
+++ b/rust/ql/test/library-tests/controlflow/BasicBlocks.expected
@@ -672,14 +672,14 @@ dominates
| test.rs:443:26:443:36 | Some(...) | test.rs:443:26:443:36 | Some(...) |
| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:453:5:458:5 | enter fn or_pattern_3 |
| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:454:9:457:9 | match a { ... } |
-| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:455:13:455:25 | 2 |
-| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:455:13:455:25 | [match(false)] 1 \| 2 |
-| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:455:13:455:25 | [match(true)] 1 \| 2 |
+| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:455:13:455:23 | 2 |
+| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:455:13:455:23 | [match(false)] 1 \| 2 |
+| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:455:13:455:23 | [match(true)] 1 \| 2 |
| test.rs:454:9:457:9 | match a { ... } | test.rs:454:9:457:9 | match a { ... } |
-| test.rs:455:13:455:25 | 2 | test.rs:455:13:455:25 | 2 |
-| test.rs:455:13:455:25 | 2 | test.rs:455:13:455:25 | [match(false)] 1 \| 2 |
-| test.rs:455:13:455:25 | [match(false)] 1 \| 2 | test.rs:455:13:455:25 | [match(false)] 1 \| 2 |
-| test.rs:455:13:455:25 | [match(true)] 1 \| 2 | test.rs:455:13:455:25 | [match(true)] 1 \| 2 |
+| test.rs:455:13:455:23 | 2 | test.rs:455:13:455:23 | 2 |
+| test.rs:455:13:455:23 | 2 | test.rs:455:13:455:23 | [match(false)] 1 \| 2 |
+| test.rs:455:13:455:23 | [match(false)] 1 \| 2 | test.rs:455:13:455:23 | [match(false)] 1 \| 2 |
+| test.rs:455:13:455:23 | [match(true)] 1 \| 2 | test.rs:455:13:455:23 | [match(true)] 1 \| 2 |
| test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code | test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code |
| test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code | test.rs:461:9:464:9 | match pair { ... } |
| test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code | test.rs:462:32:462:32 | _ |
@@ -717,20 +717,20 @@ dominates
| test.rs:513:17:513:41 | ExprStmt | test.rs:513:17:513:41 | ExprStmt |
| test.rs:523:5:525:5 | enter fn add_two | test.rs:523:5:525:5 | enter fn add_two |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:529:5:537:5 | enter fn const_block_assert |
-| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:13:533:49 | ExprStmt |
+| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:13:533:19 | ExprStmt |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | [boolean(false)] ! ... |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | [boolean(true)] ! ... |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | if ... {...} |
-| test.rs:533:13:533:49 | ExprStmt | test.rs:533:13:533:49 | ExprStmt |
-| test.rs:533:13:533:49 | enter fn panic_cold_explicit | test.rs:533:13:533:49 | enter fn panic_cold_explicit |
+| test.rs:533:13:533:19 | ExprStmt | test.rs:533:13:533:19 | ExprStmt |
+| test.rs:533:13:533:19 | enter fn panic_cold_explicit | test.rs:533:13:533:19 | enter fn panic_cold_explicit |
| test.rs:533:21:533:48 | [boolean(false)] ! ... | test.rs:533:21:533:48 | [boolean(false)] ! ... |
-| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:49 | ExprStmt |
+| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:19 | ExprStmt |
| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:21:533:48 | [boolean(true)] ! ... |
| test.rs:533:21:533:48 | if ... {...} | test.rs:533:21:533:48 | if ... {...} |
| test.rs:539:5:548:5 | enter fn const_block_panic | test.rs:539:5:548:5 | enter fn const_block_panic |
| test.rs:539:5:548:5 | enter fn const_block_panic | test.rs:541:9:546:9 | if false {...} |
| test.rs:541:9:546:9 | if false {...} | test.rs:541:9:546:9 | if false {...} |
-| test.rs:544:17:544:24 | enter fn panic_cold_explicit | test.rs:544:17:544:24 | enter fn panic_cold_explicit |
+| test.rs:544:17:544:22 | enter fn panic_cold_explicit | test.rs:544:17:544:22 | enter fn panic_cold_explicit |
| test.rs:551:1:556:1 | enter fn dead_code | test.rs:551:1:556:1 | enter fn dead_code |
| test.rs:551:1:556:1 | enter fn dead_code | test.rs:553:9:553:17 | ExprStmt |
| test.rs:553:9:553:17 | ExprStmt | test.rs:553:9:553:17 | ExprStmt |
@@ -1344,12 +1344,12 @@ postDominance
| test.rs:453:5:458:5 | enter fn or_pattern_3 | test.rs:453:5:458:5 | enter fn or_pattern_3 |
| test.rs:454:9:457:9 | match a { ... } | test.rs:453:5:458:5 | enter fn or_pattern_3 |
| test.rs:454:9:457:9 | match a { ... } | test.rs:454:9:457:9 | match a { ... } |
-| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:25 | 2 |
-| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:25 | [match(false)] 1 \| 2 |
-| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:25 | [match(true)] 1 \| 2 |
-| test.rs:455:13:455:25 | 2 | test.rs:455:13:455:25 | 2 |
-| test.rs:455:13:455:25 | [match(false)] 1 \| 2 | test.rs:455:13:455:25 | [match(false)] 1 \| 2 |
-| test.rs:455:13:455:25 | [match(true)] 1 \| 2 | test.rs:455:13:455:25 | [match(true)] 1 \| 2 |
+| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:23 | 2 |
+| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:23 | [match(false)] 1 \| 2 |
+| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:23 | [match(true)] 1 \| 2 |
+| test.rs:455:13:455:23 | 2 | test.rs:455:13:455:23 | 2 |
+| test.rs:455:13:455:23 | [match(false)] 1 \| 2 | test.rs:455:13:455:23 | [match(false)] 1 \| 2 |
+| test.rs:455:13:455:23 | [match(true)] 1 \| 2 | test.rs:455:13:455:23 | [match(true)] 1 \| 2 |
| test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code | test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code |
| test.rs:461:9:464:9 | match pair { ... } | test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code |
| test.rs:461:9:464:9 | match pair { ... } | test.rs:461:9:464:9 | match pair { ... } |
@@ -1384,20 +1384,20 @@ postDominance
| test.rs:513:17:513:41 | ExprStmt | test.rs:513:17:513:41 | ExprStmt |
| test.rs:523:5:525:5 | enter fn add_two | test.rs:523:5:525:5 | enter fn add_two |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:529:5:537:5 | enter fn const_block_assert |
-| test.rs:533:13:533:49 | ExprStmt | test.rs:533:13:533:49 | ExprStmt |
-| test.rs:533:13:533:49 | ExprStmt | test.rs:533:21:533:48 | [boolean(true)] ! ... |
-| test.rs:533:13:533:49 | enter fn panic_cold_explicit | test.rs:533:13:533:49 | enter fn panic_cold_explicit |
+| test.rs:533:13:533:19 | ExprStmt | test.rs:533:13:533:19 | ExprStmt |
+| test.rs:533:13:533:19 | ExprStmt | test.rs:533:21:533:48 | [boolean(true)] ! ... |
+| test.rs:533:13:533:19 | enter fn panic_cold_explicit | test.rs:533:13:533:19 | enter fn panic_cold_explicit |
| test.rs:533:21:533:48 | [boolean(false)] ! ... | test.rs:533:21:533:48 | [boolean(false)] ! ... |
| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:21:533:48 | [boolean(true)] ! ... |
| test.rs:533:21:533:48 | if ... {...} | test.rs:529:5:537:5 | enter fn const_block_assert |
-| test.rs:533:21:533:48 | if ... {...} | test.rs:533:13:533:49 | ExprStmt |
+| test.rs:533:21:533:48 | if ... {...} | test.rs:533:13:533:19 | ExprStmt |
| test.rs:533:21:533:48 | if ... {...} | test.rs:533:21:533:48 | [boolean(false)] ! ... |
| test.rs:533:21:533:48 | if ... {...} | test.rs:533:21:533:48 | [boolean(true)] ! ... |
| test.rs:533:21:533:48 | if ... {...} | test.rs:533:21:533:48 | if ... {...} |
| test.rs:539:5:548:5 | enter fn const_block_panic | test.rs:539:5:548:5 | enter fn const_block_panic |
| test.rs:541:9:546:9 | if false {...} | test.rs:539:5:548:5 | enter fn const_block_panic |
| test.rs:541:9:546:9 | if false {...} | test.rs:541:9:546:9 | if false {...} |
-| test.rs:544:17:544:24 | enter fn panic_cold_explicit | test.rs:544:17:544:24 | enter fn panic_cold_explicit |
+| test.rs:544:17:544:22 | enter fn panic_cold_explicit | test.rs:544:17:544:22 | enter fn panic_cold_explicit |
| test.rs:551:1:556:1 | enter fn dead_code | test.rs:551:1:556:1 | enter fn dead_code |
| test.rs:553:9:553:17 | ExprStmt | test.rs:551:1:556:1 | enter fn dead_code |
| test.rs:553:9:553:17 | ExprStmt | test.rs:553:9:553:17 | ExprStmt |
@@ -1654,9 +1654,9 @@ immediateDominator
| test.rs:443:18:443:21 | true | test.rs:443:13:443:22 | Some(...) |
| test.rs:443:26:443:36 | Some(...) | test.rs:443:13:443:22 | Some(...) |
| test.rs:454:9:457:9 | match a { ... } | test.rs:453:5:458:5 | enter fn or_pattern_3 |
-| test.rs:455:13:455:25 | 2 | test.rs:453:5:458:5 | enter fn or_pattern_3 |
-| test.rs:455:13:455:25 | [match(false)] 1 \| 2 | test.rs:455:13:455:25 | 2 |
-| test.rs:455:13:455:25 | [match(true)] 1 \| 2 | test.rs:453:5:458:5 | enter fn or_pattern_3 |
+| test.rs:455:13:455:23 | 2 | test.rs:453:5:458:5 | enter fn or_pattern_3 |
+| test.rs:455:13:455:23 | [match(false)] 1 \| 2 | test.rs:455:13:455:23 | 2 |
+| test.rs:455:13:455:23 | [match(true)] 1 \| 2 | test.rs:453:5:458:5 | enter fn or_pattern_3 |
| test.rs:461:9:464:9 | match pair { ... } | test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code |
| test.rs:462:32:462:32 | _ | test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code |
| test.rs:463:13:463:13 | _ | test.rs:460:5:465:5 | enter fn irrefutable_pattern_and_dead_code |
@@ -1669,7 +1669,7 @@ immediateDominator
| test.rs:511:28:516:9 | exit { ... } (normal) | test.rs:511:28:516:9 | enter { ... } |
| test.rs:512:13:514:13 | if b {...} | test.rs:511:28:516:9 | enter { ... } |
| test.rs:513:17:513:41 | ExprStmt | test.rs:511:28:516:9 | enter { ... } |
-| test.rs:533:13:533:49 | ExprStmt | test.rs:533:21:533:48 | [boolean(true)] ! ... |
+| test.rs:533:13:533:19 | ExprStmt | test.rs:533:21:533:48 | [boolean(true)] ! ... |
| test.rs:533:21:533:48 | [boolean(false)] ! ... | test.rs:529:5:537:5 | enter fn const_block_assert |
| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:529:5:537:5 | enter fn const_block_assert |
| test.rs:533:21:533:48 | if ... {...} | test.rs:529:5:537:5 | enter fn const_block_assert |
@@ -1874,10 +1874,10 @@ controls
| test.rs:347:18:347:18 | a | test.rs:349:15:349:18 | cond | true |
| test.rs:511:28:516:9 | enter { ... } | test.rs:512:13:514:13 | if b {...} | false |
| test.rs:511:28:516:9 | enter { ... } | test.rs:513:17:513:41 | ExprStmt | true |
-| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:13:533:49 | ExprStmt | false |
+| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:13:533:19 | ExprStmt | false |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | [boolean(false)] ! ... | true |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | [boolean(true)] ! ... | false |
-| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:49 | ExprStmt | true |
+| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:19 | ExprStmt | true |
| test.rs:539:5:548:5 | enter fn const_block_panic | test.rs:541:9:546:9 | if false {...} | false |
| test.rs:551:1:556:1 | enter fn dead_code | test.rs:553:9:553:17 | ExprStmt | true |
| test.rs:568:1:582:1 | enter fn labelled_block1 | test.rs:571:9:573:9 | if ... {...} | false |
@@ -2026,7 +2026,7 @@ successor
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | [boolean(false)] ! ... | true |
| test.rs:529:5:537:5 | enter fn const_block_assert | test.rs:533:21:533:48 | [boolean(true)] ! ... | false |
| test.rs:533:21:533:48 | [boolean(false)] ! ... | test.rs:533:21:533:48 | if ... {...} | false |
-| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:49 | ExprStmt | true |
+| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:19 | ExprStmt | true |
| test.rs:539:5:548:5 | enter fn const_block_panic | test.rs:541:9:546:9 | if false {...} | false |
| test.rs:551:1:556:1 | enter fn dead_code | test.rs:553:9:553:17 | ExprStmt | true |
| test.rs:568:1:582:1 | enter fn labelled_block1 | test.rs:571:9:573:9 | if ... {...} | false |
@@ -2185,10 +2185,10 @@ joinBlockPredecessor
| test.rs:443:13:443:36 | ... \| ... | test.rs:443:26:443:36 | Some(...) | 1 |
| test.rs:443:26:443:36 | Some(...) | test.rs:443:13:443:22 | Some(...) | 1 |
| test.rs:443:26:443:36 | Some(...) | test.rs:443:18:443:21 | true | 0 |
-| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:25 | [match(false)] 1 \| 2 | 0 |
-| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:25 | [match(true)] 1 \| 2 | 1 |
-| test.rs:455:13:455:25 | [match(true)] 1 \| 2 | test.rs:453:5:458:5 | enter fn or_pattern_3 | 1 |
-| test.rs:455:13:455:25 | [match(true)] 1 \| 2 | test.rs:455:13:455:25 | 2 | 0 |
+| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:23 | [match(false)] 1 \| 2 | 0 |
+| test.rs:454:9:457:9 | match a { ... } | test.rs:455:13:455:23 | [match(true)] 1 \| 2 | 1 |
+| test.rs:455:13:455:23 | [match(true)] 1 \| 2 | test.rs:453:5:458:5 | enter fn or_pattern_3 | 1 |
+| test.rs:455:13:455:23 | [match(true)] 1 \| 2 | test.rs:455:13:455:23 | 2 | 0 |
| test.rs:461:9:464:9 | match pair { ... } | test.rs:462:32:462:32 | _ | 0 |
| test.rs:461:9:464:9 | match pair { ... } | test.rs:463:13:463:13 | _ | 1 |
| test.rs:476:9:480:9 | match e { ... } | test.rs:477:32:477:32 | _ | 0 |
@@ -2198,7 +2198,7 @@ joinBlockPredecessor
| test.rs:487:13:487:14 | TupleExpr | test.rs:487:13:487:14 | TupleExpr | 0 |
| test.rs:511:28:516:9 | exit { ... } (normal) | test.rs:512:13:514:13 | if b {...} | 1 |
| test.rs:511:28:516:9 | exit { ... } (normal) | test.rs:513:17:513:41 | ExprStmt | 0 |
-| test.rs:533:21:533:48 | if ... {...} | test.rs:533:13:533:49 | ExprStmt | 1 |
+| test.rs:533:21:533:48 | if ... {...} | test.rs:533:13:533:19 | ExprStmt | 1 |
| test.rs:533:21:533:48 | if ... {...} | test.rs:533:21:533:48 | [boolean(false)] ! ... | 0 |
| test.rs:569:18:580:5 | 'block: { ... } | test.rs:572:13:572:27 | ExprStmt | 0 |
| test.rs:569:18:580:5 | 'block: { ... } | test.rs:575:9:577:9 | if ... {...} | 2 |
diff --git a/rust/ql/test/library-tests/controlflow/Cfg.expected b/rust/ql/test/library-tests/controlflow/Cfg.expected
index 44dd60e915a..8f36b3098e6 100644
--- a/rust/ql/test/library-tests/controlflow/Cfg.expected
+++ b/rust/ql/test/library-tests/controlflow/Cfg.expected
@@ -388,39 +388,39 @@ edges
| test.rs:170:16:170:20 | cond2 | test.rs:171:17:171:30 | ExprStmt | true |
| test.rs:170:16:170:20 | cond2 | test.rs:173:17:173:30 | ExprStmt | false |
| test.rs:170:22:172:13 | { ... } | test.rs:170:13:174:13 | if cond2 {...} else {...} | |
-| test.rs:171:17:171:29 | ...::_print | test.rs:171:26:171:28 | "1\\n" | |
+| test.rs:171:17:171:24 | ...::_print | test.rs:171:26:171:28 | "1\\n" | |
| test.rs:171:17:171:29 | MacroExpr | test.rs:170:22:172:13 | { ... } | |
| test.rs:171:17:171:29 | println!... | test.rs:171:17:171:29 | MacroExpr | |
| test.rs:171:17:171:30 | ExprStmt | test.rs:171:26:171:28 | ExprStmt | |
| test.rs:171:26:171:28 | "1\\n" | test.rs:171:26:171:28 | FormatArgsExpr | |
| test.rs:171:26:171:28 | ...::_print(...) | test.rs:171:26:171:28 | { ... } | |
| test.rs:171:26:171:28 | ...::format_args_nl!... | test.rs:171:26:171:28 | MacroExpr | |
-| test.rs:171:26:171:28 | ExprStmt | test.rs:171:17:171:29 | ...::_print | |
+| test.rs:171:26:171:28 | ExprStmt | test.rs:171:17:171:24 | ...::_print | |
| test.rs:171:26:171:28 | FormatArgsExpr | test.rs:171:26:171:28 | ...::format_args_nl!... | |
| test.rs:171:26:171:28 | MacroBlockExpr | test.rs:171:17:171:29 | println!... | |
| test.rs:171:26:171:28 | MacroExpr | test.rs:171:26:171:28 | ...::_print(...) | |
| test.rs:171:26:171:28 | { ... } | test.rs:171:26:171:28 | MacroBlockExpr | |
| test.rs:172:20:174:13 | { ... } | test.rs:170:13:174:13 | if cond2 {...} else {...} | |
-| test.rs:173:17:173:29 | ...::_print | test.rs:173:26:173:28 | "2\\n" | |
+| test.rs:173:17:173:24 | ...::_print | test.rs:173:26:173:28 | "2\\n" | |
| test.rs:173:17:173:29 | MacroExpr | test.rs:172:20:174:13 | { ... } | |
| test.rs:173:17:173:29 | println!... | test.rs:173:17:173:29 | MacroExpr | |
| test.rs:173:17:173:30 | ExprStmt | test.rs:173:26:173:28 | ExprStmt | |
| test.rs:173:26:173:28 | "2\\n" | test.rs:173:26:173:28 | FormatArgsExpr | |
| test.rs:173:26:173:28 | ...::_print(...) | test.rs:173:26:173:28 | { ... } | |
| test.rs:173:26:173:28 | ...::format_args_nl!... | test.rs:173:26:173:28 | MacroExpr | |
-| test.rs:173:26:173:28 | ExprStmt | test.rs:173:17:173:29 | ...::_print | |
+| test.rs:173:26:173:28 | ExprStmt | test.rs:173:17:173:24 | ...::_print | |
| test.rs:173:26:173:28 | FormatArgsExpr | test.rs:173:26:173:28 | ...::format_args_nl!... | |
| test.rs:173:26:173:28 | MacroBlockExpr | test.rs:173:17:173:29 | println!... | |
| test.rs:173:26:173:28 | MacroExpr | test.rs:173:26:173:28 | ...::_print(...) | |
| test.rs:173:26:173:28 | { ... } | test.rs:173:26:173:28 | MacroBlockExpr | |
-| test.rs:175:13:175:25 | ...::_print | test.rs:175:22:175:24 | "3\\n" | |
+| test.rs:175:13:175:20 | ...::_print | test.rs:175:22:175:24 | "3\\n" | |
| test.rs:175:13:175:25 | MacroExpr | test.rs:169:18:176:9 | { ... } | |
| test.rs:175:13:175:25 | println!... | test.rs:175:13:175:25 | MacroExpr | |
| test.rs:175:13:175:26 | ExprStmt | test.rs:175:22:175:24 | ExprStmt | |
| test.rs:175:22:175:24 | "3\\n" | test.rs:175:22:175:24 | FormatArgsExpr | |
| test.rs:175:22:175:24 | ...::_print(...) | test.rs:175:22:175:24 | { ... } | |
| test.rs:175:22:175:24 | ...::format_args_nl!... | test.rs:175:22:175:24 | MacroExpr | |
-| test.rs:175:22:175:24 | ExprStmt | test.rs:175:13:175:25 | ...::_print | |
+| test.rs:175:22:175:24 | ExprStmt | test.rs:175:13:175:20 | ...::_print | |
| test.rs:175:22:175:24 | FormatArgsExpr | test.rs:175:22:175:24 | ...::format_args_nl!... | |
| test.rs:175:22:175:24 | MacroBlockExpr | test.rs:175:13:175:25 | println!... | |
| test.rs:175:22:175:24 | MacroExpr | test.rs:175:22:175:24 | ...::_print(...) | |
@@ -893,14 +893,14 @@ edges
| test.rs:363:18:363:18 | n | test.rs:363:18:363:18 | n | |
| test.rs:363:18:363:18 | n | test.rs:364:9:364:9 | n | match |
| test.rs:363:23:363:23 | a | test.rs:363:13:363:19 | Some(...) | |
-| test.rs:363:32:363:54 | ...::panic_fmt | test.rs:363:39:363:53 | "Expected some" | |
+| test.rs:363:32:363:37 | ...::panic_fmt | test.rs:363:39:363:53 | "Expected some" | |
| test.rs:363:32:363:54 | MacroExpr | test.rs:363:30:363:56 | { ... } | |
| test.rs:363:32:363:54 | panic!... | test.rs:363:32:363:54 | MacroExpr | |
| test.rs:363:39:363:53 | "Expected some" | test.rs:363:39:363:53 | FormatArgsExpr | |
| test.rs:363:39:363:53 | ...::const_format_args!... | test.rs:363:39:363:53 | MacroExpr | |
| test.rs:363:39:363:53 | ...::panic_2021!... | test.rs:363:39:363:53 | MacroExpr | |
| test.rs:363:39:363:53 | ...::panic_fmt(...) | test.rs:363:39:363:53 | { ... } | |
-| test.rs:363:39:363:53 | ExprStmt | test.rs:363:32:363:54 | ...::panic_fmt | |
+| test.rs:363:39:363:53 | ExprStmt | test.rs:363:32:363:37 | ...::panic_fmt | |
| test.rs:363:39:363:53 | FormatArgsExpr | test.rs:363:39:363:53 | ...::const_format_args!... | |
| test.rs:363:39:363:53 | MacroBlockExpr | test.rs:363:32:363:54 | panic!... | |
| test.rs:363:39:363:53 | MacroBlockExpr | test.rs:363:39:363:53 | ...::panic_2021!... | |
@@ -1122,15 +1122,15 @@ edges
| test.rs:453:36:458:5 | { ... } | test.rs:453:5:458:5 | exit fn or_pattern_3 (normal) | |
| test.rs:454:9:457:9 | match a { ... } | test.rs:453:36:458:5 | { ... } | |
| test.rs:454:15:454:15 | a | test.rs:455:13:455:25 | MacroPat | |
-| test.rs:455:13:455:25 | 1 | test.rs:455:13:455:25 | 1 | |
-| test.rs:455:13:455:25 | 1 | test.rs:455:13:455:25 | 2 | no-match |
-| test.rs:455:13:455:25 | 1 | test.rs:455:13:455:25 | [match(true)] 1 \| 2 | match |
-| test.rs:455:13:455:25 | 2 | test.rs:455:13:455:25 | 2 | |
-| test.rs:455:13:455:25 | 2 | test.rs:455:13:455:25 | [match(false)] 1 \| 2 | no-match |
-| test.rs:455:13:455:25 | 2 | test.rs:455:13:455:25 | [match(true)] 1 \| 2 | match |
-| test.rs:455:13:455:25 | MacroPat | test.rs:455:13:455:25 | 1 | match |
-| test.rs:455:13:455:25 | [match(false)] 1 \| 2 | test.rs:456:13:456:13 | _ | no-match |
-| test.rs:455:13:455:25 | [match(true)] 1 \| 2 | test.rs:455:30:455:30 | 3 | match |
+| test.rs:455:13:455:23 | 1 | test.rs:455:13:455:23 | 1 | |
+| test.rs:455:13:455:23 | 1 | test.rs:455:13:455:23 | 2 | no-match |
+| test.rs:455:13:455:23 | 1 | test.rs:455:13:455:23 | [match(true)] 1 \| 2 | match |
+| test.rs:455:13:455:23 | 2 | test.rs:455:13:455:23 | 2 | |
+| test.rs:455:13:455:23 | 2 | test.rs:455:13:455:23 | [match(false)] 1 \| 2 | no-match |
+| test.rs:455:13:455:23 | 2 | test.rs:455:13:455:23 | [match(true)] 1 \| 2 | match |
+| test.rs:455:13:455:23 | [match(false)] 1 \| 2 | test.rs:456:13:456:13 | _ | no-match |
+| test.rs:455:13:455:23 | [match(true)] 1 \| 2 | test.rs:455:30:455:30 | 3 | match |
+| test.rs:455:13:455:25 | MacroPat | test.rs:455:13:455:23 | 1 | match |
| test.rs:455:30:455:30 | 3 | test.rs:454:9:457:9 | match a { ... } | |
| test.rs:456:13:456:13 | _ | test.rs:456:18:456:18 | 4 | match |
| test.rs:456:18:456:18 | 4 | test.rs:454:9:457:9 | match a { ... } | |
@@ -1178,14 +1178,14 @@ edges
| test.rs:494:5:496:5 | enter fn say_hello | test.rs:495:9:495:34 | ExprStmt | |
| test.rs:494:5:496:5 | exit fn say_hello (normal) | test.rs:494:5:496:5 | exit fn say_hello | |
| test.rs:494:26:496:5 | { ... } | test.rs:494:5:496:5 | exit fn say_hello (normal) | |
-| test.rs:495:9:495:33 | ...::_print | test.rs:495:18:495:32 | "hello, world!\\n" | |
+| test.rs:495:9:495:16 | ...::_print | test.rs:495:18:495:32 | "hello, world!\\n" | |
| test.rs:495:9:495:33 | MacroExpr | test.rs:494:26:496:5 | { ... } | |
| test.rs:495:9:495:33 | println!... | test.rs:495:9:495:33 | MacroExpr | |
| test.rs:495:9:495:34 | ExprStmt | test.rs:495:18:495:32 | ExprStmt | |
| test.rs:495:18:495:32 | "hello, world!\\n" | test.rs:495:18:495:32 | FormatArgsExpr | |
| test.rs:495:18:495:32 | ...::_print(...) | test.rs:495:18:495:32 | { ... } | |
| test.rs:495:18:495:32 | ...::format_args_nl!... | test.rs:495:18:495:32 | MacroExpr | |
-| test.rs:495:18:495:32 | ExprStmt | test.rs:495:9:495:33 | ...::_print | |
+| test.rs:495:18:495:32 | ExprStmt | test.rs:495:9:495:16 | ...::_print | |
| test.rs:495:18:495:32 | FormatArgsExpr | test.rs:495:18:495:32 | ...::format_args_nl!... | |
| test.rs:495:18:495:32 | MacroBlockExpr | test.rs:495:9:495:33 | println!... | |
| test.rs:495:18:495:32 | MacroExpr | test.rs:495:18:495:32 | ...::_print(...) | |
@@ -1202,14 +1202,14 @@ edges
| test.rs:499:26:501:9 | enter { ... } | test.rs:500:13:500:42 | ExprStmt | |
| test.rs:499:26:501:9 | exit { ... } (normal) | test.rs:499:26:501:9 | exit { ... } | |
| test.rs:499:26:501:9 | { ... } | test.rs:499:13:499:22 | say_godbye | |
-| test.rs:500:13:500:41 | ...::_print | test.rs:500:22:500:40 | "godbye, everyone!\\n" | |
+| test.rs:500:13:500:20 | ...::_print | test.rs:500:22:500:40 | "godbye, everyone!\\n" | |
| test.rs:500:13:500:41 | MacroExpr | test.rs:499:26:501:9 | exit { ... } (normal) | |
| test.rs:500:13:500:41 | println!... | test.rs:500:13:500:41 | MacroExpr | |
| test.rs:500:13:500:42 | ExprStmt | test.rs:500:22:500:40 | ExprStmt | |
| test.rs:500:22:500:40 | "godbye, everyone!\\n" | test.rs:500:22:500:40 | FormatArgsExpr | |
| test.rs:500:22:500:40 | ...::_print(...) | test.rs:500:22:500:40 | { ... } | |
| test.rs:500:22:500:40 | ...::format_args_nl!... | test.rs:500:22:500:40 | MacroExpr | |
-| test.rs:500:22:500:40 | ExprStmt | test.rs:500:13:500:41 | ...::_print | |
+| test.rs:500:22:500:40 | ExprStmt | test.rs:500:13:500:20 | ...::_print | |
| test.rs:500:22:500:40 | FormatArgsExpr | test.rs:500:22:500:40 | ...::format_args_nl!... | |
| test.rs:500:22:500:40 | MacroBlockExpr | test.rs:500:13:500:41 | println!... | |
| test.rs:500:22:500:40 | MacroExpr | test.rs:500:22:500:40 | ...::_print(...) | |
@@ -1220,14 +1220,14 @@ edges
| test.rs:502:31:504:9 | enter { ... } | test.rs:503:13:503:37 | ExprStmt | |
| test.rs:502:31:504:9 | exit { ... } (normal) | test.rs:502:31:504:9 | exit { ... } | |
| test.rs:502:31:504:9 | { ... } | test.rs:502:13:502:27 | say_how_are_you | |
-| test.rs:503:13:503:36 | ...::_print | test.rs:503:22:503:35 | "how are you?\\n" | |
+| test.rs:503:13:503:20 | ...::_print | test.rs:503:22:503:35 | "how are you?\\n" | |
| test.rs:503:13:503:36 | MacroExpr | test.rs:502:31:504:9 | exit { ... } (normal) | |
| test.rs:503:13:503:36 | println!... | test.rs:503:13:503:36 | MacroExpr | |
| test.rs:503:13:503:37 | ExprStmt | test.rs:503:22:503:35 | ExprStmt | |
| test.rs:503:22:503:35 | "how are you?\\n" | test.rs:503:22:503:35 | FormatArgsExpr | |
| test.rs:503:22:503:35 | ...::_print(...) | test.rs:503:22:503:35 | { ... } | |
| test.rs:503:22:503:35 | ...::format_args_nl!... | test.rs:503:22:503:35 | MacroExpr | |
-| test.rs:503:22:503:35 | ExprStmt | test.rs:503:13:503:36 | ...::_print | |
+| test.rs:503:22:503:35 | ExprStmt | test.rs:503:13:503:20 | ...::_print | |
| test.rs:503:22:503:35 | FormatArgsExpr | test.rs:503:22:503:35 | ...::format_args_nl!... | |
| test.rs:503:22:503:35 | MacroBlockExpr | test.rs:503:13:503:36 | println!... | |
| test.rs:503:22:503:35 | MacroExpr | test.rs:503:22:503:35 | ...::_print(...) | |
@@ -1285,23 +1285,23 @@ edges
| test.rs:529:41:537:5 | { ... } | test.rs:529:5:537:5 | exit fn const_block_assert (normal) | |
| test.rs:532:9:534:9 | ExprStmt | test.rs:533:13:533:50 | ExprStmt | |
| test.rs:532:9:534:9 | { ... } | test.rs:536:9:536:10 | 42 | |
-| test.rs:533:13:533:49 | ...::panic_2021!... | test.rs:533:13:533:49 | MacroExpr | |
-| test.rs:533:13:533:49 | ...::panic_explicit | test.rs:533:13:533:49 | ...::panic_explicit(...) | |
-| test.rs:533:13:533:49 | ...::panic_explicit(...) | test.rs:533:13:533:49 | { ... } | |
-| test.rs:533:13:533:49 | ExprStmt | test.rs:533:13:533:49 | fn panic_cold_explicit | |
-| test.rs:533:13:533:49 | ExprStmt | test.rs:533:13:533:49 | panic_cold_explicit | |
-| test.rs:533:13:533:49 | MacroBlockExpr | test.rs:533:13:533:49 | ...::panic_2021!... | |
+| test.rs:533:13:533:19 | ...::panic_2021!... | test.rs:533:13:533:19 | MacroExpr | |
+| test.rs:533:13:533:19 | ...::panic_explicit | test.rs:533:13:533:19 | ...::panic_explicit(...) | |
+| test.rs:533:13:533:19 | ...::panic_explicit(...) | test.rs:533:13:533:19 | { ... } | |
+| test.rs:533:13:533:19 | ExprStmt | test.rs:533:13:533:19 | fn panic_cold_explicit | |
+| test.rs:533:13:533:19 | ExprStmt | test.rs:533:13:533:19 | panic_cold_explicit | |
+| test.rs:533:13:533:19 | MacroBlockExpr | test.rs:533:13:533:19 | ...::panic_2021!... | |
+| test.rs:533:13:533:19 | MacroExpr | test.rs:533:13:533:19 | { ... } | |
+| test.rs:533:13:533:19 | enter fn panic_cold_explicit | test.rs:533:13:533:19 | ...::panic_explicit | |
+| test.rs:533:13:533:19 | exit fn panic_cold_explicit (normal) | test.rs:533:13:533:19 | exit fn panic_cold_explicit | |
+| test.rs:533:13:533:19 | fn panic_cold_explicit | test.rs:533:13:533:19 | ExprStmt | |
+| test.rs:533:13:533:19 | panic_cold_explicit | test.rs:533:13:533:19 | panic_cold_explicit(...) | |
+| test.rs:533:13:533:19 | panic_cold_explicit(...) | test.rs:533:13:533:19 | { ... } | |
+| test.rs:533:13:533:19 | { ... } | test.rs:533:13:533:19 | MacroBlockExpr | |
+| test.rs:533:13:533:19 | { ... } | test.rs:533:13:533:19 | exit fn panic_cold_explicit (normal) | |
+| test.rs:533:13:533:19 | { ... } | test.rs:533:21:533:48 | if ... {...} | |
| test.rs:533:13:533:49 | MacroExpr | test.rs:532:9:534:9 | { ... } | |
-| test.rs:533:13:533:49 | MacroExpr | test.rs:533:13:533:49 | { ... } | |
| test.rs:533:13:533:49 | assert!... | test.rs:533:13:533:49 | MacroExpr | |
-| test.rs:533:13:533:49 | enter fn panic_cold_explicit | test.rs:533:13:533:49 | ...::panic_explicit | |
-| test.rs:533:13:533:49 | exit fn panic_cold_explicit (normal) | test.rs:533:13:533:49 | exit fn panic_cold_explicit | |
-| test.rs:533:13:533:49 | fn panic_cold_explicit | test.rs:533:13:533:49 | ExprStmt | |
-| test.rs:533:13:533:49 | panic_cold_explicit | test.rs:533:13:533:49 | panic_cold_explicit(...) | |
-| test.rs:533:13:533:49 | panic_cold_explicit(...) | test.rs:533:13:533:49 | { ... } | |
-| test.rs:533:13:533:49 | { ... } | test.rs:533:13:533:49 | MacroBlockExpr | |
-| test.rs:533:13:533:49 | { ... } | test.rs:533:13:533:49 | exit fn panic_cold_explicit (normal) | |
-| test.rs:533:13:533:49 | { ... } | test.rs:533:21:533:48 | if ... {...} | |
| test.rs:533:13:533:50 | ExprStmt | test.rs:533:21:533:42 | ...::size_of::<...> | |
| test.rs:533:21:533:42 | ...::size_of::<...> | test.rs:533:21:533:44 | ...::size_of::<...>(...) | |
| test.rs:533:21:533:44 | ...::size_of::<...>(...) | test.rs:533:48:533:48 | 0 | |
@@ -1309,7 +1309,7 @@ edges
| test.rs:533:21:533:48 | ... > ... | test.rs:533:21:533:48 | [boolean(true)] ! ... | false |
| test.rs:533:21:533:48 | MacroBlockExpr | test.rs:533:13:533:49 | assert!... | |
| test.rs:533:21:533:48 | [boolean(false)] ! ... | test.rs:533:21:533:48 | if ... {...} | false |
-| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:49 | ExprStmt | true |
+| test.rs:533:21:533:48 | [boolean(true)] ! ... | test.rs:533:13:533:19 | ExprStmt | true |
| test.rs:533:21:533:48 | if ... {...} | test.rs:533:21:533:48 | { ... } | |
| test.rs:533:21:533:48 | { ... } | test.rs:533:21:533:48 | MacroBlockExpr | |
| test.rs:533:48:533:48 | 0 | test.rs:533:21:533:48 | ... > ... | |
@@ -1321,11 +1321,11 @@ edges
| test.rs:541:9:546:9 | ExprStmt | test.rs:541:12:541:16 | false | |
| test.rs:541:9:546:9 | if false {...} | test.rs:547:9:547:9 | N | |
| test.rs:541:12:541:16 | false | test.rs:541:9:546:9 | if false {...} | false |
-| test.rs:544:17:544:24 | ...::panic_explicit | test.rs:544:17:544:24 | ...::panic_explicit(...) | |
-| test.rs:544:17:544:24 | ...::panic_explicit(...) | test.rs:544:17:544:24 | { ... } | |
-| test.rs:544:17:544:24 | enter fn panic_cold_explicit | test.rs:544:17:544:24 | ...::panic_explicit | |
-| test.rs:544:17:544:24 | exit fn panic_cold_explicit (normal) | test.rs:544:17:544:24 | exit fn panic_cold_explicit | |
-| test.rs:544:17:544:24 | { ... } | test.rs:544:17:544:24 | exit fn panic_cold_explicit (normal) | |
+| test.rs:544:17:544:22 | ...::panic_explicit | test.rs:544:17:544:22 | ...::panic_explicit(...) | |
+| test.rs:544:17:544:22 | ...::panic_explicit(...) | test.rs:544:17:544:22 | { ... } | |
+| test.rs:544:17:544:22 | enter fn panic_cold_explicit | test.rs:544:17:544:22 | ...::panic_explicit | |
+| test.rs:544:17:544:22 | exit fn panic_cold_explicit (normal) | test.rs:544:17:544:22 | exit fn panic_cold_explicit | |
+| test.rs:544:17:544:22 | { ... } | test.rs:544:17:544:22 | exit fn panic_cold_explicit (normal) | |
| test.rs:547:9:547:9 | N | test.rs:539:35:548:5 | { ... } | |
| test.rs:551:1:556:1 | enter fn dead_code | test.rs:552:5:554:5 | ExprStmt | |
| test.rs:551:1:556:1 | exit fn dead_code (normal) | test.rs:551:1:556:1 | exit fn dead_code | |
diff --git a/rust/ql/test/library-tests/dataflow/local/DataFlowStep.expected b/rust/ql/test/library-tests/dataflow/local/DataFlowStep.expected
index b6bb529b23e..17a222973c4 100644
--- a/rust/ql/test/library-tests/dataflow/local/DataFlowStep.expected
+++ b/rust/ql/test/library-tests/dataflow/local/DataFlowStep.expected
@@ -880,8 +880,8 @@ localStep
| main.rs:537:10:537:10 | b | main.rs:537:10:537:10 | receiver for b |
| main.rs:537:10:537:10 | b | main.rs:538:20:538:20 | b |
| main.rs:565:13:565:33 | result_questionmark(...) | main.rs:565:9:565:9 | _ |
-| main.rs:577:36:577:41 | ...::new(...) | main.rs:577:36:577:41 | MacroExpr |
-| main.rs:577:36:577:41 | [post] MacroExpr | main.rs:577:36:577:41 | [post] ...::new(...) |
+| main.rs:577:36:577:39 | ...::new(...) | main.rs:577:36:577:41 | MacroExpr |
+| main.rs:577:36:577:41 | [post] MacroExpr | main.rs:577:36:577:39 | [post] ...::new(...) |
readStep
| main.rs:36:9:36:15 | Some(...) | {EXTERNAL LOCATION} | Some | main.rs:36:14:36:14 | _ |
| main.rs:90:11:90:11 | [post] receiver for i | file://:0:0:0:0 | &ref | main.rs:90:11:90:11 | [post] i |
diff --git a/rust/ql/test/library-tests/dataflow/strings/inline-taint-flow.expected b/rust/ql/test/library-tests/dataflow/strings/inline-taint-flow.expected
index a58a013816d..a33303c2bc2 100644
--- a/rust/ql/test/library-tests/dataflow/strings/inline-taint-flow.expected
+++ b/rust/ql/test/library-tests/dataflow/strings/inline-taint-flow.expected
@@ -45,13 +45,13 @@ edges
| main.rs:82:9:82:10 | s1 | main.rs:86:18:86:25 | MacroExpr | provenance | |
| main.rs:82:9:82:10 | s1 | main.rs:87:18:87:32 | MacroExpr | provenance | |
| main.rs:82:14:82:23 | source(...) | main.rs:82:9:82:10 | s1 | provenance | |
-| main.rs:86:10:86:26 | res | main.rs:86:18:86:25 | { ... } | provenance | |
-| main.rs:86:18:86:25 | ...::format(...) | main.rs:86:10:86:26 | res | provenance | |
+| main.rs:86:10:86:16 | res | main.rs:86:18:86:25 | { ... } | provenance | |
+| main.rs:86:18:86:25 | ...::format(...) | main.rs:86:10:86:16 | res | provenance | |
| main.rs:86:18:86:25 | ...::must_use(...) | main.rs:86:10:86:26 | MacroExpr | provenance | |
| main.rs:86:18:86:25 | MacroExpr | main.rs:86:18:86:25 | ...::format(...) | provenance | MaD:5 |
| main.rs:86:18:86:25 | { ... } | main.rs:86:18:86:25 | ...::must_use(...) | provenance | MaD:6 |
-| main.rs:87:10:87:33 | res | main.rs:87:18:87:32 | { ... } | provenance | |
-| main.rs:87:18:87:32 | ...::format(...) | main.rs:87:10:87:33 | res | provenance | |
+| main.rs:87:10:87:16 | res | main.rs:87:18:87:32 | { ... } | provenance | |
+| main.rs:87:18:87:32 | ...::format(...) | main.rs:87:10:87:16 | res | provenance | |
| main.rs:87:18:87:32 | ...::must_use(...) | main.rs:87:10:87:33 | MacroExpr | provenance | |
| main.rs:87:18:87:32 | MacroExpr | main.rs:87:18:87:32 | ...::format(...) | provenance | MaD:5 |
| main.rs:87:18:87:32 | { ... } | main.rs:87:18:87:32 | ...::must_use(...) | provenance | MaD:6 |
@@ -96,14 +96,14 @@ nodes
| main.rs:78:10:78:19 | formatted3 | semmle.label | formatted3 |
| main.rs:82:9:82:10 | s1 | semmle.label | s1 |
| main.rs:82:14:82:23 | source(...) | semmle.label | source(...) |
+| main.rs:86:10:86:16 | res | semmle.label | res |
| main.rs:86:10:86:26 | MacroExpr | semmle.label | MacroExpr |
-| main.rs:86:10:86:26 | res | semmle.label | res |
| main.rs:86:18:86:25 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:86:18:86:25 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:86:18:86:25 | MacroExpr | semmle.label | MacroExpr |
| main.rs:86:18:86:25 | { ... } | semmle.label | { ... } |
+| main.rs:87:10:87:16 | res | semmle.label | res |
| main.rs:87:10:87:33 | MacroExpr | semmle.label | MacroExpr |
-| main.rs:87:10:87:33 | res | semmle.label | res |
| main.rs:87:18:87:32 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:87:18:87:32 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:87:18:87:32 | MacroExpr | semmle.label | MacroExpr |
diff --git a/rust/ql/test/library-tests/path-resolution/CONSISTENCY/PathResolutionConsistency.expected b/rust/ql/test/library-tests/path-resolution/CONSISTENCY/PathResolutionConsistency.expected
index 0e649697a60..1d5f2a1994a 100644
--- a/rust/ql/test/library-tests/path-resolution/CONSISTENCY/PathResolutionConsistency.expected
+++ b/rust/ql/test/library-tests/path-resolution/CONSISTENCY/PathResolutionConsistency.expected
@@ -1,6 +1,6 @@
multipleCallTargets
| main.rs:118:9:118:11 | f(...) |
-| proc_macro.rs:9:5:11:5 | ...::new(...) |
+| proc_macro.rs:9:5:9:10 | ...::new(...) |
multiplePathResolutions
| main.rs:641:3:641:12 | proc_macro |
| main.rs:647:7:647:16 | proc_macro |
diff --git a/rust/ql/test/library-tests/variables/Cfg.expected b/rust/ql/test/library-tests/variables/Cfg.expected
index 157b3bd4e49..58b45ac46b6 100644
--- a/rust/ql/test/library-tests/variables/Cfg.expected
+++ b/rust/ql/test/library-tests/variables/Cfg.expected
@@ -5,14 +5,14 @@ edges
| main.rs:3:14:3:14 | s | main.rs:3:14:3:20 | ...: ... | match |
| main.rs:3:14:3:20 | ...: ... | main.rs:5:5:5:22 | ExprStmt | |
| main.rs:4:1:6:1 | { ... } | main.rs:3:1:6:1 | exit fn print_str (normal) | |
-| main.rs:5:5:5:21 | ...::_print | main.rs:5:14:5:17 | "{}\\n" | |
+| main.rs:5:5:5:12 | ...::_print | main.rs:5:14:5:17 | "{}\\n" | |
| main.rs:5:5:5:21 | MacroExpr | main.rs:4:1:6:1 | { ... } | |
| main.rs:5:5:5:21 | println!... | main.rs:5:5:5:21 | MacroExpr | |
| main.rs:5:5:5:22 | ExprStmt | main.rs:5:14:5:20 | ExprStmt | |
| main.rs:5:14:5:17 | "{}\\n" | main.rs:5:20:5:20 | s | |
| main.rs:5:14:5:20 | ...::_print(...) | main.rs:5:14:5:20 | { ... } | |
| main.rs:5:14:5:20 | ...::format_args_nl!... | main.rs:5:14:5:20 | MacroExpr | |
-| main.rs:5:14:5:20 | ExprStmt | main.rs:5:5:5:21 | ...::_print | |
+| main.rs:5:14:5:20 | ExprStmt | main.rs:5:5:5:12 | ...::_print | |
| main.rs:5:14:5:20 | FormatArgsExpr | main.rs:5:14:5:20 | ...::format_args_nl!... | |
| main.rs:5:14:5:20 | MacroBlockExpr | main.rs:5:5:5:21 | println!... | |
| main.rs:5:14:5:20 | MacroExpr | main.rs:5:14:5:20 | ...::_print(...) | |
@@ -24,14 +24,14 @@ edges
| main.rs:8:14:8:14 | i | main.rs:8:14:8:19 | ...: i64 | match |
| main.rs:8:14:8:19 | ...: i64 | main.rs:10:5:10:22 | ExprStmt | |
| main.rs:9:1:11:1 | { ... } | main.rs:8:1:11:1 | exit fn print_i64 (normal) | |
-| main.rs:10:5:10:21 | ...::_print | main.rs:10:14:10:17 | "{}\\n" | |
+| main.rs:10:5:10:12 | ...::_print | main.rs:10:14:10:17 | "{}\\n" | |
| main.rs:10:5:10:21 | MacroExpr | main.rs:9:1:11:1 | { ... } | |
| main.rs:10:5:10:21 | println!... | main.rs:10:5:10:21 | MacroExpr | |
| main.rs:10:5:10:22 | ExprStmt | main.rs:10:14:10:20 | ExprStmt | |
| main.rs:10:14:10:17 | "{}\\n" | main.rs:10:20:10:20 | i | |
| main.rs:10:14:10:20 | ...::_print(...) | main.rs:10:14:10:20 | { ... } | |
| main.rs:10:14:10:20 | ...::format_args_nl!... | main.rs:10:14:10:20 | MacroExpr | |
-| main.rs:10:14:10:20 | ExprStmt | main.rs:10:5:10:21 | ...::_print | |
+| main.rs:10:14:10:20 | ExprStmt | main.rs:10:5:10:12 | ...::_print | |
| main.rs:10:14:10:20 | FormatArgsExpr | main.rs:10:14:10:20 | ...::format_args_nl!... | |
| main.rs:10:14:10:20 | MacroBlockExpr | main.rs:10:5:10:21 | println!... | |
| main.rs:10:14:10:20 | MacroExpr | main.rs:10:14:10:20 | ...::_print(...) | |
@@ -234,16 +234,16 @@ edges
| main.rs:95:19:103:1 | { ... } | main.rs:95:1:103:1 | exit fn let_pattern4 (normal) | |
| main.rs:96:5:101:6 | let ... = ... else {...} | main.rs:97:7:97:10 | Some | |
| main.rs:96:9:96:16 | Some(...) | main.rs:96:14:96:15 | x5 | match |
-| main.rs:96:9:96:16 | Some(...) | main.rs:100:9:100:15 | ...::panic | no-match |
+| main.rs:96:9:96:16 | Some(...) | main.rs:100:9:100:13 | ...::panic | no-match |
| main.rs:96:14:96:15 | x5 | main.rs:96:14:96:15 | x5 | |
| main.rs:96:14:96:15 | x5 | main.rs:102:5:102:18 | ExprStmt | match |
| main.rs:97:7:97:10 | Some | main.rs:97:12:97:15 | "x5" | |
| main.rs:97:7:97:16 | Some(...) | main.rs:96:9:96:16 | Some(...) | |
| main.rs:97:12:97:15 | "x5" | main.rs:97:7:97:16 | Some(...) | |
-| main.rs:100:9:100:15 | "not yet implemented" | main.rs:100:9:100:15 | ...::panic(...) | |
-| main.rs:100:9:100:15 | ...::panic | main.rs:100:9:100:15 | "not yet implemented" | |
-| main.rs:100:9:100:15 | ...::panic(...) | main.rs:100:9:100:15 | MacroBlockExpr | |
-| main.rs:100:9:100:15 | MacroBlockExpr | main.rs:100:9:100:15 | todo!... | |
+| main.rs:100:9:100:13 | "not yet implemented" | main.rs:100:9:100:13 | ...::panic(...) | |
+| main.rs:100:9:100:13 | ...::panic | main.rs:100:9:100:13 | "not yet implemented" | |
+| main.rs:100:9:100:13 | ...::panic(...) | main.rs:100:9:100:13 | MacroBlockExpr | |
+| main.rs:100:9:100:13 | MacroBlockExpr | main.rs:100:9:100:15 | todo!... | |
| main.rs:100:9:100:15 | MacroExpr | main.rs:99:10:101:5 | { ... } | |
| main.rs:100:9:100:15 | todo!... | main.rs:100:9:100:15 | MacroExpr | |
| main.rs:102:5:102:13 | print_str | main.rs:102:15:102:16 | x5 | |
@@ -420,13 +420,13 @@ edges
| main.rs:184:35:184:36 | 12 | main.rs:185:22:185:51 | ExprStmt | match |
| main.rs:184:35:184:36 | 12 | main.rs:187:9:187:29 | ...::Hello {...} | no-match |
| main.rs:184:43:186:9 | { ... } | main.rs:179:5:192:5 | match msg { ... } | |
-| main.rs:185:13:185:52 | ...::_print | main.rs:185:22:185:51 | "Found an id in another range\\... | |
+| main.rs:185:13:185:20 | ...::_print | main.rs:185:22:185:51 | "Found an id in another range\\... | |
| main.rs:185:13:185:52 | MacroExpr | main.rs:184:43:186:9 | { ... } | |
| main.rs:185:13:185:52 | println!... | main.rs:185:13:185:52 | MacroExpr | |
| main.rs:185:22:185:51 | "Found an id in another range\\... | main.rs:185:22:185:51 | FormatArgsExpr | |
| main.rs:185:22:185:51 | ...::_print(...) | main.rs:185:22:185:51 | { ... } | |
| main.rs:185:22:185:51 | ...::format_args_nl!... | main.rs:185:22:185:51 | MacroExpr | |
-| main.rs:185:22:185:51 | ExprStmt | main.rs:185:13:185:52 | ...::_print | |
+| main.rs:185:22:185:51 | ExprStmt | main.rs:185:13:185:20 | ...::_print | |
| main.rs:185:22:185:51 | FormatArgsExpr | main.rs:185:22:185:51 | ...::format_args_nl!... | |
| main.rs:185:22:185:51 | MacroBlockExpr | main.rs:185:13:185:52 | println!... | |
| main.rs:185:22:185:51 | MacroExpr | main.rs:185:22:185:51 | ...::_print(...) | |
@@ -1438,12 +1438,12 @@ edges
| main.rs:608:5:609:26 | let ... = ... | main.rs:609:23:609:24 | let ... = 37 | |
| main.rs:608:9:608:22 | var_from_macro | main.rs:608:9:608:22 | var_from_macro | |
| main.rs:608:9:608:22 | var_from_macro | main.rs:610:5:610:30 | ExprStmt | match |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro | |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro | match |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:23:609:24 | { ... } | |
| main.rs:609:9:609:25 | MacroExpr | main.rs:608:9:608:22 | var_from_macro | |
| main.rs:609:9:609:25 | let_in_macro!... | main.rs:609:9:609:25 | MacroExpr | |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro | |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro | match |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:23:609:24 | { ... } | |
-| main.rs:609:23:609:24 | 37 | main.rs:609:9:609:25 | var_in_macro | |
+| main.rs:609:23:609:24 | 37 | main.rs:609:9:609:21 | var_in_macro | |
| main.rs:609:23:609:24 | let ... = 37 | main.rs:609:23:609:24 | 37 | |
| main.rs:609:23:609:24 | { ... } | main.rs:609:9:609:25 | let_in_macro!... | |
| main.rs:610:5:610:13 | print_i64 | main.rs:610:15:610:28 | var_from_macro | |
@@ -1454,15 +1454,15 @@ edges
| main.rs:611:9:611:20 | var_in_macro | main.rs:611:9:611:20 | var_in_macro | |
| main.rs:611:9:611:20 | var_in_macro | main.rs:615:5:615:44 | ExprStmt | match |
| main.rs:611:24:611:25 | 33 | main.rs:611:9:611:20 | var_in_macro | |
-| main.rs:615:5:615:13 | print_i64 | main.rs:615:15:615:42 | let ... = 0 | |
+| main.rs:615:5:615:13 | print_i64 | main.rs:615:15:615:28 | let ... = 0 | |
| main.rs:615:5:615:43 | print_i64(...) | main.rs:616:5:616:28 | ExprStmt | |
| main.rs:615:5:615:44 | ExprStmt | main.rs:615:5:615:13 | print_i64 | |
-| main.rs:615:15:615:42 | 0 | main.rs:615:15:615:42 | var_in_macro | |
+| main.rs:615:15:615:28 | 0 | main.rs:615:15:615:28 | var_in_macro | |
+| main.rs:615:15:615:28 | let ... = 0 | main.rs:615:15:615:28 | 0 | |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:15:615:28 | var_in_macro | |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:30:615:41 | var_in_macro | match |
| main.rs:615:15:615:42 | MacroExpr | main.rs:615:5:615:43 | print_i64(...) | |
-| main.rs:615:15:615:42 | let ... = 0 | main.rs:615:15:615:42 | 0 | |
| main.rs:615:15:615:42 | let_in_macro2!... | main.rs:615:15:615:42 | MacroExpr | |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:15:615:42 | var_in_macro | |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:30:615:41 | var_in_macro | match |
| main.rs:615:30:615:41 | var_in_macro | main.rs:615:30:615:41 | { ... } | |
| main.rs:615:30:615:41 | { ... } | main.rs:615:15:615:42 | let_in_macro2!... | |
| main.rs:616:5:616:13 | print_i64 | main.rs:616:15:616:26 | var_in_macro | |
diff --git a/rust/ql/test/library-tests/variables/Ssa.expected b/rust/ql/test/library-tests/variables/Ssa.expected
index cce5db8ffda..40a63c0100c 100644
--- a/rust/ql/test/library-tests/variables/Ssa.expected
+++ b/rust/ql/test/library-tests/variables/Ssa.expected
@@ -161,9 +161,9 @@ definition
| main.rs:587:13:587:13 | a | main.rs:587:13:587:13 | a |
| main.rs:588:5:588:5 | a | main.rs:587:13:587:13 | a |
| main.rs:608:9:608:22 | var_from_macro | main.rs:608:9:608:22 | var_from_macro |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro |
| main.rs:611:9:611:20 | var_in_macro | main.rs:611:9:611:20 | var_in_macro |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:15:615:42 | var_in_macro |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:15:615:28 | var_in_macro |
| main.rs:621:5:621:5 | x | main.rs:620:9:620:9 | x |
| main.rs:626:13:626:13 | x | main.rs:626:13:626:13 | x |
| main.rs:627:13:627:15 | cap | main.rs:627:13:627:15 | cap |
@@ -338,9 +338,9 @@ read
| main.rs:587:13:587:13 | a | main.rs:587:13:587:13 | a | main.rs:588:5:588:5 | a |
| main.rs:588:5:588:5 | a | main.rs:587:13:587:13 | a | main.rs:590:15:590:15 | a |
| main.rs:608:9:608:22 | var_from_macro | main.rs:608:9:608:22 | var_from_macro | main.rs:610:15:610:28 | var_from_macro |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro |
| main.rs:611:9:611:20 | var_in_macro | main.rs:611:9:611:20 | var_in_macro | main.rs:616:15:616:26 | var_in_macro |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:15:615:42 | var_in_macro | main.rs:615:30:615:41 | var_in_macro |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:15:615:28 | var_in_macro | main.rs:615:30:615:41 | var_in_macro |
| main.rs:621:5:621:5 | x | main.rs:620:9:620:9 | x | main.rs:622:15:622:15 | x |
| main.rs:627:13:627:15 | cap | main.rs:627:13:627:15 | cap | main.rs:633:5:633:7 | cap |
| main.rs:627:20:627:20 | b | main.rs:627:20:627:20 | b | main.rs:629:20:629:20 | b |
@@ -480,9 +480,9 @@ firstRead
| main.rs:587:13:587:13 | a | main.rs:587:13:587:13 | a | main.rs:588:5:588:5 | a |
| main.rs:588:5:588:5 | a | main.rs:587:13:587:13 | a | main.rs:590:15:590:15 | a |
| main.rs:608:9:608:22 | var_from_macro | main.rs:608:9:608:22 | var_from_macro | main.rs:610:15:610:28 | var_from_macro |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro |
| main.rs:611:9:611:20 | var_in_macro | main.rs:611:9:611:20 | var_in_macro | main.rs:616:15:616:26 | var_in_macro |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:15:615:42 | var_in_macro | main.rs:615:30:615:41 | var_in_macro |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:15:615:28 | var_in_macro | main.rs:615:30:615:41 | var_in_macro |
| main.rs:621:5:621:5 | x | main.rs:620:9:620:9 | x | main.rs:622:15:622:15 | x |
| main.rs:627:13:627:15 | cap | main.rs:627:13:627:15 | cap | main.rs:633:5:633:7 | cap |
| main.rs:627:20:627:20 | b | main.rs:627:20:627:20 | b | main.rs:629:20:629:20 | b |
@@ -659,9 +659,9 @@ assigns
| main.rs:572:9:572:9 | z | main.rs:572:13:572:14 | 17 |
| main.rs:587:13:587:13 | a | main.rs:587:17:587:35 | MyStruct {...} |
| main.rs:608:9:608:22 | var_from_macro | main.rs:609:9:609:25 | MacroExpr |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:23:609:24 | 37 |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:23:609:24 | 37 |
| main.rs:611:9:611:20 | var_in_macro | main.rs:611:24:611:25 | 33 |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:15:615:42 | 0 |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:15:615:28 | 0 |
| main.rs:621:5:621:5 | x | main.rs:621:9:621:9 | 1 |
| main.rs:626:13:626:13 | x | main.rs:626:17:626:19 | 100 |
| main.rs:627:13:627:15 | cap | main.rs:627:19:632:5 | \|...\| ... |
diff --git a/rust/ql/test/library-tests/variables/variables.expected b/rust/ql/test/library-tests/variables/variables.expected
index b77fbe505b6..d7eaf81e5a8 100644
--- a/rust/ql/test/library-tests/variables/variables.expected
+++ b/rust/ql/test/library-tests/variables/variables.expected
@@ -112,9 +112,9 @@ variable
| main.rs:581:17:581:20 | self |
| main.rs:587:13:587:13 | a |
| main.rs:608:9:608:22 | var_from_macro |
-| main.rs:609:9:609:25 | var_in_macro |
+| main.rs:609:9:609:21 | var_in_macro |
| main.rs:611:9:611:20 | var_in_macro |
-| main.rs:615:15:615:42 | var_in_macro |
+| main.rs:615:15:615:28 | var_in_macro |
| main.rs:620:9:620:9 | x |
| main.rs:626:13:626:13 | x |
| main.rs:627:13:627:15 | cap |
@@ -295,9 +295,9 @@ variableAccess
| main.rs:582:10:582:13 | self | main.rs:581:17:581:20 | self |
| main.rs:588:5:588:5 | a | main.rs:587:13:587:13 | a |
| main.rs:590:15:590:15 | a | main.rs:587:13:587:13 | a |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro |
| main.rs:610:15:610:28 | var_from_macro | main.rs:608:9:608:22 | var_from_macro |
-| main.rs:615:30:615:41 | var_in_macro | main.rs:615:15:615:42 | var_in_macro |
+| main.rs:615:30:615:41 | var_in_macro | main.rs:615:15:615:28 | var_in_macro |
| main.rs:616:15:616:26 | var_in_macro | main.rs:611:9:611:20 | var_in_macro |
| main.rs:621:5:621:5 | x | main.rs:620:9:620:9 | x |
| main.rs:622:15:622:15 | x | main.rs:620:9:620:9 | x |
@@ -473,9 +473,9 @@ variableReadAccess
| main.rs:582:10:582:13 | self | main.rs:581:17:581:20 | self |
| main.rs:588:5:588:5 | a | main.rs:587:13:587:13 | a |
| main.rs:590:15:590:15 | a | main.rs:587:13:587:13 | a |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:9:609:25 | var_in_macro |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:9:609:21 | var_in_macro |
| main.rs:610:15:610:28 | var_from_macro | main.rs:608:9:608:22 | var_from_macro |
-| main.rs:615:30:615:41 | var_in_macro | main.rs:615:15:615:42 | var_in_macro |
+| main.rs:615:30:615:41 | var_in_macro | main.rs:615:15:615:28 | var_in_macro |
| main.rs:616:15:616:26 | var_in_macro | main.rs:611:9:611:20 | var_in_macro |
| main.rs:622:15:622:15 | x | main.rs:620:9:620:9 | x |
| main.rs:629:20:629:20 | b | main.rs:627:20:627:20 | b |
@@ -537,9 +537,9 @@ variableInitializer
| main.rs:572:9:572:9 | z | main.rs:572:13:572:14 | 17 |
| main.rs:587:13:587:13 | a | main.rs:587:17:587:35 | MyStruct {...} |
| main.rs:608:9:608:22 | var_from_macro | main.rs:609:9:609:25 | MacroExpr |
-| main.rs:609:9:609:25 | var_in_macro | main.rs:609:23:609:24 | 37 |
+| main.rs:609:9:609:21 | var_in_macro | main.rs:609:23:609:24 | 37 |
| main.rs:611:9:611:20 | var_in_macro | main.rs:611:24:611:25 | 33 |
-| main.rs:615:15:615:42 | var_in_macro | main.rs:615:15:615:42 | 0 |
+| main.rs:615:15:615:28 | var_in_macro | main.rs:615:15:615:28 | 0 |
| main.rs:626:13:626:13 | x | main.rs:626:17:626:19 | 100 |
| main.rs:627:13:627:15 | cap | main.rs:627:19:632:5 | \|...\| ... |
capturedVariable
diff --git a/rust/ql/test/query-tests/security/CWE-020/RegexInjection.expected b/rust/ql/test/query-tests/security/CWE-020/RegexInjection.expected
index 08e88a3039a..26b5ede8909 100644
--- a/rust/ql/test/query-tests/security/CWE-020/RegexInjection.expected
+++ b/rust/ql/test/query-tests/security/CWE-020/RegexInjection.expected
@@ -6,8 +6,8 @@ edges
| main.rs:4:20:4:40 | ...::var(...) [Ok] | main.rs:4:20:4:66 | ... .unwrap_or(...) | provenance | MaD:2 |
| main.rs:4:20:4:66 | ... .unwrap_or(...) | main.rs:4:9:4:16 | username | provenance | |
| main.rs:5:9:5:13 | regex | main.rs:6:26:6:30 | regex | provenance | |
-| main.rs:5:17:5:45 | res | main.rs:5:25:5:44 | { ... } | provenance | |
-| main.rs:5:25:5:44 | ...::format(...) | main.rs:5:17:5:45 | res | provenance | |
+| main.rs:5:17:5:23 | res | main.rs:5:25:5:44 | { ... } | provenance | |
+| main.rs:5:25:5:44 | ...::format(...) | main.rs:5:17:5:23 | res | provenance | |
| main.rs:5:25:5:44 | ...::must_use(...) | main.rs:5:9:5:13 | regex | provenance | |
| main.rs:5:25:5:44 | MacroExpr | main.rs:5:25:5:44 | ...::format(...) | provenance | MaD:3 |
| main.rs:5:25:5:44 | { ... } | main.rs:5:25:5:44 | ...::must_use(...) | provenance | MaD:4 |
@@ -23,7 +23,7 @@ nodes
| main.rs:4:20:4:40 | ...::var(...) [Ok] | semmle.label | ...::var(...) [Ok] |
| main.rs:4:20:4:66 | ... .unwrap_or(...) | semmle.label | ... .unwrap_or(...) |
| main.rs:5:9:5:13 | regex | semmle.label | regex |
-| main.rs:5:17:5:45 | res | semmle.label | res |
+| main.rs:5:17:5:23 | res | semmle.label | res |
| main.rs:5:25:5:44 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:5:25:5:44 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:5:25:5:44 | MacroExpr | semmle.label | MacroExpr |
diff --git a/rust/ql/test/query-tests/security/CWE-089/CONSISTENCY/TypeInferenceConsistency.expected b/rust/ql/test/query-tests/security/CWE-089/CONSISTENCY/TypeInferenceConsistency.expected
index 6a60922b6f0..1a1b7ec4afe 100644
--- a/rust/ql/test/query-tests/security/CWE-089/CONSISTENCY/TypeInferenceConsistency.expected
+++ b/rust/ql/test/query-tests/security/CWE-089/CONSISTENCY/TypeInferenceConsistency.expected
@@ -1,3 +1,3 @@
nonUniqueCertainType
-| sqlx.rs:158:13:158:81 | { ... } | E |
-| sqlx.rs:160:17:160:86 | { ... } | E |
+| sqlx.rs:158:13:158:24 | { ... } | E |
+| sqlx.rs:160:17:160:28 | { ... } | E |
diff --git a/rust/ql/test/query-tests/security/CWE-089/SqlInjection.expected b/rust/ql/test/query-tests/security/CWE-089/SqlInjection.expected
index cc00a44d9fc..2168ca56a44 100644
--- a/rust/ql/test/query-tests/security/CWE-089/SqlInjection.expected
+++ b/rust/ql/test/query-tests/security/CWE-089/SqlInjection.expected
@@ -23,8 +23,8 @@ edges
| sqlx.rs:52:9:52:20 | safe_query_3 | sqlx.rs:77:25:77:45 | safe_query_3.as_str() | provenance | MaD:9 |
| sqlx.rs:52:9:52:20 | safe_query_3 | sqlx.rs:77:25:77:45 | safe_query_3.as_str() | provenance | MaD:5 |
| sqlx.rs:52:9:52:20 | safe_query_3 | sqlx.rs:77:25:77:45 | safe_query_3.as_str() | provenance | MaD:9 |
-| sqlx.rs:52:24:52:88 | res | sqlx.rs:52:32:52:87 | { ... } | provenance | |
-| sqlx.rs:52:32:52:87 | ...::format(...) | sqlx.rs:52:24:52:88 | res | provenance | |
+| sqlx.rs:52:24:52:30 | res | sqlx.rs:52:32:52:87 | { ... } | provenance | |
+| sqlx.rs:52:32:52:87 | ...::format(...) | sqlx.rs:52:24:52:30 | res | provenance | |
| sqlx.rs:52:32:52:87 | ...::must_use(...) | sqlx.rs:52:9:52:20 | safe_query_3 | provenance | |
| sqlx.rs:52:32:52:87 | MacroExpr | sqlx.rs:52:32:52:87 | ...::format(...) | provenance | MaD:12 |
| sqlx.rs:52:32:52:87 | { ... } | sqlx.rs:52:32:52:87 | ...::must_use(...) | provenance | MaD:13 |
@@ -75,7 +75,7 @@ nodes
| sqlx.rs:49:25:49:52 | remote_string.parse() [Ok] | semmle.label | remote_string.parse() [Ok] |
| sqlx.rs:49:25:49:65 | ... .unwrap_or(...) | semmle.label | ... .unwrap_or(...) |
| sqlx.rs:52:9:52:20 | safe_query_3 | semmle.label | safe_query_3 |
-| sqlx.rs:52:24:52:88 | res | semmle.label | res |
+| sqlx.rs:52:24:52:30 | res | semmle.label | res |
| sqlx.rs:52:32:52:87 | ...::format(...) | semmle.label | ...::format(...) |
| sqlx.rs:52:32:52:87 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| sqlx.rs:52:32:52:87 | MacroExpr | semmle.label | MacroExpr |
diff --git a/rust/ql/test/query-tests/security/CWE-311/CleartextTransmission.expected b/rust/ql/test/query-tests/security/CWE-311/CleartextTransmission.expected
index 0a229c72d75..dbeebc63e55 100644
--- a/rust/ql/test/query-tests/security/CWE-311/CleartextTransmission.expected
+++ b/rust/ql/test/query-tests/security/CWE-311/CleartextTransmission.expected
@@ -6,16 +6,16 @@
| main.rs:35:12:35:18 | request | main.rs:33:50:33:57 | password | main.rs:35:12:35:18 | request | This 'request' operation transmits data which may contain unencrypted sensitive data from $@. | main.rs:33:50:33:57 | password | password |
edges
| main.rs:6:9:6:11 | url | main.rs:7:28:7:30 | url | provenance | |
-| main.rs:6:15:6:58 | res | main.rs:6:23:6:57 | { ... } | provenance | |
-| main.rs:6:23:6:57 | ...::format(...) | main.rs:6:15:6:58 | res | provenance | |
+| main.rs:6:15:6:21 | res | main.rs:6:23:6:57 | { ... } | provenance | |
+| main.rs:6:23:6:57 | ...::format(...) | main.rs:6:15:6:21 | res | provenance | |
| main.rs:6:23:6:57 | ...::must_use(...) | main.rs:6:9:6:11 | url | provenance | |
| main.rs:6:23:6:57 | MacroExpr | main.rs:6:23:6:57 | ...::format(...) | provenance | MaD:7 |
| main.rs:6:23:6:57 | { ... } | main.rs:6:23:6:57 | ...::must_use(...) | provenance | MaD:8 |
| main.rs:6:50:6:57 | password | main.rs:6:23:6:57 | MacroExpr | provenance | |
| main.rs:7:28:7:30 | url | main.rs:7:5:7:26 | ...::get | provenance | MaD:4 Sink:MaD:4 |
| main.rs:12:9:12:15 | address | main.rs:13:27:13:33 | address | provenance | |
-| main.rs:12:19:12:60 | res | main.rs:12:27:12:59 | { ... } | provenance | |
-| main.rs:12:27:12:59 | ...::format(...) | main.rs:12:19:12:60 | res | provenance | |
+| main.rs:12:19:12:25 | res | main.rs:12:27:12:59 | { ... } | provenance | |
+| main.rs:12:27:12:59 | ...::format(...) | main.rs:12:19:12:25 | res | provenance | |
| main.rs:12:27:12:59 | ...::must_use(...) | main.rs:12:9:12:15 | address | provenance | |
| main.rs:12:27:12:59 | MacroExpr | main.rs:12:27:12:59 | ...::format(...) | provenance | MaD:7 |
| main.rs:12:27:12:59 | { ... } | main.rs:12:27:12:59 | ...::must_use(...) | provenance | MaD:8 |
@@ -27,24 +27,24 @@ edges
| main.rs:13:27:13:33 | address | main.rs:13:26:13:33 | &address [&ref] | provenance | |
| main.rs:14:28:14:30 | url | main.rs:14:5:14:26 | ...::get | provenance | MaD:4 Sink:MaD:4 |
| main.rs:19:9:19:11 | url | main.rs:21:17:21:19 | url | provenance | |
-| main.rs:19:15:19:58 | res | main.rs:19:23:19:57 | { ... } | provenance | |
-| main.rs:19:23:19:57 | ...::format(...) | main.rs:19:15:19:58 | res | provenance | |
+| main.rs:19:15:19:21 | res | main.rs:19:23:19:57 | { ... } | provenance | |
+| main.rs:19:23:19:57 | ...::format(...) | main.rs:19:15:19:21 | res | provenance | |
| main.rs:19:23:19:57 | ...::must_use(...) | main.rs:19:9:19:11 | url | provenance | |
| main.rs:19:23:19:57 | MacroExpr | main.rs:19:23:19:57 | ...::format(...) | provenance | MaD:7 |
| main.rs:19:23:19:57 | { ... } | main.rs:19:23:19:57 | ...::must_use(...) | provenance | MaD:8 |
| main.rs:19:50:19:57 | password | main.rs:19:23:19:57 | MacroExpr | provenance | |
| main.rs:21:17:21:19 | url | main.rs:21:12:21:15 | post | provenance | MaD:1 Sink:MaD:1 |
| main.rs:26:9:26:11 | url | main.rs:28:33:28:35 | url | provenance | |
-| main.rs:26:15:26:58 | res | main.rs:26:23:26:57 | { ... } | provenance | |
-| main.rs:26:23:26:57 | ...::format(...) | main.rs:26:15:26:58 | res | provenance | |
+| main.rs:26:15:26:21 | res | main.rs:26:23:26:57 | { ... } | provenance | |
+| main.rs:26:23:26:57 | ...::format(...) | main.rs:26:15:26:21 | res | provenance | |
| main.rs:26:23:26:57 | ...::must_use(...) | main.rs:26:9:26:11 | url | provenance | |
| main.rs:26:23:26:57 | MacroExpr | main.rs:26:23:26:57 | ...::format(...) | provenance | MaD:7 |
| main.rs:26:23:26:57 | { ... } | main.rs:26:23:26:57 | ...::must_use(...) | provenance | MaD:8 |
| main.rs:26:50:26:57 | password | main.rs:26:23:26:57 | MacroExpr | provenance | |
| main.rs:28:33:28:35 | url | main.rs:28:12:28:18 | request | provenance | MaD:3 Sink:MaD:3 |
| main.rs:33:9:33:11 | url | main.rs:35:33:35:35 | url | provenance | |
-| main.rs:33:15:33:58 | res | main.rs:33:23:33:57 | { ... } | provenance | |
-| main.rs:33:23:33:57 | ...::format(...) | main.rs:33:15:33:58 | res | provenance | |
+| main.rs:33:15:33:21 | res | main.rs:33:23:33:57 | { ... } | provenance | |
+| main.rs:33:23:33:57 | ...::format(...) | main.rs:33:15:33:21 | res | provenance | |
| main.rs:33:23:33:57 | ...::must_use(...) | main.rs:33:9:33:11 | url | provenance | |
| main.rs:33:23:33:57 | MacroExpr | main.rs:33:23:33:57 | ...::format(...) | provenance | MaD:7 |
| main.rs:33:23:33:57 | { ... } | main.rs:33:23:33:57 | ...::must_use(...) | provenance | MaD:8 |
@@ -61,7 +61,7 @@ models
| 8 | Summary: core::hint::must_use; Argument[0]; ReturnValue; value |
nodes
| main.rs:6:9:6:11 | url | semmle.label | url |
-| main.rs:6:15:6:58 | res | semmle.label | res |
+| main.rs:6:15:6:21 | res | semmle.label | res |
| main.rs:6:23:6:57 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:6:23:6:57 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:6:23:6:57 | MacroExpr | semmle.label | MacroExpr |
@@ -70,7 +70,7 @@ nodes
| main.rs:7:5:7:26 | ...::get | semmle.label | ...::get |
| main.rs:7:28:7:30 | url | semmle.label | url |
| main.rs:12:9:12:15 | address | semmle.label | address |
-| main.rs:12:19:12:60 | res | semmle.label | res |
+| main.rs:12:19:12:25 | res | semmle.label | res |
| main.rs:12:27:12:59 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:12:27:12:59 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:12:27:12:59 | MacroExpr | semmle.label | MacroExpr |
@@ -84,7 +84,7 @@ nodes
| main.rs:14:5:14:26 | ...::get | semmle.label | ...::get |
| main.rs:14:28:14:30 | url | semmle.label | url |
| main.rs:19:9:19:11 | url | semmle.label | url |
-| main.rs:19:15:19:58 | res | semmle.label | res |
+| main.rs:19:15:19:21 | res | semmle.label | res |
| main.rs:19:23:19:57 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:19:23:19:57 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:19:23:19:57 | MacroExpr | semmle.label | MacroExpr |
@@ -93,7 +93,7 @@ nodes
| main.rs:21:12:21:15 | post | semmle.label | post |
| main.rs:21:17:21:19 | url | semmle.label | url |
| main.rs:26:9:26:11 | url | semmle.label | url |
-| main.rs:26:15:26:58 | res | semmle.label | res |
+| main.rs:26:15:26:21 | res | semmle.label | res |
| main.rs:26:23:26:57 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:26:23:26:57 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:26:23:26:57 | MacroExpr | semmle.label | MacroExpr |
@@ -102,7 +102,7 @@ nodes
| main.rs:28:12:28:18 | request | semmle.label | request |
| main.rs:28:33:28:35 | url | semmle.label | url |
| main.rs:33:9:33:11 | url | semmle.label | url |
-| main.rs:33:15:33:58 | res | semmle.label | res |
+| main.rs:33:15:33:21 | res | semmle.label | res |
| main.rs:33:23:33:57 | ...::format(...) | semmle.label | ...::format(...) |
| main.rs:33:23:33:57 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| main.rs:33:23:33:57 | MacroExpr | semmle.label | MacroExpr |
diff --git a/rust/ql/test/query-tests/security/CWE-312/CONSISTENCY/PathResolutionConsistency.expected b/rust/ql/test/query-tests/security/CWE-312/CONSISTENCY/PathResolutionConsistency.expected
index e569aca9804..ca7923f5c2f 100644
--- a/rust/ql/test/query-tests/security/CWE-312/CONSISTENCY/PathResolutionConsistency.expected
+++ b/rust/ql/test/query-tests/security/CWE-312/CONSISTENCY/PathResolutionConsistency.expected
@@ -1,71 +1,71 @@
multipleCallTargets
-| test_logging.rs:42:5:42:36 | ...::max_level(...) |
-| test_logging.rs:43:5:43:36 | ...::max_level(...) |
-| test_logging.rs:44:5:44:35 | ...::max_level(...) |
-| test_logging.rs:45:5:45:36 | ...::max_level(...) |
-| test_logging.rs:46:5:46:35 | ...::max_level(...) |
-| test_logging.rs:47:5:47:48 | ...::max_level(...) |
-| test_logging.rs:50:5:50:21 | ...::max_level(...) |
-| test_logging.rs:51:5:51:36 | ...::max_level(...) |
-| test_logging.rs:52:5:52:36 | ...::max_level(...) |
-| test_logging.rs:53:5:53:46 | ...::max_level(...) |
-| test_logging.rs:54:5:54:49 | ...::max_level(...) |
-| test_logging.rs:55:5:55:34 | ...::max_level(...) |
-| test_logging.rs:56:5:56:47 | ...::max_level(...) |
-| test_logging.rs:57:5:57:34 | ...::max_level(...) |
-| test_logging.rs:58:5:58:36 | ...::max_level(...) |
-| test_logging.rs:59:5:59:54 | ...::max_level(...) |
-| test_logging.rs:60:5:60:54 | ...::max_level(...) |
-| test_logging.rs:61:5:61:55 | ...::max_level(...) |
-| test_logging.rs:64:5:64:48 | ...::max_level(...) |
-| test_logging.rs:65:5:65:48 | ...::max_level(...) |
-| test_logging.rs:66:5:66:66 | ...::max_level(...) |
-| test_logging.rs:67:5:67:66 | ...::max_level(...) |
-| test_logging.rs:68:5:68:67 | ...::max_level(...) |
-| test_logging.rs:71:5:71:47 | ...::max_level(...) |
-| test_logging.rs:72:5:72:47 | ...::max_level(...) |
-| test_logging.rs:73:5:73:50 | ...::max_level(...) |
-| test_logging.rs:74:5:74:65 | ...::max_level(...) |
-| test_logging.rs:75:5:75:51 | ...::max_level(...) |
-| test_logging.rs:76:5:76:47 | ...::max_level(...) |
-| test_logging.rs:77:5:77:48 | ...::max_level(...) |
+| test_logging.rs:42:5:42:10 | ...::max_level(...) |
+| test_logging.rs:43:5:43:10 | ...::max_level(...) |
+| test_logging.rs:44:5:44:9 | ...::max_level(...) |
+| test_logging.rs:45:5:45:10 | ...::max_level(...) |
+| test_logging.rs:46:5:46:9 | ...::max_level(...) |
+| test_logging.rs:47:5:47:8 | ...::max_level(...) |
+| test_logging.rs:50:5:50:10 | ...::max_level(...) |
+| test_logging.rs:51:5:51:10 | ...::max_level(...) |
+| test_logging.rs:52:5:52:10 | ...::max_level(...) |
+| test_logging.rs:53:5:53:10 | ...::max_level(...) |
+| test_logging.rs:54:5:54:10 | ...::max_level(...) |
+| test_logging.rs:55:5:55:10 | ...::max_level(...) |
+| test_logging.rs:56:5:56:10 | ...::max_level(...) |
+| test_logging.rs:57:5:57:10 | ...::max_level(...) |
+| test_logging.rs:58:5:58:10 | ...::max_level(...) |
+| test_logging.rs:59:5:59:10 | ...::max_level(...) |
+| test_logging.rs:60:5:60:10 | ...::max_level(...) |
+| test_logging.rs:61:5:61:10 | ...::max_level(...) |
+| test_logging.rs:64:5:64:8 | ...::max_level(...) |
+| test_logging.rs:65:5:65:8 | ...::max_level(...) |
+| test_logging.rs:66:5:66:8 | ...::max_level(...) |
+| test_logging.rs:67:5:67:8 | ...::max_level(...) |
+| test_logging.rs:68:5:68:8 | ...::max_level(...) |
+| test_logging.rs:71:5:71:10 | ...::max_level(...) |
+| test_logging.rs:72:5:72:10 | ...::max_level(...) |
+| test_logging.rs:73:5:73:10 | ...::max_level(...) |
+| test_logging.rs:74:5:74:10 | ...::max_level(...) |
+| test_logging.rs:75:5:75:10 | ...::max_level(...) |
+| test_logging.rs:76:5:76:10 | ...::max_level(...) |
+| test_logging.rs:77:5:77:10 | ...::max_level(...) |
| test_logging.rs:77:20:77:36 | password.as_str() |
-| test_logging.rs:78:5:78:50 | ...::max_level(...) |
+| test_logging.rs:78:5:78:10 | ...::max_level(...) |
| test_logging.rs:78:22:78:38 | password.as_str() |
-| test_logging.rs:81:5:81:44 | ...::max_level(...) |
-| test_logging.rs:82:5:82:44 | ...::max_level(...) |
-| test_logging.rs:83:5:83:47 | ...::max_level(...) |
-| test_logging.rs:84:5:84:62 | ...::max_level(...) |
-| test_logging.rs:85:5:85:48 | ...::max_level(...) |
-| test_logging.rs:86:5:86:44 | ...::max_level(...) |
+| test_logging.rs:81:5:81:10 | ...::max_level(...) |
+| test_logging.rs:82:5:82:10 | ...::max_level(...) |
+| test_logging.rs:83:5:83:10 | ...::max_level(...) |
+| test_logging.rs:84:5:84:10 | ...::max_level(...) |
+| test_logging.rs:85:5:85:10 | ...::max_level(...) |
+| test_logging.rs:86:5:86:10 | ...::max_level(...) |
| test_logging.rs:88:18:88:34 | password.as_str() |
-| test_logging.rs:89:5:89:29 | ...::max_level(...) |
-| test_logging.rs:90:5:90:31 | ...::max_level(...) |
-| test_logging.rs:94:5:94:29 | ...::max_level(...) |
-| test_logging.rs:97:5:97:19 | ...::max_level(...) |
-| test_logging.rs:100:5:100:19 | ...::max_level(...) |
-| test_logging.rs:104:5:104:19 | ...::max_level(...) |
-| test_logging.rs:108:5:108:19 | ...::max_level(...) |
-| test_logging.rs:112:5:112:50 | ...::max_level(...) |
-| test_logging.rs:114:9:114:55 | ...::max_level(...) |
-| test_logging.rs:118:5:118:42 | ...::max_level(...) |
-| test_logging.rs:121:5:121:33 | ...::max_level(...) |
-| test_logging.rs:123:5:123:33 | ...::max_level(...) |
-| test_logging.rs:126:5:126:33 | ...::max_level(...) |
-| test_logging.rs:130:5:130:32 | ...::max_level(...) |
-| test_logging.rs:131:5:131:32 | ...::max_level(...) |
-| test_logging.rs:132:5:132:32 | ...::max_level(...) |
-| test_logging.rs:133:5:133:33 | ...::max_level(...) |
-| test_logging.rs:140:5:140:38 | ...::max_level(...) |
-| test_logging.rs:141:5:141:38 | ...::max_level(...) |
-| test_logging.rs:142:5:142:29 | ...::max_level(...) |
-| test_logging.rs:143:5:143:31 | ...::max_level(...) |
-| test_logging.rs:144:5:144:32 | ...::max_level(...) |
-| test_logging.rs:150:5:150:38 | ...::max_level(...) |
-| test_logging.rs:151:5:151:38 | ...::max_level(...) |
-| test_logging.rs:152:5:152:29 | ...::max_level(...) |
-| test_logging.rs:153:5:153:31 | ...::max_level(...) |
-| test_logging.rs:154:5:154:32 | ...::max_level(...) |
+| test_logging.rs:89:5:89:10 | ...::max_level(...) |
+| test_logging.rs:90:5:90:10 | ...::max_level(...) |
+| test_logging.rs:94:5:94:9 | ...::max_level(...) |
+| test_logging.rs:97:5:97:9 | ...::max_level(...) |
+| test_logging.rs:100:5:100:9 | ...::max_level(...) |
+| test_logging.rs:104:5:104:9 | ...::max_level(...) |
+| test_logging.rs:108:5:108:9 | ...::max_level(...) |
+| test_logging.rs:112:5:112:9 | ...::max_level(...) |
+| test_logging.rs:114:9:114:13 | ...::max_level(...) |
+| test_logging.rs:118:5:118:10 | ...::max_level(...) |
+| test_logging.rs:121:5:121:10 | ...::max_level(...) |
+| test_logging.rs:123:5:123:10 | ...::max_level(...) |
+| test_logging.rs:126:5:126:10 | ...::max_level(...) |
+| test_logging.rs:130:5:130:10 | ...::max_level(...) |
+| test_logging.rs:131:5:131:10 | ...::max_level(...) |
+| test_logging.rs:132:5:132:10 | ...::max_level(...) |
+| test_logging.rs:133:5:133:10 | ...::max_level(...) |
+| test_logging.rs:140:5:140:9 | ...::max_level(...) |
+| test_logging.rs:141:5:141:9 | ...::max_level(...) |
+| test_logging.rs:142:5:142:9 | ...::max_level(...) |
+| test_logging.rs:143:5:143:9 | ...::max_level(...) |
+| test_logging.rs:144:5:144:9 | ...::max_level(...) |
+| test_logging.rs:150:5:150:9 | ...::max_level(...) |
+| test_logging.rs:151:5:151:9 | ...::max_level(...) |
+| test_logging.rs:152:5:152:9 | ...::max_level(...) |
+| test_logging.rs:153:5:153:9 | ...::max_level(...) |
+| test_logging.rs:154:5:154:9 | ...::max_level(...) |
| test_logging.rs:192:12:192:37 | ...::_print(...) |
| test_logging.rs:193:14:193:37 | ...::_print(...) |
| test_logging.rs:194:13:194:38 | ...::_eprint(...) |
diff --git a/rust/ql/test/query-tests/security/CWE-312/CleartextLogging.expected b/rust/ql/test/query-tests/security/CWE-312/CleartextLogging.expected
index 0cf81cf9d77..01d3b06a854 100644
--- a/rust/ql/test/query-tests/security/CWE-312/CleartextLogging.expected
+++ b/rust/ql/test/query-tests/security/CWE-312/CleartextLogging.expected
@@ -1,53 +1,53 @@
#select
-| test_logging.rs:42:5:42:36 | ...::log | test_logging.rs:42:28:42:35 | password | test_logging.rs:42:5:42:36 | ...::log | This operation writes $@ to a log file. | test_logging.rs:42:28:42:35 | password | password |
-| test_logging.rs:43:5:43:36 | ...::log | test_logging.rs:43:28:43:35 | password | test_logging.rs:43:5:43:36 | ...::log | This operation writes $@ to a log file. | test_logging.rs:43:28:43:35 | password | password |
-| test_logging.rs:44:5:44:35 | ...::log | test_logging.rs:44:27:44:34 | password | test_logging.rs:44:5:44:35 | ...::log | This operation writes $@ to a log file. | test_logging.rs:44:27:44:34 | password | password |
-| test_logging.rs:45:5:45:36 | ...::log | test_logging.rs:45:28:45:35 | password | test_logging.rs:45:5:45:36 | ...::log | This operation writes $@ to a log file. | test_logging.rs:45:28:45:35 | password | password |
-| test_logging.rs:46:5:46:35 | ...::log | test_logging.rs:46:27:46:34 | password | test_logging.rs:46:5:46:35 | ...::log | This operation writes $@ to a log file. | test_logging.rs:46:27:46:34 | password | password |
-| test_logging.rs:47:5:47:48 | ...::log | test_logging.rs:47:40:47:47 | password | test_logging.rs:47:5:47:48 | ...::log | This operation writes $@ to a log file. | test_logging.rs:47:40:47:47 | password | password |
-| test_logging.rs:52:5:52:36 | ...::log | test_logging.rs:52:28:52:35 | password | test_logging.rs:52:5:52:36 | ...::log | This operation writes $@ to a log file. | test_logging.rs:52:28:52:35 | password | password |
-| test_logging.rs:54:5:54:49 | ...::log | test_logging.rs:54:41:54:48 | password | test_logging.rs:54:5:54:49 | ...::log | This operation writes $@ to a log file. | test_logging.rs:54:41:54:48 | password | password |
-| test_logging.rs:56:5:56:47 | ...::log | test_logging.rs:56:39:56:46 | password | test_logging.rs:56:5:56:47 | ...::log | This operation writes $@ to a log file. | test_logging.rs:56:39:56:46 | password | password |
-| test_logging.rs:57:5:57:34 | ...::log | test_logging.rs:57:24:57:31 | password | test_logging.rs:57:5:57:34 | ...::log | This operation writes $@ to a log file. | test_logging.rs:57:24:57:31 | password | password |
-| test_logging.rs:58:5:58:36 | ...::log | test_logging.rs:58:24:58:31 | password | test_logging.rs:58:5:58:36 | ...::log | This operation writes $@ to a log file. | test_logging.rs:58:24:58:31 | password | password |
-| test_logging.rs:60:5:60:54 | ...::log | test_logging.rs:60:46:60:53 | password | test_logging.rs:60:5:60:54 | ...::log | This operation writes $@ to a log file. | test_logging.rs:60:46:60:53 | password | password |
-| test_logging.rs:61:5:61:55 | ...::log | test_logging.rs:61:21:61:28 | password | test_logging.rs:61:5:61:55 | ...::log | This operation writes $@ to a log file. | test_logging.rs:61:21:61:28 | password | password |
-| test_logging.rs:65:5:65:48 | ...::log | test_logging.rs:65:40:65:47 | password | test_logging.rs:65:5:65:48 | ...::log | This operation writes $@ to a log file. | test_logging.rs:65:40:65:47 | password | password |
-| test_logging.rs:67:5:67:66 | ...::log | test_logging.rs:67:58:67:65 | password | test_logging.rs:67:5:67:66 | ...::log | This operation writes $@ to a log file. | test_logging.rs:67:58:67:65 | password | password |
-| test_logging.rs:68:5:68:67 | ...::log | test_logging.rs:68:19:68:26 | password | test_logging.rs:68:5:68:67 | ...::log | This operation writes $@ to a log file. | test_logging.rs:68:19:68:26 | password | password |
-| test_logging.rs:72:5:72:47 | ...::log | test_logging.rs:72:39:72:46 | password | test_logging.rs:72:5:72:47 | ...::log | This operation writes $@ to a log file. | test_logging.rs:72:39:72:46 | password | password |
-| test_logging.rs:74:5:74:65 | ...::log | test_logging.rs:74:57:74:64 | password | test_logging.rs:74:5:74:65 | ...::log | This operation writes $@ to a log file. | test_logging.rs:74:57:74:64 | password | password |
-| test_logging.rs:75:5:75:51 | ...::log | test_logging.rs:75:21:75:28 | password | test_logging.rs:75:5:75:51 | ...::log | This operation writes $@ to a log file. | test_logging.rs:75:21:75:28 | password | password |
-| test_logging.rs:76:5:76:47 | ...::log | test_logging.rs:76:39:76:46 | password | test_logging.rs:76:5:76:47 | ...::log | This operation writes $@ to a log file. | test_logging.rs:76:39:76:46 | password | password |
-| test_logging.rs:82:5:82:44 | ...::log | test_logging.rs:82:36:82:43 | password | test_logging.rs:82:5:82:44 | ...::log | This operation writes $@ to a log file. | test_logging.rs:82:36:82:43 | password | password |
-| test_logging.rs:84:5:84:62 | ...::log | test_logging.rs:84:54:84:61 | password | test_logging.rs:84:5:84:62 | ...::log | This operation writes $@ to a log file. | test_logging.rs:84:54:84:61 | password | password |
-| test_logging.rs:85:5:85:48 | ...::log | test_logging.rs:85:21:85:28 | password | test_logging.rs:85:5:85:48 | ...::log | This operation writes $@ to a log file. | test_logging.rs:85:21:85:28 | password | password |
-| test_logging.rs:86:5:86:44 | ...::log | test_logging.rs:86:36:86:43 | password | test_logging.rs:86:5:86:44 | ...::log | This operation writes $@ to a log file. | test_logging.rs:86:36:86:43 | password | password |
-| test_logging.rs:94:5:94:29 | ...::log | test_logging.rs:93:15:93:22 | password | test_logging.rs:94:5:94:29 | ...::log | This operation writes $@ to a log file. | test_logging.rs:93:15:93:22 | password | password |
-| test_logging.rs:97:5:97:19 | ...::log | test_logging.rs:96:42:96:49 | password | test_logging.rs:97:5:97:19 | ...::log | This operation writes $@ to a log file. | test_logging.rs:96:42:96:49 | password | password |
-| test_logging.rs:100:5:100:19 | ...::log | test_logging.rs:99:38:99:45 | password | test_logging.rs:100:5:100:19 | ...::log | This operation writes $@ to a log file. | test_logging.rs:99:38:99:45 | password | password |
-| test_logging.rs:118:5:118:42 | ...::log | test_logging.rs:118:28:118:41 | get_password(...) | test_logging.rs:118:5:118:42 | ...::log | This operation writes $@ to a log file. | test_logging.rs:118:28:118:41 | get_password(...) | get_password(...) |
-| test_logging.rs:131:5:131:32 | ...::log | test_logging.rs:129:25:129:32 | password | test_logging.rs:131:5:131:32 | ...::log | This operation writes $@ to a log file. | test_logging.rs:129:25:129:32 | password | password |
-| test_logging.rs:141:5:141:38 | ...::log | test_logging.rs:141:27:141:37 | s1.password | test_logging.rs:141:5:141:38 | ...::log | This operation writes $@ to a log file. | test_logging.rs:141:27:141:37 | s1.password | s1.password |
-| test_logging.rs:151:5:151:38 | ...::log | test_logging.rs:151:27:151:37 | s2.password | test_logging.rs:151:5:151:38 | ...::log | This operation writes $@ to a log file. | test_logging.rs:151:27:151:37 | s2.password | s2.password |
+| test_logging.rs:42:5:42:10 | ...::log | test_logging.rs:42:28:42:35 | password | test_logging.rs:42:5:42:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:42:28:42:35 | password | password |
+| test_logging.rs:43:5:43:10 | ...::log | test_logging.rs:43:28:43:35 | password | test_logging.rs:43:5:43:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:43:28:43:35 | password | password |
+| test_logging.rs:44:5:44:9 | ...::log | test_logging.rs:44:27:44:34 | password | test_logging.rs:44:5:44:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:44:27:44:34 | password | password |
+| test_logging.rs:45:5:45:10 | ...::log | test_logging.rs:45:28:45:35 | password | test_logging.rs:45:5:45:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:45:28:45:35 | password | password |
+| test_logging.rs:46:5:46:9 | ...::log | test_logging.rs:46:27:46:34 | password | test_logging.rs:46:5:46:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:46:27:46:34 | password | password |
+| test_logging.rs:47:5:47:8 | ...::log | test_logging.rs:47:40:47:47 | password | test_logging.rs:47:5:47:8 | ...::log | This operation writes $@ to a log file. | test_logging.rs:47:40:47:47 | password | password |
+| test_logging.rs:52:5:52:10 | ...::log | test_logging.rs:52:28:52:35 | password | test_logging.rs:52:5:52:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:52:28:52:35 | password | password |
+| test_logging.rs:54:5:54:10 | ...::log | test_logging.rs:54:41:54:48 | password | test_logging.rs:54:5:54:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:54:41:54:48 | password | password |
+| test_logging.rs:56:5:56:10 | ...::log | test_logging.rs:56:39:56:46 | password | test_logging.rs:56:5:56:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:56:39:56:46 | password | password |
+| test_logging.rs:57:5:57:10 | ...::log | test_logging.rs:57:24:57:31 | password | test_logging.rs:57:5:57:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:57:24:57:31 | password | password |
+| test_logging.rs:58:5:58:10 | ...::log | test_logging.rs:58:24:58:31 | password | test_logging.rs:58:5:58:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:58:24:58:31 | password | password |
+| test_logging.rs:60:5:60:10 | ...::log | test_logging.rs:60:46:60:53 | password | test_logging.rs:60:5:60:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:60:46:60:53 | password | password |
+| test_logging.rs:61:5:61:10 | ...::log | test_logging.rs:61:21:61:28 | password | test_logging.rs:61:5:61:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:61:21:61:28 | password | password |
+| test_logging.rs:65:5:65:8 | ...::log | test_logging.rs:65:40:65:47 | password | test_logging.rs:65:5:65:8 | ...::log | This operation writes $@ to a log file. | test_logging.rs:65:40:65:47 | password | password |
+| test_logging.rs:67:5:67:8 | ...::log | test_logging.rs:67:58:67:65 | password | test_logging.rs:67:5:67:8 | ...::log | This operation writes $@ to a log file. | test_logging.rs:67:58:67:65 | password | password |
+| test_logging.rs:68:5:68:8 | ...::log | test_logging.rs:68:19:68:26 | password | test_logging.rs:68:5:68:8 | ...::log | This operation writes $@ to a log file. | test_logging.rs:68:19:68:26 | password | password |
+| test_logging.rs:72:5:72:10 | ...::log | test_logging.rs:72:39:72:46 | password | test_logging.rs:72:5:72:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:72:39:72:46 | password | password |
+| test_logging.rs:74:5:74:10 | ...::log | test_logging.rs:74:57:74:64 | password | test_logging.rs:74:5:74:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:74:57:74:64 | password | password |
+| test_logging.rs:75:5:75:10 | ...::log | test_logging.rs:75:21:75:28 | password | test_logging.rs:75:5:75:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:75:21:75:28 | password | password |
+| test_logging.rs:76:5:76:10 | ...::log | test_logging.rs:76:39:76:46 | password | test_logging.rs:76:5:76:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:76:39:76:46 | password | password |
+| test_logging.rs:82:5:82:10 | ...::log | test_logging.rs:82:36:82:43 | password | test_logging.rs:82:5:82:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:82:36:82:43 | password | password |
+| test_logging.rs:84:5:84:10 | ...::log | test_logging.rs:84:54:84:61 | password | test_logging.rs:84:5:84:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:84:54:84:61 | password | password |
+| test_logging.rs:85:5:85:10 | ...::log | test_logging.rs:85:21:85:28 | password | test_logging.rs:85:5:85:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:85:21:85:28 | password | password |
+| test_logging.rs:86:5:86:10 | ...::log | test_logging.rs:86:36:86:43 | password | test_logging.rs:86:5:86:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:86:36:86:43 | password | password |
+| test_logging.rs:94:5:94:9 | ...::log | test_logging.rs:93:15:93:22 | password | test_logging.rs:94:5:94:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:93:15:93:22 | password | password |
+| test_logging.rs:97:5:97:9 | ...::log | test_logging.rs:96:42:96:49 | password | test_logging.rs:97:5:97:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:96:42:96:49 | password | password |
+| test_logging.rs:100:5:100:9 | ...::log | test_logging.rs:99:38:99:45 | password | test_logging.rs:100:5:100:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:99:38:99:45 | password | password |
+| test_logging.rs:118:5:118:10 | ...::log | test_logging.rs:118:28:118:41 | get_password(...) | test_logging.rs:118:5:118:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:118:28:118:41 | get_password(...) | get_password(...) |
+| test_logging.rs:131:5:131:10 | ...::log | test_logging.rs:129:25:129:32 | password | test_logging.rs:131:5:131:10 | ...::log | This operation writes $@ to a log file. | test_logging.rs:129:25:129:32 | password | password |
+| test_logging.rs:141:5:141:9 | ...::log | test_logging.rs:141:27:141:37 | s1.password | test_logging.rs:141:5:141:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:141:27:141:37 | s1.password | s1.password |
+| test_logging.rs:151:5:151:9 | ...::log | test_logging.rs:151:27:151:37 | s2.password | test_logging.rs:151:5:151:9 | ...::log | This operation writes $@ to a log file. | test_logging.rs:151:27:151:37 | s2.password | s2.password |
| test_logging.rs:176:22:176:31 | log_expect | test_logging.rs:176:70:176:78 | password2 | test_logging.rs:176:22:176:31 | log_expect | This operation writes $@ to a log file. | test_logging.rs:176:70:176:78 | password2 | password2 |
| test_logging.rs:180:24:180:33 | log_expect | test_logging.rs:180:72:180:80 | password2 | test_logging.rs:180:24:180:33 | log_expect | This operation writes $@ to a log file. | test_logging.rs:180:72:180:80 | password2 | password2 |
| test_logging.rs:184:25:184:34 | log_expect | test_logging.rs:183:51:183:59 | password2 | test_logging.rs:184:25:184:34 | log_expect | This operation writes $@ to a log file. | test_logging.rs:183:51:183:59 | password2 | password2 |
| test_logging.rs:188:25:188:34 | log_unwrap | test_logging.rs:187:51:187:59 | password2 | test_logging.rs:188:25:188:34 | log_unwrap | This operation writes $@ to a log file. | test_logging.rs:187:51:187:59 | password2 | password2 |
-| test_logging.rs:192:5:192:38 | ...::_print | test_logging.rs:192:30:192:37 | password | test_logging.rs:192:5:192:38 | ...::_print | This operation writes $@ to a log file. | test_logging.rs:192:30:192:37 | password | password |
-| test_logging.rs:193:5:193:38 | ...::_print | test_logging.rs:193:30:193:37 | password | test_logging.rs:193:5:193:38 | ...::_print | This operation writes $@ to a log file. | test_logging.rs:193:30:193:37 | password | password |
-| test_logging.rs:194:5:194:39 | ...::_eprint | test_logging.rs:194:31:194:38 | password | test_logging.rs:194:5:194:39 | ...::_eprint | This operation writes $@ to a log file. | test_logging.rs:194:31:194:38 | password | password |
-| test_logging.rs:195:5:195:39 | ...::_eprint | test_logging.rs:195:31:195:38 | password | test_logging.rs:195:5:195:39 | ...::_eprint | This operation writes $@ to a log file. | test_logging.rs:195:31:195:38 | password | password |
-| test_logging.rs:199:13:199:44 | ...::panic_fmt | test_logging.rs:199:36:199:43 | password | test_logging.rs:199:13:199:44 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:199:36:199:43 | password | password |
-| test_logging.rs:202:13:202:43 | ...::panic_fmt | test_logging.rs:202:35:202:42 | password | test_logging.rs:202:13:202:43 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:202:35:202:42 | password | password |
-| test_logging.rs:205:13:205:52 | ...::panic_fmt | test_logging.rs:205:44:205:51 | password | test_logging.rs:205:13:205:52 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:205:44:205:51 | password | password |
-| test_logging.rs:208:13:208:50 | ...::panic_fmt | test_logging.rs:208:42:208:49 | password | test_logging.rs:208:13:208:50 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:208:42:208:49 | password | password |
-| test_logging.rs:211:13:211:52 | ...::panic_fmt | test_logging.rs:211:44:211:51 | password | test_logging.rs:211:13:211:52 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:211:44:211:51 | password | password |
-| test_logging.rs:214:13:214:54 | ...::assert_failed | test_logging.rs:214:46:214:53 | password | test_logging.rs:214:13:214:54 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:214:46:214:53 | password | password |
-| test_logging.rs:217:13:217:54 | ...::assert_failed | test_logging.rs:217:46:217:53 | password | test_logging.rs:217:13:217:54 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:217:46:217:53 | password | password |
-| test_logging.rs:220:13:220:58 | ...::panic_fmt | test_logging.rs:220:50:220:57 | password | test_logging.rs:220:13:220:58 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:220:50:220:57 | password | password |
-| test_logging.rs:223:13:223:60 | ...::assert_failed | test_logging.rs:223:52:223:59 | password | test_logging.rs:223:13:223:60 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:223:52:223:59 | password | password |
-| test_logging.rs:226:13:226:60 | ...::assert_failed | test_logging.rs:226:52:226:59 | password | test_logging.rs:226:13:226:60 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:226:52:226:59 | password | password |
+| test_logging.rs:192:5:192:10 | ...::_print | test_logging.rs:192:30:192:37 | password | test_logging.rs:192:5:192:10 | ...::_print | This operation writes $@ to a log file. | test_logging.rs:192:30:192:37 | password | password |
+| test_logging.rs:193:5:193:12 | ...::_print | test_logging.rs:193:30:193:37 | password | test_logging.rs:193:5:193:12 | ...::_print | This operation writes $@ to a log file. | test_logging.rs:193:30:193:37 | password | password |
+| test_logging.rs:194:5:194:11 | ...::_eprint | test_logging.rs:194:31:194:38 | password | test_logging.rs:194:5:194:11 | ...::_eprint | This operation writes $@ to a log file. | test_logging.rs:194:31:194:38 | password | password |
+| test_logging.rs:195:5:195:13 | ...::_eprint | test_logging.rs:195:31:195:38 | password | test_logging.rs:195:5:195:13 | ...::_eprint | This operation writes $@ to a log file. | test_logging.rs:195:31:195:38 | password | password |
+| test_logging.rs:199:13:199:18 | ...::panic_fmt | test_logging.rs:199:36:199:43 | password | test_logging.rs:199:13:199:18 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:199:36:199:43 | password | password |
+| test_logging.rs:202:13:202:17 | ...::panic_fmt | test_logging.rs:202:35:202:42 | password | test_logging.rs:202:13:202:17 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:202:35:202:42 | password | password |
+| test_logging.rs:205:13:205:26 | ...::panic_fmt | test_logging.rs:205:44:205:51 | password | test_logging.rs:205:13:205:26 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:205:44:205:51 | password | password |
+| test_logging.rs:208:13:208:24 | ...::panic_fmt | test_logging.rs:208:42:208:49 | password | test_logging.rs:208:13:208:24 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:208:42:208:49 | password | password |
+| test_logging.rs:211:13:211:19 | ...::panic_fmt | test_logging.rs:211:44:211:51 | password | test_logging.rs:211:13:211:19 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:211:44:211:51 | password | password |
+| test_logging.rs:214:13:214:22 | ...::assert_failed | test_logging.rs:214:46:214:53 | password | test_logging.rs:214:13:214:22 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:214:46:214:53 | password | password |
+| test_logging.rs:217:13:217:22 | ...::assert_failed | test_logging.rs:217:46:217:53 | password | test_logging.rs:217:13:217:22 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:217:46:217:53 | password | password |
+| test_logging.rs:220:13:220:25 | ...::panic_fmt | test_logging.rs:220:50:220:57 | password | test_logging.rs:220:13:220:25 | ...::panic_fmt | This operation writes $@ to a log file. | test_logging.rs:220:50:220:57 | password | password |
+| test_logging.rs:223:13:223:28 | ...::assert_failed | test_logging.rs:223:52:223:59 | password | test_logging.rs:223:13:223:28 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:223:52:223:59 | password | password |
+| test_logging.rs:226:13:226:28 | ...::assert_failed | test_logging.rs:226:52:226:59 | password | test_logging.rs:226:13:226:28 | ...::assert_failed | This operation writes $@ to a log file. | test_logging.rs:226:52:226:59 | password | password |
| test_logging.rs:229:23:229:28 | expect | test_logging.rs:229:54:229:61 | password | test_logging.rs:229:23:229:28 | expect | This operation writes $@ to a log file. | test_logging.rs:229:54:229:61 | password | password |
| test_logging.rs:229:23:229:28 | expect | test_logging.rs:229:54:229:61 | password | test_logging.rs:229:23:229:28 | expect | This operation writes $@ to a log file. | test_logging.rs:229:54:229:61 | password | password |
| test_logging.rs:242:10:242:14 | write | test_logging.rs:242:42:242:49 | password | test_logging.rs:242:10:242:14 | write | This operation writes $@ to a log file. | test_logging.rs:242:42:242:49 | password | password |
@@ -55,126 +55,126 @@
| test_logging.rs:248:9:248:13 | write | test_logging.rs:248:41:248:48 | password | test_logging.rs:248:9:248:13 | write | This operation writes $@ to a log file. | test_logging.rs:248:41:248:48 | password | password |
| test_logging.rs:251:9:251:13 | write | test_logging.rs:251:41:251:48 | password | test_logging.rs:251:9:251:13 | write | This operation writes $@ to a log file. | test_logging.rs:251:41:251:48 | password | password |
edges
-| test_logging.rs:42:12:42:35 | MacroExpr | test_logging.rs:42:5:42:36 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:42:12:42:35 | MacroExpr | test_logging.rs:42:5:42:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:42:28:42:35 | password | test_logging.rs:42:12:42:35 | MacroExpr | provenance | |
-| test_logging.rs:43:12:43:35 | MacroExpr | test_logging.rs:43:5:43:36 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:43:12:43:35 | MacroExpr | test_logging.rs:43:5:43:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:43:28:43:35 | password | test_logging.rs:43:12:43:35 | MacroExpr | provenance | |
-| test_logging.rs:44:11:44:34 | MacroExpr | test_logging.rs:44:5:44:35 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:44:11:44:34 | MacroExpr | test_logging.rs:44:5:44:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:44:27:44:34 | password | test_logging.rs:44:11:44:34 | MacroExpr | provenance | |
-| test_logging.rs:45:12:45:35 | MacroExpr | test_logging.rs:45:5:45:36 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:45:12:45:35 | MacroExpr | test_logging.rs:45:5:45:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:45:28:45:35 | password | test_logging.rs:45:12:45:35 | MacroExpr | provenance | |
-| test_logging.rs:46:11:46:34 | MacroExpr | test_logging.rs:46:5:46:35 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:46:11:46:34 | MacroExpr | test_logging.rs:46:5:46:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:46:27:46:34 | password | test_logging.rs:46:11:46:34 | MacroExpr | provenance | |
-| test_logging.rs:47:24:47:47 | MacroExpr | test_logging.rs:47:5:47:48 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:47:24:47:47 | MacroExpr | test_logging.rs:47:5:47:8 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:47:40:47:47 | password | test_logging.rs:47:24:47:47 | MacroExpr | provenance | |
-| test_logging.rs:52:12:52:35 | MacroExpr | test_logging.rs:52:5:52:36 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:52:12:52:35 | MacroExpr | test_logging.rs:52:5:52:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:52:28:52:35 | password | test_logging.rs:52:12:52:35 | MacroExpr | provenance | |
-| test_logging.rs:54:12:54:48 | MacroExpr | test_logging.rs:54:5:54:49 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:54:12:54:48 | MacroExpr | test_logging.rs:54:5:54:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:54:41:54:48 | password | test_logging.rs:54:12:54:48 | MacroExpr | provenance | |
-| test_logging.rs:56:12:56:46 | MacroExpr | test_logging.rs:56:5:56:47 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:56:12:56:46 | MacroExpr | test_logging.rs:56:5:56:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:56:39:56:46 | password | test_logging.rs:56:12:56:46 | MacroExpr | provenance | |
-| test_logging.rs:57:12:57:33 | MacroExpr | test_logging.rs:57:5:57:34 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:57:12:57:33 | MacroExpr | test_logging.rs:57:5:57:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:57:24:57:31 | password | test_logging.rs:57:12:57:33 | MacroExpr | provenance | |
-| test_logging.rs:58:12:58:35 | MacroExpr | test_logging.rs:58:5:58:36 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:58:12:58:35 | MacroExpr | test_logging.rs:58:5:58:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:58:24:58:31 | password | test_logging.rs:58:12:58:35 | MacroExpr | provenance | |
-| test_logging.rs:60:30:60:53 | MacroExpr | test_logging.rs:60:5:60:54 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:60:30:60:53 | MacroExpr | test_logging.rs:60:5:60:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:60:46:60:53 | password | test_logging.rs:60:30:60:53 | MacroExpr | provenance | |
-| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:61:5:61:55 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:61:5:61:55 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0] | test_logging.rs:61:5:61:55 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:61:5:61:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:61:5:61:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0] | test_logging.rs:61:5:61:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
| test_logging.rs:61:20:61:28 | &password | test_logging.rs:61:20:61:28 | TupleExpr [tuple.0] | provenance | |
| test_logging.rs:61:20:61:28 | &password [&ref] | test_logging.rs:61:20:61:28 | TupleExpr [tuple.0, &ref] | provenance | |
| test_logging.rs:61:20:61:28 | TupleExpr [tuple.0, &ref] | test_logging.rs:61:20:61:28 | &... [&ref, tuple.0, &ref] | provenance | |
| test_logging.rs:61:20:61:28 | TupleExpr [tuple.0] | test_logging.rs:61:20:61:28 | &... [&ref, tuple.0] | provenance | |
| test_logging.rs:61:21:61:28 | password | test_logging.rs:61:20:61:28 | &password | provenance | Config |
| test_logging.rs:61:21:61:28 | password | test_logging.rs:61:20:61:28 | &password [&ref] | provenance | |
-| test_logging.rs:65:24:65:47 | MacroExpr | test_logging.rs:65:5:65:48 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:65:24:65:47 | MacroExpr | test_logging.rs:65:5:65:8 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:65:40:65:47 | password | test_logging.rs:65:24:65:47 | MacroExpr | provenance | |
-| test_logging.rs:67:42:67:65 | MacroExpr | test_logging.rs:67:5:67:66 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:67:42:67:65 | MacroExpr | test_logging.rs:67:5:67:8 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:67:58:67:65 | password | test_logging.rs:67:42:67:65 | MacroExpr | provenance | |
-| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0, &ref] | test_logging.rs:68:5:68:67 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0, &ref] | test_logging.rs:68:5:68:67 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0] | test_logging.rs:68:5:68:67 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0, &ref] | test_logging.rs:68:5:68:8 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0, &ref] | test_logging.rs:68:5:68:8 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0] | test_logging.rs:68:5:68:8 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
| test_logging.rs:68:18:68:26 | &password | test_logging.rs:68:18:68:26 | TupleExpr [tuple.0] | provenance | |
| test_logging.rs:68:18:68:26 | &password [&ref] | test_logging.rs:68:18:68:26 | TupleExpr [tuple.0, &ref] | provenance | |
| test_logging.rs:68:18:68:26 | TupleExpr [tuple.0, &ref] | test_logging.rs:68:18:68:26 | &... [&ref, tuple.0, &ref] | provenance | |
| test_logging.rs:68:18:68:26 | TupleExpr [tuple.0] | test_logging.rs:68:18:68:26 | &... [&ref, tuple.0] | provenance | |
| test_logging.rs:68:19:68:26 | password | test_logging.rs:68:18:68:26 | &password | provenance | Config |
| test_logging.rs:68:19:68:26 | password | test_logging.rs:68:18:68:26 | &password [&ref] | provenance | |
-| test_logging.rs:72:23:72:46 | MacroExpr | test_logging.rs:72:5:72:47 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:72:23:72:46 | MacroExpr | test_logging.rs:72:5:72:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:72:39:72:46 | password | test_logging.rs:72:23:72:46 | MacroExpr | provenance | |
-| test_logging.rs:74:41:74:64 | MacroExpr | test_logging.rs:74:5:74:65 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:74:41:74:64 | MacroExpr | test_logging.rs:74:5:74:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:74:57:74:64 | password | test_logging.rs:74:41:74:64 | MacroExpr | provenance | |
-| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:75:5:75:51 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:75:5:75:51 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0] | test_logging.rs:75:5:75:51 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:75:5:75:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:75:5:75:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0] | test_logging.rs:75:5:75:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
| test_logging.rs:75:20:75:28 | &password | test_logging.rs:75:20:75:28 | TupleExpr [tuple.0] | provenance | |
| test_logging.rs:75:20:75:28 | &password [&ref] | test_logging.rs:75:20:75:28 | TupleExpr [tuple.0, &ref] | provenance | |
| test_logging.rs:75:20:75:28 | TupleExpr [tuple.0, &ref] | test_logging.rs:75:20:75:28 | &... [&ref, tuple.0, &ref] | provenance | |
| test_logging.rs:75:20:75:28 | TupleExpr [tuple.0] | test_logging.rs:75:20:75:28 | &... [&ref, tuple.0] | provenance | |
| test_logging.rs:75:21:75:28 | password | test_logging.rs:75:20:75:28 | &password | provenance | Config |
| test_logging.rs:75:21:75:28 | password | test_logging.rs:75:20:75:28 | &password [&ref] | provenance | |
-| test_logging.rs:76:23:76:46 | MacroExpr | test_logging.rs:76:5:76:47 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:76:23:76:46 | MacroExpr | test_logging.rs:76:5:76:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:76:39:76:46 | password | test_logging.rs:76:23:76:46 | MacroExpr | provenance | |
-| test_logging.rs:82:20:82:43 | MacroExpr | test_logging.rs:82:5:82:44 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:82:20:82:43 | MacroExpr | test_logging.rs:82:5:82:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:82:36:82:43 | password | test_logging.rs:82:20:82:43 | MacroExpr | provenance | |
-| test_logging.rs:84:38:84:61 | MacroExpr | test_logging.rs:84:5:84:62 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:84:38:84:61 | MacroExpr | test_logging.rs:84:5:84:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:84:54:84:61 | password | test_logging.rs:84:38:84:61 | MacroExpr | provenance | |
-| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:85:5:85:48 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:85:5:85:48 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
-| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0] | test_logging.rs:85:5:85:48 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:85:5:85:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0, &ref] | test_logging.rs:85:5:85:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 Sink:MaD:13 |
+| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0] | test_logging.rs:85:5:85:10 | ...::log | provenance | MaD:13 Sink:MaD:13 Sink:MaD:13 |
| test_logging.rs:85:20:85:28 | &password | test_logging.rs:85:20:85:28 | TupleExpr [tuple.0] | provenance | |
| test_logging.rs:85:20:85:28 | &password [&ref] | test_logging.rs:85:20:85:28 | TupleExpr [tuple.0, &ref] | provenance | |
| test_logging.rs:85:20:85:28 | TupleExpr [tuple.0, &ref] | test_logging.rs:85:20:85:28 | &... [&ref, tuple.0, &ref] | provenance | |
| test_logging.rs:85:20:85:28 | TupleExpr [tuple.0] | test_logging.rs:85:20:85:28 | &... [&ref, tuple.0] | provenance | |
| test_logging.rs:85:21:85:28 | password | test_logging.rs:85:20:85:28 | &password | provenance | Config |
| test_logging.rs:85:21:85:28 | password | test_logging.rs:85:20:85:28 | &password [&ref] | provenance | |
-| test_logging.rs:86:20:86:43 | MacroExpr | test_logging.rs:86:5:86:44 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:86:20:86:43 | MacroExpr | test_logging.rs:86:5:86:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:86:36:86:43 | password | test_logging.rs:86:20:86:43 | MacroExpr | provenance | |
| test_logging.rs:93:9:93:10 | m1 | test_logging.rs:94:11:94:28 | MacroExpr | provenance | |
| test_logging.rs:93:14:93:22 | &password | test_logging.rs:93:9:93:10 | m1 | provenance | |
| test_logging.rs:93:15:93:22 | password | test_logging.rs:93:14:93:22 | &password | provenance | Config |
-| test_logging.rs:94:11:94:28 | MacroExpr | test_logging.rs:94:5:94:29 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:94:11:94:28 | MacroExpr | test_logging.rs:94:5:94:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:96:9:96:10 | m2 | test_logging.rs:97:11:97:18 | MacroExpr | provenance | |
| test_logging.rs:96:41:96:49 | &password | test_logging.rs:96:9:96:10 | m2 | provenance | |
| test_logging.rs:96:42:96:49 | password | test_logging.rs:96:41:96:49 | &password | provenance | Config |
-| test_logging.rs:97:11:97:18 | MacroExpr | test_logging.rs:97:5:97:19 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:97:11:97:18 | MacroExpr | test_logging.rs:97:5:97:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:99:9:99:10 | m3 | test_logging.rs:100:11:100:18 | MacroExpr | provenance | |
-| test_logging.rs:99:14:99:46 | res | test_logging.rs:99:22:99:45 | { ... } | provenance | |
-| test_logging.rs:99:22:99:45 | ...::format(...) | test_logging.rs:99:14:99:46 | res | provenance | |
+| test_logging.rs:99:14:99:20 | res | test_logging.rs:99:22:99:45 | { ... } | provenance | |
+| test_logging.rs:99:22:99:45 | ...::format(...) | test_logging.rs:99:14:99:20 | res | provenance | |
| test_logging.rs:99:22:99:45 | ...::must_use(...) | test_logging.rs:99:9:99:10 | m3 | provenance | |
| test_logging.rs:99:22:99:45 | MacroExpr | test_logging.rs:99:22:99:45 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:99:22:99:45 | { ... } | test_logging.rs:99:22:99:45 | ...::must_use(...) | provenance | MaD:22 |
| test_logging.rs:99:38:99:45 | password | test_logging.rs:99:22:99:45 | MacroExpr | provenance | |
-| test_logging.rs:100:11:100:18 | MacroExpr | test_logging.rs:100:5:100:19 | ...::log | provenance | MaD:12 Sink:MaD:12 |
-| test_logging.rs:118:12:118:41 | MacroExpr | test_logging.rs:118:5:118:42 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:100:11:100:18 | MacroExpr | test_logging.rs:100:5:100:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:118:12:118:41 | MacroExpr | test_logging.rs:118:5:118:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:118:28:118:41 | get_password(...) | test_logging.rs:118:12:118:41 | MacroExpr | provenance | |
| test_logging.rs:129:9:129:10 | t1 [tuple.1] | test_logging.rs:131:28:131:29 | t1 [tuple.1] | provenance | |
| test_logging.rs:129:14:129:33 | TupleExpr [tuple.1] | test_logging.rs:129:9:129:10 | t1 [tuple.1] | provenance | |
| test_logging.rs:129:25:129:32 | password | test_logging.rs:129:14:129:33 | TupleExpr [tuple.1] | provenance | |
-| test_logging.rs:131:12:131:31 | MacroExpr | test_logging.rs:131:5:131:32 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:131:12:131:31 | MacroExpr | test_logging.rs:131:5:131:10 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:131:28:131:29 | t1 [tuple.1] | test_logging.rs:131:28:131:31 | t1.1 | provenance | |
| test_logging.rs:131:28:131:31 | t1.1 | test_logging.rs:131:12:131:31 | MacroExpr | provenance | |
-| test_logging.rs:141:11:141:37 | MacroExpr | test_logging.rs:141:5:141:38 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:141:11:141:37 | MacroExpr | test_logging.rs:141:5:141:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:141:27:141:37 | s1.password | test_logging.rs:141:11:141:37 | MacroExpr | provenance | |
-| test_logging.rs:151:11:151:37 | MacroExpr | test_logging.rs:151:5:151:38 | ...::log | provenance | MaD:12 Sink:MaD:12 |
+| test_logging.rs:151:11:151:37 | MacroExpr | test_logging.rs:151:5:151:9 | ...::log | provenance | MaD:12 Sink:MaD:12 |
| test_logging.rs:151:27:151:37 | s2.password | test_logging.rs:151:11:151:37 | MacroExpr | provenance | |
| test_logging.rs:176:33:176:79 | &... | test_logging.rs:176:22:176:31 | log_expect | provenance | MaD:1 Sink:MaD:1 |
| test_logging.rs:176:33:176:79 | &... [&ref] | test_logging.rs:176:22:176:31 | log_expect | provenance | MaD:1 Sink:MaD:1 |
+| test_logging.rs:176:34:176:40 | res | test_logging.rs:176:42:176:78 | { ... } | provenance | |
| test_logging.rs:176:34:176:79 | MacroExpr | test_logging.rs:176:33:176:79 | &... | provenance | Config |
| test_logging.rs:176:34:176:79 | MacroExpr | test_logging.rs:176:33:176:79 | &... [&ref] | provenance | |
-| test_logging.rs:176:34:176:79 | res | test_logging.rs:176:42:176:78 | { ... } | provenance | |
-| test_logging.rs:176:42:176:78 | ...::format(...) | test_logging.rs:176:34:176:79 | res | provenance | |
+| test_logging.rs:176:42:176:78 | ...::format(...) | test_logging.rs:176:34:176:40 | res | provenance | |
| test_logging.rs:176:42:176:78 | ...::must_use(...) | test_logging.rs:176:34:176:79 | MacroExpr | provenance | |
| test_logging.rs:176:42:176:78 | MacroExpr | test_logging.rs:176:42:176:78 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:176:42:176:78 | { ... } | test_logging.rs:176:42:176:78 | ...::must_use(...) | provenance | MaD:22 |
| test_logging.rs:176:70:176:78 | password2 | test_logging.rs:176:42:176:78 | MacroExpr | provenance | |
| test_logging.rs:180:35:180:81 | &... | test_logging.rs:180:24:180:33 | log_expect | provenance | MaD:3 Sink:MaD:3 |
| test_logging.rs:180:35:180:81 | &... [&ref] | test_logging.rs:180:24:180:33 | log_expect | provenance | MaD:3 Sink:MaD:3 |
+| test_logging.rs:180:36:180:42 | res | test_logging.rs:180:44:180:80 | { ... } | provenance | |
| test_logging.rs:180:36:180:81 | MacroExpr | test_logging.rs:180:35:180:81 | &... | provenance | Config |
| test_logging.rs:180:36:180:81 | MacroExpr | test_logging.rs:180:35:180:81 | &... [&ref] | provenance | |
-| test_logging.rs:180:36:180:81 | res | test_logging.rs:180:44:180:80 | { ... } | provenance | |
-| test_logging.rs:180:44:180:80 | ...::format(...) | test_logging.rs:180:36:180:81 | res | provenance | |
+| test_logging.rs:180:44:180:80 | ...::format(...) | test_logging.rs:180:36:180:42 | res | provenance | |
| test_logging.rs:180:44:180:80 | ...::must_use(...) | test_logging.rs:180:36:180:81 | MacroExpr | provenance | |
| test_logging.rs:180:44:180:80 | MacroExpr | test_logging.rs:180:44:180:80 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:180:44:180:80 | { ... } | test_logging.rs:180:44:180:80 | ...::must_use(...) | provenance | MaD:22 |
@@ -188,55 +188,55 @@ edges
| test_logging.rs:187:47:187:60 | Err(...) [Err] | test_logging.rs:187:9:187:19 | err_result3 [Err] | provenance | |
| test_logging.rs:187:51:187:59 | password2 | test_logging.rs:187:47:187:60 | Err(...) [Err] | provenance | |
| test_logging.rs:188:13:188:23 | err_result3 [Err] | test_logging.rs:188:25:188:34 | log_unwrap | provenance | MaD:5 Sink:MaD:5 |
-| test_logging.rs:192:12:192:37 | MacroExpr | test_logging.rs:192:5:192:38 | ...::_print | provenance | MaD:15 Sink:MaD:15 |
+| test_logging.rs:192:12:192:37 | MacroExpr | test_logging.rs:192:5:192:10 | ...::_print | provenance | MaD:15 Sink:MaD:15 |
| test_logging.rs:192:30:192:37 | password | test_logging.rs:192:12:192:37 | MacroExpr | provenance | |
-| test_logging.rs:193:14:193:37 | MacroExpr | test_logging.rs:193:5:193:38 | ...::_print | provenance | MaD:15 Sink:MaD:15 |
+| test_logging.rs:193:14:193:37 | MacroExpr | test_logging.rs:193:5:193:12 | ...::_print | provenance | MaD:15 Sink:MaD:15 |
| test_logging.rs:193:30:193:37 | password | test_logging.rs:193:14:193:37 | MacroExpr | provenance | |
-| test_logging.rs:194:13:194:38 | MacroExpr | test_logging.rs:194:5:194:39 | ...::_eprint | provenance | MaD:14 Sink:MaD:14 |
+| test_logging.rs:194:13:194:38 | MacroExpr | test_logging.rs:194:5:194:11 | ...::_eprint | provenance | MaD:14 Sink:MaD:14 |
| test_logging.rs:194:31:194:38 | password | test_logging.rs:194:13:194:38 | MacroExpr | provenance | |
-| test_logging.rs:195:15:195:38 | MacroExpr | test_logging.rs:195:5:195:39 | ...::_eprint | provenance | MaD:14 Sink:MaD:14 |
+| test_logging.rs:195:15:195:38 | MacroExpr | test_logging.rs:195:5:195:13 | ...::_eprint | provenance | MaD:14 Sink:MaD:14 |
| test_logging.rs:195:31:195:38 | password | test_logging.rs:195:15:195:38 | MacroExpr | provenance | |
-| test_logging.rs:199:20:199:43 | MacroExpr | test_logging.rs:199:13:199:44 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
+| test_logging.rs:199:20:199:43 | MacroExpr | test_logging.rs:199:13:199:18 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
| test_logging.rs:199:36:199:43 | password | test_logging.rs:199:20:199:43 | MacroExpr | provenance | |
-| test_logging.rs:202:19:202:42 | MacroExpr | test_logging.rs:202:13:202:43 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
+| test_logging.rs:202:19:202:42 | MacroExpr | test_logging.rs:202:13:202:17 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
| test_logging.rs:202:35:202:42 | password | test_logging.rs:202:19:202:42 | MacroExpr | provenance | |
-| test_logging.rs:205:28:205:51 | MacroExpr | test_logging.rs:205:13:205:52 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
+| test_logging.rs:205:28:205:51 | MacroExpr | test_logging.rs:205:13:205:26 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
| test_logging.rs:205:44:205:51 | password | test_logging.rs:205:28:205:51 | MacroExpr | provenance | |
-| test_logging.rs:208:26:208:49 | MacroExpr | test_logging.rs:208:13:208:50 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
+| test_logging.rs:208:26:208:49 | MacroExpr | test_logging.rs:208:13:208:24 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
| test_logging.rs:208:42:208:49 | password | test_logging.rs:208:26:208:49 | MacroExpr | provenance | |
-| test_logging.rs:211:28:211:51 | MacroExpr | test_logging.rs:211:13:211:52 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
+| test_logging.rs:211:28:211:51 | MacroExpr | test_logging.rs:211:13:211:19 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
| test_logging.rs:211:44:211:51 | password | test_logging.rs:211:28:211:51 | MacroExpr | provenance | |
-| test_logging.rs:214:13:214:54 | ...::assert_failed [Some] | test_logging.rs:214:13:214:54 | ...::assert_failed | provenance | Sink:MaD:9 |
-| test_logging.rs:214:30:214:53 | ...::Some(...) [Some] | test_logging.rs:214:13:214:54 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
-| test_logging.rs:214:30:214:53 | ...::Some(...) [Some] | test_logging.rs:214:13:214:54 | ...::assert_failed [Some] | provenance | MaD:10 |
+| test_logging.rs:214:13:214:22 | ...::assert_failed [Some] | test_logging.rs:214:13:214:22 | ...::assert_failed | provenance | Sink:MaD:9 |
+| test_logging.rs:214:30:214:53 | ...::Some(...) [Some] | test_logging.rs:214:13:214:22 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
+| test_logging.rs:214:30:214:53 | ...::Some(...) [Some] | test_logging.rs:214:13:214:22 | ...::assert_failed [Some] | provenance | MaD:10 |
| test_logging.rs:214:30:214:53 | MacroExpr | test_logging.rs:214:30:214:53 | ...::Some(...) [Some] | provenance | |
| test_logging.rs:214:46:214:53 | password | test_logging.rs:214:30:214:53 | MacroExpr | provenance | |
-| test_logging.rs:217:13:217:54 | ...::assert_failed [Some] | test_logging.rs:217:13:217:54 | ...::assert_failed | provenance | Sink:MaD:9 |
-| test_logging.rs:217:30:217:53 | ...::Some(...) [Some] | test_logging.rs:217:13:217:54 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
-| test_logging.rs:217:30:217:53 | ...::Some(...) [Some] | test_logging.rs:217:13:217:54 | ...::assert_failed [Some] | provenance | MaD:10 |
+| test_logging.rs:217:13:217:22 | ...::assert_failed [Some] | test_logging.rs:217:13:217:22 | ...::assert_failed | provenance | Sink:MaD:9 |
+| test_logging.rs:217:30:217:53 | ...::Some(...) [Some] | test_logging.rs:217:13:217:22 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
+| test_logging.rs:217:30:217:53 | ...::Some(...) [Some] | test_logging.rs:217:13:217:22 | ...::assert_failed [Some] | provenance | MaD:10 |
| test_logging.rs:217:30:217:53 | MacroExpr | test_logging.rs:217:30:217:53 | ...::Some(...) [Some] | provenance | |
| test_logging.rs:217:46:217:53 | password | test_logging.rs:217:30:217:53 | MacroExpr | provenance | |
-| test_logging.rs:220:34:220:57 | MacroExpr | test_logging.rs:220:13:220:58 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
+| test_logging.rs:220:34:220:57 | MacroExpr | test_logging.rs:220:13:220:25 | ...::panic_fmt | provenance | MaD:11 Sink:MaD:11 |
| test_logging.rs:220:50:220:57 | password | test_logging.rs:220:34:220:57 | MacroExpr | provenance | |
-| test_logging.rs:223:13:223:60 | ...::assert_failed [Some] | test_logging.rs:223:13:223:60 | ...::assert_failed | provenance | Sink:MaD:9 |
-| test_logging.rs:223:36:223:59 | ...::Some(...) [Some] | test_logging.rs:223:13:223:60 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
-| test_logging.rs:223:36:223:59 | ...::Some(...) [Some] | test_logging.rs:223:13:223:60 | ...::assert_failed [Some] | provenance | MaD:10 |
+| test_logging.rs:223:13:223:28 | ...::assert_failed [Some] | test_logging.rs:223:13:223:28 | ...::assert_failed | provenance | Sink:MaD:9 |
+| test_logging.rs:223:36:223:59 | ...::Some(...) [Some] | test_logging.rs:223:13:223:28 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
+| test_logging.rs:223:36:223:59 | ...::Some(...) [Some] | test_logging.rs:223:13:223:28 | ...::assert_failed [Some] | provenance | MaD:10 |
| test_logging.rs:223:36:223:59 | MacroExpr | test_logging.rs:223:36:223:59 | ...::Some(...) [Some] | provenance | |
| test_logging.rs:223:52:223:59 | password | test_logging.rs:223:36:223:59 | MacroExpr | provenance | |
-| test_logging.rs:226:13:226:60 | ...::assert_failed [Some] | test_logging.rs:226:13:226:60 | ...::assert_failed | provenance | Sink:MaD:9 |
-| test_logging.rs:226:36:226:59 | ...::Some(...) [Some] | test_logging.rs:226:13:226:60 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
-| test_logging.rs:226:36:226:59 | ...::Some(...) [Some] | test_logging.rs:226:13:226:60 | ...::assert_failed [Some] | provenance | MaD:10 |
+| test_logging.rs:226:13:226:28 | ...::assert_failed [Some] | test_logging.rs:226:13:226:28 | ...::assert_failed | provenance | Sink:MaD:9 |
+| test_logging.rs:226:36:226:59 | ...::Some(...) [Some] | test_logging.rs:226:13:226:28 | ...::assert_failed | provenance | MaD:9 Sink:MaD:9 |
+| test_logging.rs:226:36:226:59 | ...::Some(...) [Some] | test_logging.rs:226:13:226:28 | ...::assert_failed [Some] | provenance | MaD:10 |
| test_logging.rs:226:36:226:59 | MacroExpr | test_logging.rs:226:36:226:59 | ...::Some(...) [Some] | provenance | |
| test_logging.rs:226:52:226:59 | password | test_logging.rs:226:36:226:59 | MacroExpr | provenance | |
+| test_logging.rs:229:30:229:36 | res | test_logging.rs:229:38:229:61 | { ... } | provenance | |
| test_logging.rs:229:30:229:62 | MacroExpr | test_logging.rs:229:30:229:71 | ... .as_str() [&ref] | provenance | MaD:20 |
| test_logging.rs:229:30:229:62 | MacroExpr | test_logging.rs:229:30:229:71 | ... .as_str() [&ref] | provenance | MaD:18 |
| test_logging.rs:229:30:229:62 | MacroExpr | test_logging.rs:229:30:229:71 | ... .as_str() [&ref] | provenance | MaD:20 |
-| test_logging.rs:229:30:229:62 | res | test_logging.rs:229:38:229:61 | { ... } | provenance | |
| test_logging.rs:229:30:229:71 | ... .as_str() | test_logging.rs:229:23:229:28 | expect | provenance | MaD:2 Sink:MaD:2 |
| test_logging.rs:229:30:229:71 | ... .as_str() | test_logging.rs:229:23:229:28 | expect | provenance | MaD:2 Sink:MaD:2 |
| test_logging.rs:229:30:229:71 | ... .as_str() [&ref] | test_logging.rs:229:23:229:28 | expect | provenance | MaD:2 Sink:MaD:2 |
| test_logging.rs:229:30:229:71 | ... .as_str() [&ref] | test_logging.rs:229:23:229:28 | expect | provenance | MaD:2 Sink:MaD:2 |
-| test_logging.rs:229:38:229:61 | ...::format(...) | test_logging.rs:229:30:229:62 | res | provenance | |
+| test_logging.rs:229:38:229:61 | ...::format(...) | test_logging.rs:229:30:229:36 | res | provenance | |
| test_logging.rs:229:38:229:61 | ...::must_use(...) | test_logging.rs:229:30:229:62 | MacroExpr | provenance | |
| test_logging.rs:229:38:229:61 | ...::must_use(...) | test_logging.rs:229:30:229:71 | ... .as_str() | provenance | MaD:20 |
| test_logging.rs:229:38:229:61 | ...::must_use(...) | test_logging.rs:229:30:229:71 | ... .as_str() | provenance | MaD:18 |
@@ -244,48 +244,48 @@ edges
| test_logging.rs:229:38:229:61 | MacroExpr | test_logging.rs:229:38:229:61 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:229:38:229:61 | { ... } | test_logging.rs:229:38:229:61 | ...::must_use(...) | provenance | MaD:22 |
| test_logging.rs:229:54:229:61 | password | test_logging.rs:229:38:229:61 | MacroExpr | provenance | |
+| test_logging.rs:242:16:242:22 | res | test_logging.rs:242:24:242:49 | { ... } | provenance | |
| test_logging.rs:242:16:242:50 | MacroExpr | test_logging.rs:242:16:242:61 | ... .as_bytes() [&ref] | provenance | MaD:19 |
| test_logging.rs:242:16:242:50 | MacroExpr | test_logging.rs:242:16:242:61 | ... .as_bytes() [&ref] | provenance | MaD:17 |
-| test_logging.rs:242:16:242:50 | res | test_logging.rs:242:24:242:49 | { ... } | provenance | |
| test_logging.rs:242:16:242:61 | ... .as_bytes() | test_logging.rs:242:10:242:14 | write | provenance | MaD:7 Sink:MaD:7 |
| test_logging.rs:242:16:242:61 | ... .as_bytes() [&ref] | test_logging.rs:242:10:242:14 | write | provenance | MaD:7 Sink:MaD:7 |
-| test_logging.rs:242:24:242:49 | ...::format(...) | test_logging.rs:242:16:242:50 | res | provenance | |
+| test_logging.rs:242:24:242:49 | ...::format(...) | test_logging.rs:242:16:242:22 | res | provenance | |
| test_logging.rs:242:24:242:49 | ...::must_use(...) | test_logging.rs:242:16:242:50 | MacroExpr | provenance | |
| test_logging.rs:242:24:242:49 | ...::must_use(...) | test_logging.rs:242:16:242:61 | ... .as_bytes() | provenance | MaD:19 |
| test_logging.rs:242:24:242:49 | ...::must_use(...) | test_logging.rs:242:16:242:61 | ... .as_bytes() | provenance | MaD:17 |
| test_logging.rs:242:24:242:49 | MacroExpr | test_logging.rs:242:24:242:49 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:242:24:242:49 | { ... } | test_logging.rs:242:24:242:49 | ...::must_use(...) | provenance | MaD:22 |
| test_logging.rs:242:42:242:49 | password | test_logging.rs:242:24:242:49 | MacroExpr | provenance | |
+| test_logging.rs:245:20:245:26 | res | test_logging.rs:245:28:245:53 | { ... } | provenance | |
| test_logging.rs:245:20:245:54 | MacroExpr | test_logging.rs:245:20:245:65 | ... .as_bytes() [&ref] | provenance | MaD:19 |
| test_logging.rs:245:20:245:54 | MacroExpr | test_logging.rs:245:20:245:65 | ... .as_bytes() [&ref] | provenance | MaD:17 |
-| test_logging.rs:245:20:245:54 | res | test_logging.rs:245:28:245:53 | { ... } | provenance | |
| test_logging.rs:245:20:245:65 | ... .as_bytes() | test_logging.rs:245:10:245:18 | write_all | provenance | MaD:8 Sink:MaD:8 |
| test_logging.rs:245:20:245:65 | ... .as_bytes() [&ref] | test_logging.rs:245:10:245:18 | write_all | provenance | MaD:8 Sink:MaD:8 |
-| test_logging.rs:245:28:245:53 | ...::format(...) | test_logging.rs:245:20:245:54 | res | provenance | |
+| test_logging.rs:245:28:245:53 | ...::format(...) | test_logging.rs:245:20:245:26 | res | provenance | |
| test_logging.rs:245:28:245:53 | ...::must_use(...) | test_logging.rs:245:20:245:54 | MacroExpr | provenance | |
| test_logging.rs:245:28:245:53 | ...::must_use(...) | test_logging.rs:245:20:245:65 | ... .as_bytes() | provenance | MaD:19 |
| test_logging.rs:245:28:245:53 | ...::must_use(...) | test_logging.rs:245:20:245:65 | ... .as_bytes() | provenance | MaD:17 |
| test_logging.rs:245:28:245:53 | MacroExpr | test_logging.rs:245:28:245:53 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:245:28:245:53 | { ... } | test_logging.rs:245:28:245:53 | ...::must_use(...) | provenance | MaD:22 |
| test_logging.rs:245:46:245:53 | password | test_logging.rs:245:28:245:53 | MacroExpr | provenance | |
+| test_logging.rs:248:15:248:21 | res | test_logging.rs:248:23:248:48 | { ... } | provenance | |
| test_logging.rs:248:15:248:49 | MacroExpr | test_logging.rs:248:15:248:60 | ... .as_bytes() [&ref] | provenance | MaD:19 |
| test_logging.rs:248:15:248:49 | MacroExpr | test_logging.rs:248:15:248:60 | ... .as_bytes() [&ref] | provenance | MaD:17 |
-| test_logging.rs:248:15:248:49 | res | test_logging.rs:248:23:248:48 | { ... } | provenance | |
| test_logging.rs:248:15:248:60 | ... .as_bytes() | test_logging.rs:248:9:248:13 | write | provenance | MaD:7 Sink:MaD:7 |
| test_logging.rs:248:15:248:60 | ... .as_bytes() [&ref] | test_logging.rs:248:9:248:13 | write | provenance | MaD:7 Sink:MaD:7 |
-| test_logging.rs:248:23:248:48 | ...::format(...) | test_logging.rs:248:15:248:49 | res | provenance | |
+| test_logging.rs:248:23:248:48 | ...::format(...) | test_logging.rs:248:15:248:21 | res | provenance | |
| test_logging.rs:248:23:248:48 | ...::must_use(...) | test_logging.rs:248:15:248:49 | MacroExpr | provenance | |
| test_logging.rs:248:23:248:48 | ...::must_use(...) | test_logging.rs:248:15:248:60 | ... .as_bytes() | provenance | MaD:19 |
| test_logging.rs:248:23:248:48 | ...::must_use(...) | test_logging.rs:248:15:248:60 | ... .as_bytes() | provenance | MaD:17 |
| test_logging.rs:248:23:248:48 | MacroExpr | test_logging.rs:248:23:248:48 | ...::format(...) | provenance | MaD:21 |
| test_logging.rs:248:23:248:48 | { ... } | test_logging.rs:248:23:248:48 | ...::must_use(...) | provenance | MaD:22 |
| test_logging.rs:248:41:248:48 | password | test_logging.rs:248:23:248:48 | MacroExpr | provenance | |
+| test_logging.rs:251:15:251:21 | res | test_logging.rs:251:23:251:48 | { ... } | provenance | |
| test_logging.rs:251:15:251:49 | MacroExpr | test_logging.rs:251:15:251:60 | ... .as_bytes() [&ref] | provenance | MaD:19 |
| test_logging.rs:251:15:251:49 | MacroExpr | test_logging.rs:251:15:251:60 | ... .as_bytes() [&ref] | provenance | MaD:17 |
-| test_logging.rs:251:15:251:49 | res | test_logging.rs:251:23:251:48 | { ... } | provenance | |
| test_logging.rs:251:15:251:60 | ... .as_bytes() | test_logging.rs:251:9:251:13 | write | provenance | MaD:6 Sink:MaD:6 |
| test_logging.rs:251:15:251:60 | ... .as_bytes() [&ref] | test_logging.rs:251:9:251:13 | write | provenance | MaD:6 Sink:MaD:6 |
-| test_logging.rs:251:23:251:48 | ...::format(...) | test_logging.rs:251:15:251:49 | res | provenance | |
+| test_logging.rs:251:23:251:48 | ...::format(...) | test_logging.rs:251:15:251:21 | res | provenance | |
| test_logging.rs:251:23:251:48 | ...::must_use(...) | test_logging.rs:251:15:251:49 | MacroExpr | provenance | |
| test_logging.rs:251:23:251:48 | ...::must_use(...) | test_logging.rs:251:15:251:60 | ... .as_bytes() | provenance | MaD:19 |
| test_logging.rs:251:23:251:48 | ...::must_use(...) | test_logging.rs:251:15:251:60 | ... .as_bytes() | provenance | MaD:17 |
@@ -316,43 +316,43 @@ models
| 21 | Summary: alloc::fmt::format; Argument[0]; ReturnValue; taint |
| 22 | Summary: core::hint::must_use; Argument[0]; ReturnValue; value |
nodes
-| test_logging.rs:42:5:42:36 | ...::log | semmle.label | ...::log |
+| test_logging.rs:42:5:42:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:42:12:42:35 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:42:28:42:35 | password | semmle.label | password |
-| test_logging.rs:43:5:43:36 | ...::log | semmle.label | ...::log |
+| test_logging.rs:43:5:43:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:43:12:43:35 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:43:28:43:35 | password | semmle.label | password |
-| test_logging.rs:44:5:44:35 | ...::log | semmle.label | ...::log |
+| test_logging.rs:44:5:44:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:44:11:44:34 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:44:27:44:34 | password | semmle.label | password |
-| test_logging.rs:45:5:45:36 | ...::log | semmle.label | ...::log |
+| test_logging.rs:45:5:45:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:45:12:45:35 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:45:28:45:35 | password | semmle.label | password |
-| test_logging.rs:46:5:46:35 | ...::log | semmle.label | ...::log |
+| test_logging.rs:46:5:46:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:46:11:46:34 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:46:27:46:34 | password | semmle.label | password |
-| test_logging.rs:47:5:47:48 | ...::log | semmle.label | ...::log |
+| test_logging.rs:47:5:47:8 | ...::log | semmle.label | ...::log |
| test_logging.rs:47:24:47:47 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:47:40:47:47 | password | semmle.label | password |
-| test_logging.rs:52:5:52:36 | ...::log | semmle.label | ...::log |
+| test_logging.rs:52:5:52:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:52:12:52:35 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:52:28:52:35 | password | semmle.label | password |
-| test_logging.rs:54:5:54:49 | ...::log | semmle.label | ...::log |
+| test_logging.rs:54:5:54:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:54:12:54:48 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:54:41:54:48 | password | semmle.label | password |
-| test_logging.rs:56:5:56:47 | ...::log | semmle.label | ...::log |
+| test_logging.rs:56:5:56:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:56:12:56:46 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:56:39:56:46 | password | semmle.label | password |
-| test_logging.rs:57:5:57:34 | ...::log | semmle.label | ...::log |
+| test_logging.rs:57:5:57:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:57:12:57:33 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:57:24:57:31 | password | semmle.label | password |
-| test_logging.rs:58:5:58:36 | ...::log | semmle.label | ...::log |
+| test_logging.rs:58:5:58:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:58:12:58:35 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:58:24:58:31 | password | semmle.label | password |
-| test_logging.rs:60:5:60:54 | ...::log | semmle.label | ...::log |
+| test_logging.rs:60:5:60:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:60:30:60:53 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:60:46:60:53 | password | semmle.label | password |
-| test_logging.rs:61:5:61:55 | ...::log | semmle.label | ...::log |
+| test_logging.rs:61:5:61:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0, &ref] | semmle.label | &... [&ref, tuple.0, &ref] |
| test_logging.rs:61:20:61:28 | &... [&ref, tuple.0] | semmle.label | &... [&ref, tuple.0] |
| test_logging.rs:61:20:61:28 | &password | semmle.label | &password |
@@ -360,13 +360,13 @@ nodes
| test_logging.rs:61:20:61:28 | TupleExpr [tuple.0, &ref] | semmle.label | TupleExpr [tuple.0, &ref] |
| test_logging.rs:61:20:61:28 | TupleExpr [tuple.0] | semmle.label | TupleExpr [tuple.0] |
| test_logging.rs:61:21:61:28 | password | semmle.label | password |
-| test_logging.rs:65:5:65:48 | ...::log | semmle.label | ...::log |
+| test_logging.rs:65:5:65:8 | ...::log | semmle.label | ...::log |
| test_logging.rs:65:24:65:47 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:65:40:65:47 | password | semmle.label | password |
-| test_logging.rs:67:5:67:66 | ...::log | semmle.label | ...::log |
+| test_logging.rs:67:5:67:8 | ...::log | semmle.label | ...::log |
| test_logging.rs:67:42:67:65 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:67:58:67:65 | password | semmle.label | password |
-| test_logging.rs:68:5:68:67 | ...::log | semmle.label | ...::log |
+| test_logging.rs:68:5:68:8 | ...::log | semmle.label | ...::log |
| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0, &ref] | semmle.label | &... [&ref, tuple.0, &ref] |
| test_logging.rs:68:18:68:26 | &... [&ref, tuple.0] | semmle.label | &... [&ref, tuple.0] |
| test_logging.rs:68:18:68:26 | &password | semmle.label | &password |
@@ -374,13 +374,13 @@ nodes
| test_logging.rs:68:18:68:26 | TupleExpr [tuple.0, &ref] | semmle.label | TupleExpr [tuple.0, &ref] |
| test_logging.rs:68:18:68:26 | TupleExpr [tuple.0] | semmle.label | TupleExpr [tuple.0] |
| test_logging.rs:68:19:68:26 | password | semmle.label | password |
-| test_logging.rs:72:5:72:47 | ...::log | semmle.label | ...::log |
+| test_logging.rs:72:5:72:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:72:23:72:46 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:72:39:72:46 | password | semmle.label | password |
-| test_logging.rs:74:5:74:65 | ...::log | semmle.label | ...::log |
+| test_logging.rs:74:5:74:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:74:41:74:64 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:74:57:74:64 | password | semmle.label | password |
-| test_logging.rs:75:5:75:51 | ...::log | semmle.label | ...::log |
+| test_logging.rs:75:5:75:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0, &ref] | semmle.label | &... [&ref, tuple.0, &ref] |
| test_logging.rs:75:20:75:28 | &... [&ref, tuple.0] | semmle.label | &... [&ref, tuple.0] |
| test_logging.rs:75:20:75:28 | &password | semmle.label | &password |
@@ -388,16 +388,16 @@ nodes
| test_logging.rs:75:20:75:28 | TupleExpr [tuple.0, &ref] | semmle.label | TupleExpr [tuple.0, &ref] |
| test_logging.rs:75:20:75:28 | TupleExpr [tuple.0] | semmle.label | TupleExpr [tuple.0] |
| test_logging.rs:75:21:75:28 | password | semmle.label | password |
-| test_logging.rs:76:5:76:47 | ...::log | semmle.label | ...::log |
+| test_logging.rs:76:5:76:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:76:23:76:46 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:76:39:76:46 | password | semmle.label | password |
-| test_logging.rs:82:5:82:44 | ...::log | semmle.label | ...::log |
+| test_logging.rs:82:5:82:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:82:20:82:43 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:82:36:82:43 | password | semmle.label | password |
-| test_logging.rs:84:5:84:62 | ...::log | semmle.label | ...::log |
+| test_logging.rs:84:5:84:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:84:38:84:61 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:84:54:84:61 | password | semmle.label | password |
-| test_logging.rs:85:5:85:48 | ...::log | semmle.label | ...::log |
+| test_logging.rs:85:5:85:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0, &ref] | semmle.label | &... [&ref, tuple.0, &ref] |
| test_logging.rs:85:20:85:28 | &... [&ref, tuple.0] | semmle.label | &... [&ref, tuple.0] |
| test_logging.rs:85:20:85:28 | &password | semmle.label | &password |
@@ -405,49 +405,49 @@ nodes
| test_logging.rs:85:20:85:28 | TupleExpr [tuple.0, &ref] | semmle.label | TupleExpr [tuple.0, &ref] |
| test_logging.rs:85:20:85:28 | TupleExpr [tuple.0] | semmle.label | TupleExpr [tuple.0] |
| test_logging.rs:85:21:85:28 | password | semmle.label | password |
-| test_logging.rs:86:5:86:44 | ...::log | semmle.label | ...::log |
+| test_logging.rs:86:5:86:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:86:20:86:43 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:86:36:86:43 | password | semmle.label | password |
| test_logging.rs:93:9:93:10 | m1 | semmle.label | m1 |
| test_logging.rs:93:14:93:22 | &password | semmle.label | &password |
| test_logging.rs:93:15:93:22 | password | semmle.label | password |
-| test_logging.rs:94:5:94:29 | ...::log | semmle.label | ...::log |
+| test_logging.rs:94:5:94:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:94:11:94:28 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:96:9:96:10 | m2 | semmle.label | m2 |
| test_logging.rs:96:41:96:49 | &password | semmle.label | &password |
| test_logging.rs:96:42:96:49 | password | semmle.label | password |
-| test_logging.rs:97:5:97:19 | ...::log | semmle.label | ...::log |
+| test_logging.rs:97:5:97:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:97:11:97:18 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:99:9:99:10 | m3 | semmle.label | m3 |
-| test_logging.rs:99:14:99:46 | res | semmle.label | res |
+| test_logging.rs:99:14:99:20 | res | semmle.label | res |
| test_logging.rs:99:22:99:45 | ...::format(...) | semmle.label | ...::format(...) |
| test_logging.rs:99:22:99:45 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| test_logging.rs:99:22:99:45 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:99:22:99:45 | { ... } | semmle.label | { ... } |
| test_logging.rs:99:38:99:45 | password | semmle.label | password |
-| test_logging.rs:100:5:100:19 | ...::log | semmle.label | ...::log |
+| test_logging.rs:100:5:100:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:100:11:100:18 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:118:5:118:42 | ...::log | semmle.label | ...::log |
+| test_logging.rs:118:5:118:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:118:12:118:41 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:118:28:118:41 | get_password(...) | semmle.label | get_password(...) |
| test_logging.rs:129:9:129:10 | t1 [tuple.1] | semmle.label | t1 [tuple.1] |
| test_logging.rs:129:14:129:33 | TupleExpr [tuple.1] | semmle.label | TupleExpr [tuple.1] |
| test_logging.rs:129:25:129:32 | password | semmle.label | password |
-| test_logging.rs:131:5:131:32 | ...::log | semmle.label | ...::log |
+| test_logging.rs:131:5:131:10 | ...::log | semmle.label | ...::log |
| test_logging.rs:131:12:131:31 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:131:28:131:29 | t1 [tuple.1] | semmle.label | t1 [tuple.1] |
| test_logging.rs:131:28:131:31 | t1.1 | semmle.label | t1.1 |
-| test_logging.rs:141:5:141:38 | ...::log | semmle.label | ...::log |
+| test_logging.rs:141:5:141:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:141:11:141:37 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:141:27:141:37 | s1.password | semmle.label | s1.password |
-| test_logging.rs:151:5:151:38 | ...::log | semmle.label | ...::log |
+| test_logging.rs:151:5:151:9 | ...::log | semmle.label | ...::log |
| test_logging.rs:151:11:151:37 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:151:27:151:37 | s2.password | semmle.label | s2.password |
| test_logging.rs:176:22:176:31 | log_expect | semmle.label | log_expect |
| test_logging.rs:176:33:176:79 | &... | semmle.label | &... |
| test_logging.rs:176:33:176:79 | &... [&ref] | semmle.label | &... [&ref] |
+| test_logging.rs:176:34:176:40 | res | semmle.label | res |
| test_logging.rs:176:34:176:79 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:176:34:176:79 | res | semmle.label | res |
| test_logging.rs:176:42:176:78 | ...::format(...) | semmle.label | ...::format(...) |
| test_logging.rs:176:42:176:78 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| test_logging.rs:176:42:176:78 | MacroExpr | semmle.label | MacroExpr |
@@ -456,8 +456,8 @@ nodes
| test_logging.rs:180:24:180:33 | log_expect | semmle.label | log_expect |
| test_logging.rs:180:35:180:81 | &... | semmle.label | &... |
| test_logging.rs:180:35:180:81 | &... [&ref] | semmle.label | &... [&ref] |
+| test_logging.rs:180:36:180:42 | res | semmle.label | res |
| test_logging.rs:180:36:180:81 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:180:36:180:81 | res | semmle.label | res |
| test_logging.rs:180:44:180:80 | ...::format(...) | semmle.label | ...::format(...) |
| test_logging.rs:180:44:180:80 | ...::must_use(...) | semmle.label | ...::must_use(...) |
| test_logging.rs:180:44:180:80 | MacroExpr | semmle.label | MacroExpr |
@@ -474,60 +474,60 @@ nodes
| test_logging.rs:187:51:187:59 | password2 | semmle.label | password2 |
| test_logging.rs:188:13:188:23 | err_result3 [Err] | semmle.label | err_result3 [Err] |
| test_logging.rs:188:25:188:34 | log_unwrap | semmle.label | log_unwrap |
-| test_logging.rs:192:5:192:38 | ...::_print | semmle.label | ...::_print |
+| test_logging.rs:192:5:192:10 | ...::_print | semmle.label | ...::_print |
| test_logging.rs:192:12:192:37 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:192:30:192:37 | password | semmle.label | password |
-| test_logging.rs:193:5:193:38 | ...::_print | semmle.label | ...::_print |
+| test_logging.rs:193:5:193:12 | ...::_print | semmle.label | ...::_print |
| test_logging.rs:193:14:193:37 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:193:30:193:37 | password | semmle.label | password |
-| test_logging.rs:194:5:194:39 | ...::_eprint | semmle.label | ...::_eprint |
+| test_logging.rs:194:5:194:11 | ...::_eprint | semmle.label | ...::_eprint |
| test_logging.rs:194:13:194:38 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:194:31:194:38 | password | semmle.label | password |
-| test_logging.rs:195:5:195:39 | ...::_eprint | semmle.label | ...::_eprint |
+| test_logging.rs:195:5:195:13 | ...::_eprint | semmle.label | ...::_eprint |
| test_logging.rs:195:15:195:38 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:195:31:195:38 | password | semmle.label | password |
-| test_logging.rs:199:13:199:44 | ...::panic_fmt | semmle.label | ...::panic_fmt |
+| test_logging.rs:199:13:199:18 | ...::panic_fmt | semmle.label | ...::panic_fmt |
| test_logging.rs:199:20:199:43 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:199:36:199:43 | password | semmle.label | password |
-| test_logging.rs:202:13:202:43 | ...::panic_fmt | semmle.label | ...::panic_fmt |
+| test_logging.rs:202:13:202:17 | ...::panic_fmt | semmle.label | ...::panic_fmt |
| test_logging.rs:202:19:202:42 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:202:35:202:42 | password | semmle.label | password |
-| test_logging.rs:205:13:205:52 | ...::panic_fmt | semmle.label | ...::panic_fmt |
+| test_logging.rs:205:13:205:26 | ...::panic_fmt | semmle.label | ...::panic_fmt |
| test_logging.rs:205:28:205:51 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:205:44:205:51 | password | semmle.label | password |
-| test_logging.rs:208:13:208:50 | ...::panic_fmt | semmle.label | ...::panic_fmt |
+| test_logging.rs:208:13:208:24 | ...::panic_fmt | semmle.label | ...::panic_fmt |
| test_logging.rs:208:26:208:49 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:208:42:208:49 | password | semmle.label | password |
-| test_logging.rs:211:13:211:52 | ...::panic_fmt | semmle.label | ...::panic_fmt |
+| test_logging.rs:211:13:211:19 | ...::panic_fmt | semmle.label | ...::panic_fmt |
| test_logging.rs:211:28:211:51 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:211:44:211:51 | password | semmle.label | password |
-| test_logging.rs:214:13:214:54 | ...::assert_failed | semmle.label | ...::assert_failed |
-| test_logging.rs:214:13:214:54 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
+| test_logging.rs:214:13:214:22 | ...::assert_failed | semmle.label | ...::assert_failed |
+| test_logging.rs:214:13:214:22 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
| test_logging.rs:214:30:214:53 | ...::Some(...) [Some] | semmle.label | ...::Some(...) [Some] |
| test_logging.rs:214:30:214:53 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:214:46:214:53 | password | semmle.label | password |
-| test_logging.rs:217:13:217:54 | ...::assert_failed | semmle.label | ...::assert_failed |
-| test_logging.rs:217:13:217:54 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
+| test_logging.rs:217:13:217:22 | ...::assert_failed | semmle.label | ...::assert_failed |
+| test_logging.rs:217:13:217:22 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
| test_logging.rs:217:30:217:53 | ...::Some(...) [Some] | semmle.label | ...::Some(...) [Some] |
| test_logging.rs:217:30:217:53 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:217:46:217:53 | password | semmle.label | password |
-| test_logging.rs:220:13:220:58 | ...::panic_fmt | semmle.label | ...::panic_fmt |
+| test_logging.rs:220:13:220:25 | ...::panic_fmt | semmle.label | ...::panic_fmt |
| test_logging.rs:220:34:220:57 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:220:50:220:57 | password | semmle.label | password |
-| test_logging.rs:223:13:223:60 | ...::assert_failed | semmle.label | ...::assert_failed |
-| test_logging.rs:223:13:223:60 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
+| test_logging.rs:223:13:223:28 | ...::assert_failed | semmle.label | ...::assert_failed |
+| test_logging.rs:223:13:223:28 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
| test_logging.rs:223:36:223:59 | ...::Some(...) [Some] | semmle.label | ...::Some(...) [Some] |
| test_logging.rs:223:36:223:59 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:223:52:223:59 | password | semmle.label | password |
-| test_logging.rs:226:13:226:60 | ...::assert_failed | semmle.label | ...::assert_failed |
-| test_logging.rs:226:13:226:60 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
+| test_logging.rs:226:13:226:28 | ...::assert_failed | semmle.label | ...::assert_failed |
+| test_logging.rs:226:13:226:28 | ...::assert_failed [Some] | semmle.label | ...::assert_failed [Some] |
| test_logging.rs:226:36:226:59 | ...::Some(...) [Some] | semmle.label | ...::Some(...) [Some] |
| test_logging.rs:226:36:226:59 | MacroExpr | semmle.label | MacroExpr |
| test_logging.rs:226:52:226:59 | password | semmle.label | password |
| test_logging.rs:229:23:229:28 | expect | semmle.label | expect |
| test_logging.rs:229:23:229:28 | expect | semmle.label | expect |
+| test_logging.rs:229:30:229:36 | res | semmle.label | res |
| test_logging.rs:229:30:229:62 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:229:30:229:62 | res | semmle.label | res |
| test_logging.rs:229:30:229:71 | ... .as_str() | semmle.label | ... .as_str() |
| test_logging.rs:229:30:229:71 | ... .as_str() [&ref] | semmle.label | ... .as_str() [&ref] |
| test_logging.rs:229:38:229:61 | ...::format(...) | semmle.label | ...::format(...) |
@@ -536,8 +536,8 @@ nodes
| test_logging.rs:229:38:229:61 | { ... } | semmle.label | { ... } |
| test_logging.rs:229:54:229:61 | password | semmle.label | password |
| test_logging.rs:242:10:242:14 | write | semmle.label | write |
+| test_logging.rs:242:16:242:22 | res | semmle.label | res |
| test_logging.rs:242:16:242:50 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:242:16:242:50 | res | semmle.label | res |
| test_logging.rs:242:16:242:61 | ... .as_bytes() | semmle.label | ... .as_bytes() |
| test_logging.rs:242:16:242:61 | ... .as_bytes() [&ref] | semmle.label | ... .as_bytes() [&ref] |
| test_logging.rs:242:24:242:49 | ...::format(...) | semmle.label | ...::format(...) |
@@ -546,8 +546,8 @@ nodes
| test_logging.rs:242:24:242:49 | { ... } | semmle.label | { ... } |
| test_logging.rs:242:42:242:49 | password | semmle.label | password |
| test_logging.rs:245:10:245:18 | write_all | semmle.label | write_all |
+| test_logging.rs:245:20:245:26 | res | semmle.label | res |
| test_logging.rs:245:20:245:54 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:245:20:245:54 | res | semmle.label | res |
| test_logging.rs:245:20:245:65 | ... .as_bytes() | semmle.label | ... .as_bytes() |
| test_logging.rs:245:20:245:65 | ... .as_bytes() [&ref] | semmle.label | ... .as_bytes() [&ref] |
| test_logging.rs:245:28:245:53 | ...::format(...) | semmle.label | ...::format(...) |
@@ -556,8 +556,8 @@ nodes
| test_logging.rs:245:28:245:53 | { ... } | semmle.label | { ... } |
| test_logging.rs:245:46:245:53 | password | semmle.label | password |
| test_logging.rs:248:9:248:13 | write | semmle.label | write |
+| test_logging.rs:248:15:248:21 | res | semmle.label | res |
| test_logging.rs:248:15:248:49 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:248:15:248:49 | res | semmle.label | res |
| test_logging.rs:248:15:248:60 | ... .as_bytes() | semmle.label | ... .as_bytes() |
| test_logging.rs:248:15:248:60 | ... .as_bytes() [&ref] | semmle.label | ... .as_bytes() [&ref] |
| test_logging.rs:248:23:248:48 | ...::format(...) | semmle.label | ...::format(...) |
@@ -566,8 +566,8 @@ nodes
| test_logging.rs:248:23:248:48 | { ... } | semmle.label | { ... } |
| test_logging.rs:248:41:248:48 | password | semmle.label | password |
| test_logging.rs:251:9:251:13 | write | semmle.label | write |
+| test_logging.rs:251:15:251:21 | res | semmle.label | res |
| test_logging.rs:251:15:251:49 | MacroExpr | semmle.label | MacroExpr |
-| test_logging.rs:251:15:251:49 | res | semmle.label | res |
| test_logging.rs:251:15:251:60 | ... .as_bytes() | semmle.label | ... .as_bytes() |
| test_logging.rs:251:15:251:60 | ... .as_bytes() [&ref] | semmle.label | ... .as_bytes() [&ref] |
| test_logging.rs:251:23:251:48 | ...::format(...) | semmle.label | ...::format(...) |
diff --git a/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected b/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected
index c7e132bce89..2b2f7e85ec1 100644
--- a/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected
+++ b/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected
@@ -188,11 +188,11 @@ edges
| lifetime.rs:719:26:719:34 | &... | lifetime.rs:718:7:718:8 | r1 | provenance | |
| lifetime.rs:730:6:730:7 | r1 | lifetime.rs:734:12:734:13 | r1 | provenance | |
| lifetime.rs:730:11:730:25 | e1.test_match() | lifetime.rs:730:6:730:7 | r1 | provenance | |
-| lifetime.rs:766:2:766:13 | &val | lifetime.rs:766:2:766:13 | ptr | provenance | |
-| lifetime.rs:766:2:766:13 | ptr | lifetime.rs:767:2:767:13 | ptr | provenance | |
+| lifetime.rs:766:2:766:11 | &val | lifetime.rs:766:2:766:11 | ptr | provenance | |
+| lifetime.rs:766:2:766:11 | ptr | lifetime.rs:767:2:767:11 | ptr | provenance | |
| lifetime.rs:769:6:769:8 | ptr | lifetime.rs:771:12:771:14 | ptr | provenance | |
-| lifetime.rs:769:12:769:23 | &val | lifetime.rs:769:12:769:23 | ptr | provenance | |
-| lifetime.rs:769:12:769:23 | ptr | lifetime.rs:769:6:769:8 | ptr | provenance | |
+| lifetime.rs:769:12:769:21 | &val | lifetime.rs:769:12:769:21 | ptr | provenance | |
+| lifetime.rs:769:12:769:21 | ptr | lifetime.rs:769:6:769:8 | ptr | provenance | |
| lifetime.rs:781:2:781:19 | return ... | lifetime.rs:785:11:785:41 | get_local_for_unsafe_function(...) | provenance | |
| lifetime.rs:781:9:781:19 | &my_local10 | lifetime.rs:781:2:781:19 | return ... | provenance | |
| lifetime.rs:785:6:785:7 | p1 | lifetime.rs:789:12:789:13 | p1 | provenance | |
@@ -400,12 +400,12 @@ nodes
| lifetime.rs:730:6:730:7 | r1 | semmle.label | r1 |
| lifetime.rs:730:11:730:25 | e1.test_match() | semmle.label | e1.test_match() |
| lifetime.rs:734:12:734:13 | r1 | semmle.label | r1 |
-| lifetime.rs:766:2:766:13 | &val | semmle.label | &val |
-| lifetime.rs:766:2:766:13 | ptr | semmle.label | ptr |
-| lifetime.rs:767:2:767:13 | ptr | semmle.label | ptr |
+| lifetime.rs:766:2:766:11 | &val | semmle.label | &val |
+| lifetime.rs:766:2:766:11 | ptr | semmle.label | ptr |
+| lifetime.rs:767:2:767:11 | ptr | semmle.label | ptr |
| lifetime.rs:769:6:769:8 | ptr | semmle.label | ptr |
-| lifetime.rs:769:12:769:23 | &val | semmle.label | &val |
-| lifetime.rs:769:12:769:23 | ptr | semmle.label | ptr |
+| lifetime.rs:769:12:769:21 | &val | semmle.label | &val |
+| lifetime.rs:769:12:769:21 | ptr | semmle.label | ptr |
| lifetime.rs:771:12:771:14 | ptr | semmle.label | ptr |
| lifetime.rs:781:2:781:19 | return ... | semmle.label | return ... |
| lifetime.rs:781:9:781:19 | &my_local10 | semmle.label | &my_local10 |
diff --git a/rust/ql/test/query-tests/unusedentities/CONSISTENCY/PathResolutionConsistency.expected b/rust/ql/test/query-tests/unusedentities/CONSISTENCY/PathResolutionConsistency.expected
index 6f977f067db..1d84c634dd2 100644
--- a/rust/ql/test/query-tests/unusedentities/CONSISTENCY/PathResolutionConsistency.expected
+++ b/rust/ql/test/query-tests/unusedentities/CONSISTENCY/PathResolutionConsistency.expected
@@ -2,5 +2,5 @@ multipleCallTargets
| main.rs:13:13:13:29 | ...::from(...) |
| main.rs:14:13:14:29 | ...::from(...) |
| unreachable.rs:165:20:165:42 | ...::from(...) |
-| unreachable.rs:171:9:171:17 | ...::from(...) |
+| unreachable.rs:171:9:171:15 | ...::from(...) |
| unreachable.rs:177:17:177:25 | ...::from(...) |
From a8671452fc71636c3178d338c873f95e752a6128 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Mon, 18 Aug 2025 13:06:30 +0200
Subject: [PATCH 083/298] Rust: add upgrade script
---
.../old.dbscheme | 3644 +++++++++++++++++
.../rust.dbscheme | 3637 ++++++++++++++++
.../upgrade.properties | 2 +
rust/ql/.generated.list | 21 +-
rust/ql/.gitattributes | 1 -
.../lib/codeql/rust/elements/ForTypeRepr.qll | 12 +-
.../ql/lib/codeql/rust/elements/TypeBound.qll | 2 +
.../ql/lib/codeql/rust/elements/WherePred.qll | 2 +
.../rust/elements/internal/ForBinderImpl.qll | 6 +-
.../elements/internal/ForTypeReprImpl.qll | 12 +-
.../rust/elements/internal/TypeBoundImpl.qll | 2 +
.../rust/elements/internal/WherePredImpl.qll | 2 +
.../internal/generated/ForTypeRepr.qll | 12 +-
.../rust/elements/internal/generated/Raw.qll | 16 +-
.../elements/internal/generated/TypeBound.qll | 2 +
.../elements/internal/generated/WherePred.qll | 2 +
.../old.dbscheme | 3637 ++++++++++++++++
.../rust.dbscheme | 3644 +++++++++++++++++
.../upgrade.properties | 18 +
.../upgrade.ql | 94 +
.../generated/.generated_tests.list | 6 +-
.../generated/ForBinder/ForBinder.expected | 4 +-
.../ForTypeRepr/ForTypeRepr.expected | 3 +
.../ForTypeRepr/gen_for_type_repr.rs | 12 +-
.../generated/TypeBound/TypeBound.expected | 3 +
.../generated/TypeBound/gen_type_bound.rs | 2 +
.../generated/WherePred/gen_where_pred.rs | 2 +
rust/schema/annotations.py | 17 +-
28 files changed, 14749 insertions(+), 68 deletions(-)
create mode 100644 rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/old.dbscheme
create mode 100644 rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/rust.dbscheme
create mode 100644 rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
create mode 100644 rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/old.dbscheme
create mode 100644 rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme
create mode 100644 rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.properties
create mode 100644 rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/old.dbscheme b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/old.dbscheme
new file mode 100644
index 00000000000..3c1990e7f1d
--- /dev/null
+++ b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/old.dbscheme
@@ -0,0 +1,3644 @@
+// generated by codegen, do not edit
+
+// from ../shared/tree-sitter-extractor/src/generator/prefix.dbscheme
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Empty location -*/
+
+empty_location(
+ int location: @location_default ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- Diagnostic messages -*/
+
+diagnostics(
+ unique int id: @diagnostic,
+ int severity: int ref,
+ string error_tag: string ref,
+ string error_message: string ref,
+ string full_error_message: string ref,
+ int location: @location_default ref
+);
+
+/*- Diagnostic messages: severity -*/
+
+case @diagnostic.severity of
+ 10 = @diagnostic_debug
+| 20 = @diagnostic_info
+| 30 = @diagnostic_warning
+| 40 = @diagnostic_error
+;
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
+
+overlayChangedFiles(
+ string path: string ref
+);
+
+
+// from prefix.dbscheme
+#keyset[id]
+locatable_locations(
+ int id: @locatable ref,
+ int location: @location_default ref
+);
+
+
+// from schema
+
+@element =
+ @extractor_step
+| @locatable
+| @named_crate
+| @unextracted
+;
+
+extractor_steps(
+ unique int id: @extractor_step,
+ string action: string ref,
+ int duration_ms: int ref
+);
+
+#keyset[id]
+extractor_step_files(
+ int id: @extractor_step ref,
+ int file: @file ref
+);
+
+@locatable =
+ @ast_node
+| @crate
+;
+
+named_crates(
+ unique int id: @named_crate,
+ string name: string ref,
+ int crate: @crate ref
+);
+
+@unextracted =
+ @missing
+| @unimplemented
+;
+
+@ast_node =
+ @abi
+| @addressable
+| @arg_list
+| @asm_dir_spec
+| @asm_operand
+| @asm_operand_expr
+| @asm_option
+| @asm_piece
+| @asm_reg_spec
+| @assoc_item_list
+| @attr
+| @callable
+| @expr
+| @extern_item_list
+| @field_list
+| @for_binder
+| @format_args_arg
+| @generic_arg
+| @generic_arg_list
+| @generic_param
+| @generic_param_list
+| @item_list
+| @label
+| @let_else
+| @macro_items
+| @match_arm
+| @match_arm_list
+| @match_guard
+| @meta
+| @name
+| @param_base
+| @param_list
+| @parenthesized_arg_list
+| @pat
+| @path
+| @path_segment
+| @rename
+| @resolvable
+| @ret_type_repr
+| @return_type_syntax
+| @source_file
+| @stmt
+| @stmt_list
+| @struct_expr_field
+| @struct_expr_field_list
+| @struct_field
+| @struct_pat_field
+| @struct_pat_field_list
+| @token
+| @token_tree
+| @tuple_field
+| @type_bound
+| @type_bound_list
+| @type_repr
+| @use_bound_generic_arg
+| @use_bound_generic_args
+| @use_tree
+| @use_tree_list
+| @variant_list
+| @visibility
+| @where_clause
+| @where_pred
+;
+
+crates(
+ unique int id: @crate
+);
+
+#keyset[id]
+crate_names(
+ int id: @crate ref,
+ string name: string ref
+);
+
+#keyset[id]
+crate_versions(
+ int id: @crate ref,
+ string version: string ref
+);
+
+#keyset[id, index]
+crate_cfg_options(
+ int id: @crate ref,
+ int index: int ref,
+ string cfg_option: string ref
+);
+
+#keyset[id, index]
+crate_named_dependencies(
+ int id: @crate ref,
+ int index: int ref,
+ int named_dependency: @named_crate ref
+);
+
+missings(
+ unique int id: @missing
+);
+
+unimplementeds(
+ unique int id: @unimplemented
+);
+
+abis(
+ unique int id: @abi
+);
+
+#keyset[id]
+abi_abi_strings(
+ int id: @abi ref,
+ string abi_string: string ref
+);
+
+@addressable =
+ @item
+| @variant
+;
+
+#keyset[id]
+addressable_extended_canonical_paths(
+ int id: @addressable ref,
+ string extended_canonical_path: string ref
+);
+
+#keyset[id]
+addressable_crate_origins(
+ int id: @addressable ref,
+ string crate_origin: string ref
+);
+
+arg_lists(
+ unique int id: @arg_list
+);
+
+#keyset[id, index]
+arg_list_args(
+ int id: @arg_list ref,
+ int index: int ref,
+ int arg: @expr ref
+);
+
+asm_dir_specs(
+ unique int id: @asm_dir_spec
+);
+
+@asm_operand =
+ @asm_const
+| @asm_label
+| @asm_reg_operand
+| @asm_sym
+;
+
+asm_operand_exprs(
+ unique int id: @asm_operand_expr
+);
+
+#keyset[id]
+asm_operand_expr_in_exprs(
+ int id: @asm_operand_expr ref,
+ int in_expr: @expr ref
+);
+
+#keyset[id]
+asm_operand_expr_out_exprs(
+ int id: @asm_operand_expr ref,
+ int out_expr: @expr ref
+);
+
+asm_options(
+ unique int id: @asm_option
+);
+
+#keyset[id]
+asm_option_is_raw(
+ int id: @asm_option ref
+);
+
+@asm_piece =
+ @asm_clobber_abi
+| @asm_operand_named
+| @asm_options_list
+;
+
+asm_reg_specs(
+ unique int id: @asm_reg_spec
+);
+
+#keyset[id]
+asm_reg_spec_identifiers(
+ int id: @asm_reg_spec ref,
+ int identifier: @name_ref ref
+);
+
+assoc_item_lists(
+ unique int id: @assoc_item_list
+);
+
+#keyset[id, index]
+assoc_item_list_assoc_items(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int assoc_item: @assoc_item ref
+);
+
+#keyset[id, index]
+assoc_item_list_attrs(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+attrs(
+ unique int id: @attr
+);
+
+#keyset[id]
+attr_meta(
+ int id: @attr ref,
+ int meta: @meta ref
+);
+
+@callable =
+ @closure_expr
+| @function
+;
+
+#keyset[id]
+callable_param_lists(
+ int id: @callable ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id, index]
+callable_attrs(
+ int id: @callable ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+@expr =
+ @array_expr_internal
+| @asm_expr
+| @await_expr
+| @become_expr
+| @binary_expr
+| @break_expr
+| @call_expr_base
+| @cast_expr
+| @closure_expr
+| @continue_expr
+| @field_expr
+| @format_args_expr
+| @if_expr
+| @index_expr
+| @labelable_expr
+| @let_expr
+| @literal_expr
+| @macro_block_expr
+| @macro_expr
+| @match_expr
+| @offset_of_expr
+| @paren_expr
+| @path_expr_base
+| @prefix_expr
+| @range_expr
+| @ref_expr
+| @return_expr
+| @struct_expr
+| @try_expr
+| @tuple_expr
+| @underscore_expr
+| @yeet_expr
+| @yield_expr
+;
+
+extern_item_lists(
+ unique int id: @extern_item_list
+);
+
+#keyset[id, index]
+extern_item_list_attrs(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+extern_item_list_extern_items(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int extern_item: @extern_item ref
+);
+
+@field_list =
+ @struct_field_list
+| @tuple_field_list
+;
+
+for_binders(
+ unique int id: @for_binder
+);
+
+#keyset[id]
+for_binder_generic_param_lists(
+ int id: @for_binder ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+format_args_args(
+ unique int id: @format_args_arg
+);
+
+#keyset[id]
+format_args_arg_exprs(
+ int id: @format_args_arg ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+format_args_arg_names(
+ int id: @format_args_arg ref,
+ int name: @name ref
+);
+
+@generic_arg =
+ @assoc_type_arg
+| @const_arg
+| @lifetime_arg
+| @type_arg
+;
+
+generic_arg_lists(
+ unique int id: @generic_arg_list
+);
+
+#keyset[id, index]
+generic_arg_list_generic_args(
+ int id: @generic_arg_list ref,
+ int index: int ref,
+ int generic_arg: @generic_arg ref
+);
+
+@generic_param =
+ @const_param
+| @lifetime_param
+| @type_param
+;
+
+generic_param_lists(
+ unique int id: @generic_param_list
+);
+
+#keyset[id, index]
+generic_param_list_generic_params(
+ int id: @generic_param_list ref,
+ int index: int ref,
+ int generic_param: @generic_param ref
+);
+
+item_lists(
+ unique int id: @item_list
+);
+
+#keyset[id, index]
+item_list_attrs(
+ int id: @item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+item_list_items(
+ int id: @item_list ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+labels(
+ unique int id: @label
+);
+
+#keyset[id]
+label_lifetimes(
+ int id: @label ref,
+ int lifetime: @lifetime ref
+);
+
+let_elses(
+ unique int id: @let_else
+);
+
+#keyset[id]
+let_else_block_exprs(
+ int id: @let_else ref,
+ int block_expr: @block_expr ref
+);
+
+macro_items(
+ unique int id: @macro_items
+);
+
+#keyset[id, index]
+macro_items_items(
+ int id: @macro_items ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+match_arms(
+ unique int id: @match_arm
+);
+
+#keyset[id, index]
+match_arm_attrs(
+ int id: @match_arm ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_arm_exprs(
+ int id: @match_arm ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+match_arm_guards(
+ int id: @match_arm ref,
+ int guard: @match_guard ref
+);
+
+#keyset[id]
+match_arm_pats(
+ int id: @match_arm ref,
+ int pat: @pat ref
+);
+
+match_arm_lists(
+ unique int id: @match_arm_list
+);
+
+#keyset[id, index]
+match_arm_list_arms(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int arm: @match_arm ref
+);
+
+#keyset[id, index]
+match_arm_list_attrs(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+match_guards(
+ unique int id: @match_guard
+);
+
+#keyset[id]
+match_guard_conditions(
+ int id: @match_guard ref,
+ int condition: @expr ref
+);
+
+meta(
+ unique int id: @meta
+);
+
+#keyset[id]
+meta_exprs(
+ int id: @meta ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+meta_is_unsafe(
+ int id: @meta ref
+);
+
+#keyset[id]
+meta_paths(
+ int id: @meta ref,
+ int path: @path ref
+);
+
+#keyset[id]
+meta_token_trees(
+ int id: @meta ref,
+ int token_tree: @token_tree ref
+);
+
+names(
+ unique int id: @name
+);
+
+#keyset[id]
+name_texts(
+ int id: @name ref,
+ string text: string ref
+);
+
+@param_base =
+ @param
+| @self_param
+;
+
+#keyset[id, index]
+param_base_attrs(
+ int id: @param_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+param_base_type_reprs(
+ int id: @param_base ref,
+ int type_repr: @type_repr ref
+);
+
+param_lists(
+ unique int id: @param_list
+);
+
+#keyset[id, index]
+param_list_params(
+ int id: @param_list ref,
+ int index: int ref,
+ int param: @param ref
+);
+
+#keyset[id]
+param_list_self_params(
+ int id: @param_list ref,
+ int self_param: @self_param ref
+);
+
+parenthesized_arg_lists(
+ unique int id: @parenthesized_arg_list
+);
+
+#keyset[id, index]
+parenthesized_arg_list_type_args(
+ int id: @parenthesized_arg_list ref,
+ int index: int ref,
+ int type_arg: @type_arg ref
+);
+
+@pat =
+ @box_pat
+| @const_block_pat
+| @ident_pat
+| @literal_pat
+| @macro_pat
+| @or_pat
+| @paren_pat
+| @path_pat
+| @range_pat
+| @ref_pat
+| @rest_pat
+| @slice_pat
+| @struct_pat
+| @tuple_pat
+| @tuple_struct_pat
+| @wildcard_pat
+;
+
+paths(
+ unique int id: @path
+);
+
+#keyset[id]
+path_qualifiers(
+ int id: @path ref,
+ int qualifier: @path ref
+);
+
+#keyset[id]
+path_segments_(
+ int id: @path ref,
+ int segment: @path_segment ref
+);
+
+path_segments(
+ unique int id: @path_segment
+);
+
+#keyset[id]
+path_segment_generic_arg_lists(
+ int id: @path_segment ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+path_segment_identifiers(
+ int id: @path_segment ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+path_segment_parenthesized_arg_lists(
+ int id: @path_segment ref,
+ int parenthesized_arg_list: @parenthesized_arg_list ref
+);
+
+#keyset[id]
+path_segment_ret_types(
+ int id: @path_segment ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+path_segment_return_type_syntaxes(
+ int id: @path_segment ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+path_segment_type_reprs(
+ int id: @path_segment ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+path_segment_trait_type_reprs(
+ int id: @path_segment ref,
+ int trait_type_repr: @path_type_repr ref
+);
+
+renames(
+ unique int id: @rename
+);
+
+#keyset[id]
+rename_names(
+ int id: @rename ref,
+ int name: @name ref
+);
+
+@resolvable =
+ @method_call_expr
+| @path_ast_node
+;
+
+#keyset[id]
+resolvable_resolved_paths(
+ int id: @resolvable ref,
+ string resolved_path: string ref
+);
+
+#keyset[id]
+resolvable_resolved_crate_origins(
+ int id: @resolvable ref,
+ string resolved_crate_origin: string ref
+);
+
+ret_type_reprs(
+ unique int id: @ret_type_repr
+);
+
+#keyset[id]
+ret_type_repr_type_reprs(
+ int id: @ret_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+return_type_syntaxes(
+ unique int id: @return_type_syntax
+);
+
+source_files(
+ unique int id: @source_file
+);
+
+#keyset[id, index]
+source_file_attrs(
+ int id: @source_file ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+source_file_items(
+ int id: @source_file ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+@stmt =
+ @expr_stmt
+| @item
+| @let_stmt
+;
+
+stmt_lists(
+ unique int id: @stmt_list
+);
+
+#keyset[id, index]
+stmt_list_attrs(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+stmt_list_statements(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+#keyset[id]
+stmt_list_tail_exprs(
+ int id: @stmt_list ref,
+ int tail_expr: @expr ref
+);
+
+struct_expr_fields(
+ unique int id: @struct_expr_field
+);
+
+#keyset[id, index]
+struct_expr_field_attrs(
+ int id: @struct_expr_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_expr_field_exprs(
+ int id: @struct_expr_field ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+struct_expr_field_identifiers(
+ int id: @struct_expr_field ref,
+ int identifier: @name_ref ref
+);
+
+struct_expr_field_lists(
+ unique int id: @struct_expr_field_list
+);
+
+#keyset[id, index]
+struct_expr_field_list_attrs(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+struct_expr_field_list_fields(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int field: @struct_expr_field ref
+);
+
+#keyset[id]
+struct_expr_field_list_spreads(
+ int id: @struct_expr_field_list ref,
+ int spread: @expr ref
+);
+
+struct_fields(
+ unique int id: @struct_field
+);
+
+#keyset[id, index]
+struct_field_attrs(
+ int id: @struct_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_defaults(
+ int id: @struct_field ref,
+ int default: @expr ref
+);
+
+#keyset[id]
+struct_field_is_unsafe(
+ int id: @struct_field ref
+);
+
+#keyset[id]
+struct_field_names(
+ int id: @struct_field ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_field_type_reprs(
+ int id: @struct_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+struct_field_visibilities(
+ int id: @struct_field ref,
+ int visibility: @visibility ref
+);
+
+struct_pat_fields(
+ unique int id: @struct_pat_field
+);
+
+#keyset[id, index]
+struct_pat_field_attrs(
+ int id: @struct_pat_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_pat_field_identifiers(
+ int id: @struct_pat_field ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+struct_pat_field_pats(
+ int id: @struct_pat_field ref,
+ int pat: @pat ref
+);
+
+struct_pat_field_lists(
+ unique int id: @struct_pat_field_list
+);
+
+#keyset[id, index]
+struct_pat_field_list_fields(
+ int id: @struct_pat_field_list ref,
+ int index: int ref,
+ int field: @struct_pat_field ref
+);
+
+#keyset[id]
+struct_pat_field_list_rest_pats(
+ int id: @struct_pat_field_list ref,
+ int rest_pat: @rest_pat ref
+);
+
+@token =
+ @comment
+;
+
+token_trees(
+ unique int id: @token_tree
+);
+
+tuple_fields(
+ unique int id: @tuple_field
+);
+
+#keyset[id, index]
+tuple_field_attrs(
+ int id: @tuple_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+tuple_field_type_reprs(
+ int id: @tuple_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+tuple_field_visibilities(
+ int id: @tuple_field ref,
+ int visibility: @visibility ref
+);
+
+type_bounds(
+ unique int id: @type_bound
+);
+
+#keyset[id]
+type_bound_for_binders(
+ int id: @type_bound ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+type_bound_is_async(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_is_const(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_lifetimes(
+ int id: @type_bound ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+type_bound_type_reprs(
+ int id: @type_bound ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_bound_use_bound_generic_args(
+ int id: @type_bound ref,
+ int use_bound_generic_args: @use_bound_generic_args ref
+);
+
+type_bound_lists(
+ unique int id: @type_bound_list
+);
+
+#keyset[id, index]
+type_bound_list_bounds(
+ int id: @type_bound_list ref,
+ int index: int ref,
+ int bound: @type_bound ref
+);
+
+@type_repr =
+ @array_type_repr
+| @dyn_trait_type_repr
+| @fn_ptr_type_repr
+| @for_type_repr
+| @impl_trait_type_repr
+| @infer_type_repr
+| @macro_type_repr
+| @never_type_repr
+| @paren_type_repr
+| @path_type_repr
+| @ptr_type_repr
+| @ref_type_repr
+| @slice_type_repr
+| @tuple_type_repr
+;
+
+@use_bound_generic_arg =
+ @lifetime
+| @name_ref
+;
+
+use_bound_generic_args(
+ unique int id: @use_bound_generic_args
+);
+
+#keyset[id, index]
+use_bound_generic_args_use_bound_generic_args(
+ int id: @use_bound_generic_args ref,
+ int index: int ref,
+ int use_bound_generic_arg: @use_bound_generic_arg ref
+);
+
+use_trees(
+ unique int id: @use_tree
+);
+
+#keyset[id]
+use_tree_is_glob(
+ int id: @use_tree ref
+);
+
+#keyset[id]
+use_tree_paths(
+ int id: @use_tree ref,
+ int path: @path ref
+);
+
+#keyset[id]
+use_tree_renames(
+ int id: @use_tree ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+use_tree_use_tree_lists(
+ int id: @use_tree ref,
+ int use_tree_list: @use_tree_list ref
+);
+
+use_tree_lists(
+ unique int id: @use_tree_list
+);
+
+#keyset[id, index]
+use_tree_list_use_trees(
+ int id: @use_tree_list ref,
+ int index: int ref,
+ int use_tree: @use_tree ref
+);
+
+variant_lists(
+ unique int id: @variant_list
+);
+
+#keyset[id, index]
+variant_list_variants(
+ int id: @variant_list ref,
+ int index: int ref,
+ int variant: @variant ref
+);
+
+visibilities(
+ unique int id: @visibility
+);
+
+#keyset[id]
+visibility_paths(
+ int id: @visibility ref,
+ int path: @path ref
+);
+
+where_clauses(
+ unique int id: @where_clause
+);
+
+#keyset[id, index]
+where_clause_predicates(
+ int id: @where_clause ref,
+ int index: int ref,
+ int predicate: @where_pred ref
+);
+
+where_preds(
+ unique int id: @where_pred
+);
+
+#keyset[id]
+where_pred_for_binders(
+ int id: @where_pred ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+where_pred_lifetimes(
+ int id: @where_pred ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+where_pred_type_reprs(
+ int id: @where_pred ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+where_pred_type_bound_lists(
+ int id: @where_pred ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+array_expr_internals(
+ unique int id: @array_expr_internal
+);
+
+#keyset[id, index]
+array_expr_internal_attrs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+array_expr_internal_exprs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+array_expr_internal_is_semicolon(
+ int id: @array_expr_internal ref
+);
+
+array_type_reprs(
+ unique int id: @array_type_repr
+);
+
+#keyset[id]
+array_type_repr_const_args(
+ int id: @array_type_repr ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+array_type_repr_element_type_reprs(
+ int id: @array_type_repr ref,
+ int element_type_repr: @type_repr ref
+);
+
+asm_clobber_abis(
+ unique int id: @asm_clobber_abi
+);
+
+asm_consts(
+ unique int id: @asm_const
+);
+
+#keyset[id]
+asm_const_exprs(
+ int id: @asm_const ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+asm_const_is_const(
+ int id: @asm_const ref
+);
+
+asm_labels(
+ unique int id: @asm_label
+);
+
+#keyset[id]
+asm_label_block_exprs(
+ int id: @asm_label ref,
+ int block_expr: @block_expr ref
+);
+
+asm_operand_nameds(
+ unique int id: @asm_operand_named
+);
+
+#keyset[id]
+asm_operand_named_asm_operands(
+ int id: @asm_operand_named ref,
+ int asm_operand: @asm_operand ref
+);
+
+#keyset[id]
+asm_operand_named_names(
+ int id: @asm_operand_named ref,
+ int name: @name ref
+);
+
+asm_options_lists(
+ unique int id: @asm_options_list
+);
+
+#keyset[id, index]
+asm_options_list_asm_options(
+ int id: @asm_options_list ref,
+ int index: int ref,
+ int asm_option: @asm_option ref
+);
+
+asm_reg_operands(
+ unique int id: @asm_reg_operand
+);
+
+#keyset[id]
+asm_reg_operand_asm_dir_specs(
+ int id: @asm_reg_operand ref,
+ int asm_dir_spec: @asm_dir_spec ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_operand_exprs(
+ int id: @asm_reg_operand ref,
+ int asm_operand_expr: @asm_operand_expr ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_reg_specs(
+ int id: @asm_reg_operand ref,
+ int asm_reg_spec: @asm_reg_spec ref
+);
+
+asm_syms(
+ unique int id: @asm_sym
+);
+
+#keyset[id]
+asm_sym_paths(
+ int id: @asm_sym ref,
+ int path: @path ref
+);
+
+assoc_type_args(
+ unique int id: @assoc_type_arg
+);
+
+#keyset[id]
+assoc_type_arg_const_args(
+ int id: @assoc_type_arg ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+assoc_type_arg_generic_arg_lists(
+ int id: @assoc_type_arg ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+assoc_type_arg_identifiers(
+ int id: @assoc_type_arg ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+assoc_type_arg_param_lists(
+ int id: @assoc_type_arg ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+assoc_type_arg_ret_types(
+ int id: @assoc_type_arg ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_return_type_syntaxes(
+ int id: @assoc_type_arg ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+assoc_type_arg_type_reprs(
+ int id: @assoc_type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_type_bound_lists(
+ int id: @assoc_type_arg ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+await_exprs(
+ unique int id: @await_expr
+);
+
+#keyset[id, index]
+await_expr_attrs(
+ int id: @await_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+await_expr_exprs(
+ int id: @await_expr ref,
+ int expr: @expr ref
+);
+
+become_exprs(
+ unique int id: @become_expr
+);
+
+#keyset[id, index]
+become_expr_attrs(
+ int id: @become_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+become_expr_exprs(
+ int id: @become_expr ref,
+ int expr: @expr ref
+);
+
+binary_exprs(
+ unique int id: @binary_expr
+);
+
+#keyset[id, index]
+binary_expr_attrs(
+ int id: @binary_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+binary_expr_lhs(
+ int id: @binary_expr ref,
+ int lhs: @expr ref
+);
+
+#keyset[id]
+binary_expr_operator_names(
+ int id: @binary_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+binary_expr_rhs(
+ int id: @binary_expr ref,
+ int rhs: @expr ref
+);
+
+box_pats(
+ unique int id: @box_pat
+);
+
+#keyset[id]
+box_pat_pats(
+ int id: @box_pat ref,
+ int pat: @pat ref
+);
+
+break_exprs(
+ unique int id: @break_expr
+);
+
+#keyset[id, index]
+break_expr_attrs(
+ int id: @break_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+break_expr_exprs(
+ int id: @break_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+break_expr_lifetimes(
+ int id: @break_expr ref,
+ int lifetime: @lifetime ref
+);
+
+@call_expr_base =
+ @call_expr
+| @method_call_expr
+;
+
+#keyset[id]
+call_expr_base_arg_lists(
+ int id: @call_expr_base ref,
+ int arg_list: @arg_list ref
+);
+
+#keyset[id, index]
+call_expr_base_attrs(
+ int id: @call_expr_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+cast_exprs(
+ unique int id: @cast_expr
+);
+
+#keyset[id, index]
+cast_expr_attrs(
+ int id: @cast_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+cast_expr_exprs(
+ int id: @cast_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+cast_expr_type_reprs(
+ int id: @cast_expr ref,
+ int type_repr: @type_repr ref
+);
+
+closure_exprs(
+ unique int id: @closure_expr
+);
+
+#keyset[id]
+closure_expr_bodies(
+ int id: @closure_expr ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+closure_expr_for_binders(
+ int id: @closure_expr ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+closure_expr_is_async(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_const(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_gen(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_move(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_static(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_ret_types(
+ int id: @closure_expr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+comments(
+ unique int id: @comment,
+ int parent: @ast_node ref,
+ string text: string ref
+);
+
+const_args(
+ unique int id: @const_arg
+);
+
+#keyset[id]
+const_arg_exprs(
+ int id: @const_arg ref,
+ int expr: @expr ref
+);
+
+const_block_pats(
+ unique int id: @const_block_pat
+);
+
+#keyset[id]
+const_block_pat_block_exprs(
+ int id: @const_block_pat ref,
+ int block_expr: @block_expr ref
+);
+
+#keyset[id]
+const_block_pat_is_const(
+ int id: @const_block_pat ref
+);
+
+const_params(
+ unique int id: @const_param
+);
+
+#keyset[id, index]
+const_param_attrs(
+ int id: @const_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_param_default_vals(
+ int id: @const_param ref,
+ int default_val: @const_arg ref
+);
+
+#keyset[id]
+const_param_is_const(
+ int id: @const_param ref
+);
+
+#keyset[id]
+const_param_names(
+ int id: @const_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_param_type_reprs(
+ int id: @const_param ref,
+ int type_repr: @type_repr ref
+);
+
+continue_exprs(
+ unique int id: @continue_expr
+);
+
+#keyset[id, index]
+continue_expr_attrs(
+ int id: @continue_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+continue_expr_lifetimes(
+ int id: @continue_expr ref,
+ int lifetime: @lifetime ref
+);
+
+dyn_trait_type_reprs(
+ unique int id: @dyn_trait_type_repr
+);
+
+#keyset[id]
+dyn_trait_type_repr_type_bound_lists(
+ int id: @dyn_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+expr_stmts(
+ unique int id: @expr_stmt
+);
+
+#keyset[id]
+expr_stmt_exprs(
+ int id: @expr_stmt ref,
+ int expr: @expr ref
+);
+
+field_exprs(
+ unique int id: @field_expr
+);
+
+#keyset[id, index]
+field_expr_attrs(
+ int id: @field_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+field_expr_containers(
+ int id: @field_expr ref,
+ int container: @expr ref
+);
+
+#keyset[id]
+field_expr_identifiers(
+ int id: @field_expr ref,
+ int identifier: @name_ref ref
+);
+
+fn_ptr_type_reprs(
+ unique int id: @fn_ptr_type_repr
+);
+
+#keyset[id]
+fn_ptr_type_repr_abis(
+ int id: @fn_ptr_type_repr ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_async(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_const(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_unsafe(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_param_lists(
+ int id: @fn_ptr_type_repr ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_ret_types(
+ int id: @fn_ptr_type_repr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+for_type_reprs(
+ unique int id: @for_type_repr
+);
+
+#keyset[id]
+for_type_repr_for_binders(
+ int id: @for_type_repr ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+for_type_repr_type_reprs(
+ int id: @for_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+format_args_exprs(
+ unique int id: @format_args_expr
+);
+
+#keyset[id, index]
+format_args_expr_args(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int arg: @format_args_arg ref
+);
+
+#keyset[id, index]
+format_args_expr_attrs(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+format_args_expr_templates(
+ int id: @format_args_expr ref,
+ int template: @expr ref
+);
+
+ident_pats(
+ unique int id: @ident_pat
+);
+
+#keyset[id, index]
+ident_pat_attrs(
+ int id: @ident_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ident_pat_is_mut(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_is_ref(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_names(
+ int id: @ident_pat ref,
+ int name: @name ref
+);
+
+#keyset[id]
+ident_pat_pats(
+ int id: @ident_pat ref,
+ int pat: @pat ref
+);
+
+if_exprs(
+ unique int id: @if_expr
+);
+
+#keyset[id, index]
+if_expr_attrs(
+ int id: @if_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+if_expr_conditions(
+ int id: @if_expr ref,
+ int condition: @expr ref
+);
+
+#keyset[id]
+if_expr_elses(
+ int id: @if_expr ref,
+ int else: @expr ref
+);
+
+#keyset[id]
+if_expr_thens(
+ int id: @if_expr ref,
+ int then: @block_expr ref
+);
+
+impl_trait_type_reprs(
+ unique int id: @impl_trait_type_repr
+);
+
+#keyset[id]
+impl_trait_type_repr_type_bound_lists(
+ int id: @impl_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+index_exprs(
+ unique int id: @index_expr
+);
+
+#keyset[id, index]
+index_expr_attrs(
+ int id: @index_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+index_expr_bases(
+ int id: @index_expr ref,
+ int base: @expr ref
+);
+
+#keyset[id]
+index_expr_indices(
+ int id: @index_expr ref,
+ int index: @expr ref
+);
+
+infer_type_reprs(
+ unique int id: @infer_type_repr
+);
+
+@item =
+ @adt
+| @asm_expr
+| @assoc_item
+| @extern_block
+| @extern_crate
+| @extern_item
+| @impl
+| @macro_def
+| @macro_rules
+| @module
+| @trait
+| @trait_alias
+| @use
+;
+
+#keyset[id]
+item_attribute_macro_expansions(
+ int id: @item ref,
+ int attribute_macro_expansion: @macro_items ref
+);
+
+@labelable_expr =
+ @block_expr
+| @looping_expr
+;
+
+#keyset[id]
+labelable_expr_labels(
+ int id: @labelable_expr ref,
+ int label: @label ref
+);
+
+let_exprs(
+ unique int id: @let_expr
+);
+
+#keyset[id, index]
+let_expr_attrs(
+ int id: @let_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_expr_scrutinees(
+ int id: @let_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+let_expr_pats(
+ int id: @let_expr ref,
+ int pat: @pat ref
+);
+
+let_stmts(
+ unique int id: @let_stmt
+);
+
+#keyset[id, index]
+let_stmt_attrs(
+ int id: @let_stmt ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_stmt_initializers(
+ int id: @let_stmt ref,
+ int initializer: @expr ref
+);
+
+#keyset[id]
+let_stmt_let_elses(
+ int id: @let_stmt ref,
+ int let_else: @let_else ref
+);
+
+#keyset[id]
+let_stmt_pats(
+ int id: @let_stmt ref,
+ int pat: @pat ref
+);
+
+#keyset[id]
+let_stmt_type_reprs(
+ int id: @let_stmt ref,
+ int type_repr: @type_repr ref
+);
+
+lifetimes(
+ unique int id: @lifetime
+);
+
+#keyset[id]
+lifetime_texts(
+ int id: @lifetime ref,
+ string text: string ref
+);
+
+lifetime_args(
+ unique int id: @lifetime_arg
+);
+
+#keyset[id]
+lifetime_arg_lifetimes(
+ int id: @lifetime_arg ref,
+ int lifetime: @lifetime ref
+);
+
+lifetime_params(
+ unique int id: @lifetime_param
+);
+
+#keyset[id, index]
+lifetime_param_attrs(
+ int id: @lifetime_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+lifetime_param_lifetimes(
+ int id: @lifetime_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+lifetime_param_type_bound_lists(
+ int id: @lifetime_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+literal_exprs(
+ unique int id: @literal_expr
+);
+
+#keyset[id, index]
+literal_expr_attrs(
+ int id: @literal_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+literal_expr_text_values(
+ int id: @literal_expr ref,
+ string text_value: string ref
+);
+
+literal_pats(
+ unique int id: @literal_pat
+);
+
+#keyset[id]
+literal_pat_literals(
+ int id: @literal_pat ref,
+ int literal: @literal_expr ref
+);
+
+macro_block_exprs(
+ unique int id: @macro_block_expr
+);
+
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
+#keyset[id, index]
+macro_block_expr_statements(
+ int id: @macro_block_expr ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+macro_exprs(
+ unique int id: @macro_expr
+);
+
+#keyset[id]
+macro_expr_macro_calls(
+ int id: @macro_expr ref,
+ int macro_call: @macro_call ref
+);
+
+macro_pats(
+ unique int id: @macro_pat
+);
+
+#keyset[id]
+macro_pat_macro_calls(
+ int id: @macro_pat ref,
+ int macro_call: @macro_call ref
+);
+
+macro_type_reprs(
+ unique int id: @macro_type_repr
+);
+
+#keyset[id]
+macro_type_repr_macro_calls(
+ int id: @macro_type_repr ref,
+ int macro_call: @macro_call ref
+);
+
+match_exprs(
+ unique int id: @match_expr
+);
+
+#keyset[id, index]
+match_expr_attrs(
+ int id: @match_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_expr_scrutinees(
+ int id: @match_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+match_expr_match_arm_lists(
+ int id: @match_expr ref,
+ int match_arm_list: @match_arm_list ref
+);
+
+name_refs(
+ unique int id: @name_ref
+);
+
+#keyset[id]
+name_ref_texts(
+ int id: @name_ref ref,
+ string text: string ref
+);
+
+never_type_reprs(
+ unique int id: @never_type_repr
+);
+
+offset_of_exprs(
+ unique int id: @offset_of_expr
+);
+
+#keyset[id, index]
+offset_of_expr_attrs(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+offset_of_expr_fields(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int field: @name_ref ref
+);
+
+#keyset[id]
+offset_of_expr_type_reprs(
+ int id: @offset_of_expr ref,
+ int type_repr: @type_repr ref
+);
+
+or_pats(
+ unique int id: @or_pat
+);
+
+#keyset[id, index]
+or_pat_pats(
+ int id: @or_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+params(
+ unique int id: @param
+);
+
+#keyset[id]
+param_pats(
+ int id: @param ref,
+ int pat: @pat ref
+);
+
+paren_exprs(
+ unique int id: @paren_expr
+);
+
+#keyset[id, index]
+paren_expr_attrs(
+ int id: @paren_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+paren_expr_exprs(
+ int id: @paren_expr ref,
+ int expr: @expr ref
+);
+
+paren_pats(
+ unique int id: @paren_pat
+);
+
+#keyset[id]
+paren_pat_pats(
+ int id: @paren_pat ref,
+ int pat: @pat ref
+);
+
+paren_type_reprs(
+ unique int id: @paren_type_repr
+);
+
+#keyset[id]
+paren_type_repr_type_reprs(
+ int id: @paren_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+@path_ast_node =
+ @path_expr
+| @path_pat
+| @struct_expr
+| @struct_pat
+| @tuple_struct_pat
+;
+
+#keyset[id]
+path_ast_node_paths(
+ int id: @path_ast_node ref,
+ int path: @path ref
+);
+
+@path_expr_base =
+ @path_expr
+;
+
+path_type_reprs(
+ unique int id: @path_type_repr
+);
+
+#keyset[id]
+path_type_repr_paths(
+ int id: @path_type_repr ref,
+ int path: @path ref
+);
+
+prefix_exprs(
+ unique int id: @prefix_expr
+);
+
+#keyset[id, index]
+prefix_expr_attrs(
+ int id: @prefix_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+prefix_expr_exprs(
+ int id: @prefix_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+prefix_expr_operator_names(
+ int id: @prefix_expr ref,
+ string operator_name: string ref
+);
+
+ptr_type_reprs(
+ unique int id: @ptr_type_repr
+);
+
+#keyset[id]
+ptr_type_repr_is_const(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_is_mut(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_type_reprs(
+ int id: @ptr_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+range_exprs(
+ unique int id: @range_expr
+);
+
+#keyset[id, index]
+range_expr_attrs(
+ int id: @range_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+range_expr_ends(
+ int id: @range_expr ref,
+ int end: @expr ref
+);
+
+#keyset[id]
+range_expr_operator_names(
+ int id: @range_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_expr_starts(
+ int id: @range_expr ref,
+ int start: @expr ref
+);
+
+range_pats(
+ unique int id: @range_pat
+);
+
+#keyset[id]
+range_pat_ends(
+ int id: @range_pat ref,
+ int end: @pat ref
+);
+
+#keyset[id]
+range_pat_operator_names(
+ int id: @range_pat ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_pat_starts(
+ int id: @range_pat ref,
+ int start: @pat ref
+);
+
+ref_exprs(
+ unique int id: @ref_expr
+);
+
+#keyset[id, index]
+ref_expr_attrs(
+ int id: @ref_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ref_expr_exprs(
+ int id: @ref_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+ref_expr_is_const(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_mut(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_raw(
+ int id: @ref_expr ref
+);
+
+ref_pats(
+ unique int id: @ref_pat
+);
+
+#keyset[id]
+ref_pat_is_mut(
+ int id: @ref_pat ref
+);
+
+#keyset[id]
+ref_pat_pats(
+ int id: @ref_pat ref,
+ int pat: @pat ref
+);
+
+ref_type_reprs(
+ unique int id: @ref_type_repr
+);
+
+#keyset[id]
+ref_type_repr_is_mut(
+ int id: @ref_type_repr ref
+);
+
+#keyset[id]
+ref_type_repr_lifetimes(
+ int id: @ref_type_repr ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+ref_type_repr_type_reprs(
+ int id: @ref_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+rest_pats(
+ unique int id: @rest_pat
+);
+
+#keyset[id, index]
+rest_pat_attrs(
+ int id: @rest_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+return_exprs(
+ unique int id: @return_expr
+);
+
+#keyset[id, index]
+return_expr_attrs(
+ int id: @return_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+return_expr_exprs(
+ int id: @return_expr ref,
+ int expr: @expr ref
+);
+
+self_params(
+ unique int id: @self_param
+);
+
+#keyset[id]
+self_param_is_ref(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_is_mut(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_lifetimes(
+ int id: @self_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+self_param_names(
+ int id: @self_param ref,
+ int name: @name ref
+);
+
+slice_pats(
+ unique int id: @slice_pat
+);
+
+#keyset[id, index]
+slice_pat_pats(
+ int id: @slice_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+slice_type_reprs(
+ unique int id: @slice_type_repr
+);
+
+#keyset[id]
+slice_type_repr_type_reprs(
+ int id: @slice_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+struct_field_lists(
+ unique int id: @struct_field_list
+);
+
+#keyset[id, index]
+struct_field_list_fields(
+ int id: @struct_field_list ref,
+ int index: int ref,
+ int field: @struct_field ref
+);
+
+try_exprs(
+ unique int id: @try_expr
+);
+
+#keyset[id, index]
+try_expr_attrs(
+ int id: @try_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+try_expr_exprs(
+ int id: @try_expr ref,
+ int expr: @expr ref
+);
+
+tuple_exprs(
+ unique int id: @tuple_expr
+);
+
+#keyset[id, index]
+tuple_expr_attrs(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+tuple_expr_fields(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int field: @expr ref
+);
+
+tuple_field_lists(
+ unique int id: @tuple_field_list
+);
+
+#keyset[id, index]
+tuple_field_list_fields(
+ int id: @tuple_field_list ref,
+ int index: int ref,
+ int field: @tuple_field ref
+);
+
+tuple_pats(
+ unique int id: @tuple_pat
+);
+
+#keyset[id, index]
+tuple_pat_fields(
+ int id: @tuple_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+tuple_type_reprs(
+ unique int id: @tuple_type_repr
+);
+
+#keyset[id, index]
+tuple_type_repr_fields(
+ int id: @tuple_type_repr ref,
+ int index: int ref,
+ int field: @type_repr ref
+);
+
+type_args(
+ unique int id: @type_arg
+);
+
+#keyset[id]
+type_arg_type_reprs(
+ int id: @type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+type_params(
+ unique int id: @type_param
+);
+
+#keyset[id, index]
+type_param_attrs(
+ int id: @type_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_param_default_types(
+ int id: @type_param ref,
+ int default_type: @type_repr ref
+);
+
+#keyset[id]
+type_param_names(
+ int id: @type_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_param_type_bound_lists(
+ int id: @type_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+underscore_exprs(
+ unique int id: @underscore_expr
+);
+
+#keyset[id, index]
+underscore_expr_attrs(
+ int id: @underscore_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+variants(
+ unique int id: @variant
+);
+
+#keyset[id, index]
+variant_attrs(
+ int id: @variant ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+variant_discriminants(
+ int id: @variant ref,
+ int discriminant: @expr ref
+);
+
+#keyset[id]
+variant_field_lists(
+ int id: @variant ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+variant_names(
+ int id: @variant ref,
+ int name: @name ref
+);
+
+#keyset[id]
+variant_visibilities(
+ int id: @variant ref,
+ int visibility: @visibility ref
+);
+
+wildcard_pats(
+ unique int id: @wildcard_pat
+);
+
+yeet_exprs(
+ unique int id: @yeet_expr
+);
+
+#keyset[id, index]
+yeet_expr_attrs(
+ int id: @yeet_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yeet_expr_exprs(
+ int id: @yeet_expr ref,
+ int expr: @expr ref
+);
+
+yield_exprs(
+ unique int id: @yield_expr
+);
+
+#keyset[id, index]
+yield_expr_attrs(
+ int id: @yield_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yield_expr_exprs(
+ int id: @yield_expr ref,
+ int expr: @expr ref
+);
+
+@adt =
+ @enum
+| @struct
+| @union
+;
+
+#keyset[id, index]
+adt_derive_macro_expansions(
+ int id: @adt ref,
+ int index: int ref,
+ int derive_macro_expansion: @macro_items ref
+);
+
+asm_exprs(
+ unique int id: @asm_expr
+);
+
+#keyset[id, index]
+asm_expr_asm_pieces(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int asm_piece: @asm_piece ref
+);
+
+#keyset[id, index]
+asm_expr_attrs(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+asm_expr_templates(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int template: @expr ref
+);
+
+@assoc_item =
+ @const
+| @function
+| @macro_call
+| @type_alias
+;
+
+block_exprs(
+ unique int id: @block_expr
+);
+
+#keyset[id, index]
+block_expr_attrs(
+ int id: @block_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+block_expr_is_async(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_const(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_gen(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_move(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_try(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_unsafe(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_stmt_lists(
+ int id: @block_expr ref,
+ int stmt_list: @stmt_list ref
+);
+
+call_exprs(
+ unique int id: @call_expr
+);
+
+#keyset[id]
+call_expr_functions(
+ int id: @call_expr ref,
+ int function: @expr ref
+);
+
+extern_blocks(
+ unique int id: @extern_block
+);
+
+#keyset[id]
+extern_block_abis(
+ int id: @extern_block ref,
+ int abi: @abi ref
+);
+
+#keyset[id, index]
+extern_block_attrs(
+ int id: @extern_block ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_block_extern_item_lists(
+ int id: @extern_block ref,
+ int extern_item_list: @extern_item_list ref
+);
+
+#keyset[id]
+extern_block_is_unsafe(
+ int id: @extern_block ref
+);
+
+extern_crates(
+ unique int id: @extern_crate
+);
+
+#keyset[id, index]
+extern_crate_attrs(
+ int id: @extern_crate ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_crate_identifiers(
+ int id: @extern_crate ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+extern_crate_renames(
+ int id: @extern_crate ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+extern_crate_visibilities(
+ int id: @extern_crate ref,
+ int visibility: @visibility ref
+);
+
+@extern_item =
+ @function
+| @macro_call
+| @static
+| @type_alias
+;
+
+impls(
+ unique int id: @impl
+);
+
+#keyset[id]
+impl_assoc_item_lists(
+ int id: @impl ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+impl_attrs(
+ int id: @impl ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+impl_generic_param_lists(
+ int id: @impl ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+impl_is_const(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_default(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_unsafe(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_self_ties(
+ int id: @impl ref,
+ int self_ty: @type_repr ref
+);
+
+#keyset[id]
+impl_traits(
+ int id: @impl ref,
+ int trait: @type_repr ref
+);
+
+#keyset[id]
+impl_visibilities(
+ int id: @impl ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+impl_where_clauses(
+ int id: @impl ref,
+ int where_clause: @where_clause ref
+);
+
+@looping_expr =
+ @for_expr
+| @loop_expr
+| @while_expr
+;
+
+#keyset[id]
+looping_expr_loop_bodies(
+ int id: @looping_expr ref,
+ int loop_body: @block_expr ref
+);
+
+macro_defs(
+ unique int id: @macro_def
+);
+
+#keyset[id]
+macro_def_args(
+ int id: @macro_def ref,
+ int args: @token_tree ref
+);
+
+#keyset[id, index]
+macro_def_attrs(
+ int id: @macro_def ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_def_bodies(
+ int id: @macro_def ref,
+ int body: @token_tree ref
+);
+
+#keyset[id]
+macro_def_names(
+ int id: @macro_def ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_def_visibilities(
+ int id: @macro_def ref,
+ int visibility: @visibility ref
+);
+
+macro_rules(
+ unique int id: @macro_rules
+);
+
+#keyset[id, index]
+macro_rules_attrs(
+ int id: @macro_rules ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_rules_names(
+ int id: @macro_rules ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_rules_token_trees(
+ int id: @macro_rules ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_rules_visibilities(
+ int id: @macro_rules ref,
+ int visibility: @visibility ref
+);
+
+method_call_exprs(
+ unique int id: @method_call_expr
+);
+
+#keyset[id]
+method_call_expr_generic_arg_lists(
+ int id: @method_call_expr ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+method_call_expr_identifiers(
+ int id: @method_call_expr ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+method_call_expr_receivers(
+ int id: @method_call_expr ref,
+ int receiver: @expr ref
+);
+
+modules(
+ unique int id: @module
+);
+
+#keyset[id, index]
+module_attrs(
+ int id: @module ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+module_item_lists(
+ int id: @module ref,
+ int item_list: @item_list ref
+);
+
+#keyset[id]
+module_names(
+ int id: @module ref,
+ int name: @name ref
+);
+
+#keyset[id]
+module_visibilities(
+ int id: @module ref,
+ int visibility: @visibility ref
+);
+
+path_exprs(
+ unique int id: @path_expr
+);
+
+#keyset[id, index]
+path_expr_attrs(
+ int id: @path_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+path_pats(
+ unique int id: @path_pat
+);
+
+struct_exprs(
+ unique int id: @struct_expr
+);
+
+#keyset[id]
+struct_expr_struct_expr_field_lists(
+ int id: @struct_expr ref,
+ int struct_expr_field_list: @struct_expr_field_list ref
+);
+
+struct_pats(
+ unique int id: @struct_pat
+);
+
+#keyset[id]
+struct_pat_struct_pat_field_lists(
+ int id: @struct_pat ref,
+ int struct_pat_field_list: @struct_pat_field_list ref
+);
+
+traits(
+ unique int id: @trait
+);
+
+#keyset[id]
+trait_assoc_item_lists(
+ int id: @trait ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+trait_attrs(
+ int id: @trait ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_generic_param_lists(
+ int id: @trait ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_is_auto(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_is_unsafe(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_names(
+ int id: @trait ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_type_bound_lists(
+ int id: @trait ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_visibilities(
+ int id: @trait ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_where_clauses(
+ int id: @trait ref,
+ int where_clause: @where_clause ref
+);
+
+trait_aliases(
+ unique int id: @trait_alias
+);
+
+#keyset[id, index]
+trait_alias_attrs(
+ int id: @trait_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_alias_generic_param_lists(
+ int id: @trait_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_alias_names(
+ int id: @trait_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_alias_type_bound_lists(
+ int id: @trait_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_alias_visibilities(
+ int id: @trait_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_alias_where_clauses(
+ int id: @trait_alias ref,
+ int where_clause: @where_clause ref
+);
+
+tuple_struct_pats(
+ unique int id: @tuple_struct_pat
+);
+
+#keyset[id, index]
+tuple_struct_pat_fields(
+ int id: @tuple_struct_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+uses(
+ unique int id: @use
+);
+
+#keyset[id, index]
+use_attrs(
+ int id: @use ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+use_use_trees(
+ int id: @use ref,
+ int use_tree: @use_tree ref
+);
+
+#keyset[id]
+use_visibilities(
+ int id: @use ref,
+ int visibility: @visibility ref
+);
+
+consts(
+ unique int id: @const
+);
+
+#keyset[id, index]
+const_attrs(
+ int id: @const ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_bodies(
+ int id: @const ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+const_generic_param_lists(
+ int id: @const ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+const_is_const(
+ int id: @const ref
+);
+
+#keyset[id]
+const_is_default(
+ int id: @const ref
+);
+
+#keyset[id]
+const_names(
+ int id: @const ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_type_reprs(
+ int id: @const ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+const_visibilities(
+ int id: @const ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+const_where_clauses(
+ int id: @const ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+const_has_implementation(
+ int id: @const ref
+);
+
+enums(
+ unique int id: @enum
+);
+
+#keyset[id, index]
+enum_attrs(
+ int id: @enum ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+enum_generic_param_lists(
+ int id: @enum ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+enum_names(
+ int id: @enum ref,
+ int name: @name ref
+);
+
+#keyset[id]
+enum_variant_lists(
+ int id: @enum ref,
+ int variant_list: @variant_list ref
+);
+
+#keyset[id]
+enum_visibilities(
+ int id: @enum ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+enum_where_clauses(
+ int id: @enum ref,
+ int where_clause: @where_clause ref
+);
+
+for_exprs(
+ unique int id: @for_expr
+);
+
+#keyset[id, index]
+for_expr_attrs(
+ int id: @for_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+for_expr_iterables(
+ int id: @for_expr ref,
+ int iterable: @expr ref
+);
+
+#keyset[id]
+for_expr_pats(
+ int id: @for_expr ref,
+ int pat: @pat ref
+);
+
+functions(
+ unique int id: @function
+);
+
+#keyset[id]
+function_abis(
+ int id: @function ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+function_bodies(
+ int id: @function ref,
+ int body: @block_expr ref
+);
+
+#keyset[id]
+function_generic_param_lists(
+ int id: @function ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+function_is_async(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_const(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_default(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_gen(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_unsafe(
+ int id: @function ref
+);
+
+#keyset[id]
+function_names(
+ int id: @function ref,
+ int name: @name ref
+);
+
+#keyset[id]
+function_ret_types(
+ int id: @function ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+function_visibilities(
+ int id: @function ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+function_where_clauses(
+ int id: @function ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+function_has_implementation(
+ int id: @function ref
+);
+
+loop_exprs(
+ unique int id: @loop_expr
+);
+
+#keyset[id, index]
+loop_expr_attrs(
+ int id: @loop_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+macro_calls(
+ unique int id: @macro_call
+);
+
+#keyset[id, index]
+macro_call_attrs(
+ int id: @macro_call ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_call_paths(
+ int id: @macro_call ref,
+ int path: @path ref
+);
+
+#keyset[id]
+macro_call_token_trees(
+ int id: @macro_call ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_call_macro_call_expansions(
+ int id: @macro_call ref,
+ int macro_call_expansion: @ast_node ref
+);
+
+statics(
+ unique int id: @static
+);
+
+#keyset[id, index]
+static_attrs(
+ int id: @static ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+static_bodies(
+ int id: @static ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+static_is_mut(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_static(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_unsafe(
+ int id: @static ref
+);
+
+#keyset[id]
+static_names(
+ int id: @static ref,
+ int name: @name ref
+);
+
+#keyset[id]
+static_type_reprs(
+ int id: @static ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+static_visibilities(
+ int id: @static ref,
+ int visibility: @visibility ref
+);
+
+structs(
+ unique int id: @struct
+);
+
+#keyset[id, index]
+struct_attrs(
+ int id: @struct ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_lists_(
+ int id: @struct ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+struct_generic_param_lists(
+ int id: @struct ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+struct_names(
+ int id: @struct ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_visibilities(
+ int id: @struct ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+struct_where_clauses(
+ int id: @struct ref,
+ int where_clause: @where_clause ref
+);
+
+type_aliases(
+ unique int id: @type_alias
+);
+
+#keyset[id, index]
+type_alias_attrs(
+ int id: @type_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_alias_generic_param_lists(
+ int id: @type_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+type_alias_is_default(
+ int id: @type_alias ref
+);
+
+#keyset[id]
+type_alias_names(
+ int id: @type_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_alias_type_reprs(
+ int id: @type_alias ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_alias_type_bound_lists(
+ int id: @type_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+type_alias_visibilities(
+ int id: @type_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+type_alias_where_clauses(
+ int id: @type_alias ref,
+ int where_clause: @where_clause ref
+);
+
+unions(
+ unique int id: @union
+);
+
+#keyset[id, index]
+union_attrs(
+ int id: @union ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+union_generic_param_lists(
+ int id: @union ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+union_names(
+ int id: @union ref,
+ int name: @name ref
+);
+
+#keyset[id]
+union_struct_field_lists(
+ int id: @union ref,
+ int struct_field_list: @struct_field_list ref
+);
+
+#keyset[id]
+union_visibilities(
+ int id: @union ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+union_where_clauses(
+ int id: @union ref,
+ int where_clause: @where_clause ref
+);
+
+while_exprs(
+ unique int id: @while_expr
+);
+
+#keyset[id, index]
+while_expr_attrs(
+ int id: @while_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+while_expr_conditions(
+ int id: @while_expr ref,
+ int condition: @expr ref
+);
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/rust.dbscheme b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/rust.dbscheme
new file mode 100644
index 00000000000..319c933d961
--- /dev/null
+++ b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/rust.dbscheme
@@ -0,0 +1,3637 @@
+// generated by codegen, do not edit
+
+// from ../shared/tree-sitter-extractor/src/generator/prefix.dbscheme
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Empty location -*/
+
+empty_location(
+ int location: @location_default ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- Diagnostic messages -*/
+
+diagnostics(
+ unique int id: @diagnostic,
+ int severity: int ref,
+ string error_tag: string ref,
+ string error_message: string ref,
+ string full_error_message: string ref,
+ int location: @location_default ref
+);
+
+/*- Diagnostic messages: severity -*/
+
+case @diagnostic.severity of
+ 10 = @diagnostic_debug
+| 20 = @diagnostic_info
+| 30 = @diagnostic_warning
+| 40 = @diagnostic_error
+;
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
+
+overlayChangedFiles(
+ string path: string ref
+);
+
+
+// from prefix.dbscheme
+#keyset[id]
+locatable_locations(
+ int id: @locatable ref,
+ int location: @location_default ref
+);
+
+
+// from schema
+
+@element =
+ @extractor_step
+| @locatable
+| @named_crate
+| @unextracted
+;
+
+extractor_steps(
+ unique int id: @extractor_step,
+ string action: string ref,
+ int duration_ms: int ref
+);
+
+#keyset[id]
+extractor_step_files(
+ int id: @extractor_step ref,
+ int file: @file ref
+);
+
+@locatable =
+ @ast_node
+| @crate
+;
+
+named_crates(
+ unique int id: @named_crate,
+ string name: string ref,
+ int crate: @crate ref
+);
+
+@unextracted =
+ @missing
+| @unimplemented
+;
+
+@ast_node =
+ @abi
+| @addressable
+| @arg_list
+| @asm_dir_spec
+| @asm_operand
+| @asm_operand_expr
+| @asm_option
+| @asm_piece
+| @asm_reg_spec
+| @assoc_item_list
+| @attr
+| @callable
+| @closure_binder
+| @expr
+| @extern_item_list
+| @field_list
+| @format_args_arg
+| @generic_arg
+| @generic_arg_list
+| @generic_param
+| @generic_param_list
+| @item_list
+| @label
+| @let_else
+| @macro_items
+| @match_arm
+| @match_arm_list
+| @match_guard
+| @meta
+| @name
+| @param_base
+| @param_list
+| @parenthesized_arg_list
+| @pat
+| @path
+| @path_segment
+| @rename
+| @resolvable
+| @ret_type_repr
+| @return_type_syntax
+| @source_file
+| @stmt
+| @stmt_list
+| @struct_expr_field
+| @struct_expr_field_list
+| @struct_field
+| @struct_pat_field
+| @struct_pat_field_list
+| @token
+| @token_tree
+| @tuple_field
+| @type_bound
+| @type_bound_list
+| @type_repr
+| @use_bound_generic_arg
+| @use_bound_generic_args
+| @use_tree
+| @use_tree_list
+| @variant_list
+| @visibility
+| @where_clause
+| @where_pred
+;
+
+crates(
+ unique int id: @crate
+);
+
+#keyset[id]
+crate_names(
+ int id: @crate ref,
+ string name: string ref
+);
+
+#keyset[id]
+crate_versions(
+ int id: @crate ref,
+ string version: string ref
+);
+
+#keyset[id, index]
+crate_cfg_options(
+ int id: @crate ref,
+ int index: int ref,
+ string cfg_option: string ref
+);
+
+#keyset[id, index]
+crate_named_dependencies(
+ int id: @crate ref,
+ int index: int ref,
+ int named_dependency: @named_crate ref
+);
+
+missings(
+ unique int id: @missing
+);
+
+unimplementeds(
+ unique int id: @unimplemented
+);
+
+abis(
+ unique int id: @abi
+);
+
+#keyset[id]
+abi_abi_strings(
+ int id: @abi ref,
+ string abi_string: string ref
+);
+
+@addressable =
+ @item
+| @variant
+;
+
+#keyset[id]
+addressable_extended_canonical_paths(
+ int id: @addressable ref,
+ string extended_canonical_path: string ref
+);
+
+#keyset[id]
+addressable_crate_origins(
+ int id: @addressable ref,
+ string crate_origin: string ref
+);
+
+arg_lists(
+ unique int id: @arg_list
+);
+
+#keyset[id, index]
+arg_list_args(
+ int id: @arg_list ref,
+ int index: int ref,
+ int arg: @expr ref
+);
+
+asm_dir_specs(
+ unique int id: @asm_dir_spec
+);
+
+@asm_operand =
+ @asm_const
+| @asm_label
+| @asm_reg_operand
+| @asm_sym
+;
+
+asm_operand_exprs(
+ unique int id: @asm_operand_expr
+);
+
+#keyset[id]
+asm_operand_expr_in_exprs(
+ int id: @asm_operand_expr ref,
+ int in_expr: @expr ref
+);
+
+#keyset[id]
+asm_operand_expr_out_exprs(
+ int id: @asm_operand_expr ref,
+ int out_expr: @expr ref
+);
+
+asm_options(
+ unique int id: @asm_option
+);
+
+#keyset[id]
+asm_option_is_raw(
+ int id: @asm_option ref
+);
+
+@asm_piece =
+ @asm_clobber_abi
+| @asm_operand_named
+| @asm_options_list
+;
+
+asm_reg_specs(
+ unique int id: @asm_reg_spec
+);
+
+#keyset[id]
+asm_reg_spec_identifiers(
+ int id: @asm_reg_spec ref,
+ int identifier: @name_ref ref
+);
+
+assoc_item_lists(
+ unique int id: @assoc_item_list
+);
+
+#keyset[id, index]
+assoc_item_list_assoc_items(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int assoc_item: @assoc_item ref
+);
+
+#keyset[id, index]
+assoc_item_list_attrs(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+attrs(
+ unique int id: @attr
+);
+
+#keyset[id]
+attr_meta(
+ int id: @attr ref,
+ int meta: @meta ref
+);
+
+@callable =
+ @closure_expr
+| @function
+;
+
+#keyset[id]
+callable_param_lists(
+ int id: @callable ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id, index]
+callable_attrs(
+ int id: @callable ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+closure_binders(
+ unique int id: @closure_binder
+);
+
+#keyset[id]
+closure_binder_generic_param_lists(
+ int id: @closure_binder ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+@expr =
+ @array_expr_internal
+| @asm_expr
+| @await_expr
+| @become_expr
+| @binary_expr
+| @break_expr
+| @call_expr_base
+| @cast_expr
+| @closure_expr
+| @continue_expr
+| @field_expr
+| @format_args_expr
+| @if_expr
+| @index_expr
+| @labelable_expr
+| @let_expr
+| @literal_expr
+| @macro_block_expr
+| @macro_expr
+| @match_expr
+| @offset_of_expr
+| @paren_expr
+| @path_expr_base
+| @prefix_expr
+| @range_expr
+| @ref_expr
+| @return_expr
+| @struct_expr
+| @try_expr
+| @tuple_expr
+| @underscore_expr
+| @yeet_expr
+| @yield_expr
+;
+
+extern_item_lists(
+ unique int id: @extern_item_list
+);
+
+#keyset[id, index]
+extern_item_list_attrs(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+extern_item_list_extern_items(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int extern_item: @extern_item ref
+);
+
+@field_list =
+ @struct_field_list
+| @tuple_field_list
+;
+
+format_args_args(
+ unique int id: @format_args_arg
+);
+
+#keyset[id]
+format_args_arg_exprs(
+ int id: @format_args_arg ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+format_args_arg_names(
+ int id: @format_args_arg ref,
+ int name: @name ref
+);
+
+@generic_arg =
+ @assoc_type_arg
+| @const_arg
+| @lifetime_arg
+| @type_arg
+;
+
+generic_arg_lists(
+ unique int id: @generic_arg_list
+);
+
+#keyset[id, index]
+generic_arg_list_generic_args(
+ int id: @generic_arg_list ref,
+ int index: int ref,
+ int generic_arg: @generic_arg ref
+);
+
+@generic_param =
+ @const_param
+| @lifetime_param
+| @type_param
+;
+
+generic_param_lists(
+ unique int id: @generic_param_list
+);
+
+#keyset[id, index]
+generic_param_list_generic_params(
+ int id: @generic_param_list ref,
+ int index: int ref,
+ int generic_param: @generic_param ref
+);
+
+item_lists(
+ unique int id: @item_list
+);
+
+#keyset[id, index]
+item_list_attrs(
+ int id: @item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+item_list_items(
+ int id: @item_list ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+labels(
+ unique int id: @label
+);
+
+#keyset[id]
+label_lifetimes(
+ int id: @label ref,
+ int lifetime: @lifetime ref
+);
+
+let_elses(
+ unique int id: @let_else
+);
+
+#keyset[id]
+let_else_block_exprs(
+ int id: @let_else ref,
+ int block_expr: @block_expr ref
+);
+
+macro_items(
+ unique int id: @macro_items
+);
+
+#keyset[id, index]
+macro_items_items(
+ int id: @macro_items ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+match_arms(
+ unique int id: @match_arm
+);
+
+#keyset[id, index]
+match_arm_attrs(
+ int id: @match_arm ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_arm_exprs(
+ int id: @match_arm ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+match_arm_guards(
+ int id: @match_arm ref,
+ int guard: @match_guard ref
+);
+
+#keyset[id]
+match_arm_pats(
+ int id: @match_arm ref,
+ int pat: @pat ref
+);
+
+match_arm_lists(
+ unique int id: @match_arm_list
+);
+
+#keyset[id, index]
+match_arm_list_arms(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int arm: @match_arm ref
+);
+
+#keyset[id, index]
+match_arm_list_attrs(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+match_guards(
+ unique int id: @match_guard
+);
+
+#keyset[id]
+match_guard_conditions(
+ int id: @match_guard ref,
+ int condition: @expr ref
+);
+
+meta(
+ unique int id: @meta
+);
+
+#keyset[id]
+meta_exprs(
+ int id: @meta ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+meta_is_unsafe(
+ int id: @meta ref
+);
+
+#keyset[id]
+meta_paths(
+ int id: @meta ref,
+ int path: @path ref
+);
+
+#keyset[id]
+meta_token_trees(
+ int id: @meta ref,
+ int token_tree: @token_tree ref
+);
+
+names(
+ unique int id: @name
+);
+
+#keyset[id]
+name_texts(
+ int id: @name ref,
+ string text: string ref
+);
+
+@param_base =
+ @param
+| @self_param
+;
+
+#keyset[id, index]
+param_base_attrs(
+ int id: @param_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+param_base_type_reprs(
+ int id: @param_base ref,
+ int type_repr: @type_repr ref
+);
+
+param_lists(
+ unique int id: @param_list
+);
+
+#keyset[id, index]
+param_list_params(
+ int id: @param_list ref,
+ int index: int ref,
+ int param: @param ref
+);
+
+#keyset[id]
+param_list_self_params(
+ int id: @param_list ref,
+ int self_param: @self_param ref
+);
+
+parenthesized_arg_lists(
+ unique int id: @parenthesized_arg_list
+);
+
+#keyset[id, index]
+parenthesized_arg_list_type_args(
+ int id: @parenthesized_arg_list ref,
+ int index: int ref,
+ int type_arg: @type_arg ref
+);
+
+@pat =
+ @box_pat
+| @const_block_pat
+| @ident_pat
+| @literal_pat
+| @macro_pat
+| @or_pat
+| @paren_pat
+| @path_pat
+| @range_pat
+| @ref_pat
+| @rest_pat
+| @slice_pat
+| @struct_pat
+| @tuple_pat
+| @tuple_struct_pat
+| @wildcard_pat
+;
+
+paths(
+ unique int id: @path
+);
+
+#keyset[id]
+path_qualifiers(
+ int id: @path ref,
+ int qualifier: @path ref
+);
+
+#keyset[id]
+path_segments_(
+ int id: @path ref,
+ int segment: @path_segment ref
+);
+
+path_segments(
+ unique int id: @path_segment
+);
+
+#keyset[id]
+path_segment_generic_arg_lists(
+ int id: @path_segment ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+path_segment_identifiers(
+ int id: @path_segment ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+path_segment_parenthesized_arg_lists(
+ int id: @path_segment ref,
+ int parenthesized_arg_list: @parenthesized_arg_list ref
+);
+
+#keyset[id]
+path_segment_ret_types(
+ int id: @path_segment ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+path_segment_return_type_syntaxes(
+ int id: @path_segment ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+path_segment_type_reprs(
+ int id: @path_segment ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+path_segment_trait_type_reprs(
+ int id: @path_segment ref,
+ int trait_type_repr: @path_type_repr ref
+);
+
+renames(
+ unique int id: @rename
+);
+
+#keyset[id]
+rename_names(
+ int id: @rename ref,
+ int name: @name ref
+);
+
+@resolvable =
+ @method_call_expr
+| @path_ast_node
+;
+
+#keyset[id]
+resolvable_resolved_paths(
+ int id: @resolvable ref,
+ string resolved_path: string ref
+);
+
+#keyset[id]
+resolvable_resolved_crate_origins(
+ int id: @resolvable ref,
+ string resolved_crate_origin: string ref
+);
+
+ret_type_reprs(
+ unique int id: @ret_type_repr
+);
+
+#keyset[id]
+ret_type_repr_type_reprs(
+ int id: @ret_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+return_type_syntaxes(
+ unique int id: @return_type_syntax
+);
+
+source_files(
+ unique int id: @source_file
+);
+
+#keyset[id, index]
+source_file_attrs(
+ int id: @source_file ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+source_file_items(
+ int id: @source_file ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+@stmt =
+ @expr_stmt
+| @item
+| @let_stmt
+;
+
+stmt_lists(
+ unique int id: @stmt_list
+);
+
+#keyset[id, index]
+stmt_list_attrs(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+stmt_list_statements(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+#keyset[id]
+stmt_list_tail_exprs(
+ int id: @stmt_list ref,
+ int tail_expr: @expr ref
+);
+
+struct_expr_fields(
+ unique int id: @struct_expr_field
+);
+
+#keyset[id, index]
+struct_expr_field_attrs(
+ int id: @struct_expr_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_expr_field_exprs(
+ int id: @struct_expr_field ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+struct_expr_field_identifiers(
+ int id: @struct_expr_field ref,
+ int identifier: @name_ref ref
+);
+
+struct_expr_field_lists(
+ unique int id: @struct_expr_field_list
+);
+
+#keyset[id, index]
+struct_expr_field_list_attrs(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+struct_expr_field_list_fields(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int field: @struct_expr_field ref
+);
+
+#keyset[id]
+struct_expr_field_list_spreads(
+ int id: @struct_expr_field_list ref,
+ int spread: @expr ref
+);
+
+struct_fields(
+ unique int id: @struct_field
+);
+
+#keyset[id, index]
+struct_field_attrs(
+ int id: @struct_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_defaults(
+ int id: @struct_field ref,
+ int default: @expr ref
+);
+
+#keyset[id]
+struct_field_is_unsafe(
+ int id: @struct_field ref
+);
+
+#keyset[id]
+struct_field_names(
+ int id: @struct_field ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_field_type_reprs(
+ int id: @struct_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+struct_field_visibilities(
+ int id: @struct_field ref,
+ int visibility: @visibility ref
+);
+
+struct_pat_fields(
+ unique int id: @struct_pat_field
+);
+
+#keyset[id, index]
+struct_pat_field_attrs(
+ int id: @struct_pat_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_pat_field_identifiers(
+ int id: @struct_pat_field ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+struct_pat_field_pats(
+ int id: @struct_pat_field ref,
+ int pat: @pat ref
+);
+
+struct_pat_field_lists(
+ unique int id: @struct_pat_field_list
+);
+
+#keyset[id, index]
+struct_pat_field_list_fields(
+ int id: @struct_pat_field_list ref,
+ int index: int ref,
+ int field: @struct_pat_field ref
+);
+
+#keyset[id]
+struct_pat_field_list_rest_pats(
+ int id: @struct_pat_field_list ref,
+ int rest_pat: @rest_pat ref
+);
+
+@token =
+ @comment
+;
+
+token_trees(
+ unique int id: @token_tree
+);
+
+tuple_fields(
+ unique int id: @tuple_field
+);
+
+#keyset[id, index]
+tuple_field_attrs(
+ int id: @tuple_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+tuple_field_type_reprs(
+ int id: @tuple_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+tuple_field_visibilities(
+ int id: @tuple_field ref,
+ int visibility: @visibility ref
+);
+
+type_bounds(
+ unique int id: @type_bound
+);
+
+#keyset[id]
+type_bound_is_async(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_is_const(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_lifetimes(
+ int id: @type_bound ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+type_bound_type_reprs(
+ int id: @type_bound ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_bound_use_bound_generic_args(
+ int id: @type_bound ref,
+ int use_bound_generic_args: @use_bound_generic_args ref
+);
+
+type_bound_lists(
+ unique int id: @type_bound_list
+);
+
+#keyset[id, index]
+type_bound_list_bounds(
+ int id: @type_bound_list ref,
+ int index: int ref,
+ int bound: @type_bound ref
+);
+
+@type_repr =
+ @array_type_repr
+| @dyn_trait_type_repr
+| @fn_ptr_type_repr
+| @for_type_repr
+| @impl_trait_type_repr
+| @infer_type_repr
+| @macro_type_repr
+| @never_type_repr
+| @paren_type_repr
+| @path_type_repr
+| @ptr_type_repr
+| @ref_type_repr
+| @slice_type_repr
+| @tuple_type_repr
+;
+
+@use_bound_generic_arg =
+ @lifetime
+| @name_ref
+;
+
+use_bound_generic_args(
+ unique int id: @use_bound_generic_args
+);
+
+#keyset[id, index]
+use_bound_generic_args_use_bound_generic_args(
+ int id: @use_bound_generic_args ref,
+ int index: int ref,
+ int use_bound_generic_arg: @use_bound_generic_arg ref
+);
+
+use_trees(
+ unique int id: @use_tree
+);
+
+#keyset[id]
+use_tree_is_glob(
+ int id: @use_tree ref
+);
+
+#keyset[id]
+use_tree_paths(
+ int id: @use_tree ref,
+ int path: @path ref
+);
+
+#keyset[id]
+use_tree_renames(
+ int id: @use_tree ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+use_tree_use_tree_lists(
+ int id: @use_tree ref,
+ int use_tree_list: @use_tree_list ref
+);
+
+use_tree_lists(
+ unique int id: @use_tree_list
+);
+
+#keyset[id, index]
+use_tree_list_use_trees(
+ int id: @use_tree_list ref,
+ int index: int ref,
+ int use_tree: @use_tree ref
+);
+
+variant_lists(
+ unique int id: @variant_list
+);
+
+#keyset[id, index]
+variant_list_variants(
+ int id: @variant_list ref,
+ int index: int ref,
+ int variant: @variant ref
+);
+
+visibilities(
+ unique int id: @visibility
+);
+
+#keyset[id]
+visibility_paths(
+ int id: @visibility ref,
+ int path: @path ref
+);
+
+where_clauses(
+ unique int id: @where_clause
+);
+
+#keyset[id, index]
+where_clause_predicates(
+ int id: @where_clause ref,
+ int index: int ref,
+ int predicate: @where_pred ref
+);
+
+where_preds(
+ unique int id: @where_pred
+);
+
+#keyset[id]
+where_pred_generic_param_lists(
+ int id: @where_pred ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+where_pred_lifetimes(
+ int id: @where_pred ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+where_pred_type_reprs(
+ int id: @where_pred ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+where_pred_type_bound_lists(
+ int id: @where_pred ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+array_expr_internals(
+ unique int id: @array_expr_internal
+);
+
+#keyset[id, index]
+array_expr_internal_attrs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+array_expr_internal_exprs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+array_expr_internal_is_semicolon(
+ int id: @array_expr_internal ref
+);
+
+array_type_reprs(
+ unique int id: @array_type_repr
+);
+
+#keyset[id]
+array_type_repr_const_args(
+ int id: @array_type_repr ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+array_type_repr_element_type_reprs(
+ int id: @array_type_repr ref,
+ int element_type_repr: @type_repr ref
+);
+
+asm_clobber_abis(
+ unique int id: @asm_clobber_abi
+);
+
+asm_consts(
+ unique int id: @asm_const
+);
+
+#keyset[id]
+asm_const_exprs(
+ int id: @asm_const ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+asm_const_is_const(
+ int id: @asm_const ref
+);
+
+asm_exprs(
+ unique int id: @asm_expr
+);
+
+#keyset[id, index]
+asm_expr_asm_pieces(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int asm_piece: @asm_piece ref
+);
+
+#keyset[id, index]
+asm_expr_attrs(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+asm_expr_templates(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int template: @expr ref
+);
+
+asm_labels(
+ unique int id: @asm_label
+);
+
+#keyset[id]
+asm_label_block_exprs(
+ int id: @asm_label ref,
+ int block_expr: @block_expr ref
+);
+
+asm_operand_nameds(
+ unique int id: @asm_operand_named
+);
+
+#keyset[id]
+asm_operand_named_asm_operands(
+ int id: @asm_operand_named ref,
+ int asm_operand: @asm_operand ref
+);
+
+#keyset[id]
+asm_operand_named_names(
+ int id: @asm_operand_named ref,
+ int name: @name ref
+);
+
+asm_options_lists(
+ unique int id: @asm_options_list
+);
+
+#keyset[id, index]
+asm_options_list_asm_options(
+ int id: @asm_options_list ref,
+ int index: int ref,
+ int asm_option: @asm_option ref
+);
+
+asm_reg_operands(
+ unique int id: @asm_reg_operand
+);
+
+#keyset[id]
+asm_reg_operand_asm_dir_specs(
+ int id: @asm_reg_operand ref,
+ int asm_dir_spec: @asm_dir_spec ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_operand_exprs(
+ int id: @asm_reg_operand ref,
+ int asm_operand_expr: @asm_operand_expr ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_reg_specs(
+ int id: @asm_reg_operand ref,
+ int asm_reg_spec: @asm_reg_spec ref
+);
+
+asm_syms(
+ unique int id: @asm_sym
+);
+
+#keyset[id]
+asm_sym_paths(
+ int id: @asm_sym ref,
+ int path: @path ref
+);
+
+assoc_type_args(
+ unique int id: @assoc_type_arg
+);
+
+#keyset[id]
+assoc_type_arg_const_args(
+ int id: @assoc_type_arg ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+assoc_type_arg_generic_arg_lists(
+ int id: @assoc_type_arg ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+assoc_type_arg_identifiers(
+ int id: @assoc_type_arg ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+assoc_type_arg_param_lists(
+ int id: @assoc_type_arg ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+assoc_type_arg_ret_types(
+ int id: @assoc_type_arg ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_return_type_syntaxes(
+ int id: @assoc_type_arg ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+assoc_type_arg_type_reprs(
+ int id: @assoc_type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_type_bound_lists(
+ int id: @assoc_type_arg ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+await_exprs(
+ unique int id: @await_expr
+);
+
+#keyset[id, index]
+await_expr_attrs(
+ int id: @await_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+await_expr_exprs(
+ int id: @await_expr ref,
+ int expr: @expr ref
+);
+
+become_exprs(
+ unique int id: @become_expr
+);
+
+#keyset[id, index]
+become_expr_attrs(
+ int id: @become_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+become_expr_exprs(
+ int id: @become_expr ref,
+ int expr: @expr ref
+);
+
+binary_exprs(
+ unique int id: @binary_expr
+);
+
+#keyset[id, index]
+binary_expr_attrs(
+ int id: @binary_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+binary_expr_lhs(
+ int id: @binary_expr ref,
+ int lhs: @expr ref
+);
+
+#keyset[id]
+binary_expr_operator_names(
+ int id: @binary_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+binary_expr_rhs(
+ int id: @binary_expr ref,
+ int rhs: @expr ref
+);
+
+box_pats(
+ unique int id: @box_pat
+);
+
+#keyset[id]
+box_pat_pats(
+ int id: @box_pat ref,
+ int pat: @pat ref
+);
+
+break_exprs(
+ unique int id: @break_expr
+);
+
+#keyset[id, index]
+break_expr_attrs(
+ int id: @break_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+break_expr_exprs(
+ int id: @break_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+break_expr_lifetimes(
+ int id: @break_expr ref,
+ int lifetime: @lifetime ref
+);
+
+@call_expr_base =
+ @call_expr
+| @method_call_expr
+;
+
+#keyset[id]
+call_expr_base_arg_lists(
+ int id: @call_expr_base ref,
+ int arg_list: @arg_list ref
+);
+
+#keyset[id, index]
+call_expr_base_attrs(
+ int id: @call_expr_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+cast_exprs(
+ unique int id: @cast_expr
+);
+
+#keyset[id, index]
+cast_expr_attrs(
+ int id: @cast_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+cast_expr_exprs(
+ int id: @cast_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+cast_expr_type_reprs(
+ int id: @cast_expr ref,
+ int type_repr: @type_repr ref
+);
+
+closure_exprs(
+ unique int id: @closure_expr
+);
+
+#keyset[id]
+closure_expr_bodies(
+ int id: @closure_expr ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+closure_expr_closure_binders(
+ int id: @closure_expr ref,
+ int closure_binder: @closure_binder ref
+);
+
+#keyset[id]
+closure_expr_is_async(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_const(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_gen(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_move(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_static(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_ret_types(
+ int id: @closure_expr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+comments(
+ unique int id: @comment,
+ int parent: @ast_node ref,
+ string text: string ref
+);
+
+const_args(
+ unique int id: @const_arg
+);
+
+#keyset[id]
+const_arg_exprs(
+ int id: @const_arg ref,
+ int expr: @expr ref
+);
+
+const_block_pats(
+ unique int id: @const_block_pat
+);
+
+#keyset[id]
+const_block_pat_block_exprs(
+ int id: @const_block_pat ref,
+ int block_expr: @block_expr ref
+);
+
+#keyset[id]
+const_block_pat_is_const(
+ int id: @const_block_pat ref
+);
+
+const_params(
+ unique int id: @const_param
+);
+
+#keyset[id, index]
+const_param_attrs(
+ int id: @const_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_param_default_vals(
+ int id: @const_param ref,
+ int default_val: @const_arg ref
+);
+
+#keyset[id]
+const_param_is_const(
+ int id: @const_param ref
+);
+
+#keyset[id]
+const_param_names(
+ int id: @const_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_param_type_reprs(
+ int id: @const_param ref,
+ int type_repr: @type_repr ref
+);
+
+continue_exprs(
+ unique int id: @continue_expr
+);
+
+#keyset[id, index]
+continue_expr_attrs(
+ int id: @continue_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+continue_expr_lifetimes(
+ int id: @continue_expr ref,
+ int lifetime: @lifetime ref
+);
+
+dyn_trait_type_reprs(
+ unique int id: @dyn_trait_type_repr
+);
+
+#keyset[id]
+dyn_trait_type_repr_type_bound_lists(
+ int id: @dyn_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+expr_stmts(
+ unique int id: @expr_stmt
+);
+
+#keyset[id]
+expr_stmt_exprs(
+ int id: @expr_stmt ref,
+ int expr: @expr ref
+);
+
+field_exprs(
+ unique int id: @field_expr
+);
+
+#keyset[id, index]
+field_expr_attrs(
+ int id: @field_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+field_expr_containers(
+ int id: @field_expr ref,
+ int container: @expr ref
+);
+
+#keyset[id]
+field_expr_identifiers(
+ int id: @field_expr ref,
+ int identifier: @name_ref ref
+);
+
+fn_ptr_type_reprs(
+ unique int id: @fn_ptr_type_repr
+);
+
+#keyset[id]
+fn_ptr_type_repr_abis(
+ int id: @fn_ptr_type_repr ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_async(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_const(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_unsafe(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_param_lists(
+ int id: @fn_ptr_type_repr ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_ret_types(
+ int id: @fn_ptr_type_repr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+for_type_reprs(
+ unique int id: @for_type_repr
+);
+
+#keyset[id]
+for_type_repr_generic_param_lists(
+ int id: @for_type_repr ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+for_type_repr_type_reprs(
+ int id: @for_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+format_args_exprs(
+ unique int id: @format_args_expr
+);
+
+#keyset[id, index]
+format_args_expr_args(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int arg: @format_args_arg ref
+);
+
+#keyset[id, index]
+format_args_expr_attrs(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+format_args_expr_templates(
+ int id: @format_args_expr ref,
+ int template: @expr ref
+);
+
+ident_pats(
+ unique int id: @ident_pat
+);
+
+#keyset[id, index]
+ident_pat_attrs(
+ int id: @ident_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ident_pat_is_mut(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_is_ref(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_names(
+ int id: @ident_pat ref,
+ int name: @name ref
+);
+
+#keyset[id]
+ident_pat_pats(
+ int id: @ident_pat ref,
+ int pat: @pat ref
+);
+
+if_exprs(
+ unique int id: @if_expr
+);
+
+#keyset[id, index]
+if_expr_attrs(
+ int id: @if_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+if_expr_conditions(
+ int id: @if_expr ref,
+ int condition: @expr ref
+);
+
+#keyset[id]
+if_expr_elses(
+ int id: @if_expr ref,
+ int else: @expr ref
+);
+
+#keyset[id]
+if_expr_thens(
+ int id: @if_expr ref,
+ int then: @block_expr ref
+);
+
+impl_trait_type_reprs(
+ unique int id: @impl_trait_type_repr
+);
+
+#keyset[id]
+impl_trait_type_repr_type_bound_lists(
+ int id: @impl_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+index_exprs(
+ unique int id: @index_expr
+);
+
+#keyset[id, index]
+index_expr_attrs(
+ int id: @index_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+index_expr_bases(
+ int id: @index_expr ref,
+ int base: @expr ref
+);
+
+#keyset[id]
+index_expr_indices(
+ int id: @index_expr ref,
+ int index: @expr ref
+);
+
+infer_type_reprs(
+ unique int id: @infer_type_repr
+);
+
+@item =
+ @adt
+| @assoc_item
+| @extern_block
+| @extern_crate
+| @extern_item
+| @impl
+| @macro_def
+| @macro_rules
+| @module
+| @trait
+| @trait_alias
+| @use
+;
+
+#keyset[id]
+item_attribute_macro_expansions(
+ int id: @item ref,
+ int attribute_macro_expansion: @macro_items ref
+);
+
+@labelable_expr =
+ @block_expr
+| @looping_expr
+;
+
+#keyset[id]
+labelable_expr_labels(
+ int id: @labelable_expr ref,
+ int label: @label ref
+);
+
+let_exprs(
+ unique int id: @let_expr
+);
+
+#keyset[id, index]
+let_expr_attrs(
+ int id: @let_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_expr_scrutinees(
+ int id: @let_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+let_expr_pats(
+ int id: @let_expr ref,
+ int pat: @pat ref
+);
+
+let_stmts(
+ unique int id: @let_stmt
+);
+
+#keyset[id, index]
+let_stmt_attrs(
+ int id: @let_stmt ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_stmt_initializers(
+ int id: @let_stmt ref,
+ int initializer: @expr ref
+);
+
+#keyset[id]
+let_stmt_let_elses(
+ int id: @let_stmt ref,
+ int let_else: @let_else ref
+);
+
+#keyset[id]
+let_stmt_pats(
+ int id: @let_stmt ref,
+ int pat: @pat ref
+);
+
+#keyset[id]
+let_stmt_type_reprs(
+ int id: @let_stmt ref,
+ int type_repr: @type_repr ref
+);
+
+lifetimes(
+ unique int id: @lifetime
+);
+
+#keyset[id]
+lifetime_texts(
+ int id: @lifetime ref,
+ string text: string ref
+);
+
+lifetime_args(
+ unique int id: @lifetime_arg
+);
+
+#keyset[id]
+lifetime_arg_lifetimes(
+ int id: @lifetime_arg ref,
+ int lifetime: @lifetime ref
+);
+
+lifetime_params(
+ unique int id: @lifetime_param
+);
+
+#keyset[id, index]
+lifetime_param_attrs(
+ int id: @lifetime_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+lifetime_param_lifetimes(
+ int id: @lifetime_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+lifetime_param_type_bound_lists(
+ int id: @lifetime_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+literal_exprs(
+ unique int id: @literal_expr
+);
+
+#keyset[id, index]
+literal_expr_attrs(
+ int id: @literal_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+literal_expr_text_values(
+ int id: @literal_expr ref,
+ string text_value: string ref
+);
+
+literal_pats(
+ unique int id: @literal_pat
+);
+
+#keyset[id]
+literal_pat_literals(
+ int id: @literal_pat ref,
+ int literal: @literal_expr ref
+);
+
+macro_block_exprs(
+ unique int id: @macro_block_expr
+);
+
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
+#keyset[id, index]
+macro_block_expr_statements(
+ int id: @macro_block_expr ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+macro_exprs(
+ unique int id: @macro_expr
+);
+
+#keyset[id]
+macro_expr_macro_calls(
+ int id: @macro_expr ref,
+ int macro_call: @macro_call ref
+);
+
+macro_pats(
+ unique int id: @macro_pat
+);
+
+#keyset[id]
+macro_pat_macro_calls(
+ int id: @macro_pat ref,
+ int macro_call: @macro_call ref
+);
+
+macro_type_reprs(
+ unique int id: @macro_type_repr
+);
+
+#keyset[id]
+macro_type_repr_macro_calls(
+ int id: @macro_type_repr ref,
+ int macro_call: @macro_call ref
+);
+
+match_exprs(
+ unique int id: @match_expr
+);
+
+#keyset[id, index]
+match_expr_attrs(
+ int id: @match_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_expr_scrutinees(
+ int id: @match_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+match_expr_match_arm_lists(
+ int id: @match_expr ref,
+ int match_arm_list: @match_arm_list ref
+);
+
+name_refs(
+ unique int id: @name_ref
+);
+
+#keyset[id]
+name_ref_texts(
+ int id: @name_ref ref,
+ string text: string ref
+);
+
+never_type_reprs(
+ unique int id: @never_type_repr
+);
+
+offset_of_exprs(
+ unique int id: @offset_of_expr
+);
+
+#keyset[id, index]
+offset_of_expr_attrs(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+offset_of_expr_fields(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int field: @name_ref ref
+);
+
+#keyset[id]
+offset_of_expr_type_reprs(
+ int id: @offset_of_expr ref,
+ int type_repr: @type_repr ref
+);
+
+or_pats(
+ unique int id: @or_pat
+);
+
+#keyset[id, index]
+or_pat_pats(
+ int id: @or_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+params(
+ unique int id: @param
+);
+
+#keyset[id]
+param_pats(
+ int id: @param ref,
+ int pat: @pat ref
+);
+
+paren_exprs(
+ unique int id: @paren_expr
+);
+
+#keyset[id, index]
+paren_expr_attrs(
+ int id: @paren_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+paren_expr_exprs(
+ int id: @paren_expr ref,
+ int expr: @expr ref
+);
+
+paren_pats(
+ unique int id: @paren_pat
+);
+
+#keyset[id]
+paren_pat_pats(
+ int id: @paren_pat ref,
+ int pat: @pat ref
+);
+
+paren_type_reprs(
+ unique int id: @paren_type_repr
+);
+
+#keyset[id]
+paren_type_repr_type_reprs(
+ int id: @paren_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+@path_ast_node =
+ @path_expr
+| @path_pat
+| @struct_expr
+| @struct_pat
+| @tuple_struct_pat
+;
+
+#keyset[id]
+path_ast_node_paths(
+ int id: @path_ast_node ref,
+ int path: @path ref
+);
+
+@path_expr_base =
+ @path_expr
+;
+
+path_type_reprs(
+ unique int id: @path_type_repr
+);
+
+#keyset[id]
+path_type_repr_paths(
+ int id: @path_type_repr ref,
+ int path: @path ref
+);
+
+prefix_exprs(
+ unique int id: @prefix_expr
+);
+
+#keyset[id, index]
+prefix_expr_attrs(
+ int id: @prefix_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+prefix_expr_exprs(
+ int id: @prefix_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+prefix_expr_operator_names(
+ int id: @prefix_expr ref,
+ string operator_name: string ref
+);
+
+ptr_type_reprs(
+ unique int id: @ptr_type_repr
+);
+
+#keyset[id]
+ptr_type_repr_is_const(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_is_mut(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_type_reprs(
+ int id: @ptr_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+range_exprs(
+ unique int id: @range_expr
+);
+
+#keyset[id, index]
+range_expr_attrs(
+ int id: @range_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+range_expr_ends(
+ int id: @range_expr ref,
+ int end: @expr ref
+);
+
+#keyset[id]
+range_expr_operator_names(
+ int id: @range_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_expr_starts(
+ int id: @range_expr ref,
+ int start: @expr ref
+);
+
+range_pats(
+ unique int id: @range_pat
+);
+
+#keyset[id]
+range_pat_ends(
+ int id: @range_pat ref,
+ int end: @pat ref
+);
+
+#keyset[id]
+range_pat_operator_names(
+ int id: @range_pat ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_pat_starts(
+ int id: @range_pat ref,
+ int start: @pat ref
+);
+
+ref_exprs(
+ unique int id: @ref_expr
+);
+
+#keyset[id, index]
+ref_expr_attrs(
+ int id: @ref_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ref_expr_exprs(
+ int id: @ref_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+ref_expr_is_const(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_mut(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_raw(
+ int id: @ref_expr ref
+);
+
+ref_pats(
+ unique int id: @ref_pat
+);
+
+#keyset[id]
+ref_pat_is_mut(
+ int id: @ref_pat ref
+);
+
+#keyset[id]
+ref_pat_pats(
+ int id: @ref_pat ref,
+ int pat: @pat ref
+);
+
+ref_type_reprs(
+ unique int id: @ref_type_repr
+);
+
+#keyset[id]
+ref_type_repr_is_mut(
+ int id: @ref_type_repr ref
+);
+
+#keyset[id]
+ref_type_repr_lifetimes(
+ int id: @ref_type_repr ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+ref_type_repr_type_reprs(
+ int id: @ref_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+rest_pats(
+ unique int id: @rest_pat
+);
+
+#keyset[id, index]
+rest_pat_attrs(
+ int id: @rest_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+return_exprs(
+ unique int id: @return_expr
+);
+
+#keyset[id, index]
+return_expr_attrs(
+ int id: @return_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+return_expr_exprs(
+ int id: @return_expr ref,
+ int expr: @expr ref
+);
+
+self_params(
+ unique int id: @self_param
+);
+
+#keyset[id]
+self_param_is_ref(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_is_mut(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_lifetimes(
+ int id: @self_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+self_param_names(
+ int id: @self_param ref,
+ int name: @name ref
+);
+
+slice_pats(
+ unique int id: @slice_pat
+);
+
+#keyset[id, index]
+slice_pat_pats(
+ int id: @slice_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+slice_type_reprs(
+ unique int id: @slice_type_repr
+);
+
+#keyset[id]
+slice_type_repr_type_reprs(
+ int id: @slice_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+struct_field_lists(
+ unique int id: @struct_field_list
+);
+
+#keyset[id, index]
+struct_field_list_fields(
+ int id: @struct_field_list ref,
+ int index: int ref,
+ int field: @struct_field ref
+);
+
+try_exprs(
+ unique int id: @try_expr
+);
+
+#keyset[id, index]
+try_expr_attrs(
+ int id: @try_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+try_expr_exprs(
+ int id: @try_expr ref,
+ int expr: @expr ref
+);
+
+tuple_exprs(
+ unique int id: @tuple_expr
+);
+
+#keyset[id, index]
+tuple_expr_attrs(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+tuple_expr_fields(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int field: @expr ref
+);
+
+tuple_field_lists(
+ unique int id: @tuple_field_list
+);
+
+#keyset[id, index]
+tuple_field_list_fields(
+ int id: @tuple_field_list ref,
+ int index: int ref,
+ int field: @tuple_field ref
+);
+
+tuple_pats(
+ unique int id: @tuple_pat
+);
+
+#keyset[id, index]
+tuple_pat_fields(
+ int id: @tuple_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+tuple_type_reprs(
+ unique int id: @tuple_type_repr
+);
+
+#keyset[id, index]
+tuple_type_repr_fields(
+ int id: @tuple_type_repr ref,
+ int index: int ref,
+ int field: @type_repr ref
+);
+
+type_args(
+ unique int id: @type_arg
+);
+
+#keyset[id]
+type_arg_type_reprs(
+ int id: @type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+type_params(
+ unique int id: @type_param
+);
+
+#keyset[id, index]
+type_param_attrs(
+ int id: @type_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_param_default_types(
+ int id: @type_param ref,
+ int default_type: @type_repr ref
+);
+
+#keyset[id]
+type_param_names(
+ int id: @type_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_param_type_bound_lists(
+ int id: @type_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+underscore_exprs(
+ unique int id: @underscore_expr
+);
+
+#keyset[id, index]
+underscore_expr_attrs(
+ int id: @underscore_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+variants(
+ unique int id: @variant
+);
+
+#keyset[id, index]
+variant_attrs(
+ int id: @variant ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+variant_discriminants(
+ int id: @variant ref,
+ int discriminant: @expr ref
+);
+
+#keyset[id]
+variant_field_lists(
+ int id: @variant ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+variant_names(
+ int id: @variant ref,
+ int name: @name ref
+);
+
+#keyset[id]
+variant_visibilities(
+ int id: @variant ref,
+ int visibility: @visibility ref
+);
+
+wildcard_pats(
+ unique int id: @wildcard_pat
+);
+
+yeet_exprs(
+ unique int id: @yeet_expr
+);
+
+#keyset[id, index]
+yeet_expr_attrs(
+ int id: @yeet_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yeet_expr_exprs(
+ int id: @yeet_expr ref,
+ int expr: @expr ref
+);
+
+yield_exprs(
+ unique int id: @yield_expr
+);
+
+#keyset[id, index]
+yield_expr_attrs(
+ int id: @yield_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yield_expr_exprs(
+ int id: @yield_expr ref,
+ int expr: @expr ref
+);
+
+@adt =
+ @enum
+| @struct
+| @union
+;
+
+#keyset[id, index]
+adt_derive_macro_expansions(
+ int id: @adt ref,
+ int index: int ref,
+ int derive_macro_expansion: @macro_items ref
+);
+
+@assoc_item =
+ @const
+| @function
+| @macro_call
+| @type_alias
+;
+
+block_exprs(
+ unique int id: @block_expr
+);
+
+#keyset[id, index]
+block_expr_attrs(
+ int id: @block_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+block_expr_is_async(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_const(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_gen(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_move(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_try(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_unsafe(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_stmt_lists(
+ int id: @block_expr ref,
+ int stmt_list: @stmt_list ref
+);
+
+call_exprs(
+ unique int id: @call_expr
+);
+
+#keyset[id]
+call_expr_functions(
+ int id: @call_expr ref,
+ int function: @expr ref
+);
+
+extern_blocks(
+ unique int id: @extern_block
+);
+
+#keyset[id]
+extern_block_abis(
+ int id: @extern_block ref,
+ int abi: @abi ref
+);
+
+#keyset[id, index]
+extern_block_attrs(
+ int id: @extern_block ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_block_extern_item_lists(
+ int id: @extern_block ref,
+ int extern_item_list: @extern_item_list ref
+);
+
+#keyset[id]
+extern_block_is_unsafe(
+ int id: @extern_block ref
+);
+
+extern_crates(
+ unique int id: @extern_crate
+);
+
+#keyset[id, index]
+extern_crate_attrs(
+ int id: @extern_crate ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_crate_identifiers(
+ int id: @extern_crate ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+extern_crate_renames(
+ int id: @extern_crate ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+extern_crate_visibilities(
+ int id: @extern_crate ref,
+ int visibility: @visibility ref
+);
+
+@extern_item =
+ @function
+| @macro_call
+| @static
+| @type_alias
+;
+
+impls(
+ unique int id: @impl
+);
+
+#keyset[id]
+impl_assoc_item_lists(
+ int id: @impl ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+impl_attrs(
+ int id: @impl ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+impl_generic_param_lists(
+ int id: @impl ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+impl_is_const(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_default(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_unsafe(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_self_ties(
+ int id: @impl ref,
+ int self_ty: @type_repr ref
+);
+
+#keyset[id]
+impl_traits(
+ int id: @impl ref,
+ int trait: @type_repr ref
+);
+
+#keyset[id]
+impl_visibilities(
+ int id: @impl ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+impl_where_clauses(
+ int id: @impl ref,
+ int where_clause: @where_clause ref
+);
+
+@looping_expr =
+ @for_expr
+| @loop_expr
+| @while_expr
+;
+
+#keyset[id]
+looping_expr_loop_bodies(
+ int id: @looping_expr ref,
+ int loop_body: @block_expr ref
+);
+
+macro_defs(
+ unique int id: @macro_def
+);
+
+#keyset[id]
+macro_def_args(
+ int id: @macro_def ref,
+ int args: @token_tree ref
+);
+
+#keyset[id, index]
+macro_def_attrs(
+ int id: @macro_def ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_def_bodies(
+ int id: @macro_def ref,
+ int body: @token_tree ref
+);
+
+#keyset[id]
+macro_def_names(
+ int id: @macro_def ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_def_visibilities(
+ int id: @macro_def ref,
+ int visibility: @visibility ref
+);
+
+macro_rules(
+ unique int id: @macro_rules
+);
+
+#keyset[id, index]
+macro_rules_attrs(
+ int id: @macro_rules ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_rules_names(
+ int id: @macro_rules ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_rules_token_trees(
+ int id: @macro_rules ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_rules_visibilities(
+ int id: @macro_rules ref,
+ int visibility: @visibility ref
+);
+
+method_call_exprs(
+ unique int id: @method_call_expr
+);
+
+#keyset[id]
+method_call_expr_generic_arg_lists(
+ int id: @method_call_expr ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+method_call_expr_identifiers(
+ int id: @method_call_expr ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+method_call_expr_receivers(
+ int id: @method_call_expr ref,
+ int receiver: @expr ref
+);
+
+modules(
+ unique int id: @module
+);
+
+#keyset[id, index]
+module_attrs(
+ int id: @module ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+module_item_lists(
+ int id: @module ref,
+ int item_list: @item_list ref
+);
+
+#keyset[id]
+module_names(
+ int id: @module ref,
+ int name: @name ref
+);
+
+#keyset[id]
+module_visibilities(
+ int id: @module ref,
+ int visibility: @visibility ref
+);
+
+path_exprs(
+ unique int id: @path_expr
+);
+
+#keyset[id, index]
+path_expr_attrs(
+ int id: @path_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+path_pats(
+ unique int id: @path_pat
+);
+
+struct_exprs(
+ unique int id: @struct_expr
+);
+
+#keyset[id]
+struct_expr_struct_expr_field_lists(
+ int id: @struct_expr ref,
+ int struct_expr_field_list: @struct_expr_field_list ref
+);
+
+struct_pats(
+ unique int id: @struct_pat
+);
+
+#keyset[id]
+struct_pat_struct_pat_field_lists(
+ int id: @struct_pat ref,
+ int struct_pat_field_list: @struct_pat_field_list ref
+);
+
+traits(
+ unique int id: @trait
+);
+
+#keyset[id]
+trait_assoc_item_lists(
+ int id: @trait ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+trait_attrs(
+ int id: @trait ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_generic_param_lists(
+ int id: @trait ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_is_auto(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_is_unsafe(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_names(
+ int id: @trait ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_type_bound_lists(
+ int id: @trait ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_visibilities(
+ int id: @trait ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_where_clauses(
+ int id: @trait ref,
+ int where_clause: @where_clause ref
+);
+
+trait_aliases(
+ unique int id: @trait_alias
+);
+
+#keyset[id, index]
+trait_alias_attrs(
+ int id: @trait_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_alias_generic_param_lists(
+ int id: @trait_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_alias_names(
+ int id: @trait_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_alias_type_bound_lists(
+ int id: @trait_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_alias_visibilities(
+ int id: @trait_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_alias_where_clauses(
+ int id: @trait_alias ref,
+ int where_clause: @where_clause ref
+);
+
+tuple_struct_pats(
+ unique int id: @tuple_struct_pat
+);
+
+#keyset[id, index]
+tuple_struct_pat_fields(
+ int id: @tuple_struct_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+uses(
+ unique int id: @use
+);
+
+#keyset[id, index]
+use_attrs(
+ int id: @use ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+use_use_trees(
+ int id: @use ref,
+ int use_tree: @use_tree ref
+);
+
+#keyset[id]
+use_visibilities(
+ int id: @use ref,
+ int visibility: @visibility ref
+);
+
+consts(
+ unique int id: @const
+);
+
+#keyset[id, index]
+const_attrs(
+ int id: @const ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_bodies(
+ int id: @const ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+const_generic_param_lists(
+ int id: @const ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+const_is_const(
+ int id: @const ref
+);
+
+#keyset[id]
+const_is_default(
+ int id: @const ref
+);
+
+#keyset[id]
+const_names(
+ int id: @const ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_type_reprs(
+ int id: @const ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+const_visibilities(
+ int id: @const ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+const_where_clauses(
+ int id: @const ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+const_has_implementation(
+ int id: @const ref
+);
+
+enums(
+ unique int id: @enum
+);
+
+#keyset[id, index]
+enum_attrs(
+ int id: @enum ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+enum_generic_param_lists(
+ int id: @enum ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+enum_names(
+ int id: @enum ref,
+ int name: @name ref
+);
+
+#keyset[id]
+enum_variant_lists(
+ int id: @enum ref,
+ int variant_list: @variant_list ref
+);
+
+#keyset[id]
+enum_visibilities(
+ int id: @enum ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+enum_where_clauses(
+ int id: @enum ref,
+ int where_clause: @where_clause ref
+);
+
+for_exprs(
+ unique int id: @for_expr
+);
+
+#keyset[id, index]
+for_expr_attrs(
+ int id: @for_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+for_expr_iterables(
+ int id: @for_expr ref,
+ int iterable: @expr ref
+);
+
+#keyset[id]
+for_expr_pats(
+ int id: @for_expr ref,
+ int pat: @pat ref
+);
+
+functions(
+ unique int id: @function
+);
+
+#keyset[id]
+function_abis(
+ int id: @function ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+function_bodies(
+ int id: @function ref,
+ int body: @block_expr ref
+);
+
+#keyset[id]
+function_generic_param_lists(
+ int id: @function ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+function_is_async(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_const(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_default(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_gen(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_unsafe(
+ int id: @function ref
+);
+
+#keyset[id]
+function_names(
+ int id: @function ref,
+ int name: @name ref
+);
+
+#keyset[id]
+function_ret_types(
+ int id: @function ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+function_visibilities(
+ int id: @function ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+function_where_clauses(
+ int id: @function ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+function_has_implementation(
+ int id: @function ref
+);
+
+loop_exprs(
+ unique int id: @loop_expr
+);
+
+#keyset[id, index]
+loop_expr_attrs(
+ int id: @loop_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+macro_calls(
+ unique int id: @macro_call
+);
+
+#keyset[id, index]
+macro_call_attrs(
+ int id: @macro_call ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_call_paths(
+ int id: @macro_call ref,
+ int path: @path ref
+);
+
+#keyset[id]
+macro_call_token_trees(
+ int id: @macro_call ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_call_macro_call_expansions(
+ int id: @macro_call ref,
+ int macro_call_expansion: @ast_node ref
+);
+
+statics(
+ unique int id: @static
+);
+
+#keyset[id, index]
+static_attrs(
+ int id: @static ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+static_bodies(
+ int id: @static ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+static_is_mut(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_static(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_unsafe(
+ int id: @static ref
+);
+
+#keyset[id]
+static_names(
+ int id: @static ref,
+ int name: @name ref
+);
+
+#keyset[id]
+static_type_reprs(
+ int id: @static ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+static_visibilities(
+ int id: @static ref,
+ int visibility: @visibility ref
+);
+
+structs(
+ unique int id: @struct
+);
+
+#keyset[id, index]
+struct_attrs(
+ int id: @struct ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_lists_(
+ int id: @struct ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+struct_generic_param_lists(
+ int id: @struct ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+struct_names(
+ int id: @struct ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_visibilities(
+ int id: @struct ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+struct_where_clauses(
+ int id: @struct ref,
+ int where_clause: @where_clause ref
+);
+
+type_aliases(
+ unique int id: @type_alias
+);
+
+#keyset[id, index]
+type_alias_attrs(
+ int id: @type_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_alias_generic_param_lists(
+ int id: @type_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+type_alias_is_default(
+ int id: @type_alias ref
+);
+
+#keyset[id]
+type_alias_names(
+ int id: @type_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_alias_type_reprs(
+ int id: @type_alias ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_alias_type_bound_lists(
+ int id: @type_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+type_alias_visibilities(
+ int id: @type_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+type_alias_where_clauses(
+ int id: @type_alias ref,
+ int where_clause: @where_clause ref
+);
+
+unions(
+ unique int id: @union
+);
+
+#keyset[id, index]
+union_attrs(
+ int id: @union ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+union_generic_param_lists(
+ int id: @union ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+union_names(
+ int id: @union ref,
+ int name: @name ref
+);
+
+#keyset[id]
+union_struct_field_lists(
+ int id: @union ref,
+ int struct_field_list: @struct_field_list ref
+);
+
+#keyset[id]
+union_visibilities(
+ int id: @union ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+union_where_clauses(
+ int id: @union ref,
+ int where_clause: @where_clause ref
+);
+
+while_exprs(
+ unique int id: @while_expr
+);
+
+#keyset[id, index]
+while_expr_attrs(
+ int id: @while_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+while_expr_conditions(
+ int id: @while_expr ref,
+ int condition: @expr ref
+);
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
new file mode 100644
index 00000000000..597a1e6181b
--- /dev/null
+++ b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
@@ -0,0 +1,2 @@
+description: TODO
+compatibility: backwards
diff --git a/rust/ql/.generated.list b/rust/ql/.generated.list
index 2a093c83953..96f12505868 100644
--- a/rust/ql/.generated.list
+++ b/rust/ql/.generated.list
@@ -58,7 +58,7 @@ lib/codeql/rust/elements/FieldList.qll 72f3eace2f0c0600b1ad059819ae756f1feccd155
lib/codeql/rust/elements/FnPtrTypeRepr.qll d4586ac5ee2382b5ef9daafa77c7b3c1b7564647aa20d1efb1626299cde87ba9 48d9b63725c9cd89d79f9806fa5d5f22d7815e70bbd78d8da40a2359ac53fef5
lib/codeql/rust/elements/ForBinder.qll ee29b55cb4c1fa5180cc4ee1236ac089fe9f67ffa9e5a1474003b717f1ac6e0f 5b811c8cf9550cb675034315e03c5cbbfa7544ad3a696988e04d780037d434bf
lib/codeql/rust/elements/ForExpr.qll a050f60cf6fcc3ce66f5042be1b8096e5207fe2674d7477f9e299091ca99a4bd d7198495139649778894e930163add2d16b5588dd12bd6e094a9aec6863cb16f
-lib/codeql/rust/elements/ForTypeRepr.qll 0315e6850eb09d9debdd6843e4ce0cfa15a4b9502f1b81dbaafcd263efc62511 e0e612a9686502f3ff48321fea28be6f0720dfd22aad929b446b573ae70297d4
+lib/codeql/rust/elements/ForTypeRepr.qll 32473eeafc32aabfda770d585fd77a19f4eb0b55f1d78ae78f220b6371b6169c a3c4d5d406abe5513f3ed7a80a3d1cbd4d5cdeec2704eb1c12081220ebe44618
lib/codeql/rust/elements/Format.qll 1b186730710e7e29ea47594998f0b359ad308927f84841adae0c0cb35fc8aeda d6f7bfdda60a529fb9e9a1975628d5bd11aa28a45e295c7526692ac662fd19f8
lib/codeql/rust/elements/FormatArgsArg.qll a2c23cd512d44dd60b7d65eba52cc3adf6e2fbbcd0588be375daa16002cd7741 d9c5fe183fb228375223d83f857b7a9ee686f1d3e341bcf323d7c6f39652f88b
lib/codeql/rust/elements/FormatArgsExpr.qll 8127cbe4082f7acc3d8a05298c2c9bea302519b8a6cd2d158a83c516d18fc487 88cf9b3bedd69a1150968f9a465c904bbb6805da0e0b90cfd1fc0dab1f6d9319
@@ -168,7 +168,7 @@ lib/codeql/rust/elements/TupleStructPat.qll da398a23eb616bf7dd586b2a87f4ab00f286
lib/codeql/rust/elements/TupleTypeRepr.qll 1ac5abf6281ea31680a4098407fbe55459d08f92a50dec20d1f8b93d498eee41 6d9625cce4e4abf6b6e6c22e47880fbd23740d07b621137bd7fa0a2ee13badd9
lib/codeql/rust/elements/TypeAlias.qll b59f24488f0d7de8d4046a9e0ca1e1f54d1d5c11e035898b11ab97e151fc600f 7b25c9e14c8bb310cec796824904fcefced2cc486d55e981b80b7620e73dd2d7
lib/codeql/rust/elements/TypeArg.qll e91dbb399d2ab7cf7af9dd5f743a551d0bf91dba3cfb76cea9e2d42ada0f9f2e c67d64e20e35a9bba5092651e0f82c75ba53b8c165e823bc81d67975107ae375
-lib/codeql/rust/elements/TypeBound.qll d5b2a904e497ba1899fb9e19547a6dfa7716c8aabe1e6e19070cbb58af32321b eabb16616afe3e88a25db4519174828a7ead1eb69ec7f98ef4abf4b3ead1c220
+lib/codeql/rust/elements/TypeBound.qll 33583aed81734348c5097851cde3568668f259c000ccde901c75a3f2eef30237 3c9e541d47c5cfbcb0b1c5806f5d9abd7f51382d1efc1328742439e11285ab32
lib/codeql/rust/elements/TypeBoundList.qll 61a861e89b3de23801c723531cd3331a61214817a230aaae74d91cb60f0e096f d54e3d830bb550c5ba082ccd09bc0dc4e6e44e8d11066a7afba5a7172aa687a8
lib/codeql/rust/elements/TypeParam.qll 0787c1cc0c121e5b46f7d8e25153fd1b181bd3432eb040cf3b4ae3ed9ac2f28c 50092950f52a4e3bfd961dff4ffd8a719ef66ca1a0914bd33e26fed538321999
lib/codeql/rust/elements/TypeRepr.qll ea41b05ef0aaac71da460f9a6a8331cf98166f2c388526068ddacbd67488c892 11a01e42dab9183bac14de1ca49131788ede99e75b0ef759efcbc7cf08524184
@@ -185,7 +185,7 @@ lib/codeql/rust/elements/Variant.qll 7895461fa728f6c3a7293799c5e6b965b413b679566
lib/codeql/rust/elements/VariantList.qll 39803fbb873d48202c2a511c00c8eafede06e519894e0fd050c2a85bf5f4aa73 1735f89b2b8f6d5960a276b87ea10e4bb8c848c24a5d5fad7f3add7a4d94b7da
lib/codeql/rust/elements/Visibility.qll aa69e8a3fd3b01f6fea0ae2d841a2adc51f4e46dcfc9f8f03c34fbe96f7e24e7 0d475e97e07b73c8da2b53555085b8309d8dc69c113bcb396fc901361dbfe6b8
lib/codeql/rust/elements/WhereClause.qll 4e28e11ceec835a093e469854a4b615e698309cdcbc39ed83810e2e4e7c5953f 4736baf689b87dd6669cb0ef9e27eb2c0f2776ce7f29d7693670bbcea06eb4e4
-lib/codeql/rust/elements/WherePred.qll 35ef2580d20ffa6fadb05ea38152b5e4953b4dc827326e96969cd86d2dfdbfdc 6b8f7abf81bfeff7a16539f6a18746e02daedad42145b1c5a0b8cfa33676cbf8
+lib/codeql/rust/elements/WherePred.qll 589027c2fddb07620f74b8ed5e471fab49bef389749e498069d7c1fe50912cc7 dd7c90ff9c5bd563f0b8a088e0890ee11c6d5b2269223f22be01f0e1dbe0f5e2
lib/codeql/rust/elements/WhileExpr.qll 4a37e3ecd37c306a9b93b610a0e45e18adc22fcd4ce955a519b679e9f89b97e8 82026faa73b94390544e61ed2f3aaeaabd3e457439bb76d2fb06b0d1edd63f49
lib/codeql/rust/elements/WildcardPat.qll 4f941afc5f9f8d319719312399a8f787c75a0dbb709ec7cf488f019339635aab a9140a86da752f9126e586ddb9424b23b3fb4841a5420bac48108c38bb218930
lib/codeql/rust/elements/YeetExpr.qll 4172bf70de31cab17639da6eed4a12a7afcefd7aa9182216c3811c822d3d6b17 88223aab1bef696f508e0605615d6b83e1eaef755314e6a651ae977edd3757c3
@@ -272,10 +272,9 @@ lib/codeql/rust/elements/internal/FieldListImpl.qll 6b80b573989ee85389c4485729a4
lib/codeql/rust/elements/internal/FnPtrTypeReprConstructor.qll 61d8808ea027a6e04d5304c880974332a0195451f6b4474f84b3695ec907d865 0916c63a02b01a839fe23ec8b189d37dc1b8bc4e1ba753cbf6d6f5067a46965a
lib/codeql/rust/elements/internal/FnPtrTypeReprImpl.qll 6b66f9bda1b5deba50a02b6ac7deb8e922da04cf19d6ed9834141bc97074bf14 b0a07d7b9204256a85188fda2deaf14e18d24e8a881727fd6e5b571bf9debdc8
lib/codeql/rust/elements/internal/ForBinderConstructor.qll 98f16b0106a19210713404f4be8b1b9f70c88efb0b88bdf2f9ea9c8fbd129842 a7af9e75f11d824a60c367924542a31a0f46f7b1f88d3ee330d4dd26b2f29df5
-lib/codeql/rust/elements/internal/ForBinderImpl.qll 62e957e4e8a68816defed494e706a37a83ad30a455ded913b48c2c3d9c51d728 e38e1b93963513704efebec2c63e5f9a9eae372fe88e1dc8c480885e21528121
lib/codeql/rust/elements/internal/ForExprConstructor.qll d79b88dac19256300b758ba0f37ce3f07e9f848d6ae0c1fdb87bd348e760aa3e 62123b11858293429aa609ea77d2f45cb8c8eebae80a1d81da6f3ad7d1dbc19b
lib/codeql/rust/elements/internal/ForTypeReprConstructor.qll eae141dbe9256ab0eb812a926ebf226075d150f6506dfecb56c85eb169cdc76b 721c2272193a6f9504fb780d40e316a93247ebfb1f302bb0a0222af689300245
-lib/codeql/rust/elements/internal/ForTypeReprImpl.qll 75747779312b3f3ffdd02188053ba3f46b8922f02630711902f7a27eecced31a 71a900f014758d1473ef198c71892d42e20dd96e934d4bedb74581964c4d1503
+lib/codeql/rust/elements/internal/ForTypeReprImpl.qll d710208dfd3f54d973e86356f051e2938fed1025562965d6ecf6b19c0701de16 510baafa9ebc9b32969cefc5b68716fa02696f5814ae417b0cd2d9aece69f6ac
lib/codeql/rust/elements/internal/FormatArgsArgConstructor.qll 8bd9b4e035ef8adeb3ac510dd68043934c0140facb933be1f240096d01cdfa11 74e9d3bbd8882ae59a7e88935d468e0a90a6529a4e2af6a3d83e93944470f0ee
lib/codeql/rust/elements/internal/FormatArgsArgImpl.qll 6a8f55e51e141e4875ed03a7cc65eea49daa349de370b957e1e8c6bc4478425c 7efab8981ccbe75a4843315404674793dda66dde02ba432edbca25c7d355778a
lib/codeql/rust/elements/internal/FormatArgsExprConstructor.qll ce29ff5a839b885b1ab7a02d6a381ae474ab1be3e6ee7dcfd7595bdf28e4b558 63bf957426871905a51ea319662a59e38104c197a1024360aca364dc145b11e8
@@ -422,7 +421,7 @@ lib/codeql/rust/elements/internal/TypeAliasConstructor.qll 048caa79eb7d400971e3e
lib/codeql/rust/elements/internal/TypeArgConstructor.qll 51d621e170fdf5f91497f8cc8c1764ce8a59fde5a2b9ecfad17ce826a96c56c4 a5bbb329bde456a40ffa84a325a4be1271dbde842c1573d1beb7056c8fb0f681
lib/codeql/rust/elements/internal/TypeArgImpl.qll 77886af8b2c045463c4c34d781c8f618eec5f5143098548047730f73c7e4a34a 6be6c519b71f9196e0559958e85efe8a78fbce7a90ca2401d7c402e46bc865c9
lib/codeql/rust/elements/internal/TypeBoundConstructor.qll ba99616e65cf2811187016ff23e5b0005cfd0f1123622e908ff8b560aaa5847f fde78432b55b31cf68a3acb7093256217df37539f942c4441d1b1e7bf9271d89
-lib/codeql/rust/elements/internal/TypeBoundImpl.qll 8a68e3c3b2bffb02a11e07102f57e8806411dbcb57f24be27a0d615a1f6f20d4 e6c92d5df538a10519655c1d2a063bb1ca1538d5d8fe9353ed0e28ad6d56be0c
+lib/codeql/rust/elements/internal/TypeBoundImpl.qll 7274dc0307595f7431343d7542b9441362087bcb1115b21bc5ffa02f2d3dd678 257cad7cd2658cf707ee9ae2bb99a4c7e3e51e6c237d272f3058571f1e5cb133
lib/codeql/rust/elements/internal/TypeBoundListConstructor.qll 4b634b3a4ca8909ce8c0d172d9258168c5271435474089902456c2e3e47ae1c5 3af74623ced55b3263c096810a685517d36b75229431b81f3bb8101294940025
lib/codeql/rust/elements/internal/TypeBoundListImpl.qll 5641aca40c0331899f4291188e60945eb2a01679e3b33883053309fb3823d9ab c84bb1daa7c10f3bb634a179957934d7ae1bef1380fcd8a9c734004625575485
lib/codeql/rust/elements/internal/TypeParamConstructor.qll a6e57cccd6b54fa68742d7b8ce70678a79ac133ea8c1bfa89d60b5f74ad07e05 0e5f45d250d736aaf40387be22e55288543bdb55bbb20ecb43f2f056e8be8b09
@@ -447,7 +446,7 @@ lib/codeql/rust/elements/internal/VisibilityImpl.qll 85c1e75d6a7f9246cfef5c261e2
lib/codeql/rust/elements/internal/WhereClauseConstructor.qll 6d6f0f0376cf45fac37ea0c7c4345d08718d2a3d6d913e591de1de9e640317c9 ff690f3d4391e5f1fae6e9014365810105e8befe9d6b52a82625994319af9ffd
lib/codeql/rust/elements/internal/WhereClauseImpl.qll 006e330df395183d15896e5f81128e24b8274d849fe45afb5040444e4b764226 ed5e8317b5f33104e5c322588dc400755c8852bbb77ef835177b13af7480fd43
lib/codeql/rust/elements/internal/WherePredConstructor.qll f331c37085792a01159e8c218e9ef827e80e99b7c3d5978b6489808f05bd11f8 179cad3e4c5aaaf27755891694ef3569322fcf34c5290e6af49e5b5e3f8aa732
-lib/codeql/rust/elements/internal/WherePredImpl.qll 6cecb4a16c39a690d6549c0ca8c38cf2be93c03c167f81466b8b2572f8457ada ddf6583bc6e4aa4a32c156f7468a26780867b2973ff91e6fc4d1b1c72fdd0990
+lib/codeql/rust/elements/internal/WherePredImpl.qll eabd6553a16165ddb0103602d8cff65c6af22580ea7a0e2beabbf795ffabdb2d 8025d8bd2351ec2de8273225a6e59d46748d7bfd7e53251fa4eb90d5140afd92
lib/codeql/rust/elements/internal/WhileExprConstructor.qll 01eb17d834584b3cba0098d367324d137aacfc60860752d9053ec414180897e7 e5e0999fb48a48ba9b3e09f87d8f44f43cc3d8a276059d9f67e7714a1852b8a5
lib/codeql/rust/elements/internal/WildcardPatConstructor.qll 5980c4e5724f88a8cb91365fc2b65a72a47183d01a37f3ff11dcd2021e612dd9 c015e94953e02dc405f8cdc1f24f7cae6b7c1134d69878e99c6858143fc7ab34
lib/codeql/rust/elements/internal/YeetExprConstructor.qll 7763e1717d3672156587250a093dd21680ad88c8224a815b472e1c9bba18f976 70dd1fd50824902362554c8c6075468060d0abbe3b3335957be335057512a417
@@ -515,7 +514,7 @@ lib/codeql/rust/elements/internal/generated/FieldList.qll 35bb72a673c02afafc1f61
lib/codeql/rust/elements/internal/generated/FnPtrTypeRepr.qll f218fa57a01ecc39b58fa15893d6499c15ff8ab8fd9f4ed3078f0ca8b3f15c7e 2d1a7325cf2bd0174ce6fc15e0cbe39c7c1d8b40db5f91e5329acb339a1ad1e8
lib/codeql/rust/elements/internal/generated/ForBinder.qll 7be6b8e3934db8cd4ac326625cf637dda4b175fd7573a52d2feb147769c4c6a1 234484b9b4cf3a20c97334417700db5029da65313410b3c9e929512c509e5c27
lib/codeql/rust/elements/internal/generated/ForExpr.qll 7c497d2c612fd175069037d6d7ff9339e8aec63259757bb56269e9ca8b0114ea dc48c0ad3945868d6bd5e41ca34a41f8ee74d8ba0adc62b440256f59c7f21096
-lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll a8fcdff13e30cce9c30fc3ae81db9ee7160b3028872cb3a60db78523a3ffe771 d3dda40fd2547bd1acd2eeb4d1bc72a4487400bb0752e9679bbb6aea0debf35a
+lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll 11f21528d55f41d28d2b1da71631da1c02053ac723e697b886e586572c919999 852b977fe46b87efd6741a2f3c7e3d22a7e2a55a75b9c26d9dc4ea2154fe3653
lib/codeql/rust/elements/internal/generated/Format.qll 934351f8a8ffd914cc3fd88aca8e81bf646236fe34d15e0df7aeeb0b942b203f da9f146e6f52bafd67dcfd3b916692cf8f66031e0b1d5d17fc8dda5eefb99ca0
lib/codeql/rust/elements/internal/generated/FormatArgsArg.qll c762a4af8609472e285dd1b1aec8251421aec49f8d0e5ce9df2cc5e2722326f8 c8c226b94b32447634b445c62bd9af7e11b93a706f8fa35d2de4fda3ce951926
lib/codeql/rust/elements/internal/generated/FormatArgsExpr.qll 8aed8715a27d3af3de56ded4610c6792a25216b1544eb7e57c8b0b37c14bd9c1 590a2b0063d2ecd00bbbd1ce29603c8fd69972e34e6daddf309c915ce4ec1375
@@ -590,7 +589,7 @@ lib/codeql/rust/elements/internal/generated/PtrTypeRepr.qll 8d0ea4f6c7f8203340bf
lib/codeql/rust/elements/internal/generated/PureSynthConstructors.qll e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f
lib/codeql/rust/elements/internal/generated/RangeExpr.qll 23cca03bf43535f33b22a38894f70d669787be4e4f5b8fe5c8f7b964d30e9027 18624cef6c6b679eeace2a98737e472432e0ead354cca02192b4d45330f047c9
lib/codeql/rust/elements/internal/generated/RangePat.qll 80826a6a6868a803aa2372e31c52a03e1811a3f1f2abdb469f91ca0bfdd9ecb6 34ee1e208c1690cba505dff2c588837c0cd91e185e2a87d1fe673191962276a9
-lib/codeql/rust/elements/internal/generated/Raw.qll 5de291e604fbeb5a4536eeb2a417f95b227a600bb589f7aab075971cd1cbfc67 22e5b41fba360781f354edb72dbc8f53b9d7434c30d3e3bac4c22f1faa72b8ed
+lib/codeql/rust/elements/internal/generated/Raw.qll e33ef2818c9bbdd5030903592ba07286c28b35b1952fa3f4ffb0ce27173fef04 fb0a5e30947e13a06d867049ced5547d5d7bc80ac2f55c6912b2c0d1d1446072
lib/codeql/rust/elements/internal/generated/RefExpr.qll 7d995884e3dc1c25fc719f5d7253179344d63650e217e9ff6530285fe7a57f64 f2c3c12551deea4964b66553fb9b6423ee16fec53bd63db4796191aa60dc6c66
lib/codeql/rust/elements/internal/generated/RefPat.qll 456ede39837463ee22a630ec7ab6c8630d3664a8ea206fcc6e4f199e92fa564c 5622062765f32930465ba6b170e986706f159f6070f48adee3c20e24e8df4e05
lib/codeql/rust/elements/internal/generated/RefTypeRepr.qll 5b0663a6d234572fb3e467e276d019415caa95ef006438cc59b7af4e1783161e 0e27c8a8f0e323c0e4d6db01fca821bf07c0864d293cdf96fa891b10820c1e4b
@@ -631,7 +630,7 @@ lib/codeql/rust/elements/internal/generated/TupleStructPat.qll 6539d0edbdc16e7df
lib/codeql/rust/elements/internal/generated/TupleTypeRepr.qll 1756cdbad56d634bf4726bc39c768386754e62650492d7d6344012038236a05b 3ac0997a47f95f28cc70c782173ce345fcb5b073be10f3c0b414d1df8443e04c
lib/codeql/rust/elements/internal/generated/TypeAlias.qll 0d0c97d9e9213b8f0390b3456737d4611701a570b9943bb20b348c4efc8e4693 a83c701c0d8914e01517dfa9253a12be962f0a7ed2f75fbaae25a13432db403f
lib/codeql/rust/elements/internal/generated/TypeArg.qll 80245e4b52bef30e5033d4c765c72531324385deea1435dc623290271ff05b1d 097926e918dcd897ea1609010c5490dbf45d4d8f4cffb9166bcadf316a2f1558
-lib/codeql/rust/elements/internal/generated/TypeBound.qll 15e118049bb5aae24bce580e3dff62b7e73dcce9f7c6bc8dfd59d2c25ed64244 f18a35749f8fc003221e8f4315160756be592406637441929eda919ac493e835
+lib/codeql/rust/elements/internal/generated/TypeBound.qll ed27681b76b8f3ad790daad4a08f3bc243452821246bcb240b1d925bc1c362a3 8fdc0caf91f1894d8711d68547185eb029446898b66f60fc0d10ef862cd6292e
lib/codeql/rust/elements/internal/generated/TypeBoundList.qll c5d43dc27075a0d5370ba4bc56b4e247357af5d2989625deff284e7846a3a48b c33c87d080e6eb6df01e98b8b0031d780472fcaf3a1ed156a038669c0e05bf0a
lib/codeql/rust/elements/internal/generated/TypeParam.qll 81a8d39f1e227de031187534e5d8e2c34f42ad3433061d686cadfbdd0df54285 893795d62b5b89997574e9057701d308bea2c4dca6053042c5308c512137e697
lib/codeql/rust/elements/internal/generated/TypeRepr.qll 1e7b9d2ddab86e35dad7c31a6453a2a60747420f8bc2e689d5163cab4fec71bb eb80e3947649e511e7f3555ffc1fd87199e7a32624449ca80ffad996cdf9e2f3
@@ -648,7 +647,7 @@ lib/codeql/rust/elements/internal/generated/Variant.qll fa6909715133049b3dba4622
lib/codeql/rust/elements/internal/generated/VariantList.qll 3f70bfde982e5c5e8ee45da6ebe149286214f8d40377d5bc5e25df6ae8f3e2d1 22e5f428bf64fd3fd21c537bfa69a46089aad7c363d72c6566474fbe1d75859e
lib/codeql/rust/elements/internal/generated/Visibility.qll af1069733c0120fae8610b3ebbcdcebe4b4c9ce4c3e3d9be3f82a93541873625 266106bdff4d7041d017871d755c011e7dd396c5999803d9e46725b6a03a2458
lib/codeql/rust/elements/internal/generated/WhereClause.qll aec72d358689d99741c769b6e8e72b92c1458138c097ec2380e917aa68119ff0 81bb9d303bc0c8d2513dc7a2b8802ec15345b364e6c1e8b300f7860aac219c36
-lib/codeql/rust/elements/internal/generated/WherePred.qll 6826373cede8b4ac5d4719a183c6b30f840d48266f0e0c8e400574476f5a2f15 a82dcc24efac562d5b6247f9a105465ebafc9bebb4fc3648518bf9166e300dbd
+lib/codeql/rust/elements/internal/generated/WherePred.qll 73b28efc1682bf527bdc97a07568d08666d61686940400c99095cb9593bc8df3 2ec1fb5577d033c120d31f1620753b3618fcb7f384a35a6d3e6b5e0bb375a8a5
lib/codeql/rust/elements/internal/generated/WhileExpr.qll 0353aab87c49569e1fbf5828b8f44457230edfa6b408fb5ec70e3d9b70f2e277 e1ba7c9c41ff150b9aaa43642c0714def4407850f2149232260c1a2672dd574a
lib/codeql/rust/elements/internal/generated/WildcardPat.qll d74b70b57a0a66bfae017a329352a5b27a6b9e73dd5521d627f680e810c6c59e 4b913b548ba27ff3c82fcd32cf996ff329cb57d176d3bebd0fcef394486ea499
lib/codeql/rust/elements/internal/generated/YeetExpr.qll cac328200872a35337b4bcb15c851afb4743f82c080f9738d295571eb01d7392 94af734eea08129b587fed849b643e7572800e8330c0b57d727d41abda47930b
diff --git a/rust/ql/.gitattributes b/rust/ql/.gitattributes
index d7dbdaa982e..4ec7fbbc2e3 100644
--- a/rust/ql/.gitattributes
+++ b/rust/ql/.gitattributes
@@ -274,7 +274,6 @@
/lib/codeql/rust/elements/internal/FnPtrTypeReprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/FnPtrTypeReprImpl.qll linguist-generated
/lib/codeql/rust/elements/internal/ForBinderConstructor.qll linguist-generated
-/lib/codeql/rust/elements/internal/ForBinderImpl.qll linguist-generated
/lib/codeql/rust/elements/internal/ForExprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/ForTypeReprConstructor.qll linguist-generated
/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll linguist-generated
diff --git a/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll b/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
index bf4627783ed..6b58c0c70f6 100644
--- a/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
+++ b/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
@@ -8,17 +8,13 @@ import codeql.rust.elements.ForBinder
import codeql.rust.elements.TypeRepr
/**
- * A higher-ranked trait bound.
+ * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
+ * only be applied to traits to form a `TypeBound`).
*
* For example:
* ```rust
- * fn foo(value: T)
- * where
- * T: for<'a> Fn(&'a str) -> &'a str
- * // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- * {
- * // ...
- * }
+ * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
+ * // ^^^^^^^^^^^^^
* ```
*/
final class ForTypeRepr = Impl::ForTypeRepr;
diff --git a/rust/ql/lib/codeql/rust/elements/TypeBound.qll b/rust/ql/lib/codeql/rust/elements/TypeBound.qll
index 03e0afa8cd3..fd9d460b09a 100644
--- a/rust/ql/lib/codeql/rust/elements/TypeBound.qll
+++ b/rust/ql/lib/codeql/rust/elements/TypeBound.qll
@@ -17,6 +17,8 @@ import codeql.rust.elements.UseBoundGenericArgs
* ```rust
* fn foo(t: T) {}
* // ^^^^^
+ * fn bar(value: impl for<'a> From<&'a str>) {}
+ * // ^^^^^^^^^^^^^^^^^^^^^
* ```
*/
final class TypeBound = Impl::TypeBound;
diff --git a/rust/ql/lib/codeql/rust/elements/WherePred.qll b/rust/ql/lib/codeql/rust/elements/WherePred.qll
index c08334fb1b9..7141819362a 100644
--- a/rust/ql/lib/codeql/rust/elements/WherePred.qll
+++ b/rust/ql/lib/codeql/rust/elements/WherePred.qll
@@ -17,6 +17,8 @@ import codeql.rust.elements.TypeRepr
* ```rust
* fn foo(t: T, u: U) where T: Debug, U: Clone {}
* // ^^^^^^^^ ^^^^^^^^
+ * fn bar(value: T) where for<'a> T: From<&'a str> {}
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^
* ```
*/
final class WherePred = Impl::WherePred;
diff --git a/rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll
index 8281a549b29..9f9b22f6c70 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/ForBinderImpl.qll
@@ -1,4 +1,3 @@
-// generated by codegen, remove this comment if you wish to edit this file
/**
* This module provides a hand-modifiable wrapper around the generated class `ForBinder`.
*
@@ -12,6 +11,7 @@ private import codeql.rust.elements.internal.generated.ForBinder
* be referenced directly.
*/
module Impl {
+ // the following QLdoc is generated: if you need to edit it, do it in the schema file
/**
* A for binder, specifying lifetime or type parameters for a closure or a type.
*
@@ -26,5 +26,7 @@ module Impl {
* print_any("hello");
* ```
*/
- class ForBinder extends Generated::ForBinder { }
+ class ForBinder extends Generated::ForBinder {
+ override string toStringImpl() { result = "for<...>" }
+ }
}
diff --git a/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll
index f555c664963..961085f026a 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll
@@ -13,17 +13,13 @@ private import codeql.rust.elements.internal.generated.ForTypeRepr
*/
module Impl {
/**
- * A higher-ranked trait bound.
+ * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
+ * only be applied to traits to form a `TypeBound`).
*
* For example:
* ```rust
- * fn foo(value: T)
- * where
- * T: for<'a> Fn(&'a str) -> &'a str
- * // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- * {
- * // ...
- * }
+ * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
+ * // ^^^^^^^^^^^^^
* ```
*/
class ForTypeRepr extends Generated::ForTypeRepr { }
diff --git a/rust/ql/lib/codeql/rust/elements/internal/TypeBoundImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/TypeBoundImpl.qll
index c4b70217db2..5dd87536a03 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/TypeBoundImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/TypeBoundImpl.qll
@@ -19,6 +19,8 @@ module Impl {
* ```rust
* fn foo(t: T) {}
* // ^^^^^
+ * fn bar(value: impl for<'a> From<&'a str>) {}
+ * // ^^^^^^^^^^^^^^^^^^^^^
* ```
*/
class TypeBound extends Generated::TypeBound { }
diff --git a/rust/ql/lib/codeql/rust/elements/internal/WherePredImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/WherePredImpl.qll
index 9f77b9c3c69..9e4231ec515 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/WherePredImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/WherePredImpl.qll
@@ -19,6 +19,8 @@ module Impl {
* ```rust
* fn foo(t: T, u: U) where T: Debug, U: Clone {}
* // ^^^^^^^^ ^^^^^^^^
+ * fn bar(value: T) where for<'a> T: From<&'a str> {}
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^
* ```
*/
class WherePred extends Generated::WherePred { }
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
index f52af334108..49e0f009c09 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
@@ -16,17 +16,13 @@ import codeql.rust.elements.internal.TypeReprImpl::Impl as TypeReprImpl
*/
module Generated {
/**
- * A higher-ranked trait bound.
+ * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
+ * only be applied to traits to form a `TypeBound`).
*
* For example:
* ```rust
- * fn foo(value: T)
- * where
- * T: for<'a> Fn(&'a str) -> &'a str
- * // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- * {
- * // ...
- * }
+ * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
+ * // ^^^^^^^^^^^^^
* ```
* INTERNAL: Do not reference the `Generated::ForTypeRepr` class directly.
* Use the subclass `ForTypeRepr`, where the following predicates are available.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
index dbb1ae77237..c689089be1e 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
@@ -1204,6 +1204,8 @@ module Raw {
* ```rust
* fn foo(t: T) {}
* // ^^^^^
+ * fn bar(value: impl for<'a> From<&'a str>) {}
+ * // ^^^^^^^^^^^^^^^^^^^^^
* ```
*/
class TypeBound extends @type_bound, AstNode {
@@ -1414,6 +1416,8 @@ module Raw {
* ```rust
* fn foo(t: T, u: U) where T: Debug, U: Clone {}
* // ^^^^^^^^ ^^^^^^^^
+ * fn bar(value: T) where for<'a> T: From<&'a str> {}
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^
* ```
*/
class WherePred extends @where_pred, AstNode {
@@ -2200,17 +2204,13 @@ module Raw {
/**
* INTERNAL: Do not use.
- * A higher-ranked trait bound.
+ * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
+ * only be applied to traits to form a `TypeBound`).
*
* For example:
* ```rust
- * fn foo(value: T)
- * where
- * T: for<'a> Fn(&'a str) -> &'a str
- * // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- * {
- * // ...
- * }
+ * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
+ * // ^^^^^^^^^^^^^
* ```
*/
class ForTypeRepr extends @for_type_repr, TypeRepr {
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll
index 48089b82083..958867911ce 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/TypeBound.qll
@@ -24,6 +24,8 @@ module Generated {
* ```rust
* fn foo(t: T) {}
* // ^^^^^
+ * fn bar(value: impl for<'a> From<&'a str>) {}
+ * // ^^^^^^^^^^^^^^^^^^^^^
* ```
* INTERNAL: Do not reference the `Generated::TypeBound` class directly.
* Use the subclass `TypeBound`, where the following predicates are available.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll
index dc007f3aa21..7a96b326f1c 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/WherePred.qll
@@ -24,6 +24,8 @@ module Generated {
* ```rust
* fn foo(t: T, u: U) where T: Debug, U: Clone {}
* // ^^^^^^^^ ^^^^^^^^
+ * fn bar(value: T) where for<'a> T: From<&'a str> {}
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^
* ```
* INTERNAL: Do not reference the `Generated::WherePred` class directly.
* Use the subclass `WherePred`, where the following predicates are available.
diff --git a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/old.dbscheme b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/old.dbscheme
new file mode 100644
index 00000000000..319c933d961
--- /dev/null
+++ b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/old.dbscheme
@@ -0,0 +1,3637 @@
+// generated by codegen, do not edit
+
+// from ../shared/tree-sitter-extractor/src/generator/prefix.dbscheme
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Empty location -*/
+
+empty_location(
+ int location: @location_default ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- Diagnostic messages -*/
+
+diagnostics(
+ unique int id: @diagnostic,
+ int severity: int ref,
+ string error_tag: string ref,
+ string error_message: string ref,
+ string full_error_message: string ref,
+ int location: @location_default ref
+);
+
+/*- Diagnostic messages: severity -*/
+
+case @diagnostic.severity of
+ 10 = @diagnostic_debug
+| 20 = @diagnostic_info
+| 30 = @diagnostic_warning
+| 40 = @diagnostic_error
+;
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
+
+overlayChangedFiles(
+ string path: string ref
+);
+
+
+// from prefix.dbscheme
+#keyset[id]
+locatable_locations(
+ int id: @locatable ref,
+ int location: @location_default ref
+);
+
+
+// from schema
+
+@element =
+ @extractor_step
+| @locatable
+| @named_crate
+| @unextracted
+;
+
+extractor_steps(
+ unique int id: @extractor_step,
+ string action: string ref,
+ int duration_ms: int ref
+);
+
+#keyset[id]
+extractor_step_files(
+ int id: @extractor_step ref,
+ int file: @file ref
+);
+
+@locatable =
+ @ast_node
+| @crate
+;
+
+named_crates(
+ unique int id: @named_crate,
+ string name: string ref,
+ int crate: @crate ref
+);
+
+@unextracted =
+ @missing
+| @unimplemented
+;
+
+@ast_node =
+ @abi
+| @addressable
+| @arg_list
+| @asm_dir_spec
+| @asm_operand
+| @asm_operand_expr
+| @asm_option
+| @asm_piece
+| @asm_reg_spec
+| @assoc_item_list
+| @attr
+| @callable
+| @closure_binder
+| @expr
+| @extern_item_list
+| @field_list
+| @format_args_arg
+| @generic_arg
+| @generic_arg_list
+| @generic_param
+| @generic_param_list
+| @item_list
+| @label
+| @let_else
+| @macro_items
+| @match_arm
+| @match_arm_list
+| @match_guard
+| @meta
+| @name
+| @param_base
+| @param_list
+| @parenthesized_arg_list
+| @pat
+| @path
+| @path_segment
+| @rename
+| @resolvable
+| @ret_type_repr
+| @return_type_syntax
+| @source_file
+| @stmt
+| @stmt_list
+| @struct_expr_field
+| @struct_expr_field_list
+| @struct_field
+| @struct_pat_field
+| @struct_pat_field_list
+| @token
+| @token_tree
+| @tuple_field
+| @type_bound
+| @type_bound_list
+| @type_repr
+| @use_bound_generic_arg
+| @use_bound_generic_args
+| @use_tree
+| @use_tree_list
+| @variant_list
+| @visibility
+| @where_clause
+| @where_pred
+;
+
+crates(
+ unique int id: @crate
+);
+
+#keyset[id]
+crate_names(
+ int id: @crate ref,
+ string name: string ref
+);
+
+#keyset[id]
+crate_versions(
+ int id: @crate ref,
+ string version: string ref
+);
+
+#keyset[id, index]
+crate_cfg_options(
+ int id: @crate ref,
+ int index: int ref,
+ string cfg_option: string ref
+);
+
+#keyset[id, index]
+crate_named_dependencies(
+ int id: @crate ref,
+ int index: int ref,
+ int named_dependency: @named_crate ref
+);
+
+missings(
+ unique int id: @missing
+);
+
+unimplementeds(
+ unique int id: @unimplemented
+);
+
+abis(
+ unique int id: @abi
+);
+
+#keyset[id]
+abi_abi_strings(
+ int id: @abi ref,
+ string abi_string: string ref
+);
+
+@addressable =
+ @item
+| @variant
+;
+
+#keyset[id]
+addressable_extended_canonical_paths(
+ int id: @addressable ref,
+ string extended_canonical_path: string ref
+);
+
+#keyset[id]
+addressable_crate_origins(
+ int id: @addressable ref,
+ string crate_origin: string ref
+);
+
+arg_lists(
+ unique int id: @arg_list
+);
+
+#keyset[id, index]
+arg_list_args(
+ int id: @arg_list ref,
+ int index: int ref,
+ int arg: @expr ref
+);
+
+asm_dir_specs(
+ unique int id: @asm_dir_spec
+);
+
+@asm_operand =
+ @asm_const
+| @asm_label
+| @asm_reg_operand
+| @asm_sym
+;
+
+asm_operand_exprs(
+ unique int id: @asm_operand_expr
+);
+
+#keyset[id]
+asm_operand_expr_in_exprs(
+ int id: @asm_operand_expr ref,
+ int in_expr: @expr ref
+);
+
+#keyset[id]
+asm_operand_expr_out_exprs(
+ int id: @asm_operand_expr ref,
+ int out_expr: @expr ref
+);
+
+asm_options(
+ unique int id: @asm_option
+);
+
+#keyset[id]
+asm_option_is_raw(
+ int id: @asm_option ref
+);
+
+@asm_piece =
+ @asm_clobber_abi
+| @asm_operand_named
+| @asm_options_list
+;
+
+asm_reg_specs(
+ unique int id: @asm_reg_spec
+);
+
+#keyset[id]
+asm_reg_spec_identifiers(
+ int id: @asm_reg_spec ref,
+ int identifier: @name_ref ref
+);
+
+assoc_item_lists(
+ unique int id: @assoc_item_list
+);
+
+#keyset[id, index]
+assoc_item_list_assoc_items(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int assoc_item: @assoc_item ref
+);
+
+#keyset[id, index]
+assoc_item_list_attrs(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+attrs(
+ unique int id: @attr
+);
+
+#keyset[id]
+attr_meta(
+ int id: @attr ref,
+ int meta: @meta ref
+);
+
+@callable =
+ @closure_expr
+| @function
+;
+
+#keyset[id]
+callable_param_lists(
+ int id: @callable ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id, index]
+callable_attrs(
+ int id: @callable ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+closure_binders(
+ unique int id: @closure_binder
+);
+
+#keyset[id]
+closure_binder_generic_param_lists(
+ int id: @closure_binder ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+@expr =
+ @array_expr_internal
+| @asm_expr
+| @await_expr
+| @become_expr
+| @binary_expr
+| @break_expr
+| @call_expr_base
+| @cast_expr
+| @closure_expr
+| @continue_expr
+| @field_expr
+| @format_args_expr
+| @if_expr
+| @index_expr
+| @labelable_expr
+| @let_expr
+| @literal_expr
+| @macro_block_expr
+| @macro_expr
+| @match_expr
+| @offset_of_expr
+| @paren_expr
+| @path_expr_base
+| @prefix_expr
+| @range_expr
+| @ref_expr
+| @return_expr
+| @struct_expr
+| @try_expr
+| @tuple_expr
+| @underscore_expr
+| @yeet_expr
+| @yield_expr
+;
+
+extern_item_lists(
+ unique int id: @extern_item_list
+);
+
+#keyset[id, index]
+extern_item_list_attrs(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+extern_item_list_extern_items(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int extern_item: @extern_item ref
+);
+
+@field_list =
+ @struct_field_list
+| @tuple_field_list
+;
+
+format_args_args(
+ unique int id: @format_args_arg
+);
+
+#keyset[id]
+format_args_arg_exprs(
+ int id: @format_args_arg ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+format_args_arg_names(
+ int id: @format_args_arg ref,
+ int name: @name ref
+);
+
+@generic_arg =
+ @assoc_type_arg
+| @const_arg
+| @lifetime_arg
+| @type_arg
+;
+
+generic_arg_lists(
+ unique int id: @generic_arg_list
+);
+
+#keyset[id, index]
+generic_arg_list_generic_args(
+ int id: @generic_arg_list ref,
+ int index: int ref,
+ int generic_arg: @generic_arg ref
+);
+
+@generic_param =
+ @const_param
+| @lifetime_param
+| @type_param
+;
+
+generic_param_lists(
+ unique int id: @generic_param_list
+);
+
+#keyset[id, index]
+generic_param_list_generic_params(
+ int id: @generic_param_list ref,
+ int index: int ref,
+ int generic_param: @generic_param ref
+);
+
+item_lists(
+ unique int id: @item_list
+);
+
+#keyset[id, index]
+item_list_attrs(
+ int id: @item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+item_list_items(
+ int id: @item_list ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+labels(
+ unique int id: @label
+);
+
+#keyset[id]
+label_lifetimes(
+ int id: @label ref,
+ int lifetime: @lifetime ref
+);
+
+let_elses(
+ unique int id: @let_else
+);
+
+#keyset[id]
+let_else_block_exprs(
+ int id: @let_else ref,
+ int block_expr: @block_expr ref
+);
+
+macro_items(
+ unique int id: @macro_items
+);
+
+#keyset[id, index]
+macro_items_items(
+ int id: @macro_items ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+match_arms(
+ unique int id: @match_arm
+);
+
+#keyset[id, index]
+match_arm_attrs(
+ int id: @match_arm ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_arm_exprs(
+ int id: @match_arm ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+match_arm_guards(
+ int id: @match_arm ref,
+ int guard: @match_guard ref
+);
+
+#keyset[id]
+match_arm_pats(
+ int id: @match_arm ref,
+ int pat: @pat ref
+);
+
+match_arm_lists(
+ unique int id: @match_arm_list
+);
+
+#keyset[id, index]
+match_arm_list_arms(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int arm: @match_arm ref
+);
+
+#keyset[id, index]
+match_arm_list_attrs(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+match_guards(
+ unique int id: @match_guard
+);
+
+#keyset[id]
+match_guard_conditions(
+ int id: @match_guard ref,
+ int condition: @expr ref
+);
+
+meta(
+ unique int id: @meta
+);
+
+#keyset[id]
+meta_exprs(
+ int id: @meta ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+meta_is_unsafe(
+ int id: @meta ref
+);
+
+#keyset[id]
+meta_paths(
+ int id: @meta ref,
+ int path: @path ref
+);
+
+#keyset[id]
+meta_token_trees(
+ int id: @meta ref,
+ int token_tree: @token_tree ref
+);
+
+names(
+ unique int id: @name
+);
+
+#keyset[id]
+name_texts(
+ int id: @name ref,
+ string text: string ref
+);
+
+@param_base =
+ @param
+| @self_param
+;
+
+#keyset[id, index]
+param_base_attrs(
+ int id: @param_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+param_base_type_reprs(
+ int id: @param_base ref,
+ int type_repr: @type_repr ref
+);
+
+param_lists(
+ unique int id: @param_list
+);
+
+#keyset[id, index]
+param_list_params(
+ int id: @param_list ref,
+ int index: int ref,
+ int param: @param ref
+);
+
+#keyset[id]
+param_list_self_params(
+ int id: @param_list ref,
+ int self_param: @self_param ref
+);
+
+parenthesized_arg_lists(
+ unique int id: @parenthesized_arg_list
+);
+
+#keyset[id, index]
+parenthesized_arg_list_type_args(
+ int id: @parenthesized_arg_list ref,
+ int index: int ref,
+ int type_arg: @type_arg ref
+);
+
+@pat =
+ @box_pat
+| @const_block_pat
+| @ident_pat
+| @literal_pat
+| @macro_pat
+| @or_pat
+| @paren_pat
+| @path_pat
+| @range_pat
+| @ref_pat
+| @rest_pat
+| @slice_pat
+| @struct_pat
+| @tuple_pat
+| @tuple_struct_pat
+| @wildcard_pat
+;
+
+paths(
+ unique int id: @path
+);
+
+#keyset[id]
+path_qualifiers(
+ int id: @path ref,
+ int qualifier: @path ref
+);
+
+#keyset[id]
+path_segments_(
+ int id: @path ref,
+ int segment: @path_segment ref
+);
+
+path_segments(
+ unique int id: @path_segment
+);
+
+#keyset[id]
+path_segment_generic_arg_lists(
+ int id: @path_segment ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+path_segment_identifiers(
+ int id: @path_segment ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+path_segment_parenthesized_arg_lists(
+ int id: @path_segment ref,
+ int parenthesized_arg_list: @parenthesized_arg_list ref
+);
+
+#keyset[id]
+path_segment_ret_types(
+ int id: @path_segment ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+path_segment_return_type_syntaxes(
+ int id: @path_segment ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+path_segment_type_reprs(
+ int id: @path_segment ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+path_segment_trait_type_reprs(
+ int id: @path_segment ref,
+ int trait_type_repr: @path_type_repr ref
+);
+
+renames(
+ unique int id: @rename
+);
+
+#keyset[id]
+rename_names(
+ int id: @rename ref,
+ int name: @name ref
+);
+
+@resolvable =
+ @method_call_expr
+| @path_ast_node
+;
+
+#keyset[id]
+resolvable_resolved_paths(
+ int id: @resolvable ref,
+ string resolved_path: string ref
+);
+
+#keyset[id]
+resolvable_resolved_crate_origins(
+ int id: @resolvable ref,
+ string resolved_crate_origin: string ref
+);
+
+ret_type_reprs(
+ unique int id: @ret_type_repr
+);
+
+#keyset[id]
+ret_type_repr_type_reprs(
+ int id: @ret_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+return_type_syntaxes(
+ unique int id: @return_type_syntax
+);
+
+source_files(
+ unique int id: @source_file
+);
+
+#keyset[id, index]
+source_file_attrs(
+ int id: @source_file ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+source_file_items(
+ int id: @source_file ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+@stmt =
+ @expr_stmt
+| @item
+| @let_stmt
+;
+
+stmt_lists(
+ unique int id: @stmt_list
+);
+
+#keyset[id, index]
+stmt_list_attrs(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+stmt_list_statements(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+#keyset[id]
+stmt_list_tail_exprs(
+ int id: @stmt_list ref,
+ int tail_expr: @expr ref
+);
+
+struct_expr_fields(
+ unique int id: @struct_expr_field
+);
+
+#keyset[id, index]
+struct_expr_field_attrs(
+ int id: @struct_expr_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_expr_field_exprs(
+ int id: @struct_expr_field ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+struct_expr_field_identifiers(
+ int id: @struct_expr_field ref,
+ int identifier: @name_ref ref
+);
+
+struct_expr_field_lists(
+ unique int id: @struct_expr_field_list
+);
+
+#keyset[id, index]
+struct_expr_field_list_attrs(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+struct_expr_field_list_fields(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int field: @struct_expr_field ref
+);
+
+#keyset[id]
+struct_expr_field_list_spreads(
+ int id: @struct_expr_field_list ref,
+ int spread: @expr ref
+);
+
+struct_fields(
+ unique int id: @struct_field
+);
+
+#keyset[id, index]
+struct_field_attrs(
+ int id: @struct_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_defaults(
+ int id: @struct_field ref,
+ int default: @expr ref
+);
+
+#keyset[id]
+struct_field_is_unsafe(
+ int id: @struct_field ref
+);
+
+#keyset[id]
+struct_field_names(
+ int id: @struct_field ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_field_type_reprs(
+ int id: @struct_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+struct_field_visibilities(
+ int id: @struct_field ref,
+ int visibility: @visibility ref
+);
+
+struct_pat_fields(
+ unique int id: @struct_pat_field
+);
+
+#keyset[id, index]
+struct_pat_field_attrs(
+ int id: @struct_pat_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_pat_field_identifiers(
+ int id: @struct_pat_field ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+struct_pat_field_pats(
+ int id: @struct_pat_field ref,
+ int pat: @pat ref
+);
+
+struct_pat_field_lists(
+ unique int id: @struct_pat_field_list
+);
+
+#keyset[id, index]
+struct_pat_field_list_fields(
+ int id: @struct_pat_field_list ref,
+ int index: int ref,
+ int field: @struct_pat_field ref
+);
+
+#keyset[id]
+struct_pat_field_list_rest_pats(
+ int id: @struct_pat_field_list ref,
+ int rest_pat: @rest_pat ref
+);
+
+@token =
+ @comment
+;
+
+token_trees(
+ unique int id: @token_tree
+);
+
+tuple_fields(
+ unique int id: @tuple_field
+);
+
+#keyset[id, index]
+tuple_field_attrs(
+ int id: @tuple_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+tuple_field_type_reprs(
+ int id: @tuple_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+tuple_field_visibilities(
+ int id: @tuple_field ref,
+ int visibility: @visibility ref
+);
+
+type_bounds(
+ unique int id: @type_bound
+);
+
+#keyset[id]
+type_bound_is_async(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_is_const(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_lifetimes(
+ int id: @type_bound ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+type_bound_type_reprs(
+ int id: @type_bound ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_bound_use_bound_generic_args(
+ int id: @type_bound ref,
+ int use_bound_generic_args: @use_bound_generic_args ref
+);
+
+type_bound_lists(
+ unique int id: @type_bound_list
+);
+
+#keyset[id, index]
+type_bound_list_bounds(
+ int id: @type_bound_list ref,
+ int index: int ref,
+ int bound: @type_bound ref
+);
+
+@type_repr =
+ @array_type_repr
+| @dyn_trait_type_repr
+| @fn_ptr_type_repr
+| @for_type_repr
+| @impl_trait_type_repr
+| @infer_type_repr
+| @macro_type_repr
+| @never_type_repr
+| @paren_type_repr
+| @path_type_repr
+| @ptr_type_repr
+| @ref_type_repr
+| @slice_type_repr
+| @tuple_type_repr
+;
+
+@use_bound_generic_arg =
+ @lifetime
+| @name_ref
+;
+
+use_bound_generic_args(
+ unique int id: @use_bound_generic_args
+);
+
+#keyset[id, index]
+use_bound_generic_args_use_bound_generic_args(
+ int id: @use_bound_generic_args ref,
+ int index: int ref,
+ int use_bound_generic_arg: @use_bound_generic_arg ref
+);
+
+use_trees(
+ unique int id: @use_tree
+);
+
+#keyset[id]
+use_tree_is_glob(
+ int id: @use_tree ref
+);
+
+#keyset[id]
+use_tree_paths(
+ int id: @use_tree ref,
+ int path: @path ref
+);
+
+#keyset[id]
+use_tree_renames(
+ int id: @use_tree ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+use_tree_use_tree_lists(
+ int id: @use_tree ref,
+ int use_tree_list: @use_tree_list ref
+);
+
+use_tree_lists(
+ unique int id: @use_tree_list
+);
+
+#keyset[id, index]
+use_tree_list_use_trees(
+ int id: @use_tree_list ref,
+ int index: int ref,
+ int use_tree: @use_tree ref
+);
+
+variant_lists(
+ unique int id: @variant_list
+);
+
+#keyset[id, index]
+variant_list_variants(
+ int id: @variant_list ref,
+ int index: int ref,
+ int variant: @variant ref
+);
+
+visibilities(
+ unique int id: @visibility
+);
+
+#keyset[id]
+visibility_paths(
+ int id: @visibility ref,
+ int path: @path ref
+);
+
+where_clauses(
+ unique int id: @where_clause
+);
+
+#keyset[id, index]
+where_clause_predicates(
+ int id: @where_clause ref,
+ int index: int ref,
+ int predicate: @where_pred ref
+);
+
+where_preds(
+ unique int id: @where_pred
+);
+
+#keyset[id]
+where_pred_generic_param_lists(
+ int id: @where_pred ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+where_pred_lifetimes(
+ int id: @where_pred ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+where_pred_type_reprs(
+ int id: @where_pred ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+where_pred_type_bound_lists(
+ int id: @where_pred ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+array_expr_internals(
+ unique int id: @array_expr_internal
+);
+
+#keyset[id, index]
+array_expr_internal_attrs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+array_expr_internal_exprs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+array_expr_internal_is_semicolon(
+ int id: @array_expr_internal ref
+);
+
+array_type_reprs(
+ unique int id: @array_type_repr
+);
+
+#keyset[id]
+array_type_repr_const_args(
+ int id: @array_type_repr ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+array_type_repr_element_type_reprs(
+ int id: @array_type_repr ref,
+ int element_type_repr: @type_repr ref
+);
+
+asm_clobber_abis(
+ unique int id: @asm_clobber_abi
+);
+
+asm_consts(
+ unique int id: @asm_const
+);
+
+#keyset[id]
+asm_const_exprs(
+ int id: @asm_const ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+asm_const_is_const(
+ int id: @asm_const ref
+);
+
+asm_exprs(
+ unique int id: @asm_expr
+);
+
+#keyset[id, index]
+asm_expr_asm_pieces(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int asm_piece: @asm_piece ref
+);
+
+#keyset[id, index]
+asm_expr_attrs(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+asm_expr_templates(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int template: @expr ref
+);
+
+asm_labels(
+ unique int id: @asm_label
+);
+
+#keyset[id]
+asm_label_block_exprs(
+ int id: @asm_label ref,
+ int block_expr: @block_expr ref
+);
+
+asm_operand_nameds(
+ unique int id: @asm_operand_named
+);
+
+#keyset[id]
+asm_operand_named_asm_operands(
+ int id: @asm_operand_named ref,
+ int asm_operand: @asm_operand ref
+);
+
+#keyset[id]
+asm_operand_named_names(
+ int id: @asm_operand_named ref,
+ int name: @name ref
+);
+
+asm_options_lists(
+ unique int id: @asm_options_list
+);
+
+#keyset[id, index]
+asm_options_list_asm_options(
+ int id: @asm_options_list ref,
+ int index: int ref,
+ int asm_option: @asm_option ref
+);
+
+asm_reg_operands(
+ unique int id: @asm_reg_operand
+);
+
+#keyset[id]
+asm_reg_operand_asm_dir_specs(
+ int id: @asm_reg_operand ref,
+ int asm_dir_spec: @asm_dir_spec ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_operand_exprs(
+ int id: @asm_reg_operand ref,
+ int asm_operand_expr: @asm_operand_expr ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_reg_specs(
+ int id: @asm_reg_operand ref,
+ int asm_reg_spec: @asm_reg_spec ref
+);
+
+asm_syms(
+ unique int id: @asm_sym
+);
+
+#keyset[id]
+asm_sym_paths(
+ int id: @asm_sym ref,
+ int path: @path ref
+);
+
+assoc_type_args(
+ unique int id: @assoc_type_arg
+);
+
+#keyset[id]
+assoc_type_arg_const_args(
+ int id: @assoc_type_arg ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+assoc_type_arg_generic_arg_lists(
+ int id: @assoc_type_arg ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+assoc_type_arg_identifiers(
+ int id: @assoc_type_arg ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+assoc_type_arg_param_lists(
+ int id: @assoc_type_arg ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+assoc_type_arg_ret_types(
+ int id: @assoc_type_arg ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_return_type_syntaxes(
+ int id: @assoc_type_arg ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+assoc_type_arg_type_reprs(
+ int id: @assoc_type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_type_bound_lists(
+ int id: @assoc_type_arg ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+await_exprs(
+ unique int id: @await_expr
+);
+
+#keyset[id, index]
+await_expr_attrs(
+ int id: @await_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+await_expr_exprs(
+ int id: @await_expr ref,
+ int expr: @expr ref
+);
+
+become_exprs(
+ unique int id: @become_expr
+);
+
+#keyset[id, index]
+become_expr_attrs(
+ int id: @become_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+become_expr_exprs(
+ int id: @become_expr ref,
+ int expr: @expr ref
+);
+
+binary_exprs(
+ unique int id: @binary_expr
+);
+
+#keyset[id, index]
+binary_expr_attrs(
+ int id: @binary_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+binary_expr_lhs(
+ int id: @binary_expr ref,
+ int lhs: @expr ref
+);
+
+#keyset[id]
+binary_expr_operator_names(
+ int id: @binary_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+binary_expr_rhs(
+ int id: @binary_expr ref,
+ int rhs: @expr ref
+);
+
+box_pats(
+ unique int id: @box_pat
+);
+
+#keyset[id]
+box_pat_pats(
+ int id: @box_pat ref,
+ int pat: @pat ref
+);
+
+break_exprs(
+ unique int id: @break_expr
+);
+
+#keyset[id, index]
+break_expr_attrs(
+ int id: @break_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+break_expr_exprs(
+ int id: @break_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+break_expr_lifetimes(
+ int id: @break_expr ref,
+ int lifetime: @lifetime ref
+);
+
+@call_expr_base =
+ @call_expr
+| @method_call_expr
+;
+
+#keyset[id]
+call_expr_base_arg_lists(
+ int id: @call_expr_base ref,
+ int arg_list: @arg_list ref
+);
+
+#keyset[id, index]
+call_expr_base_attrs(
+ int id: @call_expr_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+cast_exprs(
+ unique int id: @cast_expr
+);
+
+#keyset[id, index]
+cast_expr_attrs(
+ int id: @cast_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+cast_expr_exprs(
+ int id: @cast_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+cast_expr_type_reprs(
+ int id: @cast_expr ref,
+ int type_repr: @type_repr ref
+);
+
+closure_exprs(
+ unique int id: @closure_expr
+);
+
+#keyset[id]
+closure_expr_bodies(
+ int id: @closure_expr ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+closure_expr_closure_binders(
+ int id: @closure_expr ref,
+ int closure_binder: @closure_binder ref
+);
+
+#keyset[id]
+closure_expr_is_async(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_const(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_gen(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_move(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_static(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_ret_types(
+ int id: @closure_expr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+comments(
+ unique int id: @comment,
+ int parent: @ast_node ref,
+ string text: string ref
+);
+
+const_args(
+ unique int id: @const_arg
+);
+
+#keyset[id]
+const_arg_exprs(
+ int id: @const_arg ref,
+ int expr: @expr ref
+);
+
+const_block_pats(
+ unique int id: @const_block_pat
+);
+
+#keyset[id]
+const_block_pat_block_exprs(
+ int id: @const_block_pat ref,
+ int block_expr: @block_expr ref
+);
+
+#keyset[id]
+const_block_pat_is_const(
+ int id: @const_block_pat ref
+);
+
+const_params(
+ unique int id: @const_param
+);
+
+#keyset[id, index]
+const_param_attrs(
+ int id: @const_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_param_default_vals(
+ int id: @const_param ref,
+ int default_val: @const_arg ref
+);
+
+#keyset[id]
+const_param_is_const(
+ int id: @const_param ref
+);
+
+#keyset[id]
+const_param_names(
+ int id: @const_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_param_type_reprs(
+ int id: @const_param ref,
+ int type_repr: @type_repr ref
+);
+
+continue_exprs(
+ unique int id: @continue_expr
+);
+
+#keyset[id, index]
+continue_expr_attrs(
+ int id: @continue_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+continue_expr_lifetimes(
+ int id: @continue_expr ref,
+ int lifetime: @lifetime ref
+);
+
+dyn_trait_type_reprs(
+ unique int id: @dyn_trait_type_repr
+);
+
+#keyset[id]
+dyn_trait_type_repr_type_bound_lists(
+ int id: @dyn_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+expr_stmts(
+ unique int id: @expr_stmt
+);
+
+#keyset[id]
+expr_stmt_exprs(
+ int id: @expr_stmt ref,
+ int expr: @expr ref
+);
+
+field_exprs(
+ unique int id: @field_expr
+);
+
+#keyset[id, index]
+field_expr_attrs(
+ int id: @field_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+field_expr_containers(
+ int id: @field_expr ref,
+ int container: @expr ref
+);
+
+#keyset[id]
+field_expr_identifiers(
+ int id: @field_expr ref,
+ int identifier: @name_ref ref
+);
+
+fn_ptr_type_reprs(
+ unique int id: @fn_ptr_type_repr
+);
+
+#keyset[id]
+fn_ptr_type_repr_abis(
+ int id: @fn_ptr_type_repr ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_async(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_const(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_unsafe(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_param_lists(
+ int id: @fn_ptr_type_repr ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_ret_types(
+ int id: @fn_ptr_type_repr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+for_type_reprs(
+ unique int id: @for_type_repr
+);
+
+#keyset[id]
+for_type_repr_generic_param_lists(
+ int id: @for_type_repr ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+for_type_repr_type_reprs(
+ int id: @for_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+format_args_exprs(
+ unique int id: @format_args_expr
+);
+
+#keyset[id, index]
+format_args_expr_args(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int arg: @format_args_arg ref
+);
+
+#keyset[id, index]
+format_args_expr_attrs(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+format_args_expr_templates(
+ int id: @format_args_expr ref,
+ int template: @expr ref
+);
+
+ident_pats(
+ unique int id: @ident_pat
+);
+
+#keyset[id, index]
+ident_pat_attrs(
+ int id: @ident_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ident_pat_is_mut(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_is_ref(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_names(
+ int id: @ident_pat ref,
+ int name: @name ref
+);
+
+#keyset[id]
+ident_pat_pats(
+ int id: @ident_pat ref,
+ int pat: @pat ref
+);
+
+if_exprs(
+ unique int id: @if_expr
+);
+
+#keyset[id, index]
+if_expr_attrs(
+ int id: @if_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+if_expr_conditions(
+ int id: @if_expr ref,
+ int condition: @expr ref
+);
+
+#keyset[id]
+if_expr_elses(
+ int id: @if_expr ref,
+ int else: @expr ref
+);
+
+#keyset[id]
+if_expr_thens(
+ int id: @if_expr ref,
+ int then: @block_expr ref
+);
+
+impl_trait_type_reprs(
+ unique int id: @impl_trait_type_repr
+);
+
+#keyset[id]
+impl_trait_type_repr_type_bound_lists(
+ int id: @impl_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+index_exprs(
+ unique int id: @index_expr
+);
+
+#keyset[id, index]
+index_expr_attrs(
+ int id: @index_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+index_expr_bases(
+ int id: @index_expr ref,
+ int base: @expr ref
+);
+
+#keyset[id]
+index_expr_indices(
+ int id: @index_expr ref,
+ int index: @expr ref
+);
+
+infer_type_reprs(
+ unique int id: @infer_type_repr
+);
+
+@item =
+ @adt
+| @assoc_item
+| @extern_block
+| @extern_crate
+| @extern_item
+| @impl
+| @macro_def
+| @macro_rules
+| @module
+| @trait
+| @trait_alias
+| @use
+;
+
+#keyset[id]
+item_attribute_macro_expansions(
+ int id: @item ref,
+ int attribute_macro_expansion: @macro_items ref
+);
+
+@labelable_expr =
+ @block_expr
+| @looping_expr
+;
+
+#keyset[id]
+labelable_expr_labels(
+ int id: @labelable_expr ref,
+ int label: @label ref
+);
+
+let_exprs(
+ unique int id: @let_expr
+);
+
+#keyset[id, index]
+let_expr_attrs(
+ int id: @let_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_expr_scrutinees(
+ int id: @let_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+let_expr_pats(
+ int id: @let_expr ref,
+ int pat: @pat ref
+);
+
+let_stmts(
+ unique int id: @let_stmt
+);
+
+#keyset[id, index]
+let_stmt_attrs(
+ int id: @let_stmt ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_stmt_initializers(
+ int id: @let_stmt ref,
+ int initializer: @expr ref
+);
+
+#keyset[id]
+let_stmt_let_elses(
+ int id: @let_stmt ref,
+ int let_else: @let_else ref
+);
+
+#keyset[id]
+let_stmt_pats(
+ int id: @let_stmt ref,
+ int pat: @pat ref
+);
+
+#keyset[id]
+let_stmt_type_reprs(
+ int id: @let_stmt ref,
+ int type_repr: @type_repr ref
+);
+
+lifetimes(
+ unique int id: @lifetime
+);
+
+#keyset[id]
+lifetime_texts(
+ int id: @lifetime ref,
+ string text: string ref
+);
+
+lifetime_args(
+ unique int id: @lifetime_arg
+);
+
+#keyset[id]
+lifetime_arg_lifetimes(
+ int id: @lifetime_arg ref,
+ int lifetime: @lifetime ref
+);
+
+lifetime_params(
+ unique int id: @lifetime_param
+);
+
+#keyset[id, index]
+lifetime_param_attrs(
+ int id: @lifetime_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+lifetime_param_lifetimes(
+ int id: @lifetime_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+lifetime_param_type_bound_lists(
+ int id: @lifetime_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+literal_exprs(
+ unique int id: @literal_expr
+);
+
+#keyset[id, index]
+literal_expr_attrs(
+ int id: @literal_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+literal_expr_text_values(
+ int id: @literal_expr ref,
+ string text_value: string ref
+);
+
+literal_pats(
+ unique int id: @literal_pat
+);
+
+#keyset[id]
+literal_pat_literals(
+ int id: @literal_pat ref,
+ int literal: @literal_expr ref
+);
+
+macro_block_exprs(
+ unique int id: @macro_block_expr
+);
+
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
+#keyset[id, index]
+macro_block_expr_statements(
+ int id: @macro_block_expr ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+macro_exprs(
+ unique int id: @macro_expr
+);
+
+#keyset[id]
+macro_expr_macro_calls(
+ int id: @macro_expr ref,
+ int macro_call: @macro_call ref
+);
+
+macro_pats(
+ unique int id: @macro_pat
+);
+
+#keyset[id]
+macro_pat_macro_calls(
+ int id: @macro_pat ref,
+ int macro_call: @macro_call ref
+);
+
+macro_type_reprs(
+ unique int id: @macro_type_repr
+);
+
+#keyset[id]
+macro_type_repr_macro_calls(
+ int id: @macro_type_repr ref,
+ int macro_call: @macro_call ref
+);
+
+match_exprs(
+ unique int id: @match_expr
+);
+
+#keyset[id, index]
+match_expr_attrs(
+ int id: @match_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_expr_scrutinees(
+ int id: @match_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+match_expr_match_arm_lists(
+ int id: @match_expr ref,
+ int match_arm_list: @match_arm_list ref
+);
+
+name_refs(
+ unique int id: @name_ref
+);
+
+#keyset[id]
+name_ref_texts(
+ int id: @name_ref ref,
+ string text: string ref
+);
+
+never_type_reprs(
+ unique int id: @never_type_repr
+);
+
+offset_of_exprs(
+ unique int id: @offset_of_expr
+);
+
+#keyset[id, index]
+offset_of_expr_attrs(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+offset_of_expr_fields(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int field: @name_ref ref
+);
+
+#keyset[id]
+offset_of_expr_type_reprs(
+ int id: @offset_of_expr ref,
+ int type_repr: @type_repr ref
+);
+
+or_pats(
+ unique int id: @or_pat
+);
+
+#keyset[id, index]
+or_pat_pats(
+ int id: @or_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+params(
+ unique int id: @param
+);
+
+#keyset[id]
+param_pats(
+ int id: @param ref,
+ int pat: @pat ref
+);
+
+paren_exprs(
+ unique int id: @paren_expr
+);
+
+#keyset[id, index]
+paren_expr_attrs(
+ int id: @paren_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+paren_expr_exprs(
+ int id: @paren_expr ref,
+ int expr: @expr ref
+);
+
+paren_pats(
+ unique int id: @paren_pat
+);
+
+#keyset[id]
+paren_pat_pats(
+ int id: @paren_pat ref,
+ int pat: @pat ref
+);
+
+paren_type_reprs(
+ unique int id: @paren_type_repr
+);
+
+#keyset[id]
+paren_type_repr_type_reprs(
+ int id: @paren_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+@path_ast_node =
+ @path_expr
+| @path_pat
+| @struct_expr
+| @struct_pat
+| @tuple_struct_pat
+;
+
+#keyset[id]
+path_ast_node_paths(
+ int id: @path_ast_node ref,
+ int path: @path ref
+);
+
+@path_expr_base =
+ @path_expr
+;
+
+path_type_reprs(
+ unique int id: @path_type_repr
+);
+
+#keyset[id]
+path_type_repr_paths(
+ int id: @path_type_repr ref,
+ int path: @path ref
+);
+
+prefix_exprs(
+ unique int id: @prefix_expr
+);
+
+#keyset[id, index]
+prefix_expr_attrs(
+ int id: @prefix_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+prefix_expr_exprs(
+ int id: @prefix_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+prefix_expr_operator_names(
+ int id: @prefix_expr ref,
+ string operator_name: string ref
+);
+
+ptr_type_reprs(
+ unique int id: @ptr_type_repr
+);
+
+#keyset[id]
+ptr_type_repr_is_const(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_is_mut(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_type_reprs(
+ int id: @ptr_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+range_exprs(
+ unique int id: @range_expr
+);
+
+#keyset[id, index]
+range_expr_attrs(
+ int id: @range_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+range_expr_ends(
+ int id: @range_expr ref,
+ int end: @expr ref
+);
+
+#keyset[id]
+range_expr_operator_names(
+ int id: @range_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_expr_starts(
+ int id: @range_expr ref,
+ int start: @expr ref
+);
+
+range_pats(
+ unique int id: @range_pat
+);
+
+#keyset[id]
+range_pat_ends(
+ int id: @range_pat ref,
+ int end: @pat ref
+);
+
+#keyset[id]
+range_pat_operator_names(
+ int id: @range_pat ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_pat_starts(
+ int id: @range_pat ref,
+ int start: @pat ref
+);
+
+ref_exprs(
+ unique int id: @ref_expr
+);
+
+#keyset[id, index]
+ref_expr_attrs(
+ int id: @ref_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ref_expr_exprs(
+ int id: @ref_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+ref_expr_is_const(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_mut(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_raw(
+ int id: @ref_expr ref
+);
+
+ref_pats(
+ unique int id: @ref_pat
+);
+
+#keyset[id]
+ref_pat_is_mut(
+ int id: @ref_pat ref
+);
+
+#keyset[id]
+ref_pat_pats(
+ int id: @ref_pat ref,
+ int pat: @pat ref
+);
+
+ref_type_reprs(
+ unique int id: @ref_type_repr
+);
+
+#keyset[id]
+ref_type_repr_is_mut(
+ int id: @ref_type_repr ref
+);
+
+#keyset[id]
+ref_type_repr_lifetimes(
+ int id: @ref_type_repr ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+ref_type_repr_type_reprs(
+ int id: @ref_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+rest_pats(
+ unique int id: @rest_pat
+);
+
+#keyset[id, index]
+rest_pat_attrs(
+ int id: @rest_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+return_exprs(
+ unique int id: @return_expr
+);
+
+#keyset[id, index]
+return_expr_attrs(
+ int id: @return_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+return_expr_exprs(
+ int id: @return_expr ref,
+ int expr: @expr ref
+);
+
+self_params(
+ unique int id: @self_param
+);
+
+#keyset[id]
+self_param_is_ref(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_is_mut(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_lifetimes(
+ int id: @self_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+self_param_names(
+ int id: @self_param ref,
+ int name: @name ref
+);
+
+slice_pats(
+ unique int id: @slice_pat
+);
+
+#keyset[id, index]
+slice_pat_pats(
+ int id: @slice_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+slice_type_reprs(
+ unique int id: @slice_type_repr
+);
+
+#keyset[id]
+slice_type_repr_type_reprs(
+ int id: @slice_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+struct_field_lists(
+ unique int id: @struct_field_list
+);
+
+#keyset[id, index]
+struct_field_list_fields(
+ int id: @struct_field_list ref,
+ int index: int ref,
+ int field: @struct_field ref
+);
+
+try_exprs(
+ unique int id: @try_expr
+);
+
+#keyset[id, index]
+try_expr_attrs(
+ int id: @try_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+try_expr_exprs(
+ int id: @try_expr ref,
+ int expr: @expr ref
+);
+
+tuple_exprs(
+ unique int id: @tuple_expr
+);
+
+#keyset[id, index]
+tuple_expr_attrs(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+tuple_expr_fields(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int field: @expr ref
+);
+
+tuple_field_lists(
+ unique int id: @tuple_field_list
+);
+
+#keyset[id, index]
+tuple_field_list_fields(
+ int id: @tuple_field_list ref,
+ int index: int ref,
+ int field: @tuple_field ref
+);
+
+tuple_pats(
+ unique int id: @tuple_pat
+);
+
+#keyset[id, index]
+tuple_pat_fields(
+ int id: @tuple_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+tuple_type_reprs(
+ unique int id: @tuple_type_repr
+);
+
+#keyset[id, index]
+tuple_type_repr_fields(
+ int id: @tuple_type_repr ref,
+ int index: int ref,
+ int field: @type_repr ref
+);
+
+type_args(
+ unique int id: @type_arg
+);
+
+#keyset[id]
+type_arg_type_reprs(
+ int id: @type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+type_params(
+ unique int id: @type_param
+);
+
+#keyset[id, index]
+type_param_attrs(
+ int id: @type_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_param_default_types(
+ int id: @type_param ref,
+ int default_type: @type_repr ref
+);
+
+#keyset[id]
+type_param_names(
+ int id: @type_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_param_type_bound_lists(
+ int id: @type_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+underscore_exprs(
+ unique int id: @underscore_expr
+);
+
+#keyset[id, index]
+underscore_expr_attrs(
+ int id: @underscore_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+variants(
+ unique int id: @variant
+);
+
+#keyset[id, index]
+variant_attrs(
+ int id: @variant ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+variant_discriminants(
+ int id: @variant ref,
+ int discriminant: @expr ref
+);
+
+#keyset[id]
+variant_field_lists(
+ int id: @variant ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+variant_names(
+ int id: @variant ref,
+ int name: @name ref
+);
+
+#keyset[id]
+variant_visibilities(
+ int id: @variant ref,
+ int visibility: @visibility ref
+);
+
+wildcard_pats(
+ unique int id: @wildcard_pat
+);
+
+yeet_exprs(
+ unique int id: @yeet_expr
+);
+
+#keyset[id, index]
+yeet_expr_attrs(
+ int id: @yeet_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yeet_expr_exprs(
+ int id: @yeet_expr ref,
+ int expr: @expr ref
+);
+
+yield_exprs(
+ unique int id: @yield_expr
+);
+
+#keyset[id, index]
+yield_expr_attrs(
+ int id: @yield_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yield_expr_exprs(
+ int id: @yield_expr ref,
+ int expr: @expr ref
+);
+
+@adt =
+ @enum
+| @struct
+| @union
+;
+
+#keyset[id, index]
+adt_derive_macro_expansions(
+ int id: @adt ref,
+ int index: int ref,
+ int derive_macro_expansion: @macro_items ref
+);
+
+@assoc_item =
+ @const
+| @function
+| @macro_call
+| @type_alias
+;
+
+block_exprs(
+ unique int id: @block_expr
+);
+
+#keyset[id, index]
+block_expr_attrs(
+ int id: @block_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+block_expr_is_async(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_const(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_gen(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_move(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_try(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_unsafe(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_stmt_lists(
+ int id: @block_expr ref,
+ int stmt_list: @stmt_list ref
+);
+
+call_exprs(
+ unique int id: @call_expr
+);
+
+#keyset[id]
+call_expr_functions(
+ int id: @call_expr ref,
+ int function: @expr ref
+);
+
+extern_blocks(
+ unique int id: @extern_block
+);
+
+#keyset[id]
+extern_block_abis(
+ int id: @extern_block ref,
+ int abi: @abi ref
+);
+
+#keyset[id, index]
+extern_block_attrs(
+ int id: @extern_block ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_block_extern_item_lists(
+ int id: @extern_block ref,
+ int extern_item_list: @extern_item_list ref
+);
+
+#keyset[id]
+extern_block_is_unsafe(
+ int id: @extern_block ref
+);
+
+extern_crates(
+ unique int id: @extern_crate
+);
+
+#keyset[id, index]
+extern_crate_attrs(
+ int id: @extern_crate ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_crate_identifiers(
+ int id: @extern_crate ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+extern_crate_renames(
+ int id: @extern_crate ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+extern_crate_visibilities(
+ int id: @extern_crate ref,
+ int visibility: @visibility ref
+);
+
+@extern_item =
+ @function
+| @macro_call
+| @static
+| @type_alias
+;
+
+impls(
+ unique int id: @impl
+);
+
+#keyset[id]
+impl_assoc_item_lists(
+ int id: @impl ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+impl_attrs(
+ int id: @impl ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+impl_generic_param_lists(
+ int id: @impl ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+impl_is_const(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_default(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_unsafe(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_self_ties(
+ int id: @impl ref,
+ int self_ty: @type_repr ref
+);
+
+#keyset[id]
+impl_traits(
+ int id: @impl ref,
+ int trait: @type_repr ref
+);
+
+#keyset[id]
+impl_visibilities(
+ int id: @impl ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+impl_where_clauses(
+ int id: @impl ref,
+ int where_clause: @where_clause ref
+);
+
+@looping_expr =
+ @for_expr
+| @loop_expr
+| @while_expr
+;
+
+#keyset[id]
+looping_expr_loop_bodies(
+ int id: @looping_expr ref,
+ int loop_body: @block_expr ref
+);
+
+macro_defs(
+ unique int id: @macro_def
+);
+
+#keyset[id]
+macro_def_args(
+ int id: @macro_def ref,
+ int args: @token_tree ref
+);
+
+#keyset[id, index]
+macro_def_attrs(
+ int id: @macro_def ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_def_bodies(
+ int id: @macro_def ref,
+ int body: @token_tree ref
+);
+
+#keyset[id]
+macro_def_names(
+ int id: @macro_def ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_def_visibilities(
+ int id: @macro_def ref,
+ int visibility: @visibility ref
+);
+
+macro_rules(
+ unique int id: @macro_rules
+);
+
+#keyset[id, index]
+macro_rules_attrs(
+ int id: @macro_rules ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_rules_names(
+ int id: @macro_rules ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_rules_token_trees(
+ int id: @macro_rules ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_rules_visibilities(
+ int id: @macro_rules ref,
+ int visibility: @visibility ref
+);
+
+method_call_exprs(
+ unique int id: @method_call_expr
+);
+
+#keyset[id]
+method_call_expr_generic_arg_lists(
+ int id: @method_call_expr ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+method_call_expr_identifiers(
+ int id: @method_call_expr ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+method_call_expr_receivers(
+ int id: @method_call_expr ref,
+ int receiver: @expr ref
+);
+
+modules(
+ unique int id: @module
+);
+
+#keyset[id, index]
+module_attrs(
+ int id: @module ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+module_item_lists(
+ int id: @module ref,
+ int item_list: @item_list ref
+);
+
+#keyset[id]
+module_names(
+ int id: @module ref,
+ int name: @name ref
+);
+
+#keyset[id]
+module_visibilities(
+ int id: @module ref,
+ int visibility: @visibility ref
+);
+
+path_exprs(
+ unique int id: @path_expr
+);
+
+#keyset[id, index]
+path_expr_attrs(
+ int id: @path_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+path_pats(
+ unique int id: @path_pat
+);
+
+struct_exprs(
+ unique int id: @struct_expr
+);
+
+#keyset[id]
+struct_expr_struct_expr_field_lists(
+ int id: @struct_expr ref,
+ int struct_expr_field_list: @struct_expr_field_list ref
+);
+
+struct_pats(
+ unique int id: @struct_pat
+);
+
+#keyset[id]
+struct_pat_struct_pat_field_lists(
+ int id: @struct_pat ref,
+ int struct_pat_field_list: @struct_pat_field_list ref
+);
+
+traits(
+ unique int id: @trait
+);
+
+#keyset[id]
+trait_assoc_item_lists(
+ int id: @trait ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+trait_attrs(
+ int id: @trait ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_generic_param_lists(
+ int id: @trait ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_is_auto(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_is_unsafe(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_names(
+ int id: @trait ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_type_bound_lists(
+ int id: @trait ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_visibilities(
+ int id: @trait ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_where_clauses(
+ int id: @trait ref,
+ int where_clause: @where_clause ref
+);
+
+trait_aliases(
+ unique int id: @trait_alias
+);
+
+#keyset[id, index]
+trait_alias_attrs(
+ int id: @trait_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_alias_generic_param_lists(
+ int id: @trait_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_alias_names(
+ int id: @trait_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_alias_type_bound_lists(
+ int id: @trait_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_alias_visibilities(
+ int id: @trait_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_alias_where_clauses(
+ int id: @trait_alias ref,
+ int where_clause: @where_clause ref
+);
+
+tuple_struct_pats(
+ unique int id: @tuple_struct_pat
+);
+
+#keyset[id, index]
+tuple_struct_pat_fields(
+ int id: @tuple_struct_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+uses(
+ unique int id: @use
+);
+
+#keyset[id, index]
+use_attrs(
+ int id: @use ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+use_use_trees(
+ int id: @use ref,
+ int use_tree: @use_tree ref
+);
+
+#keyset[id]
+use_visibilities(
+ int id: @use ref,
+ int visibility: @visibility ref
+);
+
+consts(
+ unique int id: @const
+);
+
+#keyset[id, index]
+const_attrs(
+ int id: @const ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_bodies(
+ int id: @const ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+const_generic_param_lists(
+ int id: @const ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+const_is_const(
+ int id: @const ref
+);
+
+#keyset[id]
+const_is_default(
+ int id: @const ref
+);
+
+#keyset[id]
+const_names(
+ int id: @const ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_type_reprs(
+ int id: @const ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+const_visibilities(
+ int id: @const ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+const_where_clauses(
+ int id: @const ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+const_has_implementation(
+ int id: @const ref
+);
+
+enums(
+ unique int id: @enum
+);
+
+#keyset[id, index]
+enum_attrs(
+ int id: @enum ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+enum_generic_param_lists(
+ int id: @enum ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+enum_names(
+ int id: @enum ref,
+ int name: @name ref
+);
+
+#keyset[id]
+enum_variant_lists(
+ int id: @enum ref,
+ int variant_list: @variant_list ref
+);
+
+#keyset[id]
+enum_visibilities(
+ int id: @enum ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+enum_where_clauses(
+ int id: @enum ref,
+ int where_clause: @where_clause ref
+);
+
+for_exprs(
+ unique int id: @for_expr
+);
+
+#keyset[id, index]
+for_expr_attrs(
+ int id: @for_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+for_expr_iterables(
+ int id: @for_expr ref,
+ int iterable: @expr ref
+);
+
+#keyset[id]
+for_expr_pats(
+ int id: @for_expr ref,
+ int pat: @pat ref
+);
+
+functions(
+ unique int id: @function
+);
+
+#keyset[id]
+function_abis(
+ int id: @function ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+function_bodies(
+ int id: @function ref,
+ int body: @block_expr ref
+);
+
+#keyset[id]
+function_generic_param_lists(
+ int id: @function ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+function_is_async(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_const(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_default(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_gen(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_unsafe(
+ int id: @function ref
+);
+
+#keyset[id]
+function_names(
+ int id: @function ref,
+ int name: @name ref
+);
+
+#keyset[id]
+function_ret_types(
+ int id: @function ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+function_visibilities(
+ int id: @function ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+function_where_clauses(
+ int id: @function ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+function_has_implementation(
+ int id: @function ref
+);
+
+loop_exprs(
+ unique int id: @loop_expr
+);
+
+#keyset[id, index]
+loop_expr_attrs(
+ int id: @loop_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+macro_calls(
+ unique int id: @macro_call
+);
+
+#keyset[id, index]
+macro_call_attrs(
+ int id: @macro_call ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_call_paths(
+ int id: @macro_call ref,
+ int path: @path ref
+);
+
+#keyset[id]
+macro_call_token_trees(
+ int id: @macro_call ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_call_macro_call_expansions(
+ int id: @macro_call ref,
+ int macro_call_expansion: @ast_node ref
+);
+
+statics(
+ unique int id: @static
+);
+
+#keyset[id, index]
+static_attrs(
+ int id: @static ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+static_bodies(
+ int id: @static ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+static_is_mut(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_static(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_unsafe(
+ int id: @static ref
+);
+
+#keyset[id]
+static_names(
+ int id: @static ref,
+ int name: @name ref
+);
+
+#keyset[id]
+static_type_reprs(
+ int id: @static ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+static_visibilities(
+ int id: @static ref,
+ int visibility: @visibility ref
+);
+
+structs(
+ unique int id: @struct
+);
+
+#keyset[id, index]
+struct_attrs(
+ int id: @struct ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_lists_(
+ int id: @struct ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+struct_generic_param_lists(
+ int id: @struct ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+struct_names(
+ int id: @struct ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_visibilities(
+ int id: @struct ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+struct_where_clauses(
+ int id: @struct ref,
+ int where_clause: @where_clause ref
+);
+
+type_aliases(
+ unique int id: @type_alias
+);
+
+#keyset[id, index]
+type_alias_attrs(
+ int id: @type_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_alias_generic_param_lists(
+ int id: @type_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+type_alias_is_default(
+ int id: @type_alias ref
+);
+
+#keyset[id]
+type_alias_names(
+ int id: @type_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_alias_type_reprs(
+ int id: @type_alias ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_alias_type_bound_lists(
+ int id: @type_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+type_alias_visibilities(
+ int id: @type_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+type_alias_where_clauses(
+ int id: @type_alias ref,
+ int where_clause: @where_clause ref
+);
+
+unions(
+ unique int id: @union
+);
+
+#keyset[id, index]
+union_attrs(
+ int id: @union ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+union_generic_param_lists(
+ int id: @union ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+union_names(
+ int id: @union ref,
+ int name: @name ref
+);
+
+#keyset[id]
+union_struct_field_lists(
+ int id: @union ref,
+ int struct_field_list: @struct_field_list ref
+);
+
+#keyset[id]
+union_visibilities(
+ int id: @union ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+union_where_clauses(
+ int id: @union ref,
+ int where_clause: @where_clause ref
+);
+
+while_exprs(
+ unique int id: @while_expr
+);
+
+#keyset[id, index]
+while_expr_attrs(
+ int id: @while_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+while_expr_conditions(
+ int id: @while_expr ref,
+ int condition: @expr ref
+);
diff --git a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme
new file mode 100644
index 00000000000..3c1990e7f1d
--- /dev/null
+++ b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme
@@ -0,0 +1,3644 @@
+// generated by codegen, do not edit
+
+// from ../shared/tree-sitter-extractor/src/generator/prefix.dbscheme
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Empty location -*/
+
+empty_location(
+ int location: @location_default ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- Diagnostic messages -*/
+
+diagnostics(
+ unique int id: @diagnostic,
+ int severity: int ref,
+ string error_tag: string ref,
+ string error_message: string ref,
+ string full_error_message: string ref,
+ int location: @location_default ref
+);
+
+/*- Diagnostic messages: severity -*/
+
+case @diagnostic.severity of
+ 10 = @diagnostic_debug
+| 20 = @diagnostic_info
+| 30 = @diagnostic_warning
+| 40 = @diagnostic_error
+;
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
+
+overlayChangedFiles(
+ string path: string ref
+);
+
+
+// from prefix.dbscheme
+#keyset[id]
+locatable_locations(
+ int id: @locatable ref,
+ int location: @location_default ref
+);
+
+
+// from schema
+
+@element =
+ @extractor_step
+| @locatable
+| @named_crate
+| @unextracted
+;
+
+extractor_steps(
+ unique int id: @extractor_step,
+ string action: string ref,
+ int duration_ms: int ref
+);
+
+#keyset[id]
+extractor_step_files(
+ int id: @extractor_step ref,
+ int file: @file ref
+);
+
+@locatable =
+ @ast_node
+| @crate
+;
+
+named_crates(
+ unique int id: @named_crate,
+ string name: string ref,
+ int crate: @crate ref
+);
+
+@unextracted =
+ @missing
+| @unimplemented
+;
+
+@ast_node =
+ @abi
+| @addressable
+| @arg_list
+| @asm_dir_spec
+| @asm_operand
+| @asm_operand_expr
+| @asm_option
+| @asm_piece
+| @asm_reg_spec
+| @assoc_item_list
+| @attr
+| @callable
+| @expr
+| @extern_item_list
+| @field_list
+| @for_binder
+| @format_args_arg
+| @generic_arg
+| @generic_arg_list
+| @generic_param
+| @generic_param_list
+| @item_list
+| @label
+| @let_else
+| @macro_items
+| @match_arm
+| @match_arm_list
+| @match_guard
+| @meta
+| @name
+| @param_base
+| @param_list
+| @parenthesized_arg_list
+| @pat
+| @path
+| @path_segment
+| @rename
+| @resolvable
+| @ret_type_repr
+| @return_type_syntax
+| @source_file
+| @stmt
+| @stmt_list
+| @struct_expr_field
+| @struct_expr_field_list
+| @struct_field
+| @struct_pat_field
+| @struct_pat_field_list
+| @token
+| @token_tree
+| @tuple_field
+| @type_bound
+| @type_bound_list
+| @type_repr
+| @use_bound_generic_arg
+| @use_bound_generic_args
+| @use_tree
+| @use_tree_list
+| @variant_list
+| @visibility
+| @where_clause
+| @where_pred
+;
+
+crates(
+ unique int id: @crate
+);
+
+#keyset[id]
+crate_names(
+ int id: @crate ref,
+ string name: string ref
+);
+
+#keyset[id]
+crate_versions(
+ int id: @crate ref,
+ string version: string ref
+);
+
+#keyset[id, index]
+crate_cfg_options(
+ int id: @crate ref,
+ int index: int ref,
+ string cfg_option: string ref
+);
+
+#keyset[id, index]
+crate_named_dependencies(
+ int id: @crate ref,
+ int index: int ref,
+ int named_dependency: @named_crate ref
+);
+
+missings(
+ unique int id: @missing
+);
+
+unimplementeds(
+ unique int id: @unimplemented
+);
+
+abis(
+ unique int id: @abi
+);
+
+#keyset[id]
+abi_abi_strings(
+ int id: @abi ref,
+ string abi_string: string ref
+);
+
+@addressable =
+ @item
+| @variant
+;
+
+#keyset[id]
+addressable_extended_canonical_paths(
+ int id: @addressable ref,
+ string extended_canonical_path: string ref
+);
+
+#keyset[id]
+addressable_crate_origins(
+ int id: @addressable ref,
+ string crate_origin: string ref
+);
+
+arg_lists(
+ unique int id: @arg_list
+);
+
+#keyset[id, index]
+arg_list_args(
+ int id: @arg_list ref,
+ int index: int ref,
+ int arg: @expr ref
+);
+
+asm_dir_specs(
+ unique int id: @asm_dir_spec
+);
+
+@asm_operand =
+ @asm_const
+| @asm_label
+| @asm_reg_operand
+| @asm_sym
+;
+
+asm_operand_exprs(
+ unique int id: @asm_operand_expr
+);
+
+#keyset[id]
+asm_operand_expr_in_exprs(
+ int id: @asm_operand_expr ref,
+ int in_expr: @expr ref
+);
+
+#keyset[id]
+asm_operand_expr_out_exprs(
+ int id: @asm_operand_expr ref,
+ int out_expr: @expr ref
+);
+
+asm_options(
+ unique int id: @asm_option
+);
+
+#keyset[id]
+asm_option_is_raw(
+ int id: @asm_option ref
+);
+
+@asm_piece =
+ @asm_clobber_abi
+| @asm_operand_named
+| @asm_options_list
+;
+
+asm_reg_specs(
+ unique int id: @asm_reg_spec
+);
+
+#keyset[id]
+asm_reg_spec_identifiers(
+ int id: @asm_reg_spec ref,
+ int identifier: @name_ref ref
+);
+
+assoc_item_lists(
+ unique int id: @assoc_item_list
+);
+
+#keyset[id, index]
+assoc_item_list_assoc_items(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int assoc_item: @assoc_item ref
+);
+
+#keyset[id, index]
+assoc_item_list_attrs(
+ int id: @assoc_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+attrs(
+ unique int id: @attr
+);
+
+#keyset[id]
+attr_meta(
+ int id: @attr ref,
+ int meta: @meta ref
+);
+
+@callable =
+ @closure_expr
+| @function
+;
+
+#keyset[id]
+callable_param_lists(
+ int id: @callable ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id, index]
+callable_attrs(
+ int id: @callable ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+@expr =
+ @array_expr_internal
+| @asm_expr
+| @await_expr
+| @become_expr
+| @binary_expr
+| @break_expr
+| @call_expr_base
+| @cast_expr
+| @closure_expr
+| @continue_expr
+| @field_expr
+| @format_args_expr
+| @if_expr
+| @index_expr
+| @labelable_expr
+| @let_expr
+| @literal_expr
+| @macro_block_expr
+| @macro_expr
+| @match_expr
+| @offset_of_expr
+| @paren_expr
+| @path_expr_base
+| @prefix_expr
+| @range_expr
+| @ref_expr
+| @return_expr
+| @struct_expr
+| @try_expr
+| @tuple_expr
+| @underscore_expr
+| @yeet_expr
+| @yield_expr
+;
+
+extern_item_lists(
+ unique int id: @extern_item_list
+);
+
+#keyset[id, index]
+extern_item_list_attrs(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+extern_item_list_extern_items(
+ int id: @extern_item_list ref,
+ int index: int ref,
+ int extern_item: @extern_item ref
+);
+
+@field_list =
+ @struct_field_list
+| @tuple_field_list
+;
+
+for_binders(
+ unique int id: @for_binder
+);
+
+#keyset[id]
+for_binder_generic_param_lists(
+ int id: @for_binder ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+format_args_args(
+ unique int id: @format_args_arg
+);
+
+#keyset[id]
+format_args_arg_exprs(
+ int id: @format_args_arg ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+format_args_arg_names(
+ int id: @format_args_arg ref,
+ int name: @name ref
+);
+
+@generic_arg =
+ @assoc_type_arg
+| @const_arg
+| @lifetime_arg
+| @type_arg
+;
+
+generic_arg_lists(
+ unique int id: @generic_arg_list
+);
+
+#keyset[id, index]
+generic_arg_list_generic_args(
+ int id: @generic_arg_list ref,
+ int index: int ref,
+ int generic_arg: @generic_arg ref
+);
+
+@generic_param =
+ @const_param
+| @lifetime_param
+| @type_param
+;
+
+generic_param_lists(
+ unique int id: @generic_param_list
+);
+
+#keyset[id, index]
+generic_param_list_generic_params(
+ int id: @generic_param_list ref,
+ int index: int ref,
+ int generic_param: @generic_param ref
+);
+
+item_lists(
+ unique int id: @item_list
+);
+
+#keyset[id, index]
+item_list_attrs(
+ int id: @item_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+item_list_items(
+ int id: @item_list ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+labels(
+ unique int id: @label
+);
+
+#keyset[id]
+label_lifetimes(
+ int id: @label ref,
+ int lifetime: @lifetime ref
+);
+
+let_elses(
+ unique int id: @let_else
+);
+
+#keyset[id]
+let_else_block_exprs(
+ int id: @let_else ref,
+ int block_expr: @block_expr ref
+);
+
+macro_items(
+ unique int id: @macro_items
+);
+
+#keyset[id, index]
+macro_items_items(
+ int id: @macro_items ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+match_arms(
+ unique int id: @match_arm
+);
+
+#keyset[id, index]
+match_arm_attrs(
+ int id: @match_arm ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_arm_exprs(
+ int id: @match_arm ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+match_arm_guards(
+ int id: @match_arm ref,
+ int guard: @match_guard ref
+);
+
+#keyset[id]
+match_arm_pats(
+ int id: @match_arm ref,
+ int pat: @pat ref
+);
+
+match_arm_lists(
+ unique int id: @match_arm_list
+);
+
+#keyset[id, index]
+match_arm_list_arms(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int arm: @match_arm ref
+);
+
+#keyset[id, index]
+match_arm_list_attrs(
+ int id: @match_arm_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+match_guards(
+ unique int id: @match_guard
+);
+
+#keyset[id]
+match_guard_conditions(
+ int id: @match_guard ref,
+ int condition: @expr ref
+);
+
+meta(
+ unique int id: @meta
+);
+
+#keyset[id]
+meta_exprs(
+ int id: @meta ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+meta_is_unsafe(
+ int id: @meta ref
+);
+
+#keyset[id]
+meta_paths(
+ int id: @meta ref,
+ int path: @path ref
+);
+
+#keyset[id]
+meta_token_trees(
+ int id: @meta ref,
+ int token_tree: @token_tree ref
+);
+
+names(
+ unique int id: @name
+);
+
+#keyset[id]
+name_texts(
+ int id: @name ref,
+ string text: string ref
+);
+
+@param_base =
+ @param
+| @self_param
+;
+
+#keyset[id, index]
+param_base_attrs(
+ int id: @param_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+param_base_type_reprs(
+ int id: @param_base ref,
+ int type_repr: @type_repr ref
+);
+
+param_lists(
+ unique int id: @param_list
+);
+
+#keyset[id, index]
+param_list_params(
+ int id: @param_list ref,
+ int index: int ref,
+ int param: @param ref
+);
+
+#keyset[id]
+param_list_self_params(
+ int id: @param_list ref,
+ int self_param: @self_param ref
+);
+
+parenthesized_arg_lists(
+ unique int id: @parenthesized_arg_list
+);
+
+#keyset[id, index]
+parenthesized_arg_list_type_args(
+ int id: @parenthesized_arg_list ref,
+ int index: int ref,
+ int type_arg: @type_arg ref
+);
+
+@pat =
+ @box_pat
+| @const_block_pat
+| @ident_pat
+| @literal_pat
+| @macro_pat
+| @or_pat
+| @paren_pat
+| @path_pat
+| @range_pat
+| @ref_pat
+| @rest_pat
+| @slice_pat
+| @struct_pat
+| @tuple_pat
+| @tuple_struct_pat
+| @wildcard_pat
+;
+
+paths(
+ unique int id: @path
+);
+
+#keyset[id]
+path_qualifiers(
+ int id: @path ref,
+ int qualifier: @path ref
+);
+
+#keyset[id]
+path_segments_(
+ int id: @path ref,
+ int segment: @path_segment ref
+);
+
+path_segments(
+ unique int id: @path_segment
+);
+
+#keyset[id]
+path_segment_generic_arg_lists(
+ int id: @path_segment ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+path_segment_identifiers(
+ int id: @path_segment ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+path_segment_parenthesized_arg_lists(
+ int id: @path_segment ref,
+ int parenthesized_arg_list: @parenthesized_arg_list ref
+);
+
+#keyset[id]
+path_segment_ret_types(
+ int id: @path_segment ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+path_segment_return_type_syntaxes(
+ int id: @path_segment ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+path_segment_type_reprs(
+ int id: @path_segment ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+path_segment_trait_type_reprs(
+ int id: @path_segment ref,
+ int trait_type_repr: @path_type_repr ref
+);
+
+renames(
+ unique int id: @rename
+);
+
+#keyset[id]
+rename_names(
+ int id: @rename ref,
+ int name: @name ref
+);
+
+@resolvable =
+ @method_call_expr
+| @path_ast_node
+;
+
+#keyset[id]
+resolvable_resolved_paths(
+ int id: @resolvable ref,
+ string resolved_path: string ref
+);
+
+#keyset[id]
+resolvable_resolved_crate_origins(
+ int id: @resolvable ref,
+ string resolved_crate_origin: string ref
+);
+
+ret_type_reprs(
+ unique int id: @ret_type_repr
+);
+
+#keyset[id]
+ret_type_repr_type_reprs(
+ int id: @ret_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+return_type_syntaxes(
+ unique int id: @return_type_syntax
+);
+
+source_files(
+ unique int id: @source_file
+);
+
+#keyset[id, index]
+source_file_attrs(
+ int id: @source_file ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+source_file_items(
+ int id: @source_file ref,
+ int index: int ref,
+ int item: @item ref
+);
+
+@stmt =
+ @expr_stmt
+| @item
+| @let_stmt
+;
+
+stmt_lists(
+ unique int id: @stmt_list
+);
+
+#keyset[id, index]
+stmt_list_attrs(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+stmt_list_statements(
+ int id: @stmt_list ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+#keyset[id]
+stmt_list_tail_exprs(
+ int id: @stmt_list ref,
+ int tail_expr: @expr ref
+);
+
+struct_expr_fields(
+ unique int id: @struct_expr_field
+);
+
+#keyset[id, index]
+struct_expr_field_attrs(
+ int id: @struct_expr_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_expr_field_exprs(
+ int id: @struct_expr_field ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+struct_expr_field_identifiers(
+ int id: @struct_expr_field ref,
+ int identifier: @name_ref ref
+);
+
+struct_expr_field_lists(
+ unique int id: @struct_expr_field_list
+);
+
+#keyset[id, index]
+struct_expr_field_list_attrs(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+struct_expr_field_list_fields(
+ int id: @struct_expr_field_list ref,
+ int index: int ref,
+ int field: @struct_expr_field ref
+);
+
+#keyset[id]
+struct_expr_field_list_spreads(
+ int id: @struct_expr_field_list ref,
+ int spread: @expr ref
+);
+
+struct_fields(
+ unique int id: @struct_field
+);
+
+#keyset[id, index]
+struct_field_attrs(
+ int id: @struct_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_defaults(
+ int id: @struct_field ref,
+ int default: @expr ref
+);
+
+#keyset[id]
+struct_field_is_unsafe(
+ int id: @struct_field ref
+);
+
+#keyset[id]
+struct_field_names(
+ int id: @struct_field ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_field_type_reprs(
+ int id: @struct_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+struct_field_visibilities(
+ int id: @struct_field ref,
+ int visibility: @visibility ref
+);
+
+struct_pat_fields(
+ unique int id: @struct_pat_field
+);
+
+#keyset[id, index]
+struct_pat_field_attrs(
+ int id: @struct_pat_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_pat_field_identifiers(
+ int id: @struct_pat_field ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+struct_pat_field_pats(
+ int id: @struct_pat_field ref,
+ int pat: @pat ref
+);
+
+struct_pat_field_lists(
+ unique int id: @struct_pat_field_list
+);
+
+#keyset[id, index]
+struct_pat_field_list_fields(
+ int id: @struct_pat_field_list ref,
+ int index: int ref,
+ int field: @struct_pat_field ref
+);
+
+#keyset[id]
+struct_pat_field_list_rest_pats(
+ int id: @struct_pat_field_list ref,
+ int rest_pat: @rest_pat ref
+);
+
+@token =
+ @comment
+;
+
+token_trees(
+ unique int id: @token_tree
+);
+
+tuple_fields(
+ unique int id: @tuple_field
+);
+
+#keyset[id, index]
+tuple_field_attrs(
+ int id: @tuple_field ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+tuple_field_type_reprs(
+ int id: @tuple_field ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+tuple_field_visibilities(
+ int id: @tuple_field ref,
+ int visibility: @visibility ref
+);
+
+type_bounds(
+ unique int id: @type_bound
+);
+
+#keyset[id]
+type_bound_for_binders(
+ int id: @type_bound ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+type_bound_is_async(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_is_const(
+ int id: @type_bound ref
+);
+
+#keyset[id]
+type_bound_lifetimes(
+ int id: @type_bound ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+type_bound_type_reprs(
+ int id: @type_bound ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_bound_use_bound_generic_args(
+ int id: @type_bound ref,
+ int use_bound_generic_args: @use_bound_generic_args ref
+);
+
+type_bound_lists(
+ unique int id: @type_bound_list
+);
+
+#keyset[id, index]
+type_bound_list_bounds(
+ int id: @type_bound_list ref,
+ int index: int ref,
+ int bound: @type_bound ref
+);
+
+@type_repr =
+ @array_type_repr
+| @dyn_trait_type_repr
+| @fn_ptr_type_repr
+| @for_type_repr
+| @impl_trait_type_repr
+| @infer_type_repr
+| @macro_type_repr
+| @never_type_repr
+| @paren_type_repr
+| @path_type_repr
+| @ptr_type_repr
+| @ref_type_repr
+| @slice_type_repr
+| @tuple_type_repr
+;
+
+@use_bound_generic_arg =
+ @lifetime
+| @name_ref
+;
+
+use_bound_generic_args(
+ unique int id: @use_bound_generic_args
+);
+
+#keyset[id, index]
+use_bound_generic_args_use_bound_generic_args(
+ int id: @use_bound_generic_args ref,
+ int index: int ref,
+ int use_bound_generic_arg: @use_bound_generic_arg ref
+);
+
+use_trees(
+ unique int id: @use_tree
+);
+
+#keyset[id]
+use_tree_is_glob(
+ int id: @use_tree ref
+);
+
+#keyset[id]
+use_tree_paths(
+ int id: @use_tree ref,
+ int path: @path ref
+);
+
+#keyset[id]
+use_tree_renames(
+ int id: @use_tree ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+use_tree_use_tree_lists(
+ int id: @use_tree ref,
+ int use_tree_list: @use_tree_list ref
+);
+
+use_tree_lists(
+ unique int id: @use_tree_list
+);
+
+#keyset[id, index]
+use_tree_list_use_trees(
+ int id: @use_tree_list ref,
+ int index: int ref,
+ int use_tree: @use_tree ref
+);
+
+variant_lists(
+ unique int id: @variant_list
+);
+
+#keyset[id, index]
+variant_list_variants(
+ int id: @variant_list ref,
+ int index: int ref,
+ int variant: @variant ref
+);
+
+visibilities(
+ unique int id: @visibility
+);
+
+#keyset[id]
+visibility_paths(
+ int id: @visibility ref,
+ int path: @path ref
+);
+
+where_clauses(
+ unique int id: @where_clause
+);
+
+#keyset[id, index]
+where_clause_predicates(
+ int id: @where_clause ref,
+ int index: int ref,
+ int predicate: @where_pred ref
+);
+
+where_preds(
+ unique int id: @where_pred
+);
+
+#keyset[id]
+where_pred_for_binders(
+ int id: @where_pred ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+where_pred_lifetimes(
+ int id: @where_pred ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+where_pred_type_reprs(
+ int id: @where_pred ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+where_pred_type_bound_lists(
+ int id: @where_pred ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+array_expr_internals(
+ unique int id: @array_expr_internal
+);
+
+#keyset[id, index]
+array_expr_internal_attrs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+array_expr_internal_exprs(
+ int id: @array_expr_internal ref,
+ int index: int ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+array_expr_internal_is_semicolon(
+ int id: @array_expr_internal ref
+);
+
+array_type_reprs(
+ unique int id: @array_type_repr
+);
+
+#keyset[id]
+array_type_repr_const_args(
+ int id: @array_type_repr ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+array_type_repr_element_type_reprs(
+ int id: @array_type_repr ref,
+ int element_type_repr: @type_repr ref
+);
+
+asm_clobber_abis(
+ unique int id: @asm_clobber_abi
+);
+
+asm_consts(
+ unique int id: @asm_const
+);
+
+#keyset[id]
+asm_const_exprs(
+ int id: @asm_const ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+asm_const_is_const(
+ int id: @asm_const ref
+);
+
+asm_labels(
+ unique int id: @asm_label
+);
+
+#keyset[id]
+asm_label_block_exprs(
+ int id: @asm_label ref,
+ int block_expr: @block_expr ref
+);
+
+asm_operand_nameds(
+ unique int id: @asm_operand_named
+);
+
+#keyset[id]
+asm_operand_named_asm_operands(
+ int id: @asm_operand_named ref,
+ int asm_operand: @asm_operand ref
+);
+
+#keyset[id]
+asm_operand_named_names(
+ int id: @asm_operand_named ref,
+ int name: @name ref
+);
+
+asm_options_lists(
+ unique int id: @asm_options_list
+);
+
+#keyset[id, index]
+asm_options_list_asm_options(
+ int id: @asm_options_list ref,
+ int index: int ref,
+ int asm_option: @asm_option ref
+);
+
+asm_reg_operands(
+ unique int id: @asm_reg_operand
+);
+
+#keyset[id]
+asm_reg_operand_asm_dir_specs(
+ int id: @asm_reg_operand ref,
+ int asm_dir_spec: @asm_dir_spec ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_operand_exprs(
+ int id: @asm_reg_operand ref,
+ int asm_operand_expr: @asm_operand_expr ref
+);
+
+#keyset[id]
+asm_reg_operand_asm_reg_specs(
+ int id: @asm_reg_operand ref,
+ int asm_reg_spec: @asm_reg_spec ref
+);
+
+asm_syms(
+ unique int id: @asm_sym
+);
+
+#keyset[id]
+asm_sym_paths(
+ int id: @asm_sym ref,
+ int path: @path ref
+);
+
+assoc_type_args(
+ unique int id: @assoc_type_arg
+);
+
+#keyset[id]
+assoc_type_arg_const_args(
+ int id: @assoc_type_arg ref,
+ int const_arg: @const_arg ref
+);
+
+#keyset[id]
+assoc_type_arg_generic_arg_lists(
+ int id: @assoc_type_arg ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+assoc_type_arg_identifiers(
+ int id: @assoc_type_arg ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+assoc_type_arg_param_lists(
+ int id: @assoc_type_arg ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+assoc_type_arg_ret_types(
+ int id: @assoc_type_arg ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_return_type_syntaxes(
+ int id: @assoc_type_arg ref,
+ int return_type_syntax: @return_type_syntax ref
+);
+
+#keyset[id]
+assoc_type_arg_type_reprs(
+ int id: @assoc_type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+assoc_type_arg_type_bound_lists(
+ int id: @assoc_type_arg ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+await_exprs(
+ unique int id: @await_expr
+);
+
+#keyset[id, index]
+await_expr_attrs(
+ int id: @await_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+await_expr_exprs(
+ int id: @await_expr ref,
+ int expr: @expr ref
+);
+
+become_exprs(
+ unique int id: @become_expr
+);
+
+#keyset[id, index]
+become_expr_attrs(
+ int id: @become_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+become_expr_exprs(
+ int id: @become_expr ref,
+ int expr: @expr ref
+);
+
+binary_exprs(
+ unique int id: @binary_expr
+);
+
+#keyset[id, index]
+binary_expr_attrs(
+ int id: @binary_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+binary_expr_lhs(
+ int id: @binary_expr ref,
+ int lhs: @expr ref
+);
+
+#keyset[id]
+binary_expr_operator_names(
+ int id: @binary_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+binary_expr_rhs(
+ int id: @binary_expr ref,
+ int rhs: @expr ref
+);
+
+box_pats(
+ unique int id: @box_pat
+);
+
+#keyset[id]
+box_pat_pats(
+ int id: @box_pat ref,
+ int pat: @pat ref
+);
+
+break_exprs(
+ unique int id: @break_expr
+);
+
+#keyset[id, index]
+break_expr_attrs(
+ int id: @break_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+break_expr_exprs(
+ int id: @break_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+break_expr_lifetimes(
+ int id: @break_expr ref,
+ int lifetime: @lifetime ref
+);
+
+@call_expr_base =
+ @call_expr
+| @method_call_expr
+;
+
+#keyset[id]
+call_expr_base_arg_lists(
+ int id: @call_expr_base ref,
+ int arg_list: @arg_list ref
+);
+
+#keyset[id, index]
+call_expr_base_attrs(
+ int id: @call_expr_base ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+cast_exprs(
+ unique int id: @cast_expr
+);
+
+#keyset[id, index]
+cast_expr_attrs(
+ int id: @cast_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+cast_expr_exprs(
+ int id: @cast_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+cast_expr_type_reprs(
+ int id: @cast_expr ref,
+ int type_repr: @type_repr ref
+);
+
+closure_exprs(
+ unique int id: @closure_expr
+);
+
+#keyset[id]
+closure_expr_bodies(
+ int id: @closure_expr ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+closure_expr_for_binders(
+ int id: @closure_expr ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+closure_expr_is_async(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_const(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_gen(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_move(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_is_static(
+ int id: @closure_expr ref
+);
+
+#keyset[id]
+closure_expr_ret_types(
+ int id: @closure_expr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+comments(
+ unique int id: @comment,
+ int parent: @ast_node ref,
+ string text: string ref
+);
+
+const_args(
+ unique int id: @const_arg
+);
+
+#keyset[id]
+const_arg_exprs(
+ int id: @const_arg ref,
+ int expr: @expr ref
+);
+
+const_block_pats(
+ unique int id: @const_block_pat
+);
+
+#keyset[id]
+const_block_pat_block_exprs(
+ int id: @const_block_pat ref,
+ int block_expr: @block_expr ref
+);
+
+#keyset[id]
+const_block_pat_is_const(
+ int id: @const_block_pat ref
+);
+
+const_params(
+ unique int id: @const_param
+);
+
+#keyset[id, index]
+const_param_attrs(
+ int id: @const_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_param_default_vals(
+ int id: @const_param ref,
+ int default_val: @const_arg ref
+);
+
+#keyset[id]
+const_param_is_const(
+ int id: @const_param ref
+);
+
+#keyset[id]
+const_param_names(
+ int id: @const_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_param_type_reprs(
+ int id: @const_param ref,
+ int type_repr: @type_repr ref
+);
+
+continue_exprs(
+ unique int id: @continue_expr
+);
+
+#keyset[id, index]
+continue_expr_attrs(
+ int id: @continue_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+continue_expr_lifetimes(
+ int id: @continue_expr ref,
+ int lifetime: @lifetime ref
+);
+
+dyn_trait_type_reprs(
+ unique int id: @dyn_trait_type_repr
+);
+
+#keyset[id]
+dyn_trait_type_repr_type_bound_lists(
+ int id: @dyn_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+expr_stmts(
+ unique int id: @expr_stmt
+);
+
+#keyset[id]
+expr_stmt_exprs(
+ int id: @expr_stmt ref,
+ int expr: @expr ref
+);
+
+field_exprs(
+ unique int id: @field_expr
+);
+
+#keyset[id, index]
+field_expr_attrs(
+ int id: @field_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+field_expr_containers(
+ int id: @field_expr ref,
+ int container: @expr ref
+);
+
+#keyset[id]
+field_expr_identifiers(
+ int id: @field_expr ref,
+ int identifier: @name_ref ref
+);
+
+fn_ptr_type_reprs(
+ unique int id: @fn_ptr_type_repr
+);
+
+#keyset[id]
+fn_ptr_type_repr_abis(
+ int id: @fn_ptr_type_repr ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_async(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_const(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_is_unsafe(
+ int id: @fn_ptr_type_repr ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_param_lists(
+ int id: @fn_ptr_type_repr ref,
+ int param_list: @param_list ref
+);
+
+#keyset[id]
+fn_ptr_type_repr_ret_types(
+ int id: @fn_ptr_type_repr ref,
+ int ret_type: @ret_type_repr ref
+);
+
+for_type_reprs(
+ unique int id: @for_type_repr
+);
+
+#keyset[id]
+for_type_repr_for_binders(
+ int id: @for_type_repr ref,
+ int for_binder: @for_binder ref
+);
+
+#keyset[id]
+for_type_repr_type_reprs(
+ int id: @for_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+format_args_exprs(
+ unique int id: @format_args_expr
+);
+
+#keyset[id, index]
+format_args_expr_args(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int arg: @format_args_arg ref
+);
+
+#keyset[id, index]
+format_args_expr_attrs(
+ int id: @format_args_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+format_args_expr_templates(
+ int id: @format_args_expr ref,
+ int template: @expr ref
+);
+
+ident_pats(
+ unique int id: @ident_pat
+);
+
+#keyset[id, index]
+ident_pat_attrs(
+ int id: @ident_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ident_pat_is_mut(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_is_ref(
+ int id: @ident_pat ref
+);
+
+#keyset[id]
+ident_pat_names(
+ int id: @ident_pat ref,
+ int name: @name ref
+);
+
+#keyset[id]
+ident_pat_pats(
+ int id: @ident_pat ref,
+ int pat: @pat ref
+);
+
+if_exprs(
+ unique int id: @if_expr
+);
+
+#keyset[id, index]
+if_expr_attrs(
+ int id: @if_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+if_expr_conditions(
+ int id: @if_expr ref,
+ int condition: @expr ref
+);
+
+#keyset[id]
+if_expr_elses(
+ int id: @if_expr ref,
+ int else: @expr ref
+);
+
+#keyset[id]
+if_expr_thens(
+ int id: @if_expr ref,
+ int then: @block_expr ref
+);
+
+impl_trait_type_reprs(
+ unique int id: @impl_trait_type_repr
+);
+
+#keyset[id]
+impl_trait_type_repr_type_bound_lists(
+ int id: @impl_trait_type_repr ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+index_exprs(
+ unique int id: @index_expr
+);
+
+#keyset[id, index]
+index_expr_attrs(
+ int id: @index_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+index_expr_bases(
+ int id: @index_expr ref,
+ int base: @expr ref
+);
+
+#keyset[id]
+index_expr_indices(
+ int id: @index_expr ref,
+ int index: @expr ref
+);
+
+infer_type_reprs(
+ unique int id: @infer_type_repr
+);
+
+@item =
+ @adt
+| @asm_expr
+| @assoc_item
+| @extern_block
+| @extern_crate
+| @extern_item
+| @impl
+| @macro_def
+| @macro_rules
+| @module
+| @trait
+| @trait_alias
+| @use
+;
+
+#keyset[id]
+item_attribute_macro_expansions(
+ int id: @item ref,
+ int attribute_macro_expansion: @macro_items ref
+);
+
+@labelable_expr =
+ @block_expr
+| @looping_expr
+;
+
+#keyset[id]
+labelable_expr_labels(
+ int id: @labelable_expr ref,
+ int label: @label ref
+);
+
+let_exprs(
+ unique int id: @let_expr
+);
+
+#keyset[id, index]
+let_expr_attrs(
+ int id: @let_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_expr_scrutinees(
+ int id: @let_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+let_expr_pats(
+ int id: @let_expr ref,
+ int pat: @pat ref
+);
+
+let_stmts(
+ unique int id: @let_stmt
+);
+
+#keyset[id, index]
+let_stmt_attrs(
+ int id: @let_stmt ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+let_stmt_initializers(
+ int id: @let_stmt ref,
+ int initializer: @expr ref
+);
+
+#keyset[id]
+let_stmt_let_elses(
+ int id: @let_stmt ref,
+ int let_else: @let_else ref
+);
+
+#keyset[id]
+let_stmt_pats(
+ int id: @let_stmt ref,
+ int pat: @pat ref
+);
+
+#keyset[id]
+let_stmt_type_reprs(
+ int id: @let_stmt ref,
+ int type_repr: @type_repr ref
+);
+
+lifetimes(
+ unique int id: @lifetime
+);
+
+#keyset[id]
+lifetime_texts(
+ int id: @lifetime ref,
+ string text: string ref
+);
+
+lifetime_args(
+ unique int id: @lifetime_arg
+);
+
+#keyset[id]
+lifetime_arg_lifetimes(
+ int id: @lifetime_arg ref,
+ int lifetime: @lifetime ref
+);
+
+lifetime_params(
+ unique int id: @lifetime_param
+);
+
+#keyset[id, index]
+lifetime_param_attrs(
+ int id: @lifetime_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+lifetime_param_lifetimes(
+ int id: @lifetime_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+lifetime_param_type_bound_lists(
+ int id: @lifetime_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+literal_exprs(
+ unique int id: @literal_expr
+);
+
+#keyset[id, index]
+literal_expr_attrs(
+ int id: @literal_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+literal_expr_text_values(
+ int id: @literal_expr ref,
+ string text_value: string ref
+);
+
+literal_pats(
+ unique int id: @literal_pat
+);
+
+#keyset[id]
+literal_pat_literals(
+ int id: @literal_pat ref,
+ int literal: @literal_expr ref
+);
+
+macro_block_exprs(
+ unique int id: @macro_block_expr
+);
+
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
+#keyset[id, index]
+macro_block_expr_statements(
+ int id: @macro_block_expr ref,
+ int index: int ref,
+ int statement: @stmt ref
+);
+
+macro_exprs(
+ unique int id: @macro_expr
+);
+
+#keyset[id]
+macro_expr_macro_calls(
+ int id: @macro_expr ref,
+ int macro_call: @macro_call ref
+);
+
+macro_pats(
+ unique int id: @macro_pat
+);
+
+#keyset[id]
+macro_pat_macro_calls(
+ int id: @macro_pat ref,
+ int macro_call: @macro_call ref
+);
+
+macro_type_reprs(
+ unique int id: @macro_type_repr
+);
+
+#keyset[id]
+macro_type_repr_macro_calls(
+ int id: @macro_type_repr ref,
+ int macro_call: @macro_call ref
+);
+
+match_exprs(
+ unique int id: @match_expr
+);
+
+#keyset[id, index]
+match_expr_attrs(
+ int id: @match_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+match_expr_scrutinees(
+ int id: @match_expr ref,
+ int scrutinee: @expr ref
+);
+
+#keyset[id]
+match_expr_match_arm_lists(
+ int id: @match_expr ref,
+ int match_arm_list: @match_arm_list ref
+);
+
+name_refs(
+ unique int id: @name_ref
+);
+
+#keyset[id]
+name_ref_texts(
+ int id: @name_ref ref,
+ string text: string ref
+);
+
+never_type_reprs(
+ unique int id: @never_type_repr
+);
+
+offset_of_exprs(
+ unique int id: @offset_of_expr
+);
+
+#keyset[id, index]
+offset_of_expr_attrs(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+offset_of_expr_fields(
+ int id: @offset_of_expr ref,
+ int index: int ref,
+ int field: @name_ref ref
+);
+
+#keyset[id]
+offset_of_expr_type_reprs(
+ int id: @offset_of_expr ref,
+ int type_repr: @type_repr ref
+);
+
+or_pats(
+ unique int id: @or_pat
+);
+
+#keyset[id, index]
+or_pat_pats(
+ int id: @or_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+params(
+ unique int id: @param
+);
+
+#keyset[id]
+param_pats(
+ int id: @param ref,
+ int pat: @pat ref
+);
+
+paren_exprs(
+ unique int id: @paren_expr
+);
+
+#keyset[id, index]
+paren_expr_attrs(
+ int id: @paren_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+paren_expr_exprs(
+ int id: @paren_expr ref,
+ int expr: @expr ref
+);
+
+paren_pats(
+ unique int id: @paren_pat
+);
+
+#keyset[id]
+paren_pat_pats(
+ int id: @paren_pat ref,
+ int pat: @pat ref
+);
+
+paren_type_reprs(
+ unique int id: @paren_type_repr
+);
+
+#keyset[id]
+paren_type_repr_type_reprs(
+ int id: @paren_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+@path_ast_node =
+ @path_expr
+| @path_pat
+| @struct_expr
+| @struct_pat
+| @tuple_struct_pat
+;
+
+#keyset[id]
+path_ast_node_paths(
+ int id: @path_ast_node ref,
+ int path: @path ref
+);
+
+@path_expr_base =
+ @path_expr
+;
+
+path_type_reprs(
+ unique int id: @path_type_repr
+);
+
+#keyset[id]
+path_type_repr_paths(
+ int id: @path_type_repr ref,
+ int path: @path ref
+);
+
+prefix_exprs(
+ unique int id: @prefix_expr
+);
+
+#keyset[id, index]
+prefix_expr_attrs(
+ int id: @prefix_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+prefix_expr_exprs(
+ int id: @prefix_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+prefix_expr_operator_names(
+ int id: @prefix_expr ref,
+ string operator_name: string ref
+);
+
+ptr_type_reprs(
+ unique int id: @ptr_type_repr
+);
+
+#keyset[id]
+ptr_type_repr_is_const(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_is_mut(
+ int id: @ptr_type_repr ref
+);
+
+#keyset[id]
+ptr_type_repr_type_reprs(
+ int id: @ptr_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+range_exprs(
+ unique int id: @range_expr
+);
+
+#keyset[id, index]
+range_expr_attrs(
+ int id: @range_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+range_expr_ends(
+ int id: @range_expr ref,
+ int end: @expr ref
+);
+
+#keyset[id]
+range_expr_operator_names(
+ int id: @range_expr ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_expr_starts(
+ int id: @range_expr ref,
+ int start: @expr ref
+);
+
+range_pats(
+ unique int id: @range_pat
+);
+
+#keyset[id]
+range_pat_ends(
+ int id: @range_pat ref,
+ int end: @pat ref
+);
+
+#keyset[id]
+range_pat_operator_names(
+ int id: @range_pat ref,
+ string operator_name: string ref
+);
+
+#keyset[id]
+range_pat_starts(
+ int id: @range_pat ref,
+ int start: @pat ref
+);
+
+ref_exprs(
+ unique int id: @ref_expr
+);
+
+#keyset[id, index]
+ref_expr_attrs(
+ int id: @ref_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+ref_expr_exprs(
+ int id: @ref_expr ref,
+ int expr: @expr ref
+);
+
+#keyset[id]
+ref_expr_is_const(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_mut(
+ int id: @ref_expr ref
+);
+
+#keyset[id]
+ref_expr_is_raw(
+ int id: @ref_expr ref
+);
+
+ref_pats(
+ unique int id: @ref_pat
+);
+
+#keyset[id]
+ref_pat_is_mut(
+ int id: @ref_pat ref
+);
+
+#keyset[id]
+ref_pat_pats(
+ int id: @ref_pat ref,
+ int pat: @pat ref
+);
+
+ref_type_reprs(
+ unique int id: @ref_type_repr
+);
+
+#keyset[id]
+ref_type_repr_is_mut(
+ int id: @ref_type_repr ref
+);
+
+#keyset[id]
+ref_type_repr_lifetimes(
+ int id: @ref_type_repr ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+ref_type_repr_type_reprs(
+ int id: @ref_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+rest_pats(
+ unique int id: @rest_pat
+);
+
+#keyset[id, index]
+rest_pat_attrs(
+ int id: @rest_pat ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+return_exprs(
+ unique int id: @return_expr
+);
+
+#keyset[id, index]
+return_expr_attrs(
+ int id: @return_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+return_expr_exprs(
+ int id: @return_expr ref,
+ int expr: @expr ref
+);
+
+self_params(
+ unique int id: @self_param
+);
+
+#keyset[id]
+self_param_is_ref(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_is_mut(
+ int id: @self_param ref
+);
+
+#keyset[id]
+self_param_lifetimes(
+ int id: @self_param ref,
+ int lifetime: @lifetime ref
+);
+
+#keyset[id]
+self_param_names(
+ int id: @self_param ref,
+ int name: @name ref
+);
+
+slice_pats(
+ unique int id: @slice_pat
+);
+
+#keyset[id, index]
+slice_pat_pats(
+ int id: @slice_pat ref,
+ int index: int ref,
+ int pat: @pat ref
+);
+
+slice_type_reprs(
+ unique int id: @slice_type_repr
+);
+
+#keyset[id]
+slice_type_repr_type_reprs(
+ int id: @slice_type_repr ref,
+ int type_repr: @type_repr ref
+);
+
+struct_field_lists(
+ unique int id: @struct_field_list
+);
+
+#keyset[id, index]
+struct_field_list_fields(
+ int id: @struct_field_list ref,
+ int index: int ref,
+ int field: @struct_field ref
+);
+
+try_exprs(
+ unique int id: @try_expr
+);
+
+#keyset[id, index]
+try_expr_attrs(
+ int id: @try_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+try_expr_exprs(
+ int id: @try_expr ref,
+ int expr: @expr ref
+);
+
+tuple_exprs(
+ unique int id: @tuple_expr
+);
+
+#keyset[id, index]
+tuple_expr_attrs(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+tuple_expr_fields(
+ int id: @tuple_expr ref,
+ int index: int ref,
+ int field: @expr ref
+);
+
+tuple_field_lists(
+ unique int id: @tuple_field_list
+);
+
+#keyset[id, index]
+tuple_field_list_fields(
+ int id: @tuple_field_list ref,
+ int index: int ref,
+ int field: @tuple_field ref
+);
+
+tuple_pats(
+ unique int id: @tuple_pat
+);
+
+#keyset[id, index]
+tuple_pat_fields(
+ int id: @tuple_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+tuple_type_reprs(
+ unique int id: @tuple_type_repr
+);
+
+#keyset[id, index]
+tuple_type_repr_fields(
+ int id: @tuple_type_repr ref,
+ int index: int ref,
+ int field: @type_repr ref
+);
+
+type_args(
+ unique int id: @type_arg
+);
+
+#keyset[id]
+type_arg_type_reprs(
+ int id: @type_arg ref,
+ int type_repr: @type_repr ref
+);
+
+type_params(
+ unique int id: @type_param
+);
+
+#keyset[id, index]
+type_param_attrs(
+ int id: @type_param ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_param_default_types(
+ int id: @type_param ref,
+ int default_type: @type_repr ref
+);
+
+#keyset[id]
+type_param_names(
+ int id: @type_param ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_param_type_bound_lists(
+ int id: @type_param ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+underscore_exprs(
+ unique int id: @underscore_expr
+);
+
+#keyset[id, index]
+underscore_expr_attrs(
+ int id: @underscore_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+variants(
+ unique int id: @variant
+);
+
+#keyset[id, index]
+variant_attrs(
+ int id: @variant ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+variant_discriminants(
+ int id: @variant ref,
+ int discriminant: @expr ref
+);
+
+#keyset[id]
+variant_field_lists(
+ int id: @variant ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+variant_names(
+ int id: @variant ref,
+ int name: @name ref
+);
+
+#keyset[id]
+variant_visibilities(
+ int id: @variant ref,
+ int visibility: @visibility ref
+);
+
+wildcard_pats(
+ unique int id: @wildcard_pat
+);
+
+yeet_exprs(
+ unique int id: @yeet_expr
+);
+
+#keyset[id, index]
+yeet_expr_attrs(
+ int id: @yeet_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yeet_expr_exprs(
+ int id: @yeet_expr ref,
+ int expr: @expr ref
+);
+
+yield_exprs(
+ unique int id: @yield_expr
+);
+
+#keyset[id, index]
+yield_expr_attrs(
+ int id: @yield_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+yield_expr_exprs(
+ int id: @yield_expr ref,
+ int expr: @expr ref
+);
+
+@adt =
+ @enum
+| @struct
+| @union
+;
+
+#keyset[id, index]
+adt_derive_macro_expansions(
+ int id: @adt ref,
+ int index: int ref,
+ int derive_macro_expansion: @macro_items ref
+);
+
+asm_exprs(
+ unique int id: @asm_expr
+);
+
+#keyset[id, index]
+asm_expr_asm_pieces(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int asm_piece: @asm_piece ref
+);
+
+#keyset[id, index]
+asm_expr_attrs(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id, index]
+asm_expr_templates(
+ int id: @asm_expr ref,
+ int index: int ref,
+ int template: @expr ref
+);
+
+@assoc_item =
+ @const
+| @function
+| @macro_call
+| @type_alias
+;
+
+block_exprs(
+ unique int id: @block_expr
+);
+
+#keyset[id, index]
+block_expr_attrs(
+ int id: @block_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+block_expr_is_async(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_const(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_gen(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_move(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_try(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_is_unsafe(
+ int id: @block_expr ref
+);
+
+#keyset[id]
+block_expr_stmt_lists(
+ int id: @block_expr ref,
+ int stmt_list: @stmt_list ref
+);
+
+call_exprs(
+ unique int id: @call_expr
+);
+
+#keyset[id]
+call_expr_functions(
+ int id: @call_expr ref,
+ int function: @expr ref
+);
+
+extern_blocks(
+ unique int id: @extern_block
+);
+
+#keyset[id]
+extern_block_abis(
+ int id: @extern_block ref,
+ int abi: @abi ref
+);
+
+#keyset[id, index]
+extern_block_attrs(
+ int id: @extern_block ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_block_extern_item_lists(
+ int id: @extern_block ref,
+ int extern_item_list: @extern_item_list ref
+);
+
+#keyset[id]
+extern_block_is_unsafe(
+ int id: @extern_block ref
+);
+
+extern_crates(
+ unique int id: @extern_crate
+);
+
+#keyset[id, index]
+extern_crate_attrs(
+ int id: @extern_crate ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+extern_crate_identifiers(
+ int id: @extern_crate ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+extern_crate_renames(
+ int id: @extern_crate ref,
+ int rename: @rename ref
+);
+
+#keyset[id]
+extern_crate_visibilities(
+ int id: @extern_crate ref,
+ int visibility: @visibility ref
+);
+
+@extern_item =
+ @function
+| @macro_call
+| @static
+| @type_alias
+;
+
+impls(
+ unique int id: @impl
+);
+
+#keyset[id]
+impl_assoc_item_lists(
+ int id: @impl ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+impl_attrs(
+ int id: @impl ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+impl_generic_param_lists(
+ int id: @impl ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+impl_is_const(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_default(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_is_unsafe(
+ int id: @impl ref
+);
+
+#keyset[id]
+impl_self_ties(
+ int id: @impl ref,
+ int self_ty: @type_repr ref
+);
+
+#keyset[id]
+impl_traits(
+ int id: @impl ref,
+ int trait: @type_repr ref
+);
+
+#keyset[id]
+impl_visibilities(
+ int id: @impl ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+impl_where_clauses(
+ int id: @impl ref,
+ int where_clause: @where_clause ref
+);
+
+@looping_expr =
+ @for_expr
+| @loop_expr
+| @while_expr
+;
+
+#keyset[id]
+looping_expr_loop_bodies(
+ int id: @looping_expr ref,
+ int loop_body: @block_expr ref
+);
+
+macro_defs(
+ unique int id: @macro_def
+);
+
+#keyset[id]
+macro_def_args(
+ int id: @macro_def ref,
+ int args: @token_tree ref
+);
+
+#keyset[id, index]
+macro_def_attrs(
+ int id: @macro_def ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_def_bodies(
+ int id: @macro_def ref,
+ int body: @token_tree ref
+);
+
+#keyset[id]
+macro_def_names(
+ int id: @macro_def ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_def_visibilities(
+ int id: @macro_def ref,
+ int visibility: @visibility ref
+);
+
+macro_rules(
+ unique int id: @macro_rules
+);
+
+#keyset[id, index]
+macro_rules_attrs(
+ int id: @macro_rules ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_rules_names(
+ int id: @macro_rules ref,
+ int name: @name ref
+);
+
+#keyset[id]
+macro_rules_token_trees(
+ int id: @macro_rules ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_rules_visibilities(
+ int id: @macro_rules ref,
+ int visibility: @visibility ref
+);
+
+method_call_exprs(
+ unique int id: @method_call_expr
+);
+
+#keyset[id]
+method_call_expr_generic_arg_lists(
+ int id: @method_call_expr ref,
+ int generic_arg_list: @generic_arg_list ref
+);
+
+#keyset[id]
+method_call_expr_identifiers(
+ int id: @method_call_expr ref,
+ int identifier: @name_ref ref
+);
+
+#keyset[id]
+method_call_expr_receivers(
+ int id: @method_call_expr ref,
+ int receiver: @expr ref
+);
+
+modules(
+ unique int id: @module
+);
+
+#keyset[id, index]
+module_attrs(
+ int id: @module ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+module_item_lists(
+ int id: @module ref,
+ int item_list: @item_list ref
+);
+
+#keyset[id]
+module_names(
+ int id: @module ref,
+ int name: @name ref
+);
+
+#keyset[id]
+module_visibilities(
+ int id: @module ref,
+ int visibility: @visibility ref
+);
+
+path_exprs(
+ unique int id: @path_expr
+);
+
+#keyset[id, index]
+path_expr_attrs(
+ int id: @path_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+path_pats(
+ unique int id: @path_pat
+);
+
+struct_exprs(
+ unique int id: @struct_expr
+);
+
+#keyset[id]
+struct_expr_struct_expr_field_lists(
+ int id: @struct_expr ref,
+ int struct_expr_field_list: @struct_expr_field_list ref
+);
+
+struct_pats(
+ unique int id: @struct_pat
+);
+
+#keyset[id]
+struct_pat_struct_pat_field_lists(
+ int id: @struct_pat ref,
+ int struct_pat_field_list: @struct_pat_field_list ref
+);
+
+traits(
+ unique int id: @trait
+);
+
+#keyset[id]
+trait_assoc_item_lists(
+ int id: @trait ref,
+ int assoc_item_list: @assoc_item_list ref
+);
+
+#keyset[id, index]
+trait_attrs(
+ int id: @trait ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_generic_param_lists(
+ int id: @trait ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_is_auto(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_is_unsafe(
+ int id: @trait ref
+);
+
+#keyset[id]
+trait_names(
+ int id: @trait ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_type_bound_lists(
+ int id: @trait ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_visibilities(
+ int id: @trait ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_where_clauses(
+ int id: @trait ref,
+ int where_clause: @where_clause ref
+);
+
+trait_aliases(
+ unique int id: @trait_alias
+);
+
+#keyset[id, index]
+trait_alias_attrs(
+ int id: @trait_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+trait_alias_generic_param_lists(
+ int id: @trait_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+trait_alias_names(
+ int id: @trait_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+trait_alias_type_bound_lists(
+ int id: @trait_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+trait_alias_visibilities(
+ int id: @trait_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+trait_alias_where_clauses(
+ int id: @trait_alias ref,
+ int where_clause: @where_clause ref
+);
+
+tuple_struct_pats(
+ unique int id: @tuple_struct_pat
+);
+
+#keyset[id, index]
+tuple_struct_pat_fields(
+ int id: @tuple_struct_pat ref,
+ int index: int ref,
+ int field: @pat ref
+);
+
+uses(
+ unique int id: @use
+);
+
+#keyset[id, index]
+use_attrs(
+ int id: @use ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+use_use_trees(
+ int id: @use ref,
+ int use_tree: @use_tree ref
+);
+
+#keyset[id]
+use_visibilities(
+ int id: @use ref,
+ int visibility: @visibility ref
+);
+
+consts(
+ unique int id: @const
+);
+
+#keyset[id, index]
+const_attrs(
+ int id: @const ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+const_bodies(
+ int id: @const ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+const_generic_param_lists(
+ int id: @const ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+const_is_const(
+ int id: @const ref
+);
+
+#keyset[id]
+const_is_default(
+ int id: @const ref
+);
+
+#keyset[id]
+const_names(
+ int id: @const ref,
+ int name: @name ref
+);
+
+#keyset[id]
+const_type_reprs(
+ int id: @const ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+const_visibilities(
+ int id: @const ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+const_where_clauses(
+ int id: @const ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+const_has_implementation(
+ int id: @const ref
+);
+
+enums(
+ unique int id: @enum
+);
+
+#keyset[id, index]
+enum_attrs(
+ int id: @enum ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+enum_generic_param_lists(
+ int id: @enum ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+enum_names(
+ int id: @enum ref,
+ int name: @name ref
+);
+
+#keyset[id]
+enum_variant_lists(
+ int id: @enum ref,
+ int variant_list: @variant_list ref
+);
+
+#keyset[id]
+enum_visibilities(
+ int id: @enum ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+enum_where_clauses(
+ int id: @enum ref,
+ int where_clause: @where_clause ref
+);
+
+for_exprs(
+ unique int id: @for_expr
+);
+
+#keyset[id, index]
+for_expr_attrs(
+ int id: @for_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+for_expr_iterables(
+ int id: @for_expr ref,
+ int iterable: @expr ref
+);
+
+#keyset[id]
+for_expr_pats(
+ int id: @for_expr ref,
+ int pat: @pat ref
+);
+
+functions(
+ unique int id: @function
+);
+
+#keyset[id]
+function_abis(
+ int id: @function ref,
+ int abi: @abi ref
+);
+
+#keyset[id]
+function_bodies(
+ int id: @function ref,
+ int body: @block_expr ref
+);
+
+#keyset[id]
+function_generic_param_lists(
+ int id: @function ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+function_is_async(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_const(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_default(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_gen(
+ int id: @function ref
+);
+
+#keyset[id]
+function_is_unsafe(
+ int id: @function ref
+);
+
+#keyset[id]
+function_names(
+ int id: @function ref,
+ int name: @name ref
+);
+
+#keyset[id]
+function_ret_types(
+ int id: @function ref,
+ int ret_type: @ret_type_repr ref
+);
+
+#keyset[id]
+function_visibilities(
+ int id: @function ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+function_where_clauses(
+ int id: @function ref,
+ int where_clause: @where_clause ref
+);
+
+#keyset[id]
+function_has_implementation(
+ int id: @function ref
+);
+
+loop_exprs(
+ unique int id: @loop_expr
+);
+
+#keyset[id, index]
+loop_expr_attrs(
+ int id: @loop_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+macro_calls(
+ unique int id: @macro_call
+);
+
+#keyset[id, index]
+macro_call_attrs(
+ int id: @macro_call ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+macro_call_paths(
+ int id: @macro_call ref,
+ int path: @path ref
+);
+
+#keyset[id]
+macro_call_token_trees(
+ int id: @macro_call ref,
+ int token_tree: @token_tree ref
+);
+
+#keyset[id]
+macro_call_macro_call_expansions(
+ int id: @macro_call ref,
+ int macro_call_expansion: @ast_node ref
+);
+
+statics(
+ unique int id: @static
+);
+
+#keyset[id, index]
+static_attrs(
+ int id: @static ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+static_bodies(
+ int id: @static ref,
+ int body: @expr ref
+);
+
+#keyset[id]
+static_is_mut(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_static(
+ int id: @static ref
+);
+
+#keyset[id]
+static_is_unsafe(
+ int id: @static ref
+);
+
+#keyset[id]
+static_names(
+ int id: @static ref,
+ int name: @name ref
+);
+
+#keyset[id]
+static_type_reprs(
+ int id: @static ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+static_visibilities(
+ int id: @static ref,
+ int visibility: @visibility ref
+);
+
+structs(
+ unique int id: @struct
+);
+
+#keyset[id, index]
+struct_attrs(
+ int id: @struct ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+struct_field_lists_(
+ int id: @struct ref,
+ int field_list: @field_list ref
+);
+
+#keyset[id]
+struct_generic_param_lists(
+ int id: @struct ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+struct_names(
+ int id: @struct ref,
+ int name: @name ref
+);
+
+#keyset[id]
+struct_visibilities(
+ int id: @struct ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+struct_where_clauses(
+ int id: @struct ref,
+ int where_clause: @where_clause ref
+);
+
+type_aliases(
+ unique int id: @type_alias
+);
+
+#keyset[id, index]
+type_alias_attrs(
+ int id: @type_alias ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+type_alias_generic_param_lists(
+ int id: @type_alias ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+type_alias_is_default(
+ int id: @type_alias ref
+);
+
+#keyset[id]
+type_alias_names(
+ int id: @type_alias ref,
+ int name: @name ref
+);
+
+#keyset[id]
+type_alias_type_reprs(
+ int id: @type_alias ref,
+ int type_repr: @type_repr ref
+);
+
+#keyset[id]
+type_alias_type_bound_lists(
+ int id: @type_alias ref,
+ int type_bound_list: @type_bound_list ref
+);
+
+#keyset[id]
+type_alias_visibilities(
+ int id: @type_alias ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+type_alias_where_clauses(
+ int id: @type_alias ref,
+ int where_clause: @where_clause ref
+);
+
+unions(
+ unique int id: @union
+);
+
+#keyset[id, index]
+union_attrs(
+ int id: @union ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+union_generic_param_lists(
+ int id: @union ref,
+ int generic_param_list: @generic_param_list ref
+);
+
+#keyset[id]
+union_names(
+ int id: @union ref,
+ int name: @name ref
+);
+
+#keyset[id]
+union_struct_field_lists(
+ int id: @union ref,
+ int struct_field_list: @struct_field_list ref
+);
+
+#keyset[id]
+union_visibilities(
+ int id: @union ref,
+ int visibility: @visibility ref
+);
+
+#keyset[id]
+union_where_clauses(
+ int id: @union ref,
+ int where_clause: @where_clause ref
+);
+
+while_exprs(
+ unique int id: @while_expr
+);
+
+#keyset[id, index]
+while_expr_attrs(
+ int id: @while_expr ref,
+ int index: int ref,
+ int attr: @attr ref
+);
+
+#keyset[id]
+while_expr_conditions(
+ int id: @while_expr ref,
+ int condition: @expr ref
+);
diff --git a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.properties b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.properties
new file mode 100644
index 00000000000..f843aa79559
--- /dev/null
+++ b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.properties
@@ -0,0 +1,18 @@
+description: Upgrade rust-analyzer to 0.0.300
+compatibility: backwards
+
+closure_binders.rel: delete
+closure_binder_generic_param_lists.rel: delete
+where_pred_generic_param_lists.rel: delete
+for_type_repr_generic_param_lists.rel: delete
+closure_expr_closure_binders.rel: delete
+closure_expr_for_binders.rel: reorder closure_expr_closure_binders.rel (@closure_expr id, @closure_binder binder) id binder
+
+for_binders.rel: run upgrade.ql new_for_binders
+for_binder_generic_param_lists.rel: run upgrade.ql new_for_binder_generic_param_lists
+for_type_repr_for_binders.rel: run upgrade.ql new_for_type_repr_for_binders
+where_pred_for_binders.rel: run upgrade.ql new_where_pred_for_binders
+type_bound_for_binders.rel: run upgrade.ql new_type_bound_for_binders
+for_type_reprs.rel: run upgrade.ql new_for_type_reprs
+type_bound_type_reprs.rel: run upgrade.ql new_type_bound_type_reprs
+locatable_locations.rel: run upgrade.ql new_locatable_locations
diff --git a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql
new file mode 100644
index 00000000000..9ddf709c59c
--- /dev/null
+++ b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql
@@ -0,0 +1,94 @@
+class Element extends @element {
+ string toString() { none() }
+}
+
+class ForTypeInTypeBound extends Element, @for_type_repr {
+ Element bound;
+
+ ForTypeInTypeBound() { type_bound_type_reprs(bound, this) }
+
+ Element getBound() { result = bound }
+
+ Element getGenericParamList() { for_type_repr_generic_param_lists(this, result) }
+}
+
+class Location extends @location_default {
+ string toString() { none() }
+}
+
+// we must create new `ForBinder` elements to wrap `genericParamList`s of
+// `WherePred` and `ForType` elements
+//
+// previously, T: for<'a> X was TypeBound(type_repr=ForType(generic_param_list='a, type_repr=X))
+// but now it is TypeBound(for_binder=ForBinder()
+// so in that case we don't create new ForBinders, but rather we repurpose ForType ids as
+// the new ForBinders ones
+newtype TAddedElement =
+ TWherePredForBinder(Element wherePred, Element genericParamList) {
+ where_pred_generic_param_lists(wherePred, genericParamList)
+ } or
+ TForTypeForBinder(Element forType, Element genericParamList) {
+ for_type_repr_generic_param_lists(forType, genericParamList) and
+ not forType instanceof ForTypeInTypeBound
+ }
+
+module Fresh = QlBuiltins::NewEntity;
+
+class TNewElement = @element or Fresh::EntityId;
+
+class NewElement extends TNewElement {
+ string toString() { none() }
+
+ Element newGenericParamList() {
+ this = Fresh::map(TWherePredForBinder(_, result)) or
+ this = Fresh::map(TForTypeForBinder(_, result))
+ }
+}
+
+query predicate new_for_binders(NewElement id) {
+ closure_binders(id) or
+ id = Fresh::map(_) or
+ id instanceof ForTypeInTypeBound
+}
+
+query predicate new_for_binder_generic_param_lists(NewElement id, Element list) {
+ closure_binder_generic_param_lists(id, list) or
+ id.newGenericParamList() = list or
+ id.(ForTypeInTypeBound).getGenericParamList() = list
+}
+
+query predicate new_where_pred_for_binders(Element id, NewElement binder) {
+ binder = Fresh::map(TWherePredForBinder(id, _))
+}
+
+// we need to add a ForBinder to ForType if it's not in a TypeBound
+query predicate new_for_type_repr_for_binders(Element id, NewElement binder) {
+ binder = Fresh::map(TForTypeForBinder(id, _))
+}
+
+// we attach a ForTypeInTypeBound id as a ForBinder one to its TypeBound
+query predicate new_type_bound_for_binders(Element id, NewElement binder) {
+ id = binder.(ForTypeInTypeBound).getBound()
+}
+
+// we restrict ForTypes to just the ones that are not in a TypeBound
+query predicate new_for_type_reprs(Element id) {
+ for_type_reprs(id) and not id instanceof ForTypeInTypeBound
+}
+
+// for a TypeBound around a ForType, we need to move type_repr from one directly to the other
+query predicate new_type_bound_type_reprs(Element bound, Element type) {
+ exists(Element originalType |
+ type_bound_type_reprs(bound, originalType) and
+ if for_type_reprs(originalType)
+ then for_type_repr_type_reprs(originalType, type)
+ else type = originalType
+ )
+}
+
+// for newly addded ForBinders, use same location as their generic param list
+query predicate new_locatable_locations(NewElement id, Location location) {
+ locatable_locations(id, location)
+ or
+ locatable_locations(id.newGenericParamList(), location)
+}
diff --git a/rust/ql/test/extractor-tests/generated/.generated_tests.list b/rust/ql/test/extractor-tests/generated/.generated_tests.list
index 952b93b3339..2cfccde4c10 100644
--- a/rust/ql/test/extractor-tests/generated/.generated_tests.list
+++ b/rust/ql/test/extractor-tests/generated/.generated_tests.list
@@ -42,7 +42,7 @@ FieldExpr/gen_field_expr.rs 9a70500d592e0a071b03d974a55558b3bc0df531ff11bce5898f
FnPtrTypeRepr/gen_fn_ptr_type_repr.rs c154ec0cc43236d133f6b946374f3063b89e5cbf9e96d9ee66877be4f948888e c154ec0cc43236d133f6b946374f3063b89e5cbf9e96d9ee66877be4f948888e
ForBinder/gen_for_binder.rs e3c9e5ffd3f2a5a546af9ab6e2a2ed733baf9cf609e05850b70feb31478a0bae e3c9e5ffd3f2a5a546af9ab6e2a2ed733baf9cf609e05850b70feb31478a0bae
ForExpr/gen_for_expr.rs 003dc36e3dc4db6e3a4accd410c316f14334ba5b3d5d675c851a91dcd5185122 003dc36e3dc4db6e3a4accd410c316f14334ba5b3d5d675c851a91dcd5185122
-ForTypeRepr/gen_for_type_repr.rs 86f2f11f399d8072add3d3109a186d82d95d141660b18986bce738b7e9ec81a2 86f2f11f399d8072add3d3109a186d82d95d141660b18986bce738b7e9ec81a2
+ForTypeRepr/gen_for_type_repr.rs d6dc10cdb4f505447805d24e83a24f876f2b6e6d8cdb193e786405f3ffbc7cda d6dc10cdb4f505447805d24e83a24f876f2b6e6d8cdb193e786405f3ffbc7cda
FormatArgsExpr/gen_format.rs e9d8e7b98d0050ad6053c2459cb21faab00078e74245336a5962438336f76d33 e9d8e7b98d0050ad6053c2459cb21faab00078e74245336a5962438336f76d33
FormatArgsExpr/gen_format_args_arg.rs 53ffd6abe4cd899c57d1973b31df0edc1d5eaa5835b19172ec4cda15bb3db28f 53ffd6abe4cd899c57d1973b31df0edc1d5eaa5835b19172ec4cda15bb3db28f
FormatArgsExpr/gen_format_args_expr.rs 72c806ed163e9dcce2d0c5c8664d409b2aa635c1022c91959f9e8ae084f05bf2 72c806ed163e9dcce2d0c5c8664d409b2aa635c1022c91959f9e8ae084f05bf2
@@ -136,7 +136,7 @@ TupleStructPat/gen_tuple_struct_pat.rs 601ca8813272d15b4c8fd7402d0d28a42a62be828
TupleTypeRepr/gen_tuple_type_repr.rs 64873a6a1cd5df6cd10165d7e9fa0399902b6bfbac086ef3a7ce83237b816879 64873a6a1cd5df6cd10165d7e9fa0399902b6bfbac086ef3a7ce83237b816879
TypeAlias/gen_type_alias.rs da2b959f1a2a4f5471c231025404ca82a1bc79ac68adcda5a67292c428ad6143 da2b959f1a2a4f5471c231025404ca82a1bc79ac68adcda5a67292c428ad6143
TypeArg/gen_type_arg.rs a0e455d7173b51330db63f1b7ac9c5d4263d33b3a115f97a8167d4dcc42469ff a0e455d7173b51330db63f1b7ac9c5d4263d33b3a115f97a8167d4dcc42469ff
-TypeBound/gen_type_bound.rs 7487ae3fd7c3a481efe96ce7894fc974b96276ecd78e0ccb141c698b5c6f5eaa 7487ae3fd7c3a481efe96ce7894fc974b96276ecd78e0ccb141c698b5c6f5eaa
+TypeBound/gen_type_bound.rs f7ed1dcfde0b9cae65580a990be6dc122be3e02f5771dd0f8f75b306bda1b29a f7ed1dcfde0b9cae65580a990be6dc122be3e02f5771dd0f8f75b306bda1b29a
TypeBoundList/gen_type_bound_list.rs f61e80667385f6e8f51452a401d355b8939dbb1e1a7d3a506023639cb387bfbd f61e80667385f6e8f51452a401d355b8939dbb1e1a7d3a506023639cb387bfbd
TypeParam/gen_type_param.rs 00b92ac7042ae83be1e37cd22f6d02098ca3157dc1ef45fbdf3b5f252ea6a8de 00b92ac7042ae83be1e37cd22f6d02098ca3157dc1ef45fbdf3b5f252ea6a8de
UnderscoreExpr/gen_underscore_expr.rs fe34e99d322bf86c0f5509c9b5fd6e1e8abbdf63dbe7e01687344a41e9aabe52 fe34e99d322bf86c0f5509c9b5fd6e1e8abbdf63dbe7e01687344a41e9aabe52
@@ -149,7 +149,7 @@ Variant/gen_variant.rs fa3d3a9e3e0c3aa565b965fad9c3dc2ffd5a8d82963e3a55a9acbb0f1
VariantList/gen_variant_list.rs a1faa4d59b072f139d14cb8a6d63a0ce8c473170d6320a07ce6bb9d517f8486d a1faa4d59b072f139d14cb8a6d63a0ce8c473170d6320a07ce6bb9d517f8486d
Visibility/gen_visibility.rs cfa4b05fa7ba7c4ffa8f9c880b13792735e4f7e92a648f43110e914075e97a52 cfa4b05fa7ba7c4ffa8f9c880b13792735e4f7e92a648f43110e914075e97a52
WhereClause/gen_where_clause.rs 22522c933be47f8f7f9d0caddfa41925c08df343c564baad2fe2daa14f1bfb1a 22522c933be47f8f7f9d0caddfa41925c08df343c564baad2fe2daa14f1bfb1a
-WherePred/gen_where_pred.rs dbc7bf0f246a04b42783f910c6f09841393f0e0a78f0a584891a99d0cf461619 dbc7bf0f246a04b42783f910c6f09841393f0e0a78f0a584891a99d0cf461619
+WherePred/gen_where_pred.rs 7036e34f1a1f77c5cf031f385be4583472ea4f99e8b4b4ec3c72a65c23e418bb 7036e34f1a1f77c5cf031f385be4583472ea4f99e8b4b4ec3c72a65c23e418bb
WhileExpr/gen_while_expr.rs 97276c5946a36001638491c99a36170d22bc6011c5e59f621b37c7a2d7737879 97276c5946a36001638491c99a36170d22bc6011c5e59f621b37c7a2d7737879
WildcardPat/gen_wildcard_pat.rs f1b175eeb3a0fc32bbcfb70a207be33dfde51a7d5198f72b8e08948f0d43e3dc f1b175eeb3a0fc32bbcfb70a207be33dfde51a7d5198f72b8e08948f0d43e3dc
YeetExpr/gen_yeet_expr.rs c243b785a2cbd941bcec23dafc23ffbc64b93cf2843b6ede9783cdb81fed439d c243b785a2cbd941bcec23dafc23ffbc64b93cf2843b6ede9783cdb81fed439d
diff --git a/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected b/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected
index 3607f89a6dd..34274dddb8b 100644
--- a/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected
+++ b/rust/ql/test/extractor-tests/generated/ForBinder/ForBinder.expected
@@ -1,4 +1,4 @@
instances
-| gen_for_binder.rs:7:21:7:43 | ForBinder |
+| gen_for_binder.rs:7:21:7:43 | for<...> |
getGenericParamList
-| gen_for_binder.rs:7:21:7:43 | ForBinder | gen_for_binder.rs:7:24:7:43 | <...> |
+| gen_for_binder.rs:7:21:7:43 | for<...> | gen_for_binder.rs:7:24:7:43 | <...> |
diff --git a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
index 450d0b6c754..896894bcc06 100644
--- a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
+++ b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
@@ -1,3 +1,6 @@
instances
+| gen_for_type_repr.rs:8:19:8:31 | ForTypeRepr |
getForBinder
+| gen_for_type_repr.rs:8:19:8:31 | ForTypeRepr | gen_for_type_repr.rs:8:19:8:25 | for<...> |
getTypeRepr
+| gen_for_type_repr.rs:8:19:8:31 | ForTypeRepr | gen_for_type_repr.rs:8:27:8:31 | usize |
diff --git a/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs b/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs
index 49cd9e5c1ab..448cd5f615f 100644
--- a/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs
+++ b/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs
@@ -1,14 +1,10 @@
// generated by codegen, do not edit
fn test_for_type_repr() -> () {
- // A higher-ranked trait bound.
+ // A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
+ // only be applied to traits to form a `TypeBound`).
//
// For example:
- fn foo(value: T)
- where
- T: for<'a> Fn(&'a str) -> &'a str
- // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- {
- // ...
- }
+ fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
+ // ^^^^^^^^^^^^^
}
diff --git a/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected b/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected
index f294d646676..f987837ffe3 100644
--- a/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected
+++ b/rust/ql/test/extractor-tests/generated/TypeBound/TypeBound.expected
@@ -1,7 +1,10 @@
instances
| gen_type_bound.rs:7:15:7:19 | TypeBound | isAsync: | no | isConst: | no |
+| gen_type_bound.rs:9:24:9:44 | TypeBound | isAsync: | no | isConst: | no |
getForBinder
+| gen_type_bound.rs:9:24:9:44 | TypeBound | gen_type_bound.rs:9:24:9:30 | for<...> |
getLifetime
getTypeRepr
| gen_type_bound.rs:7:15:7:19 | TypeBound | gen_type_bound.rs:7:15:7:19 | Debug |
+| gen_type_bound.rs:9:24:9:44 | TypeBound | gen_type_bound.rs:9:32:9:44 | From::<...> |
getUseBoundGenericArgs
diff --git a/rust/ql/test/extractor-tests/generated/TypeBound/gen_type_bound.rs b/rust/ql/test/extractor-tests/generated/TypeBound/gen_type_bound.rs
index 9e182cbeefc..7b4c9e4f423 100644
--- a/rust/ql/test/extractor-tests/generated/TypeBound/gen_type_bound.rs
+++ b/rust/ql/test/extractor-tests/generated/TypeBound/gen_type_bound.rs
@@ -6,4 +6,6 @@ fn test_type_bound() -> () {
// For example:
fn foo(t: T) {}
// ^^^^^
+ fn bar(value: impl for<'a> From<&'a str>) {}
+ // ^^^^^^^^^^^^^^^^^^^^^
}
diff --git a/rust/ql/test/extractor-tests/generated/WherePred/gen_where_pred.rs b/rust/ql/test/extractor-tests/generated/WherePred/gen_where_pred.rs
index 48a6b7bf256..8e037453bf7 100644
--- a/rust/ql/test/extractor-tests/generated/WherePred/gen_where_pred.rs
+++ b/rust/ql/test/extractor-tests/generated/WherePred/gen_where_pred.rs
@@ -6,4 +6,6 @@ fn test_where_pred() -> () {
// For example:
fn foo(t: T, u: U) where T: Debug, U: Clone {}
// ^^^^^^^^ ^^^^^^^^
+ fn bar(value: T) where for<'a> T: From<&'a str> {}
+ // ^^^^^^^^^^^^^^^^^^^^^^^^
}
diff --git a/rust/schema/annotations.py b/rust/schema/annotations.py
index 3c17ec99756..6b7cb3f4f76 100644
--- a/rust/schema/annotations.py
+++ b/rust/schema/annotations.py
@@ -1158,21 +1158,16 @@ class _:
@annotate(ForTypeRepr)
class _:
"""
- A higher-ranked trait bound.
+ A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
+ only be applied to traits to form a `TypeBound`).
For example:
```rust
- fn foo(value: T)
- where
- T: for<'a> Fn(&'a str) -> &'a str
- // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- {
- // ...
- }
+ fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
+ // ^^^^^^^^^^^^^
```
"""
-
@annotate(FormatArgsArg, cfg=True)
@qltest.test_with(FormatArgsExpr)
class _:
@@ -1987,6 +1982,8 @@ class _:
```rust
fn foo(t: T) {}
// ^^^^^
+ fn bar(value: impl for<'a> From<&'a str>) {}
+ // ^^^^^^^^^^^^^^^^^^^^^
```
"""
@@ -2126,6 +2123,8 @@ class _:
```rust
fn foo(t: T, u: U) where T: Debug, U: Clone {}
// ^^^^^^^^ ^^^^^^^^
+ fn bar(value: T) where for<'a> T: From<&'a str> {}
+ // ^^^^^^^^^^^^^^^^^^^^^^^^
```
"""
From 4df479471f4b4a893f50535311a1903bd1388446 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Mon, 18 Aug 2025 15:55:06 +0200
Subject: [PATCH 084/298] Rust: accept test changes
---
.../generated/ClosureExpr/ClosureExpr.expected | 2 +-
.../extractor-tests/generated/WherePred/WherePred.expected | 4 ++++
2 files changed, 5 insertions(+), 1 deletion(-)
diff --git a/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected b/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected
index 1c3f489930b..d7ae60022b1 100644
--- a/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected
+++ b/rust/ql/test/extractor-tests/generated/ClosureExpr/ClosureExpr.expected
@@ -31,6 +31,6 @@ getBody
| gen_closure_expr.rs:10:5:11:22 | \|...\| ... | gen_closure_expr.rs:11:16:11:22 | YieldExpr |
| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | gen_closure_expr.rs:12:36:14:5 | { ... } |
getForBinder
-| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | gen_closure_expr.rs:12:5:12:27 | ForBinder |
+| gen_closure_expr.rs:12:5:14:5 | \|...\| ... | gen_closure_expr.rs:12:5:12:27 | for<...> |
getRetType
| gen_closure_expr.rs:6:5:6:34 | \|...\| ... | gen_closure_expr.rs:6:19:6:24 | RetTypeRepr |
diff --git a/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected b/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected
index 18fd13987c3..41b5739818c 100644
--- a/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected
+++ b/rust/ql/test/extractor-tests/generated/WherePred/WherePred.expected
@@ -1,11 +1,15 @@
instances
| gen_where_pred.rs:7:36:7:43 | WherePred |
| gen_where_pred.rs:7:46:7:53 | WherePred |
+| gen_where_pred.rs:9:31:9:54 | WherePred |
getForBinder
+| gen_where_pred.rs:9:31:9:54 | WherePred | gen_where_pred.rs:9:31:9:37 | for<...> |
getLifetime
getTypeRepr
| gen_where_pred.rs:7:36:7:43 | WherePred | gen_where_pred.rs:7:36:7:36 | T |
| gen_where_pred.rs:7:46:7:53 | WherePred | gen_where_pred.rs:7:46:7:46 | U |
+| gen_where_pred.rs:9:31:9:54 | WherePred | gen_where_pred.rs:9:39:9:39 | T |
getTypeBoundList
| gen_where_pred.rs:7:36:7:43 | WherePred | gen_where_pred.rs:7:39:7:43 | TypeBoundList |
| gen_where_pred.rs:7:46:7:53 | WherePred | gen_where_pred.rs:7:49:7:53 | TypeBoundList |
+| gen_where_pred.rs:9:31:9:54 | WherePred | gen_where_pred.rs:9:42:9:54 | TypeBoundList |
From 6266d6e7b0138826efac85d0ad118168c079e7b6 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Mon, 18 Aug 2025 17:12:05 +0200
Subject: [PATCH 085/298] Rust: add downgrade script
---
.../downgrade.ql | 93 +++++++++++++++++++
.../upgrade.properties | 29 +++++-
2 files changed, 121 insertions(+), 1 deletion(-)
create mode 100644 rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/downgrade.ql
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/downgrade.ql b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/downgrade.ql
new file mode 100644
index 00000000000..56e3d5b652c
--- /dev/null
+++ b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/downgrade.ql
@@ -0,0 +1,93 @@
+class Element extends @element {
+ string toString() { none() }
+}
+
+class Location extends @location_default {
+ string toString() { none() }
+}
+
+query predicate new_closure_binders(Element id) {
+ for_binders(id) and closure_expr_for_binders(_, id)
+}
+
+query predicate new_closure_binder_generic_param_lists(Element id, Element list) {
+ for_binder_generic_param_lists(id, list) and closure_expr_for_binders(_, id)
+}
+
+query predicate new_where_pred_generic_param_lists(Element id, Element list) {
+ exists(Element forBinder |
+ where_pred_for_binders(id, forBinder) and
+ for_binder_generic_param_lists(forBinder, list)
+ )
+}
+
+// We need to transform `TypeBound(for_binder=ForBinder(generic_param_list=X), type_repr=Y)`
+// into `TypeBound(type_repr=ForTypeRepr(generic_param_list=X, type_repr=Y))`
+// we repurpose the `@for_binder` id into a `@for_type_repr` one
+query predicate new_for_type_reprs(Element id) {
+ for_type_reprs(id) or
+ exists(Element typeBound | type_bound_for_binders(typeBound, id))
+}
+
+query predicate new_for_type_repr_generic_param_lists(Element id, Element list) {
+ exists(Element forBinder |
+ for_type_repr_for_binders(id, forBinder) and for_binder_generic_param_lists(forBinder, list)
+ )
+ or
+ exists(Element typeBound |
+ type_bound_for_binders(typeBound, id) and for_binder_generic_param_lists(id, list)
+ )
+}
+
+query predicate new_for_type_repr_type_reprs(Element id, Element type) {
+ for_type_repr_type_reprs(id, type)
+ or
+ exists(Element typeBound |
+ type_bound_for_binders(typeBound, id) and type_bound_type_reprs(typeBound, type)
+ )
+}
+
+query predicate new_type_bound_type_reprs(Element bound, Element type) {
+ type_bound_type_reprs(bound, type) and not type_bound_for_binders(bound, _)
+ or
+ type_bound_for_binders(bound, type)
+}
+
+// remove locations of removed @for_binder elements
+query predicate new_locatable_locations(Element id, Location loc) {
+ locatable_locations(id, loc) and not where_pred_for_binders(_, id)
+}
+
+// remove @asm_expr from the subtypes of @item (and therefore @addressable and @stmt)
+// this means removing any @asm_expr ids from tables that accept @item, @stmt or @addressable
+query predicate new_item_attribute_macro_expansions(Element id, Element items) {
+ item_attribute_macro_expansions(id, items) and not asm_exprs(id)
+}
+
+query predicate new_item_list_items(Element id, int index, Element item) {
+ item_list_items(id, index, item) and not asm_exprs(item)
+}
+
+query predicate new_macro_items_items(Element id, int index, Element item) {
+ macro_items_items(id, index, item) and not asm_exprs(item)
+}
+
+query predicate new_source_file_items(Element id, int index, Element item) {
+ source_file_items(id, index, item) and not asm_exprs(item)
+}
+
+query predicate new_stmt_list_statements(Element id, int index, Element stmt) {
+ stmt_list_statements(id, index, stmt) and not asm_exprs(stmt)
+}
+
+query predicate new_macro_block_expr_statements(Element id, int index, Element stmt) {
+ macro_block_expr_statements(id, index, stmt) and not asm_exprs(stmt)
+}
+
+query predicate new_addressable_extended_canonical_paths(Element id, string path) {
+ addressable_extended_canonical_paths(id, path) and not asm_exprs(id)
+}
+
+query predicate new_addressable_crate_origins(Element id, string crate) {
+ addressable_crate_origins(id, crate) and not asm_exprs(id)
+}
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
index 597a1e6181b..8376124b7f8 100644
--- a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
+++ b/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
@@ -1,2 +1,29 @@
-description: TODO
+description: Revert rust-analyzer upgrade to 0.0.300
compatibility: backwards
+
+for_type_repr_for_binders.rel: delete
+where_pred_for_binders.rel: delete
+type_bound_for_binders.rel: delete
+for_binders.rel: delete
+for_binder_generic_param_lists.rel: delete
+closure_expr_for_binders.rel: delete
+
+closure_expr_closure_binders.rel: reorder closure_expr_for_binders.rel (@closure_expr id, @for_binder binder) id binder
+
+closure_binders.rel: run downgrade.ql new_closure_binders
+closure_binder_generic_param_lists.rel: run downgrade.ql new_closure_binder_generic_param_lists
+where_pred_generic_param_lists.rel: run downgrade.ql new_where_pred_generic_param_lists
+for_type_reprs.rel: run downgrade.ql new_for_type_reprs
+for_type_repr_generic_param_lists.rel: run downgrade.ql new_for_type_repr_generic_param_lists
+for_type_repr_type_reprs.rel: run downgrade.ql new_for_type_repr_type_reprs
+type_bound_type_reprs.rel: run downgrade.ql new_type_bound_type_reprs
+locatable_locations.rel: run downgrade.ql new_locatable_locations
+
+item_attribute_macro_expansions.rel: run downgrade.ql new_item_attribute_macro_expansions
+item_list_items.rel: run downgrade.ql new_item_list_items
+macro_items_items.rel: run downgrade.ql new_macro_items_items
+source_file_items.rel: run downgrade.ql new_source_file_items
+stmt_list_statements.rel: run downgrade.ql new_stmt_list_statements
+macro_block_expr_statements.rel: run downgrade.ql new_macro_block_expr_statements
+addressable_extended_canonical_paths.rel: run downgrade.ql new_addressable_extended_canonical_paths
+addressable_crate_origins.rel: run downgrade.ql new_addressable_crate_origins
From a658fa168d13bf3bb2526819ebcc46b664ec1619 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Mon, 18 Aug 2025 17:19:47 +0200
Subject: [PATCH 086/298] Rust: refine upgrade script
---
.../319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql
index 9ddf709c59c..240991854e8 100644
--- a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql
+++ b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/upgrade.ql
@@ -66,6 +66,10 @@ query predicate new_for_type_repr_for_binders(Element id, NewElement binder) {
binder = Fresh::map(TForTypeForBinder(id, _))
}
+query predicate new_for_type_repr_type_reprs(Element id, Element type) {
+ for_type_repr_type_reprs(id, type) and not id instanceof ForTypeInTypeBound
+}
+
// we attach a ForTypeInTypeBound id as a ForBinder one to its TypeBound
query predicate new_type_bound_for_binders(Element id, NewElement binder) {
id = binder.(ForTypeInTypeBound).getBound()
From 6872f517252bfa82d9e078c603d2d681a276912c Mon Sep 17 00:00:00 2001
From: Asger F
Date: Tue, 24 Jun 2025 12:49:41 +0200
Subject: [PATCH 087/298] JS: Add metadata to dbscheme and stats
---
.../ql/lib/semmlecode.javascript.dbscheme | 6 ++++
.../lib/semmlecode.javascript.dbscheme.stats | 36 +++++++++++++++++++
2 files changed, 42 insertions(+)
diff --git a/javascript/ql/lib/semmlecode.javascript.dbscheme b/javascript/ql/lib/semmlecode.javascript.dbscheme
index ccefb5e2d49..b5611725acb 100644
--- a/javascript/ql/lib/semmlecode.javascript.dbscheme
+++ b/javascript/ql/lib/semmlecode.javascript.dbscheme
@@ -1192,3 +1192,9 @@ configLocations(
);
@configLocatable = @config | @configName | @configValue;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
diff --git a/javascript/ql/lib/semmlecode.javascript.dbscheme.stats b/javascript/ql/lib/semmlecode.javascript.dbscheme.stats
index 51889bd9286..96f8cd6eb4c 100644
--- a/javascript/ql/lib/semmlecode.javascript.dbscheme.stats
+++ b/javascript/ql/lib/semmlecode.javascript.dbscheme.stats
@@ -28260,5 +28260,41 @@
+
+databaseMetadata
+1
+
+
+metadataKey
+1
+
+
+value
+1
+
+
+
+
+metadataKey
+value
+
+
+12
+
+
+
+
+
+value
+metadataKey
+
+
+12
+
+
+
+
+
+
From c1df8a95cbebac021a2eb757aefb6896d9924113 Mon Sep 17 00:00:00 2001
From: Asger F
Date: Tue, 24 Jun 2025 17:17:17 +0200
Subject: [PATCH 088/298] JS: Overlay extraction support
---
.../com/semmle/js/extractor/AutoBuild.java | 41 ++++++++++++++++++-
.../semmle/js/extractor/OverlayChanges.java | 7 ++++
javascript/resources/codeql-extractor.yml | 1 +
3 files changed, 48 insertions(+), 1 deletion(-)
create mode 100644 javascript/extractor/src/com/semmle/js/extractor/OverlayChanges.java
diff --git a/javascript/extractor/src/com/semmle/js/extractor/AutoBuild.java b/javascript/extractor/src/com/semmle/js/extractor/AutoBuild.java
index 08dac06c4d9..96cd76e5a7a 100644
--- a/javascript/extractor/src/com/semmle/js/extractor/AutoBuild.java
+++ b/javascript/extractor/src/com/semmle/js/extractor/AutoBuild.java
@@ -465,10 +465,11 @@ public class AutoBuild {
try {
CompletableFuture> sourceFuture = extractSource();
sourceFuture.join(); // wait for source extraction to complete
- if (hasSeenCode()) { // don't bother with the externs if no code was seen
+ if (hasSeenCode() && !isOverlayChangeMode()) { // don't bother with the externs if no code was seen
extractExterns();
}
extractXml();
+ writeOverlayMetadata();
} catch (OutOfMemoryError oom) {
System.err.println("Out of memory while extracting the project.");
return 137; // the CodeQL CLI will interpret this as an out-of-memory error
@@ -509,6 +510,21 @@ public class AutoBuild {
return 0;
}
+ private void writeOverlayMetadata() {
+ String file = getEnvVar("CODEQL_EXTRACTOR_JAVASCRIPT_OVERLAY_BASE_METADATA_OUT");
+ if (file == null) {
+ // no overlay metadata file specified, so nothing to do
+ return;
+ }
+ // Write an empty string to the file as we currently have no metadata to emit.
+ // The file must be created for the database to recognized as an overlay base.
+ try {
+ Files.writeString(Paths.get(file), "", StandardCharsets.UTF_8);
+ } catch (IOException e) {
+ throw new ResourceError("Could not write overlay metadata to " + file, e);
+ }
+ }
+
/**
* A kind of error that can happen during extraction of JavaScript or TypeScript
* code.
@@ -734,6 +750,17 @@ public class AutoBuild {
List tsconfigFiles = new ArrayList<>();
findFilesToExtract(defaultExtractor, filesToExtract, tsconfigFiles);
+ OverlayChanges overlay = getOverlayChanges();
+ if (overlay != null) {
+ Set changedFiles = overlay.changes.stream()
+ .map(file -> Paths.get(file).toAbsolutePath())
+ .collect(Collectors.toSet());
+ int before = filesToExtract.size();
+ filesToExtract.retainAll(changedFiles);
+ int after = filesToExtract.size();
+ System.out.println("Overlay filter removed " + (before - after) + " out of " + before + " files from extraction.");
+ }
+
tsconfigFiles = tsconfigFiles.stream()
.sorted(PATH_ORDERING)
.collect(Collectors.toList());
@@ -1338,6 +1365,18 @@ protected DependencyInstallationResult preparePackagesAndDependencies(Set
}
}
+ private boolean isOverlayChangeMode() {
+ return getEnvVar("CODEQL_EXTRACTOR_JAVASCRIPT_OVERLAY_CHANGES") != null;
+ }
+
+ private OverlayChanges getOverlayChanges() throws IOException {
+ String jsonFile = getEnvVar("CODEQL_EXTRACTOR_JAVASCRIPT_OVERLAY_CHANGES");
+ if (jsonFile == null) {
+ return null;
+ }
+ return new Gson().fromJson(Files.newBufferedReader(Paths.get(jsonFile)), OverlayChanges.class);
+ }
+
public static void main(String[] args) {
try {
System.exit(new AutoBuild().run());
diff --git a/javascript/extractor/src/com/semmle/js/extractor/OverlayChanges.java b/javascript/extractor/src/com/semmle/js/extractor/OverlayChanges.java
new file mode 100644
index 00000000000..25cae238920
--- /dev/null
+++ b/javascript/extractor/src/com/semmle/js/extractor/OverlayChanges.java
@@ -0,0 +1,7 @@
+package com.semmle.js.extractor;
+
+import java.util.List;
+
+public class OverlayChanges {
+ public List changes;
+}
diff --git a/javascript/resources/codeql-extractor.yml b/javascript/resources/codeql-extractor.yml
index b82b2a96581..77844bd6bae 100644
--- a/javascript/resources/codeql-extractor.yml
+++ b/javascript/resources/codeql-extractor.yml
@@ -6,6 +6,7 @@ display_name: "JavaScript/TypeScript"
version: 1.22.1
column_kind: "utf16"
unicode_newlines: true
+overlay_support_version: 20250108
build_modes:
- none
file_coverage_languages:
From 30baf0acecc6f4e2f5939f7e428ca4209142d3b9 Mon Sep 17 00:00:00 2001
From: Asger F
Date: Tue, 1 Jul 2025 12:58:20 +0200
Subject: [PATCH 089/298] JS: Add overlayChangedFiles
---
javascript/ql/lib/semmlecode.javascript.dbscheme | 4 ++++
.../ql/lib/semmlecode.javascript.dbscheme.stats | 11 +++++++++++
javascript/resources/codeql-extractor.yml | 2 +-
3 files changed, 16 insertions(+), 1 deletion(-)
diff --git a/javascript/ql/lib/semmlecode.javascript.dbscheme b/javascript/ql/lib/semmlecode.javascript.dbscheme
index b5611725acb..76a926a00d5 100644
--- a/javascript/ql/lib/semmlecode.javascript.dbscheme
+++ b/javascript/ql/lib/semmlecode.javascript.dbscheme
@@ -1198,3 +1198,7 @@ databaseMetadata(
string metadataKey: string ref,
string value: string ref
);
+
+overlayChangedFiles(
+ string path: string ref
+);
diff --git a/javascript/ql/lib/semmlecode.javascript.dbscheme.stats b/javascript/ql/lib/semmlecode.javascript.dbscheme.stats
index 96f8cd6eb4c..eee67ae3e4f 100644
--- a/javascript/ql/lib/semmlecode.javascript.dbscheme.stats
+++ b/javascript/ql/lib/semmlecode.javascript.dbscheme.stats
@@ -28296,5 +28296,16 @@
+
+overlayChangedFiles
+50
+
+
+path
+50
+
+
+
+
diff --git a/javascript/resources/codeql-extractor.yml b/javascript/resources/codeql-extractor.yml
index 77844bd6bae..54a8c86d73a 100644
--- a/javascript/resources/codeql-extractor.yml
+++ b/javascript/resources/codeql-extractor.yml
@@ -6,7 +6,7 @@ display_name: "JavaScript/TypeScript"
version: 1.22.1
column_kind: "utf16"
unicode_newlines: true
-overlay_support_version: 20250108
+overlay_support_version: 20250626
build_modes:
- none
file_coverage_languages:
From ba585b8af5e78c77416b3e99f62fffa82c89db41 Mon Sep 17 00:00:00 2001
From: Asger F
Date: Wed, 2 Jul 2025 10:12:18 +0200
Subject: [PATCH 090/298] JS: Add upgrade/downgrade scripts
---
.../old.dbscheme | 1204 +++++++++++++++++
.../semmlecode.javascript.dbscheme | 1194 ++++++++++++++++
.../upgrade.properties | 5 +
.../old.dbscheme | 1194 ++++++++++++++++
.../semmlecode.javascript.dbscheme | 1204 +++++++++++++++++
.../upgrade.properties | 2 +
6 files changed, 4803 insertions(+)
create mode 100644 javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/old.dbscheme
create mode 100644 javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/semmlecode.javascript.dbscheme
create mode 100644 javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/upgrade.properties
create mode 100644 javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/old.dbscheme
create mode 100644 javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/semmlecode.javascript.dbscheme
create mode 100644 javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/upgrade.properties
diff --git a/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/old.dbscheme b/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/old.dbscheme
new file mode 100644
index 00000000000..76a926a00d5
--- /dev/null
+++ b/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/old.dbscheme
@@ -0,0 +1,1204 @@
+/*** Standard fragments ***/
+
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Lines of code -*/
+
+numlines(
+ int element_id: @sourceline ref,
+ int num_lines: int ref,
+ int num_code: int ref,
+ int num_comment: int ref
+);
+
+/*- External data -*/
+
+/**
+ * External data, loaded from CSV files during snapshot creation. See
+ * [Tutorial: Incorporating external data](https://help.semmle.com/wiki/display/SD/Tutorial%3A+Incorporating+external+data)
+ * for more information.
+ */
+externalData(
+ int id : @externalDataElement,
+ string path : string ref,
+ int column: int ref,
+ string value : string ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- JavaScript-specific part -*/
+
+@location = @location_default
+
+@sourceline = @locatable;
+
+filetype(
+ int file: @file ref,
+ string filetype: string ref
+)
+
+// top-level code fragments
+toplevels (unique int id: @toplevel,
+ int kind: int ref);
+
+is_externs (int toplevel: @toplevel ref);
+
+case @toplevel.kind of
+ 0 = @script
+| 1 = @inline_script
+| 2 = @event_handler
+| 3 = @javascript_url
+| 4 = @template_toplevel;
+
+is_module (int tl: @toplevel ref);
+is_nodejs (int tl: @toplevel ref);
+is_es2015_module (int tl: @toplevel ref);
+is_closure_module (int tl: @toplevel ref);
+
+@xml_node_with_code = @xmlelement | @xmlattribute | @template_placeholder_tag;
+toplevel_parent_xml_node(
+ unique int toplevel: @toplevel ref,
+ int xmlnode: @xml_node_with_code ref);
+
+xml_element_parent_expression(
+ unique int xmlnode: @xmlelement ref,
+ int expression: @expr ref,
+ int index: int ref);
+
+// statements
+#keyset[parent, idx]
+stmts (unique int id: @stmt,
+ int kind: int ref,
+ int parent: @stmt_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+stmt_containers (unique int stmt: @stmt ref,
+ int container: @stmt_container ref);
+
+jump_targets (unique int jump: @stmt ref,
+ int target: @stmt ref);
+
+@stmt_parent = @stmt | @toplevel | @function_expr | @arrow_function_expr | @static_initializer;
+@stmt_container = @toplevel | @function | @namespace_declaration | @external_module_declaration | @global_augmentation_declaration;
+
+case @stmt.kind of
+ 0 = @empty_stmt
+| 1 = @block_stmt
+| 2 = @expr_stmt
+| 3 = @if_stmt
+| 4 = @labeled_stmt
+| 5 = @break_stmt
+| 6 = @continue_stmt
+| 7 = @with_stmt
+| 8 = @switch_stmt
+| 9 = @return_stmt
+| 10 = @throw_stmt
+| 11 = @try_stmt
+| 12 = @while_stmt
+| 13 = @do_while_stmt
+| 14 = @for_stmt
+| 15 = @for_in_stmt
+| 16 = @debugger_stmt
+| 17 = @function_decl_stmt
+| 18 = @var_decl_stmt
+| 19 = @case
+| 20 = @catch_clause
+| 21 = @for_of_stmt
+| 22 = @const_decl_stmt
+| 23 = @let_stmt
+| 24 = @legacy_let_stmt
+| 25 = @for_each_stmt
+| 26 = @class_decl_stmt
+| 27 = @import_declaration
+| 28 = @export_all_declaration
+| 29 = @export_default_declaration
+| 30 = @export_named_declaration
+| 31 = @namespace_declaration
+| 32 = @import_equals_declaration
+| 33 = @export_assign_declaration
+| 34 = @interface_declaration
+| 35 = @type_alias_declaration
+| 36 = @enum_declaration
+| 37 = @external_module_declaration
+| 38 = @export_as_namespace_declaration
+| 39 = @global_augmentation_declaration
+| 40 = @using_decl_stmt
+;
+
+@decl_stmt = @var_decl_stmt | @const_decl_stmt | @let_stmt | @legacy_let_stmt | @using_decl_stmt;
+
+@export_declaration = @export_all_declaration | @export_default_declaration | @export_named_declaration;
+
+@namespace_definition = @namespace_declaration | @enum_declaration;
+@type_definition = @class_definition | @interface_declaration | @enum_declaration | @type_alias_declaration | @enum_member;
+
+is_instantiated(unique int decl: @namespace_declaration ref);
+
+@declarable_node = @decl_stmt | @namespace_declaration | @class_decl_stmt | @function_decl_stmt | @enum_declaration | @external_module_declaration | @global_augmentation_declaration | @field;
+has_declare_keyword(unique int stmt: @declarable_node ref);
+
+is_for_await_of(unique int forof: @for_of_stmt ref);
+
+// expressions
+#keyset[parent, idx]
+exprs (unique int id: @expr,
+ int kind: int ref,
+ int parent: @expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @expr_or_type ref);
+
+enclosing_stmt (unique int expr: @expr_or_type ref,
+ int stmt: @stmt ref);
+
+expr_containers (unique int expr: @expr_or_type ref,
+ int container: @stmt_container ref);
+
+array_size (unique int ae: @arraylike ref,
+ int sz: int ref);
+
+is_delegating (int yield: @yield_expr ref);
+
+@expr_or_stmt = @expr | @stmt;
+@expr_or_type = @expr | @typeexpr;
+@expr_parent = @expr_or_stmt | @property | @function_typeexpr;
+@arraylike = @array_expr | @array_pattern;
+@type_annotation = @typeexpr | @jsdoc_type_expr;
+@node_in_stmt_container = @cfg_node | @type_annotation | @toplevel;
+
+case @expr.kind of
+ 0 = @label
+| 1 = @null_literal
+| 2 = @boolean_literal
+| 3 = @number_literal
+| 4 = @string_literal
+| 5 = @regexp_literal
+| 6 = @this_expr
+| 7 = @array_expr
+| 8 = @obj_expr
+| 9 = @function_expr
+| 10 = @seq_expr
+| 11 = @conditional_expr
+| 12 = @new_expr
+| 13 = @call_expr
+| 14 = @dot_expr
+| 15 = @index_expr
+| 16 = @neg_expr
+| 17 = @plus_expr
+| 18 = @log_not_expr
+| 19 = @bit_not_expr
+| 20 = @typeof_expr
+| 21 = @void_expr
+| 22 = @delete_expr
+| 23 = @eq_expr
+| 24 = @neq_expr
+| 25 = @eqq_expr
+| 26 = @neqq_expr
+| 27 = @lt_expr
+| 28 = @le_expr
+| 29 = @gt_expr
+| 30 = @ge_expr
+| 31 = @lshift_expr
+| 32 = @rshift_expr
+| 33 = @urshift_expr
+| 34 = @add_expr
+| 35 = @sub_expr
+| 36 = @mul_expr
+| 37 = @div_expr
+| 38 = @mod_expr
+| 39 = @bitor_expr
+| 40 = @xor_expr
+| 41 = @bitand_expr
+| 42 = @in_expr
+| 43 = @instanceof_expr
+| 44 = @logand_expr
+| 45 = @logor_expr
+| 47 = @assign_expr
+| 48 = @assign_add_expr
+| 49 = @assign_sub_expr
+| 50 = @assign_mul_expr
+| 51 = @assign_div_expr
+| 52 = @assign_mod_expr
+| 53 = @assign_lshift_expr
+| 54 = @assign_rshift_expr
+| 55 = @assign_urshift_expr
+| 56 = @assign_or_expr
+| 57 = @assign_xor_expr
+| 58 = @assign_and_expr
+| 59 = @preinc_expr
+| 60 = @postinc_expr
+| 61 = @predec_expr
+| 62 = @postdec_expr
+| 63 = @par_expr
+| 64 = @var_declarator
+| 65 = @arrow_function_expr
+| 66 = @spread_element
+| 67 = @array_pattern
+| 68 = @object_pattern
+| 69 = @yield_expr
+| 70 = @tagged_template_expr
+| 71 = @template_literal
+| 72 = @template_element
+| 73 = @array_comprehension_expr
+| 74 = @generator_expr
+| 75 = @for_in_comprehension_block
+| 76 = @for_of_comprehension_block
+| 77 = @legacy_letexpr
+| 78 = @var_decl
+| 79 = @proper_varaccess
+| 80 = @class_expr
+| 81 = @super_expr
+| 82 = @newtarget_expr
+| 83 = @named_import_specifier
+| 84 = @import_default_specifier
+| 85 = @import_namespace_specifier
+| 86 = @named_export_specifier
+| 87 = @exp_expr
+| 88 = @assign_exp_expr
+| 89 = @jsx_element
+| 90 = @jsx_qualified_name
+| 91 = @jsx_empty_expr
+| 92 = @await_expr
+| 93 = @function_sent_expr
+| 94 = @decorator
+| 95 = @export_default_specifier
+| 96 = @export_namespace_specifier
+| 97 = @bind_expr
+| 98 = @external_module_reference
+| 99 = @dynamic_import
+| 100 = @expression_with_type_arguments
+| 101 = @prefix_type_assertion
+| 102 = @as_type_assertion
+| 103 = @export_varaccess
+| 104 = @decorator_list
+| 105 = @non_null_assertion
+| 106 = @bigint_literal
+| 107 = @nullishcoalescing_expr
+| 108 = @e4x_xml_anyname
+| 109 = @e4x_xml_static_attribute_selector
+| 110 = @e4x_xml_dynamic_attribute_selector
+| 111 = @e4x_xml_filter_expression
+| 112 = @e4x_xml_static_qualident
+| 113 = @e4x_xml_dynamic_qualident
+| 114 = @e4x_xml_dotdotexpr
+| 115 = @import_meta_expr
+| 116 = @assignlogandexpr
+| 117 = @assignlogorexpr
+| 118 = @assignnullishcoalescingexpr
+| 119 = @template_pipe_ref
+| 120 = @generated_code_expr
+| 121 = @satisfies_expr
+;
+
+@varaccess = @proper_varaccess | @export_varaccess;
+@varref = @var_decl | @varaccess;
+
+@identifier = @label | @varref | @type_identifier;
+
+@literal = @null_literal | @boolean_literal | @number_literal | @string_literal | @regexp_literal | @bigint_literal;
+
+@propaccess = @dot_expr | @index_expr;
+
+@invokeexpr = @new_expr | @call_expr;
+
+@unaryexpr = @neg_expr | @plus_expr | @log_not_expr | @bit_not_expr | @typeof_expr | @void_expr | @delete_expr | @spread_element;
+
+@equality_test = @eq_expr | @neq_expr | @eqq_expr | @neqq_expr;
+
+@comparison = @equality_test | @lt_expr | @le_expr | @gt_expr | @ge_expr;
+
+@binaryexpr = @comparison | @lshift_expr | @rshift_expr | @urshift_expr | @add_expr | @sub_expr | @mul_expr | @div_expr | @mod_expr | @exp_expr | @bitor_expr | @xor_expr | @bitand_expr | @in_expr | @instanceof_expr | @logand_expr | @logor_expr | @nullishcoalescing_expr;
+
+@assignment = @assign_expr | @assign_add_expr | @assign_sub_expr | @assign_mul_expr | @assign_div_expr | @assign_mod_expr | @assign_exp_expr | @assign_lshift_expr | @assign_rshift_expr | @assign_urshift_expr | @assign_or_expr | @assign_xor_expr | @assign_and_expr | @assignlogandexpr | @assignlogorexpr | @assignnullishcoalescingexpr;
+
+@updateexpr = @preinc_expr | @postinc_expr | @predec_expr | @postdec_expr;
+
+@pattern = @varref | @array_pattern | @object_pattern;
+
+@comprehension_expr = @array_comprehension_expr | @generator_expr;
+
+@comprehension_block = @for_in_comprehension_block | @for_of_comprehension_block;
+
+@import_specifier = @named_import_specifier | @import_default_specifier | @import_namespace_specifier;
+
+@exportspecifier = @named_export_specifier | @export_default_specifier | @export_namespace_specifier;
+
+@type_keyword_operand = @import_declaration | @export_declaration | @import_specifier;
+
+@type_assertion = @as_type_assertion | @prefix_type_assertion;
+
+@class_definition = @class_decl_stmt | @class_expr;
+@interface_definition = @interface_declaration | @interface_typeexpr;
+@class_or_interface = @class_definition | @interface_definition;
+
+@lexical_decl = @var_decl | @type_decl;
+@lexical_access = @varaccess | @local_type_access | @local_var_type_access | @local_namespace_access;
+@lexical_ref = @lexical_decl | @lexical_access;
+
+@e4x_xml_attribute_selector = @e4x_xml_static_attribute_selector | @e4x_xml_dynamic_attribute_selector;
+@e4x_xml_qualident = @e4x_xml_static_qualident | @e4x_xml_dynamic_qualident;
+
+expr_contains_template_tag_location(
+ int expr: @expr ref,
+ int location: @location ref
+);
+
+@template_placeholder_tag_parent = @xmlelement | @xmlattribute | @file;
+
+template_placeholder_tag_info(
+ unique int node: @template_placeholder_tag,
+ int parentNode: @template_placeholder_tag_parent ref,
+ varchar(900) raw: string ref
+);
+
+// scopes
+scopes (unique int id: @scope,
+ int kind: int ref);
+
+case @scope.kind of
+ 0 = @global_scope
+| 1 = @function_scope
+| 2 = @catch_scope
+| 3 = @module_scope
+| 4 = @block_scope
+| 5 = @for_scope
+| 6 = @for_in_scope // for-of scopes work the same as for-in scopes
+| 7 = @comprehension_block_scope
+| 8 = @class_expr_scope
+| 9 = @namespace_scope
+| 10 = @class_decl_scope
+| 11 = @interface_scope
+| 12 = @type_alias_scope
+| 13 = @mapped_type_scope
+| 14 = @enum_scope
+| 15 = @external_module_scope
+| 16 = @conditional_type_scope;
+
+scopenodes (unique int node: @ast_node ref,
+ int scope: @scope ref);
+
+scopenesting (unique int inner: @scope ref,
+ int outer: @scope ref);
+
+// functions
+@function = @function_decl_stmt | @function_expr | @arrow_function_expr;
+
+@parameterized = @function | @catch_clause;
+@type_parameterized = @function | @class_or_interface | @type_alias_declaration | @mapped_typeexpr | @infer_typeexpr;
+
+is_generator (int fun: @function ref);
+has_rest_parameter (int fun: @function ref);
+is_async (int fun: @function ref);
+
+// variables and lexically scoped type names
+#keyset[scope, name]
+variables (unique int id: @variable,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_type_names (unique int id: @local_type_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_namespace_names (unique int id: @local_namespace_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+is_arguments_object (int id: @variable ref);
+
+@lexical_name = @variable | @local_type_name | @local_namespace_name;
+
+@bind_id = @varaccess | @local_var_type_access;
+bind (unique int id: @bind_id ref,
+ int decl: @variable ref);
+
+decl (unique int id: @var_decl ref,
+ int decl: @variable ref);
+
+@typebind_id = @local_type_access | @export_varaccess;
+typebind (unique int id: @typebind_id ref,
+ int decl: @local_type_name ref);
+
+@typedecl_id = @type_decl | @var_decl;
+typedecl (unique int id: @typedecl_id ref,
+ int decl: @local_type_name ref);
+
+namespacedecl (unique int id: @var_decl ref,
+ int decl: @local_namespace_name ref);
+
+@namespacebind_id = @local_namespace_access | @export_varaccess;
+namespacebind (unique int id: @namespacebind_id ref,
+ int decl: @local_namespace_name ref);
+
+
+// properties in object literals, property patterns in object patterns, and method declarations in classes
+#keyset[parent, index]
+properties (unique int id: @property,
+ int parent: @property_parent ref,
+ int index: int ref,
+ int kind: int ref,
+ varchar(900) tostring: string ref);
+
+case @property.kind of
+ 0 = @value_property
+| 1 = @property_getter
+| 2 = @property_setter
+| 3 = @jsx_attribute
+| 4 = @function_call_signature
+| 5 = @constructor_call_signature
+| 6 = @index_signature
+| 7 = @enum_member
+| 8 = @proper_field
+| 9 = @parameter_field
+| 10 = @static_initializer
+;
+
+@property_parent = @obj_expr | @object_pattern | @class_definition | @jsx_element | @interface_definition | @enum_declaration;
+@property_accessor = @property_getter | @property_setter;
+@call_signature = @function_call_signature | @constructor_call_signature;
+@field = @proper_field | @parameter_field;
+@field_or_vardeclarator = @field | @var_declarator;
+
+is_computed (int id: @property ref);
+is_method (int id: @property ref);
+is_static (int id: @property ref);
+is_abstract_member (int id: @property ref);
+is_const_enum (int id: @enum_declaration ref);
+is_abstract_class (int id: @class_decl_stmt ref);
+
+has_public_keyword (int id: @property ref);
+has_private_keyword (int id: @property ref);
+has_protected_keyword (int id: @property ref);
+has_readonly_keyword (int id: @property ref);
+has_type_keyword (int id: @type_keyword_operand ref);
+is_optional_member (int id: @property ref);
+has_definite_assignment_assertion (int id: @field_or_vardeclarator ref);
+is_optional_parameter_declaration (unique int parameter: @pattern ref);
+
+#keyset[constructor, param_index]
+parameter_fields(
+ unique int field: @parameter_field ref,
+ int constructor: @function_expr ref,
+ int param_index: int ref
+);
+
+// types
+#keyset[parent, idx]
+typeexprs (
+ unique int id: @typeexpr,
+ int kind: int ref,
+ int parent: @typeexpr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref
+);
+
+case @typeexpr.kind of
+ 0 = @local_type_access
+| 1 = @type_decl
+| 2 = @keyword_typeexpr
+| 3 = @string_literal_typeexpr
+| 4 = @number_literal_typeexpr
+| 5 = @boolean_literal_typeexpr
+| 6 = @array_typeexpr
+| 7 = @union_typeexpr
+| 8 = @indexed_access_typeexpr
+| 9 = @intersection_typeexpr
+| 10 = @parenthesized_typeexpr
+| 11 = @tuple_typeexpr
+| 12 = @keyof_typeexpr
+| 13 = @qualified_type_access
+| 14 = @generic_typeexpr
+| 15 = @type_label
+| 16 = @typeof_typeexpr
+| 17 = @local_var_type_access
+| 18 = @qualified_var_type_access
+| 19 = @this_var_type_access
+| 20 = @predicate_typeexpr
+| 21 = @interface_typeexpr
+| 22 = @type_parameter
+| 23 = @plain_function_typeexpr
+| 24 = @constructor_typeexpr
+| 25 = @local_namespace_access
+| 26 = @qualified_namespace_access
+| 27 = @mapped_typeexpr
+| 28 = @conditional_typeexpr
+| 29 = @infer_typeexpr
+| 30 = @import_type_access
+| 31 = @import_namespace_access
+| 32 = @import_var_type_access
+| 33 = @optional_typeexpr
+| 34 = @rest_typeexpr
+| 35 = @bigint_literal_typeexpr
+| 36 = @readonly_typeexpr
+| 37 = @template_literal_typeexpr
+;
+
+@typeref = @typeaccess | @type_decl;
+@type_identifier = @type_decl | @local_type_access | @type_label | @local_var_type_access | @local_namespace_access;
+@typeexpr_parent = @expr | @stmt | @property | @typeexpr;
+@literal_typeexpr = @string_literal_typeexpr | @number_literal_typeexpr | @boolean_literal_typeexpr | @bigint_literal_typeexpr;
+@typeaccess = @local_type_access | @qualified_type_access | @import_type_access;
+@vartypeaccess = @local_var_type_access | @qualified_var_type_access | @this_var_type_access | @import_var_type_access;
+@namespace_access = @local_namespace_access | @qualified_namespace_access | @import_namespace_access;
+@import_typeexpr = @import_type_access | @import_namespace_access | @import_var_type_access;
+
+@function_typeexpr = @plain_function_typeexpr | @constructor_typeexpr;
+
+// types
+types (
+ unique int id: @type,
+ int kind: int ref,
+ varchar(900) tostring: string ref
+);
+
+#keyset[parent, idx]
+type_child (
+ int child: @type ref,
+ int parent: @type ref,
+ int idx: int ref
+);
+
+case @type.kind of
+ 0 = @any_type
+| 1 = @string_type
+| 2 = @number_type
+| 3 = @union_type
+| 4 = @true_type
+| 5 = @false_type
+| 6 = @type_reference
+| 7 = @object_type
+| 8 = @canonical_type_variable_type
+| 9 = @typeof_type
+| 10 = @void_type
+| 11 = @undefined_type
+| 12 = @null_type
+| 13 = @never_type
+| 14 = @plain_symbol_type
+| 15 = @unique_symbol_type
+| 16 = @objectkeyword_type
+| 17 = @intersection_type
+| 18 = @tuple_type
+| 19 = @lexical_type_variable_type
+| 20 = @this_type
+| 21 = @number_literal_type
+| 22 = @string_literal_type
+| 23 = @unknown_type
+| 24 = @bigint_type
+| 25 = @bigint_literal_type
+;
+
+@boolean_literal_type = @true_type | @false_type;
+@symbol_type = @plain_symbol_type | @unique_symbol_type;
+@union_or_intersection_type = @union_type | @intersection_type;
+@typevariable_type = @canonical_type_variable_type | @lexical_type_variable_type;
+
+has_asserts_keyword(int node: @predicate_typeexpr ref);
+
+@typed_ast_node = @expr | @typeexpr | @function;
+ast_node_type(
+ unique int node: @typed_ast_node ref,
+ int typ: @type ref);
+
+declared_function_signature(
+ unique int node: @function ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_signature(
+ unique int node: @invokeexpr ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_overload_index(
+ unique int node: @invokeexpr ref,
+ int index: int ref
+);
+
+symbols (
+ unique int id: @symbol,
+ int kind: int ref,
+ varchar(900) name: string ref
+);
+
+symbol_parent (
+ unique int symbol: @symbol ref,
+ int parent: @symbol ref
+);
+
+symbol_module (
+ int symbol: @symbol ref,
+ varchar(900) moduleName: string ref
+);
+
+symbol_global (
+ int symbol: @symbol ref,
+ varchar(900) globalName: string ref
+);
+
+case @symbol.kind of
+ 0 = @root_symbol
+| 1 = @member_symbol
+| 2 = @other_symbol
+;
+
+@type_with_symbol = @type_reference | @typevariable_type | @typeof_type | @unique_symbol_type;
+@ast_node_with_symbol = @type_definition | @namespace_definition | @toplevel | @typeaccess | @namespace_access | @var_decl | @function | @invokeexpr | @import_declaration | @external_module_reference | @external_module_declaration;
+
+ast_node_symbol(
+ unique int node: @ast_node_with_symbol ref,
+ int symbol: @symbol ref);
+
+type_symbol(
+ unique int typ: @type_with_symbol ref,
+ int symbol: @symbol ref);
+
+#keyset[typ, name]
+type_property(
+ int typ: @type ref,
+ varchar(900) name: string ref,
+ int propertyType: @type ref);
+
+type_alias(
+ unique int aliasType: @type ref,
+ int underlyingType: @type ref);
+
+@literal_type = @string_literal_type | @number_literal_type | @boolean_literal_type | @bigint_literal_type;
+@type_with_literal_value = @string_literal_type | @number_literal_type | @bigint_literal_type;
+type_literal_value(
+ unique int typ: @type_with_literal_value ref,
+ varchar(900) value: string ref);
+
+signature_types (
+ unique int id: @signature_type,
+ int kind: int ref,
+ varchar(900) tostring: string ref,
+ int type_parameters: int ref,
+ int required_params: int ref
+);
+
+is_abstract_signature(
+ unique int sig: @signature_type ref
+);
+
+signature_rest_parameter(
+ unique int sig: @signature_type ref,
+ int rest_param_arra_type: @type ref
+);
+
+case @signature_type.kind of
+ 0 = @function_signature_type
+| 1 = @constructor_signature_type
+;
+
+#keyset[typ, kind, index]
+type_contains_signature (
+ int typ: @type ref,
+ int kind: int ref, // constructor/call/index
+ int index: int ref, // ordering of overloaded signatures
+ int sig: @signature_type ref
+);
+
+#keyset[parent, index]
+signature_contains_type (
+ int child: @type ref,
+ int parent: @signature_type ref,
+ int index: int ref
+);
+
+#keyset[sig, index]
+signature_parameter_name (
+ int sig: @signature_type ref,
+ int index: int ref,
+ varchar(900) name: string ref
+);
+
+number_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+string_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+base_type_names(
+ int typeName: @symbol ref,
+ int baseTypeName: @symbol ref
+);
+
+self_types(
+ int typeName: @symbol ref,
+ int selfType: @type_reference ref
+);
+
+tuple_type_min_length(
+ unique int typ: @type ref,
+ int minLength: int ref
+);
+
+tuple_type_rest_index(
+ unique int typ: @type ref,
+ int index: int ref
+);
+
+// comments
+comments (unique int id: @comment,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(900) tostring: string ref);
+
+case @comment.kind of
+ 0 = @slashslash_comment
+| 1 = @slashstar_comment
+| 2 = @doc_comment
+| 3 = @html_comment_start
+| 4 = @htmlcommentend;
+
+@html_comment = @html_comment_start | @htmlcommentend;
+@line_comment = @slashslash_comment | @html_comment;
+@block_comment = @slashstar_comment | @doc_comment;
+
+// source lines
+lines (unique int id: @line,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(2) terminator: string ref);
+indentation (int file: @file ref,
+ int lineno: int ref,
+ varchar(1) indentChar: string ref,
+ int indentDepth: int ref);
+
+// JavaScript parse errors
+js_parse_errors (unique int id: @js_parse_error,
+ int toplevel: @toplevel ref,
+ varchar(900) message: string ref,
+ varchar(900) line: string ref);
+
+// regular expressions
+#keyset[parent, idx]
+regexpterm (unique int id: @regexpterm,
+ int kind: int ref,
+ int parent: @regexpparent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+@regexpparent = @regexpterm | @regexp_literal | @string_literal | @add_expr;
+
+case @regexpterm.kind of
+ 0 = @regexp_alt
+| 1 = @regexp_seq
+| 2 = @regexp_caret
+| 3 = @regexp_dollar
+| 4 = @regexp_wordboundary
+| 5 = @regexp_nonwordboundary
+| 6 = @regexp_positive_lookahead
+| 7 = @regexp_negative_lookahead
+| 8 = @regexp_star
+| 9 = @regexp_plus
+| 10 = @regexp_opt
+| 11 = @regexp_range
+| 12 = @regexp_dot
+| 13 = @regexp_group
+| 14 = @regexp_normal_constant
+| 15 = @regexp_hex_escape
+| 16 = @regexp_unicode_escape
+| 17 = @regexp_dec_escape
+| 18 = @regexp_oct_escape
+| 19 = @regexp_ctrl_escape
+| 20 = @regexp_char_class_escape
+| 21 = @regexp_id_escape
+| 22 = @regexp_backref
+| 23 = @regexp_char_class
+| 24 = @regexp_char_range
+| 25 = @regexp_positive_lookbehind
+| 26 = @regexp_negative_lookbehind
+| 27 = @regexp_unicode_property_escape
+| 28 = @regexp_quoted_string
+| 29 = @regexp_intersection
+| 30 = @regexp_subtraction;
+
+regexp_parse_errors (unique int id: @regexp_parse_error,
+ int regexp: @regexpterm ref,
+ varchar(900) message: string ref);
+
+@regexp_quantifier = @regexp_star | @regexp_plus | @regexp_opt | @regexp_range;
+@regexp_escape = @regexp_char_escape | @regexp_char_class_escape | @regexp_unicode_property_escape;
+@regexp_char_escape = @regexp_hex_escape | @regexp_unicode_escape | @regexp_dec_escape | @regexp_oct_escape | @regexp_ctrl_escape | @regexp_id_escape;
+@regexp_constant = @regexp_normal_constant | @regexp_char_escape;
+@regexp_lookahead = @regexp_positive_lookahead | @regexp_negative_lookahead;
+@regexp_lookbehind = @regexp_positive_lookbehind | @regexp_negative_lookbehind;
+@regexp_subpattern = @regexp_lookahead | @regexp_lookbehind;
+@regexp_anchor = @regexp_dollar | @regexp_caret;
+
+is_greedy (int id: @regexp_quantifier ref);
+range_quantifier_lower_bound (unique int id: @regexp_range ref, int lo: int ref);
+range_quantifier_upper_bound (unique int id: @regexp_range ref, int hi: int ref);
+is_capture (unique int id: @regexp_group ref, int number: int ref);
+is_named_capture (unique int id: @regexp_group ref, string name: string ref);
+is_inverted (int id: @regexp_char_class ref);
+regexp_const_value (unique int id: @regexp_constant ref, varchar(1) value: string ref);
+char_class_escape (unique int id: @regexp_char_class_escape ref, varchar(1) value: string ref);
+backref (unique int id: @regexp_backref ref, int value: int ref);
+named_backref (unique int id: @regexp_backref ref, string name: string ref);
+unicode_property_escapename (unique int id: @regexp_unicode_property_escape ref, string name: string ref);
+unicode_property_escapevalue (unique int id: @regexp_unicode_property_escape ref, string value: string ref);
+
+// tokens
+#keyset[toplevel, idx]
+tokeninfo (unique int id: @token,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ int idx: int ref,
+ varchar(900) value: string ref);
+
+case @token.kind of
+ 0 = @token_eof
+| 1 = @token_null_literal
+| 2 = @token_boolean_literal
+| 3 = @token_numeric_literal
+| 4 = @token_string_literal
+| 5 = @token_regular_expression
+| 6 = @token_identifier
+| 7 = @token_keyword
+| 8 = @token_punctuator;
+
+// associate comments with the token immediately following them (which may be EOF)
+next_token (int comment: @comment ref, int token: @token ref);
+
+// JSON
+#keyset[parent, idx]
+json (unique int id: @json_value,
+ int kind: int ref,
+ int parent: @json_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+json_literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @json_value ref);
+
+json_properties (int obj: @json_object ref,
+ varchar(900) property: string ref,
+ int value: @json_value ref);
+
+json_errors (unique int id: @json_parse_error,
+ varchar(900) message: string ref);
+
+json_locations(unique int locatable: @json_locatable ref,
+ int location: @location_default ref);
+
+case @json_value.kind of
+ 0 = @json_null
+| 1 = @json_boolean
+| 2 = @json_number
+| 3 = @json_string
+| 4 = @json_array
+| 5 = @json_object;
+
+@json_parent = @json_object | @json_array | @file;
+
+@json_locatable = @json_value | @json_parse_error;
+
+// locations
+@ast_node = @toplevel | @stmt | @expr | @property | @typeexpr;
+
+@locatable = @file
+ | @ast_node
+ | @comment
+ | @line
+ | @js_parse_error | @regexp_parse_error
+ | @regexpterm
+ | @json_locatable
+ | @token
+ | @cfg_node
+ | @jsdoc | @jsdoc_type_expr | @jsdoc_tag
+ | @yaml_locatable
+ | @xmllocatable
+ | @configLocatable
+ | @template_placeholder_tag;
+
+hasLocation (unique int locatable: @locatable ref,
+ int location: @location ref);
+
+// CFG
+entry_cfg_node (unique int id: @entry_node, int container: @stmt_container ref);
+exit_cfg_node (unique int id: @exit_node, int container: @stmt_container ref);
+guard_node (unique int id: @guard_node, int kind: int ref, int test: @expr ref);
+case @guard_node.kind of
+ 0 = @falsy_guard
+| 1 = @truthy_guard;
+@condition_guard = @falsy_guard | @truthy_guard;
+
+@synthetic_cfg_node = @entry_node | @exit_node | @guard_node;
+@cfg_node = @synthetic_cfg_node | @expr_parent;
+
+successor (int pred: @cfg_node ref, int succ: @cfg_node ref);
+
+// JSDoc comments
+jsdoc (unique int id: @jsdoc, varchar(900) description: string ref, int comment: @comment ref);
+#keyset[parent, idx]
+jsdoc_tags (unique int id: @jsdoc_tag, varchar(900) title: string ref,
+ int parent: @jsdoc ref, int idx: int ref, varchar(900) tostring: string ref);
+jsdoc_tag_descriptions (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+jsdoc_tag_names (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+
+#keyset[parent, idx]
+jsdoc_type_exprs (unique int id: @jsdoc_type_expr,
+ int kind: int ref,
+ int parent: @jsdoc_type_expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+case @jsdoc_type_expr.kind of
+ 0 = @jsdoc_any_type_expr
+| 1 = @jsdoc_null_type_expr
+| 2 = @jsdoc_undefined_type_expr
+| 3 = @jsdoc_unknown_type_expr
+| 4 = @jsdoc_void_type_expr
+| 5 = @jsdoc_identifier_type_expr
+| 6 = @jsdoc_applied_type_expr
+| 7 = @jsdoc_nullable_type_expr
+| 8 = @jsdoc_non_nullable_type_expr
+| 9 = @jsdoc_record_type_expr
+| 10 = @jsdoc_array_type_expr
+| 11 = @jsdoc_union_type_expr
+| 12 = @jsdoc_function_type_expr
+| 13 = @jsdoc_optional_type_expr
+| 14 = @jsdoc_rest_type_expr
+| 15 = @jsdoc_qualified_type_expr
+;
+
+#keyset[id, idx]
+jsdoc_record_field_name (int id: @jsdoc_record_type_expr ref, int idx: int ref, varchar(900) name: string ref);
+jsdoc_prefix_qualifier (int id: @jsdoc_type_expr ref);
+jsdoc_has_new_parameter (int fn: @jsdoc_function_type_expr ref);
+
+@jsdoc_type_expr_parent = @jsdoc_type_expr | @jsdoc_tag;
+
+jsdoc_errors (unique int id: @jsdoc_error, int tag: @jsdoc_tag ref, varchar(900) message: string ref, varchar(900) tostring: string ref);
+
+@dataflownode = @expr | @function_decl_stmt | @class_decl_stmt | @namespace_declaration | @enum_declaration | @property;
+
+@optionalchainable = @call_expr | @propaccess;
+
+isOptionalChaining(int id: @optionalchainable ref);
+
+/**
+ * The time taken for the extraction of a file.
+ * This table contains non-deterministic content.
+ *
+ * The sum of the `time` column for each (`file`, `timerKind`) pair
+ * is the total time taken for extraction of `file`. The `extractionPhase`
+ * column provides a granular view of the extraction time of the file.
+ */
+extraction_time(
+ int file : @file ref,
+ // see `com.semmle.js.extractor.ExtractionMetrics.ExtractionPhase`.
+ int extractionPhase: int ref,
+ // 0 for the elapsed CPU time in nanoseconds, 1 for the elapsed wallclock time in nanoseconds
+ int timerKind: int ref,
+ float time: float ref
+)
+
+/**
+* Non-timing related data for the extraction of a single file.
+* This table contains non-deterministic content.
+*/
+extraction_data(
+ int file : @file ref,
+ // the absolute path to the cache file
+ varchar(900) cacheFile: string ref,
+ boolean fromCache: boolean ref,
+ int length: int ref
+)
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- XML Files -*/
+
+xmlEncoding(
+ unique int id: @file ref,
+ string encoding: string ref
+);
+
+xmlDTDs(
+ unique int id: @xmldtd,
+ string root: string ref,
+ string publicId: string ref,
+ string systemId: string ref,
+ int fileid: @file ref
+);
+
+xmlElements(
+ unique int id: @xmlelement,
+ string name: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlAttrs(
+ unique int id: @xmlattribute,
+ int elementid: @xmlelement ref,
+ string name: string ref,
+ string value: string ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlNs(
+ int id: @xmlnamespace,
+ string prefixName: string ref,
+ string URI: string ref,
+ int fileid: @file ref
+);
+
+xmlHasNs(
+ int elementId: @xmlnamespaceable ref,
+ int nsId: @xmlnamespace ref,
+ int fileid: @file ref
+);
+
+xmlComments(
+ unique int id: @xmlcomment,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int fileid: @file ref
+);
+
+xmlChars(
+ unique int id: @xmlcharacters,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int isCDATA: int ref,
+ int fileid: @file ref
+);
+
+@xmlparent = @file | @xmlelement;
+@xmlnamespaceable = @xmlelement | @xmlattribute;
+
+xmllocations(
+ int xmlElement: @xmllocatable ref,
+ int location: @location_default ref
+);
+
+@xmllocatable = @xmlcharacters | @xmlelement | @xmlcomment | @xmlattribute | @xmldtd | @file | @xmlnamespace;
+
+/*- Configuration files with key value pairs -*/
+
+configs(
+ unique int id: @config
+);
+
+configNames(
+ unique int id: @configName,
+ int config: @config ref,
+ string name: string ref
+);
+
+configValues(
+ unique int id: @configValue,
+ int config: @config ref,
+ string value: string ref
+);
+
+configLocations(
+ int locatable: @configLocatable ref,
+ int location: @location_default ref
+);
+
+@configLocatable = @config | @configName | @configValue;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
+
+overlayChangedFiles(
+ string path: string ref
+);
diff --git a/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/semmlecode.javascript.dbscheme b/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/semmlecode.javascript.dbscheme
new file mode 100644
index 00000000000..ccefb5e2d49
--- /dev/null
+++ b/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/semmlecode.javascript.dbscheme
@@ -0,0 +1,1194 @@
+/*** Standard fragments ***/
+
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Lines of code -*/
+
+numlines(
+ int element_id: @sourceline ref,
+ int num_lines: int ref,
+ int num_code: int ref,
+ int num_comment: int ref
+);
+
+/*- External data -*/
+
+/**
+ * External data, loaded from CSV files during snapshot creation. See
+ * [Tutorial: Incorporating external data](https://help.semmle.com/wiki/display/SD/Tutorial%3A+Incorporating+external+data)
+ * for more information.
+ */
+externalData(
+ int id : @externalDataElement,
+ string path : string ref,
+ int column: int ref,
+ string value : string ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- JavaScript-specific part -*/
+
+@location = @location_default
+
+@sourceline = @locatable;
+
+filetype(
+ int file: @file ref,
+ string filetype: string ref
+)
+
+// top-level code fragments
+toplevels (unique int id: @toplevel,
+ int kind: int ref);
+
+is_externs (int toplevel: @toplevel ref);
+
+case @toplevel.kind of
+ 0 = @script
+| 1 = @inline_script
+| 2 = @event_handler
+| 3 = @javascript_url
+| 4 = @template_toplevel;
+
+is_module (int tl: @toplevel ref);
+is_nodejs (int tl: @toplevel ref);
+is_es2015_module (int tl: @toplevel ref);
+is_closure_module (int tl: @toplevel ref);
+
+@xml_node_with_code = @xmlelement | @xmlattribute | @template_placeholder_tag;
+toplevel_parent_xml_node(
+ unique int toplevel: @toplevel ref,
+ int xmlnode: @xml_node_with_code ref);
+
+xml_element_parent_expression(
+ unique int xmlnode: @xmlelement ref,
+ int expression: @expr ref,
+ int index: int ref);
+
+// statements
+#keyset[parent, idx]
+stmts (unique int id: @stmt,
+ int kind: int ref,
+ int parent: @stmt_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+stmt_containers (unique int stmt: @stmt ref,
+ int container: @stmt_container ref);
+
+jump_targets (unique int jump: @stmt ref,
+ int target: @stmt ref);
+
+@stmt_parent = @stmt | @toplevel | @function_expr | @arrow_function_expr | @static_initializer;
+@stmt_container = @toplevel | @function | @namespace_declaration | @external_module_declaration | @global_augmentation_declaration;
+
+case @stmt.kind of
+ 0 = @empty_stmt
+| 1 = @block_stmt
+| 2 = @expr_stmt
+| 3 = @if_stmt
+| 4 = @labeled_stmt
+| 5 = @break_stmt
+| 6 = @continue_stmt
+| 7 = @with_stmt
+| 8 = @switch_stmt
+| 9 = @return_stmt
+| 10 = @throw_stmt
+| 11 = @try_stmt
+| 12 = @while_stmt
+| 13 = @do_while_stmt
+| 14 = @for_stmt
+| 15 = @for_in_stmt
+| 16 = @debugger_stmt
+| 17 = @function_decl_stmt
+| 18 = @var_decl_stmt
+| 19 = @case
+| 20 = @catch_clause
+| 21 = @for_of_stmt
+| 22 = @const_decl_stmt
+| 23 = @let_stmt
+| 24 = @legacy_let_stmt
+| 25 = @for_each_stmt
+| 26 = @class_decl_stmt
+| 27 = @import_declaration
+| 28 = @export_all_declaration
+| 29 = @export_default_declaration
+| 30 = @export_named_declaration
+| 31 = @namespace_declaration
+| 32 = @import_equals_declaration
+| 33 = @export_assign_declaration
+| 34 = @interface_declaration
+| 35 = @type_alias_declaration
+| 36 = @enum_declaration
+| 37 = @external_module_declaration
+| 38 = @export_as_namespace_declaration
+| 39 = @global_augmentation_declaration
+| 40 = @using_decl_stmt
+;
+
+@decl_stmt = @var_decl_stmt | @const_decl_stmt | @let_stmt | @legacy_let_stmt | @using_decl_stmt;
+
+@export_declaration = @export_all_declaration | @export_default_declaration | @export_named_declaration;
+
+@namespace_definition = @namespace_declaration | @enum_declaration;
+@type_definition = @class_definition | @interface_declaration | @enum_declaration | @type_alias_declaration | @enum_member;
+
+is_instantiated(unique int decl: @namespace_declaration ref);
+
+@declarable_node = @decl_stmt | @namespace_declaration | @class_decl_stmt | @function_decl_stmt | @enum_declaration | @external_module_declaration | @global_augmentation_declaration | @field;
+has_declare_keyword(unique int stmt: @declarable_node ref);
+
+is_for_await_of(unique int forof: @for_of_stmt ref);
+
+// expressions
+#keyset[parent, idx]
+exprs (unique int id: @expr,
+ int kind: int ref,
+ int parent: @expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @expr_or_type ref);
+
+enclosing_stmt (unique int expr: @expr_or_type ref,
+ int stmt: @stmt ref);
+
+expr_containers (unique int expr: @expr_or_type ref,
+ int container: @stmt_container ref);
+
+array_size (unique int ae: @arraylike ref,
+ int sz: int ref);
+
+is_delegating (int yield: @yield_expr ref);
+
+@expr_or_stmt = @expr | @stmt;
+@expr_or_type = @expr | @typeexpr;
+@expr_parent = @expr_or_stmt | @property | @function_typeexpr;
+@arraylike = @array_expr | @array_pattern;
+@type_annotation = @typeexpr | @jsdoc_type_expr;
+@node_in_stmt_container = @cfg_node | @type_annotation | @toplevel;
+
+case @expr.kind of
+ 0 = @label
+| 1 = @null_literal
+| 2 = @boolean_literal
+| 3 = @number_literal
+| 4 = @string_literal
+| 5 = @regexp_literal
+| 6 = @this_expr
+| 7 = @array_expr
+| 8 = @obj_expr
+| 9 = @function_expr
+| 10 = @seq_expr
+| 11 = @conditional_expr
+| 12 = @new_expr
+| 13 = @call_expr
+| 14 = @dot_expr
+| 15 = @index_expr
+| 16 = @neg_expr
+| 17 = @plus_expr
+| 18 = @log_not_expr
+| 19 = @bit_not_expr
+| 20 = @typeof_expr
+| 21 = @void_expr
+| 22 = @delete_expr
+| 23 = @eq_expr
+| 24 = @neq_expr
+| 25 = @eqq_expr
+| 26 = @neqq_expr
+| 27 = @lt_expr
+| 28 = @le_expr
+| 29 = @gt_expr
+| 30 = @ge_expr
+| 31 = @lshift_expr
+| 32 = @rshift_expr
+| 33 = @urshift_expr
+| 34 = @add_expr
+| 35 = @sub_expr
+| 36 = @mul_expr
+| 37 = @div_expr
+| 38 = @mod_expr
+| 39 = @bitor_expr
+| 40 = @xor_expr
+| 41 = @bitand_expr
+| 42 = @in_expr
+| 43 = @instanceof_expr
+| 44 = @logand_expr
+| 45 = @logor_expr
+| 47 = @assign_expr
+| 48 = @assign_add_expr
+| 49 = @assign_sub_expr
+| 50 = @assign_mul_expr
+| 51 = @assign_div_expr
+| 52 = @assign_mod_expr
+| 53 = @assign_lshift_expr
+| 54 = @assign_rshift_expr
+| 55 = @assign_urshift_expr
+| 56 = @assign_or_expr
+| 57 = @assign_xor_expr
+| 58 = @assign_and_expr
+| 59 = @preinc_expr
+| 60 = @postinc_expr
+| 61 = @predec_expr
+| 62 = @postdec_expr
+| 63 = @par_expr
+| 64 = @var_declarator
+| 65 = @arrow_function_expr
+| 66 = @spread_element
+| 67 = @array_pattern
+| 68 = @object_pattern
+| 69 = @yield_expr
+| 70 = @tagged_template_expr
+| 71 = @template_literal
+| 72 = @template_element
+| 73 = @array_comprehension_expr
+| 74 = @generator_expr
+| 75 = @for_in_comprehension_block
+| 76 = @for_of_comprehension_block
+| 77 = @legacy_letexpr
+| 78 = @var_decl
+| 79 = @proper_varaccess
+| 80 = @class_expr
+| 81 = @super_expr
+| 82 = @newtarget_expr
+| 83 = @named_import_specifier
+| 84 = @import_default_specifier
+| 85 = @import_namespace_specifier
+| 86 = @named_export_specifier
+| 87 = @exp_expr
+| 88 = @assign_exp_expr
+| 89 = @jsx_element
+| 90 = @jsx_qualified_name
+| 91 = @jsx_empty_expr
+| 92 = @await_expr
+| 93 = @function_sent_expr
+| 94 = @decorator
+| 95 = @export_default_specifier
+| 96 = @export_namespace_specifier
+| 97 = @bind_expr
+| 98 = @external_module_reference
+| 99 = @dynamic_import
+| 100 = @expression_with_type_arguments
+| 101 = @prefix_type_assertion
+| 102 = @as_type_assertion
+| 103 = @export_varaccess
+| 104 = @decorator_list
+| 105 = @non_null_assertion
+| 106 = @bigint_literal
+| 107 = @nullishcoalescing_expr
+| 108 = @e4x_xml_anyname
+| 109 = @e4x_xml_static_attribute_selector
+| 110 = @e4x_xml_dynamic_attribute_selector
+| 111 = @e4x_xml_filter_expression
+| 112 = @e4x_xml_static_qualident
+| 113 = @e4x_xml_dynamic_qualident
+| 114 = @e4x_xml_dotdotexpr
+| 115 = @import_meta_expr
+| 116 = @assignlogandexpr
+| 117 = @assignlogorexpr
+| 118 = @assignnullishcoalescingexpr
+| 119 = @template_pipe_ref
+| 120 = @generated_code_expr
+| 121 = @satisfies_expr
+;
+
+@varaccess = @proper_varaccess | @export_varaccess;
+@varref = @var_decl | @varaccess;
+
+@identifier = @label | @varref | @type_identifier;
+
+@literal = @null_literal | @boolean_literal | @number_literal | @string_literal | @regexp_literal | @bigint_literal;
+
+@propaccess = @dot_expr | @index_expr;
+
+@invokeexpr = @new_expr | @call_expr;
+
+@unaryexpr = @neg_expr | @plus_expr | @log_not_expr | @bit_not_expr | @typeof_expr | @void_expr | @delete_expr | @spread_element;
+
+@equality_test = @eq_expr | @neq_expr | @eqq_expr | @neqq_expr;
+
+@comparison = @equality_test | @lt_expr | @le_expr | @gt_expr | @ge_expr;
+
+@binaryexpr = @comparison | @lshift_expr | @rshift_expr | @urshift_expr | @add_expr | @sub_expr | @mul_expr | @div_expr | @mod_expr | @exp_expr | @bitor_expr | @xor_expr | @bitand_expr | @in_expr | @instanceof_expr | @logand_expr | @logor_expr | @nullishcoalescing_expr;
+
+@assignment = @assign_expr | @assign_add_expr | @assign_sub_expr | @assign_mul_expr | @assign_div_expr | @assign_mod_expr | @assign_exp_expr | @assign_lshift_expr | @assign_rshift_expr | @assign_urshift_expr | @assign_or_expr | @assign_xor_expr | @assign_and_expr | @assignlogandexpr | @assignlogorexpr | @assignnullishcoalescingexpr;
+
+@updateexpr = @preinc_expr | @postinc_expr | @predec_expr | @postdec_expr;
+
+@pattern = @varref | @array_pattern | @object_pattern;
+
+@comprehension_expr = @array_comprehension_expr | @generator_expr;
+
+@comprehension_block = @for_in_comprehension_block | @for_of_comprehension_block;
+
+@import_specifier = @named_import_specifier | @import_default_specifier | @import_namespace_specifier;
+
+@exportspecifier = @named_export_specifier | @export_default_specifier | @export_namespace_specifier;
+
+@type_keyword_operand = @import_declaration | @export_declaration | @import_specifier;
+
+@type_assertion = @as_type_assertion | @prefix_type_assertion;
+
+@class_definition = @class_decl_stmt | @class_expr;
+@interface_definition = @interface_declaration | @interface_typeexpr;
+@class_or_interface = @class_definition | @interface_definition;
+
+@lexical_decl = @var_decl | @type_decl;
+@lexical_access = @varaccess | @local_type_access | @local_var_type_access | @local_namespace_access;
+@lexical_ref = @lexical_decl | @lexical_access;
+
+@e4x_xml_attribute_selector = @e4x_xml_static_attribute_selector | @e4x_xml_dynamic_attribute_selector;
+@e4x_xml_qualident = @e4x_xml_static_qualident | @e4x_xml_dynamic_qualident;
+
+expr_contains_template_tag_location(
+ int expr: @expr ref,
+ int location: @location ref
+);
+
+@template_placeholder_tag_parent = @xmlelement | @xmlattribute | @file;
+
+template_placeholder_tag_info(
+ unique int node: @template_placeholder_tag,
+ int parentNode: @template_placeholder_tag_parent ref,
+ varchar(900) raw: string ref
+);
+
+// scopes
+scopes (unique int id: @scope,
+ int kind: int ref);
+
+case @scope.kind of
+ 0 = @global_scope
+| 1 = @function_scope
+| 2 = @catch_scope
+| 3 = @module_scope
+| 4 = @block_scope
+| 5 = @for_scope
+| 6 = @for_in_scope // for-of scopes work the same as for-in scopes
+| 7 = @comprehension_block_scope
+| 8 = @class_expr_scope
+| 9 = @namespace_scope
+| 10 = @class_decl_scope
+| 11 = @interface_scope
+| 12 = @type_alias_scope
+| 13 = @mapped_type_scope
+| 14 = @enum_scope
+| 15 = @external_module_scope
+| 16 = @conditional_type_scope;
+
+scopenodes (unique int node: @ast_node ref,
+ int scope: @scope ref);
+
+scopenesting (unique int inner: @scope ref,
+ int outer: @scope ref);
+
+// functions
+@function = @function_decl_stmt | @function_expr | @arrow_function_expr;
+
+@parameterized = @function | @catch_clause;
+@type_parameterized = @function | @class_or_interface | @type_alias_declaration | @mapped_typeexpr | @infer_typeexpr;
+
+is_generator (int fun: @function ref);
+has_rest_parameter (int fun: @function ref);
+is_async (int fun: @function ref);
+
+// variables and lexically scoped type names
+#keyset[scope, name]
+variables (unique int id: @variable,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_type_names (unique int id: @local_type_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_namespace_names (unique int id: @local_namespace_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+is_arguments_object (int id: @variable ref);
+
+@lexical_name = @variable | @local_type_name | @local_namespace_name;
+
+@bind_id = @varaccess | @local_var_type_access;
+bind (unique int id: @bind_id ref,
+ int decl: @variable ref);
+
+decl (unique int id: @var_decl ref,
+ int decl: @variable ref);
+
+@typebind_id = @local_type_access | @export_varaccess;
+typebind (unique int id: @typebind_id ref,
+ int decl: @local_type_name ref);
+
+@typedecl_id = @type_decl | @var_decl;
+typedecl (unique int id: @typedecl_id ref,
+ int decl: @local_type_name ref);
+
+namespacedecl (unique int id: @var_decl ref,
+ int decl: @local_namespace_name ref);
+
+@namespacebind_id = @local_namespace_access | @export_varaccess;
+namespacebind (unique int id: @namespacebind_id ref,
+ int decl: @local_namespace_name ref);
+
+
+// properties in object literals, property patterns in object patterns, and method declarations in classes
+#keyset[parent, index]
+properties (unique int id: @property,
+ int parent: @property_parent ref,
+ int index: int ref,
+ int kind: int ref,
+ varchar(900) tostring: string ref);
+
+case @property.kind of
+ 0 = @value_property
+| 1 = @property_getter
+| 2 = @property_setter
+| 3 = @jsx_attribute
+| 4 = @function_call_signature
+| 5 = @constructor_call_signature
+| 6 = @index_signature
+| 7 = @enum_member
+| 8 = @proper_field
+| 9 = @parameter_field
+| 10 = @static_initializer
+;
+
+@property_parent = @obj_expr | @object_pattern | @class_definition | @jsx_element | @interface_definition | @enum_declaration;
+@property_accessor = @property_getter | @property_setter;
+@call_signature = @function_call_signature | @constructor_call_signature;
+@field = @proper_field | @parameter_field;
+@field_or_vardeclarator = @field | @var_declarator;
+
+is_computed (int id: @property ref);
+is_method (int id: @property ref);
+is_static (int id: @property ref);
+is_abstract_member (int id: @property ref);
+is_const_enum (int id: @enum_declaration ref);
+is_abstract_class (int id: @class_decl_stmt ref);
+
+has_public_keyword (int id: @property ref);
+has_private_keyword (int id: @property ref);
+has_protected_keyword (int id: @property ref);
+has_readonly_keyword (int id: @property ref);
+has_type_keyword (int id: @type_keyword_operand ref);
+is_optional_member (int id: @property ref);
+has_definite_assignment_assertion (int id: @field_or_vardeclarator ref);
+is_optional_parameter_declaration (unique int parameter: @pattern ref);
+
+#keyset[constructor, param_index]
+parameter_fields(
+ unique int field: @parameter_field ref,
+ int constructor: @function_expr ref,
+ int param_index: int ref
+);
+
+// types
+#keyset[parent, idx]
+typeexprs (
+ unique int id: @typeexpr,
+ int kind: int ref,
+ int parent: @typeexpr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref
+);
+
+case @typeexpr.kind of
+ 0 = @local_type_access
+| 1 = @type_decl
+| 2 = @keyword_typeexpr
+| 3 = @string_literal_typeexpr
+| 4 = @number_literal_typeexpr
+| 5 = @boolean_literal_typeexpr
+| 6 = @array_typeexpr
+| 7 = @union_typeexpr
+| 8 = @indexed_access_typeexpr
+| 9 = @intersection_typeexpr
+| 10 = @parenthesized_typeexpr
+| 11 = @tuple_typeexpr
+| 12 = @keyof_typeexpr
+| 13 = @qualified_type_access
+| 14 = @generic_typeexpr
+| 15 = @type_label
+| 16 = @typeof_typeexpr
+| 17 = @local_var_type_access
+| 18 = @qualified_var_type_access
+| 19 = @this_var_type_access
+| 20 = @predicate_typeexpr
+| 21 = @interface_typeexpr
+| 22 = @type_parameter
+| 23 = @plain_function_typeexpr
+| 24 = @constructor_typeexpr
+| 25 = @local_namespace_access
+| 26 = @qualified_namespace_access
+| 27 = @mapped_typeexpr
+| 28 = @conditional_typeexpr
+| 29 = @infer_typeexpr
+| 30 = @import_type_access
+| 31 = @import_namespace_access
+| 32 = @import_var_type_access
+| 33 = @optional_typeexpr
+| 34 = @rest_typeexpr
+| 35 = @bigint_literal_typeexpr
+| 36 = @readonly_typeexpr
+| 37 = @template_literal_typeexpr
+;
+
+@typeref = @typeaccess | @type_decl;
+@type_identifier = @type_decl | @local_type_access | @type_label | @local_var_type_access | @local_namespace_access;
+@typeexpr_parent = @expr | @stmt | @property | @typeexpr;
+@literal_typeexpr = @string_literal_typeexpr | @number_literal_typeexpr | @boolean_literal_typeexpr | @bigint_literal_typeexpr;
+@typeaccess = @local_type_access | @qualified_type_access | @import_type_access;
+@vartypeaccess = @local_var_type_access | @qualified_var_type_access | @this_var_type_access | @import_var_type_access;
+@namespace_access = @local_namespace_access | @qualified_namespace_access | @import_namespace_access;
+@import_typeexpr = @import_type_access | @import_namespace_access | @import_var_type_access;
+
+@function_typeexpr = @plain_function_typeexpr | @constructor_typeexpr;
+
+// types
+types (
+ unique int id: @type,
+ int kind: int ref,
+ varchar(900) tostring: string ref
+);
+
+#keyset[parent, idx]
+type_child (
+ int child: @type ref,
+ int parent: @type ref,
+ int idx: int ref
+);
+
+case @type.kind of
+ 0 = @any_type
+| 1 = @string_type
+| 2 = @number_type
+| 3 = @union_type
+| 4 = @true_type
+| 5 = @false_type
+| 6 = @type_reference
+| 7 = @object_type
+| 8 = @canonical_type_variable_type
+| 9 = @typeof_type
+| 10 = @void_type
+| 11 = @undefined_type
+| 12 = @null_type
+| 13 = @never_type
+| 14 = @plain_symbol_type
+| 15 = @unique_symbol_type
+| 16 = @objectkeyword_type
+| 17 = @intersection_type
+| 18 = @tuple_type
+| 19 = @lexical_type_variable_type
+| 20 = @this_type
+| 21 = @number_literal_type
+| 22 = @string_literal_type
+| 23 = @unknown_type
+| 24 = @bigint_type
+| 25 = @bigint_literal_type
+;
+
+@boolean_literal_type = @true_type | @false_type;
+@symbol_type = @plain_symbol_type | @unique_symbol_type;
+@union_or_intersection_type = @union_type | @intersection_type;
+@typevariable_type = @canonical_type_variable_type | @lexical_type_variable_type;
+
+has_asserts_keyword(int node: @predicate_typeexpr ref);
+
+@typed_ast_node = @expr | @typeexpr | @function;
+ast_node_type(
+ unique int node: @typed_ast_node ref,
+ int typ: @type ref);
+
+declared_function_signature(
+ unique int node: @function ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_signature(
+ unique int node: @invokeexpr ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_overload_index(
+ unique int node: @invokeexpr ref,
+ int index: int ref
+);
+
+symbols (
+ unique int id: @symbol,
+ int kind: int ref,
+ varchar(900) name: string ref
+);
+
+symbol_parent (
+ unique int symbol: @symbol ref,
+ int parent: @symbol ref
+);
+
+symbol_module (
+ int symbol: @symbol ref,
+ varchar(900) moduleName: string ref
+);
+
+symbol_global (
+ int symbol: @symbol ref,
+ varchar(900) globalName: string ref
+);
+
+case @symbol.kind of
+ 0 = @root_symbol
+| 1 = @member_symbol
+| 2 = @other_symbol
+;
+
+@type_with_symbol = @type_reference | @typevariable_type | @typeof_type | @unique_symbol_type;
+@ast_node_with_symbol = @type_definition | @namespace_definition | @toplevel | @typeaccess | @namespace_access | @var_decl | @function | @invokeexpr | @import_declaration | @external_module_reference | @external_module_declaration;
+
+ast_node_symbol(
+ unique int node: @ast_node_with_symbol ref,
+ int symbol: @symbol ref);
+
+type_symbol(
+ unique int typ: @type_with_symbol ref,
+ int symbol: @symbol ref);
+
+#keyset[typ, name]
+type_property(
+ int typ: @type ref,
+ varchar(900) name: string ref,
+ int propertyType: @type ref);
+
+type_alias(
+ unique int aliasType: @type ref,
+ int underlyingType: @type ref);
+
+@literal_type = @string_literal_type | @number_literal_type | @boolean_literal_type | @bigint_literal_type;
+@type_with_literal_value = @string_literal_type | @number_literal_type | @bigint_literal_type;
+type_literal_value(
+ unique int typ: @type_with_literal_value ref,
+ varchar(900) value: string ref);
+
+signature_types (
+ unique int id: @signature_type,
+ int kind: int ref,
+ varchar(900) tostring: string ref,
+ int type_parameters: int ref,
+ int required_params: int ref
+);
+
+is_abstract_signature(
+ unique int sig: @signature_type ref
+);
+
+signature_rest_parameter(
+ unique int sig: @signature_type ref,
+ int rest_param_arra_type: @type ref
+);
+
+case @signature_type.kind of
+ 0 = @function_signature_type
+| 1 = @constructor_signature_type
+;
+
+#keyset[typ, kind, index]
+type_contains_signature (
+ int typ: @type ref,
+ int kind: int ref, // constructor/call/index
+ int index: int ref, // ordering of overloaded signatures
+ int sig: @signature_type ref
+);
+
+#keyset[parent, index]
+signature_contains_type (
+ int child: @type ref,
+ int parent: @signature_type ref,
+ int index: int ref
+);
+
+#keyset[sig, index]
+signature_parameter_name (
+ int sig: @signature_type ref,
+ int index: int ref,
+ varchar(900) name: string ref
+);
+
+number_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+string_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+base_type_names(
+ int typeName: @symbol ref,
+ int baseTypeName: @symbol ref
+);
+
+self_types(
+ int typeName: @symbol ref,
+ int selfType: @type_reference ref
+);
+
+tuple_type_min_length(
+ unique int typ: @type ref,
+ int minLength: int ref
+);
+
+tuple_type_rest_index(
+ unique int typ: @type ref,
+ int index: int ref
+);
+
+// comments
+comments (unique int id: @comment,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(900) tostring: string ref);
+
+case @comment.kind of
+ 0 = @slashslash_comment
+| 1 = @slashstar_comment
+| 2 = @doc_comment
+| 3 = @html_comment_start
+| 4 = @htmlcommentend;
+
+@html_comment = @html_comment_start | @htmlcommentend;
+@line_comment = @slashslash_comment | @html_comment;
+@block_comment = @slashstar_comment | @doc_comment;
+
+// source lines
+lines (unique int id: @line,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(2) terminator: string ref);
+indentation (int file: @file ref,
+ int lineno: int ref,
+ varchar(1) indentChar: string ref,
+ int indentDepth: int ref);
+
+// JavaScript parse errors
+js_parse_errors (unique int id: @js_parse_error,
+ int toplevel: @toplevel ref,
+ varchar(900) message: string ref,
+ varchar(900) line: string ref);
+
+// regular expressions
+#keyset[parent, idx]
+regexpterm (unique int id: @regexpterm,
+ int kind: int ref,
+ int parent: @regexpparent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+@regexpparent = @regexpterm | @regexp_literal | @string_literal | @add_expr;
+
+case @regexpterm.kind of
+ 0 = @regexp_alt
+| 1 = @regexp_seq
+| 2 = @regexp_caret
+| 3 = @regexp_dollar
+| 4 = @regexp_wordboundary
+| 5 = @regexp_nonwordboundary
+| 6 = @regexp_positive_lookahead
+| 7 = @regexp_negative_lookahead
+| 8 = @regexp_star
+| 9 = @regexp_plus
+| 10 = @regexp_opt
+| 11 = @regexp_range
+| 12 = @regexp_dot
+| 13 = @regexp_group
+| 14 = @regexp_normal_constant
+| 15 = @regexp_hex_escape
+| 16 = @regexp_unicode_escape
+| 17 = @regexp_dec_escape
+| 18 = @regexp_oct_escape
+| 19 = @regexp_ctrl_escape
+| 20 = @regexp_char_class_escape
+| 21 = @regexp_id_escape
+| 22 = @regexp_backref
+| 23 = @regexp_char_class
+| 24 = @regexp_char_range
+| 25 = @regexp_positive_lookbehind
+| 26 = @regexp_negative_lookbehind
+| 27 = @regexp_unicode_property_escape
+| 28 = @regexp_quoted_string
+| 29 = @regexp_intersection
+| 30 = @regexp_subtraction;
+
+regexp_parse_errors (unique int id: @regexp_parse_error,
+ int regexp: @regexpterm ref,
+ varchar(900) message: string ref);
+
+@regexp_quantifier = @regexp_star | @regexp_plus | @regexp_opt | @regexp_range;
+@regexp_escape = @regexp_char_escape | @regexp_char_class_escape | @regexp_unicode_property_escape;
+@regexp_char_escape = @regexp_hex_escape | @regexp_unicode_escape | @regexp_dec_escape | @regexp_oct_escape | @regexp_ctrl_escape | @regexp_id_escape;
+@regexp_constant = @regexp_normal_constant | @regexp_char_escape;
+@regexp_lookahead = @regexp_positive_lookahead | @regexp_negative_lookahead;
+@regexp_lookbehind = @regexp_positive_lookbehind | @regexp_negative_lookbehind;
+@regexp_subpattern = @regexp_lookahead | @regexp_lookbehind;
+@regexp_anchor = @regexp_dollar | @regexp_caret;
+
+is_greedy (int id: @regexp_quantifier ref);
+range_quantifier_lower_bound (unique int id: @regexp_range ref, int lo: int ref);
+range_quantifier_upper_bound (unique int id: @regexp_range ref, int hi: int ref);
+is_capture (unique int id: @regexp_group ref, int number: int ref);
+is_named_capture (unique int id: @regexp_group ref, string name: string ref);
+is_inverted (int id: @regexp_char_class ref);
+regexp_const_value (unique int id: @regexp_constant ref, varchar(1) value: string ref);
+char_class_escape (unique int id: @regexp_char_class_escape ref, varchar(1) value: string ref);
+backref (unique int id: @regexp_backref ref, int value: int ref);
+named_backref (unique int id: @regexp_backref ref, string name: string ref);
+unicode_property_escapename (unique int id: @regexp_unicode_property_escape ref, string name: string ref);
+unicode_property_escapevalue (unique int id: @regexp_unicode_property_escape ref, string value: string ref);
+
+// tokens
+#keyset[toplevel, idx]
+tokeninfo (unique int id: @token,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ int idx: int ref,
+ varchar(900) value: string ref);
+
+case @token.kind of
+ 0 = @token_eof
+| 1 = @token_null_literal
+| 2 = @token_boolean_literal
+| 3 = @token_numeric_literal
+| 4 = @token_string_literal
+| 5 = @token_regular_expression
+| 6 = @token_identifier
+| 7 = @token_keyword
+| 8 = @token_punctuator;
+
+// associate comments with the token immediately following them (which may be EOF)
+next_token (int comment: @comment ref, int token: @token ref);
+
+// JSON
+#keyset[parent, idx]
+json (unique int id: @json_value,
+ int kind: int ref,
+ int parent: @json_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+json_literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @json_value ref);
+
+json_properties (int obj: @json_object ref,
+ varchar(900) property: string ref,
+ int value: @json_value ref);
+
+json_errors (unique int id: @json_parse_error,
+ varchar(900) message: string ref);
+
+json_locations(unique int locatable: @json_locatable ref,
+ int location: @location_default ref);
+
+case @json_value.kind of
+ 0 = @json_null
+| 1 = @json_boolean
+| 2 = @json_number
+| 3 = @json_string
+| 4 = @json_array
+| 5 = @json_object;
+
+@json_parent = @json_object | @json_array | @file;
+
+@json_locatable = @json_value | @json_parse_error;
+
+// locations
+@ast_node = @toplevel | @stmt | @expr | @property | @typeexpr;
+
+@locatable = @file
+ | @ast_node
+ | @comment
+ | @line
+ | @js_parse_error | @regexp_parse_error
+ | @regexpterm
+ | @json_locatable
+ | @token
+ | @cfg_node
+ | @jsdoc | @jsdoc_type_expr | @jsdoc_tag
+ | @yaml_locatable
+ | @xmllocatable
+ | @configLocatable
+ | @template_placeholder_tag;
+
+hasLocation (unique int locatable: @locatable ref,
+ int location: @location ref);
+
+// CFG
+entry_cfg_node (unique int id: @entry_node, int container: @stmt_container ref);
+exit_cfg_node (unique int id: @exit_node, int container: @stmt_container ref);
+guard_node (unique int id: @guard_node, int kind: int ref, int test: @expr ref);
+case @guard_node.kind of
+ 0 = @falsy_guard
+| 1 = @truthy_guard;
+@condition_guard = @falsy_guard | @truthy_guard;
+
+@synthetic_cfg_node = @entry_node | @exit_node | @guard_node;
+@cfg_node = @synthetic_cfg_node | @expr_parent;
+
+successor (int pred: @cfg_node ref, int succ: @cfg_node ref);
+
+// JSDoc comments
+jsdoc (unique int id: @jsdoc, varchar(900) description: string ref, int comment: @comment ref);
+#keyset[parent, idx]
+jsdoc_tags (unique int id: @jsdoc_tag, varchar(900) title: string ref,
+ int parent: @jsdoc ref, int idx: int ref, varchar(900) tostring: string ref);
+jsdoc_tag_descriptions (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+jsdoc_tag_names (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+
+#keyset[parent, idx]
+jsdoc_type_exprs (unique int id: @jsdoc_type_expr,
+ int kind: int ref,
+ int parent: @jsdoc_type_expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+case @jsdoc_type_expr.kind of
+ 0 = @jsdoc_any_type_expr
+| 1 = @jsdoc_null_type_expr
+| 2 = @jsdoc_undefined_type_expr
+| 3 = @jsdoc_unknown_type_expr
+| 4 = @jsdoc_void_type_expr
+| 5 = @jsdoc_identifier_type_expr
+| 6 = @jsdoc_applied_type_expr
+| 7 = @jsdoc_nullable_type_expr
+| 8 = @jsdoc_non_nullable_type_expr
+| 9 = @jsdoc_record_type_expr
+| 10 = @jsdoc_array_type_expr
+| 11 = @jsdoc_union_type_expr
+| 12 = @jsdoc_function_type_expr
+| 13 = @jsdoc_optional_type_expr
+| 14 = @jsdoc_rest_type_expr
+| 15 = @jsdoc_qualified_type_expr
+;
+
+#keyset[id, idx]
+jsdoc_record_field_name (int id: @jsdoc_record_type_expr ref, int idx: int ref, varchar(900) name: string ref);
+jsdoc_prefix_qualifier (int id: @jsdoc_type_expr ref);
+jsdoc_has_new_parameter (int fn: @jsdoc_function_type_expr ref);
+
+@jsdoc_type_expr_parent = @jsdoc_type_expr | @jsdoc_tag;
+
+jsdoc_errors (unique int id: @jsdoc_error, int tag: @jsdoc_tag ref, varchar(900) message: string ref, varchar(900) tostring: string ref);
+
+@dataflownode = @expr | @function_decl_stmt | @class_decl_stmt | @namespace_declaration | @enum_declaration | @property;
+
+@optionalchainable = @call_expr | @propaccess;
+
+isOptionalChaining(int id: @optionalchainable ref);
+
+/**
+ * The time taken for the extraction of a file.
+ * This table contains non-deterministic content.
+ *
+ * The sum of the `time` column for each (`file`, `timerKind`) pair
+ * is the total time taken for extraction of `file`. The `extractionPhase`
+ * column provides a granular view of the extraction time of the file.
+ */
+extraction_time(
+ int file : @file ref,
+ // see `com.semmle.js.extractor.ExtractionMetrics.ExtractionPhase`.
+ int extractionPhase: int ref,
+ // 0 for the elapsed CPU time in nanoseconds, 1 for the elapsed wallclock time in nanoseconds
+ int timerKind: int ref,
+ float time: float ref
+)
+
+/**
+* Non-timing related data for the extraction of a single file.
+* This table contains non-deterministic content.
+*/
+extraction_data(
+ int file : @file ref,
+ // the absolute path to the cache file
+ varchar(900) cacheFile: string ref,
+ boolean fromCache: boolean ref,
+ int length: int ref
+)
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- XML Files -*/
+
+xmlEncoding(
+ unique int id: @file ref,
+ string encoding: string ref
+);
+
+xmlDTDs(
+ unique int id: @xmldtd,
+ string root: string ref,
+ string publicId: string ref,
+ string systemId: string ref,
+ int fileid: @file ref
+);
+
+xmlElements(
+ unique int id: @xmlelement,
+ string name: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlAttrs(
+ unique int id: @xmlattribute,
+ int elementid: @xmlelement ref,
+ string name: string ref,
+ string value: string ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlNs(
+ int id: @xmlnamespace,
+ string prefixName: string ref,
+ string URI: string ref,
+ int fileid: @file ref
+);
+
+xmlHasNs(
+ int elementId: @xmlnamespaceable ref,
+ int nsId: @xmlnamespace ref,
+ int fileid: @file ref
+);
+
+xmlComments(
+ unique int id: @xmlcomment,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int fileid: @file ref
+);
+
+xmlChars(
+ unique int id: @xmlcharacters,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int isCDATA: int ref,
+ int fileid: @file ref
+);
+
+@xmlparent = @file | @xmlelement;
+@xmlnamespaceable = @xmlelement | @xmlattribute;
+
+xmllocations(
+ int xmlElement: @xmllocatable ref,
+ int location: @location_default ref
+);
+
+@xmllocatable = @xmlcharacters | @xmlelement | @xmlcomment | @xmlattribute | @xmldtd | @file | @xmlnamespace;
+
+/*- Configuration files with key value pairs -*/
+
+configs(
+ unique int id: @config
+);
+
+configNames(
+ unique int id: @configName,
+ int config: @config ref,
+ string name: string ref
+);
+
+configValues(
+ unique int id: @configValue,
+ int config: @config ref,
+ string value: string ref
+);
+
+configLocations(
+ int locatable: @configLocatable ref,
+ int location: @location_default ref
+);
+
+@configLocatable = @config | @configName | @configValue;
diff --git a/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/upgrade.properties b/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/upgrade.properties
new file mode 100644
index 00000000000..bae98029d4b
--- /dev/null
+++ b/javascript/downgrades/76a926a00d5f3bc199c203a1437796fd7b2835ba/upgrade.properties
@@ -0,0 +1,5 @@
+description: downgrade overlay relations
+compatibility: full
+
+databaseMetadata.rel: delete
+overlayChangedFiles.rel: delete
diff --git a/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/old.dbscheme b/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/old.dbscheme
new file mode 100644
index 00000000000..ccefb5e2d49
--- /dev/null
+++ b/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/old.dbscheme
@@ -0,0 +1,1194 @@
+/*** Standard fragments ***/
+
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Lines of code -*/
+
+numlines(
+ int element_id: @sourceline ref,
+ int num_lines: int ref,
+ int num_code: int ref,
+ int num_comment: int ref
+);
+
+/*- External data -*/
+
+/**
+ * External data, loaded from CSV files during snapshot creation. See
+ * [Tutorial: Incorporating external data](https://help.semmle.com/wiki/display/SD/Tutorial%3A+Incorporating+external+data)
+ * for more information.
+ */
+externalData(
+ int id : @externalDataElement,
+ string path : string ref,
+ int column: int ref,
+ string value : string ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- JavaScript-specific part -*/
+
+@location = @location_default
+
+@sourceline = @locatable;
+
+filetype(
+ int file: @file ref,
+ string filetype: string ref
+)
+
+// top-level code fragments
+toplevels (unique int id: @toplevel,
+ int kind: int ref);
+
+is_externs (int toplevel: @toplevel ref);
+
+case @toplevel.kind of
+ 0 = @script
+| 1 = @inline_script
+| 2 = @event_handler
+| 3 = @javascript_url
+| 4 = @template_toplevel;
+
+is_module (int tl: @toplevel ref);
+is_nodejs (int tl: @toplevel ref);
+is_es2015_module (int tl: @toplevel ref);
+is_closure_module (int tl: @toplevel ref);
+
+@xml_node_with_code = @xmlelement | @xmlattribute | @template_placeholder_tag;
+toplevel_parent_xml_node(
+ unique int toplevel: @toplevel ref,
+ int xmlnode: @xml_node_with_code ref);
+
+xml_element_parent_expression(
+ unique int xmlnode: @xmlelement ref,
+ int expression: @expr ref,
+ int index: int ref);
+
+// statements
+#keyset[parent, idx]
+stmts (unique int id: @stmt,
+ int kind: int ref,
+ int parent: @stmt_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+stmt_containers (unique int stmt: @stmt ref,
+ int container: @stmt_container ref);
+
+jump_targets (unique int jump: @stmt ref,
+ int target: @stmt ref);
+
+@stmt_parent = @stmt | @toplevel | @function_expr | @arrow_function_expr | @static_initializer;
+@stmt_container = @toplevel | @function | @namespace_declaration | @external_module_declaration | @global_augmentation_declaration;
+
+case @stmt.kind of
+ 0 = @empty_stmt
+| 1 = @block_stmt
+| 2 = @expr_stmt
+| 3 = @if_stmt
+| 4 = @labeled_stmt
+| 5 = @break_stmt
+| 6 = @continue_stmt
+| 7 = @with_stmt
+| 8 = @switch_stmt
+| 9 = @return_stmt
+| 10 = @throw_stmt
+| 11 = @try_stmt
+| 12 = @while_stmt
+| 13 = @do_while_stmt
+| 14 = @for_stmt
+| 15 = @for_in_stmt
+| 16 = @debugger_stmt
+| 17 = @function_decl_stmt
+| 18 = @var_decl_stmt
+| 19 = @case
+| 20 = @catch_clause
+| 21 = @for_of_stmt
+| 22 = @const_decl_stmt
+| 23 = @let_stmt
+| 24 = @legacy_let_stmt
+| 25 = @for_each_stmt
+| 26 = @class_decl_stmt
+| 27 = @import_declaration
+| 28 = @export_all_declaration
+| 29 = @export_default_declaration
+| 30 = @export_named_declaration
+| 31 = @namespace_declaration
+| 32 = @import_equals_declaration
+| 33 = @export_assign_declaration
+| 34 = @interface_declaration
+| 35 = @type_alias_declaration
+| 36 = @enum_declaration
+| 37 = @external_module_declaration
+| 38 = @export_as_namespace_declaration
+| 39 = @global_augmentation_declaration
+| 40 = @using_decl_stmt
+;
+
+@decl_stmt = @var_decl_stmt | @const_decl_stmt | @let_stmt | @legacy_let_stmt | @using_decl_stmt;
+
+@export_declaration = @export_all_declaration | @export_default_declaration | @export_named_declaration;
+
+@namespace_definition = @namespace_declaration | @enum_declaration;
+@type_definition = @class_definition | @interface_declaration | @enum_declaration | @type_alias_declaration | @enum_member;
+
+is_instantiated(unique int decl: @namespace_declaration ref);
+
+@declarable_node = @decl_stmt | @namespace_declaration | @class_decl_stmt | @function_decl_stmt | @enum_declaration | @external_module_declaration | @global_augmentation_declaration | @field;
+has_declare_keyword(unique int stmt: @declarable_node ref);
+
+is_for_await_of(unique int forof: @for_of_stmt ref);
+
+// expressions
+#keyset[parent, idx]
+exprs (unique int id: @expr,
+ int kind: int ref,
+ int parent: @expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @expr_or_type ref);
+
+enclosing_stmt (unique int expr: @expr_or_type ref,
+ int stmt: @stmt ref);
+
+expr_containers (unique int expr: @expr_or_type ref,
+ int container: @stmt_container ref);
+
+array_size (unique int ae: @arraylike ref,
+ int sz: int ref);
+
+is_delegating (int yield: @yield_expr ref);
+
+@expr_or_stmt = @expr | @stmt;
+@expr_or_type = @expr | @typeexpr;
+@expr_parent = @expr_or_stmt | @property | @function_typeexpr;
+@arraylike = @array_expr | @array_pattern;
+@type_annotation = @typeexpr | @jsdoc_type_expr;
+@node_in_stmt_container = @cfg_node | @type_annotation | @toplevel;
+
+case @expr.kind of
+ 0 = @label
+| 1 = @null_literal
+| 2 = @boolean_literal
+| 3 = @number_literal
+| 4 = @string_literal
+| 5 = @regexp_literal
+| 6 = @this_expr
+| 7 = @array_expr
+| 8 = @obj_expr
+| 9 = @function_expr
+| 10 = @seq_expr
+| 11 = @conditional_expr
+| 12 = @new_expr
+| 13 = @call_expr
+| 14 = @dot_expr
+| 15 = @index_expr
+| 16 = @neg_expr
+| 17 = @plus_expr
+| 18 = @log_not_expr
+| 19 = @bit_not_expr
+| 20 = @typeof_expr
+| 21 = @void_expr
+| 22 = @delete_expr
+| 23 = @eq_expr
+| 24 = @neq_expr
+| 25 = @eqq_expr
+| 26 = @neqq_expr
+| 27 = @lt_expr
+| 28 = @le_expr
+| 29 = @gt_expr
+| 30 = @ge_expr
+| 31 = @lshift_expr
+| 32 = @rshift_expr
+| 33 = @urshift_expr
+| 34 = @add_expr
+| 35 = @sub_expr
+| 36 = @mul_expr
+| 37 = @div_expr
+| 38 = @mod_expr
+| 39 = @bitor_expr
+| 40 = @xor_expr
+| 41 = @bitand_expr
+| 42 = @in_expr
+| 43 = @instanceof_expr
+| 44 = @logand_expr
+| 45 = @logor_expr
+| 47 = @assign_expr
+| 48 = @assign_add_expr
+| 49 = @assign_sub_expr
+| 50 = @assign_mul_expr
+| 51 = @assign_div_expr
+| 52 = @assign_mod_expr
+| 53 = @assign_lshift_expr
+| 54 = @assign_rshift_expr
+| 55 = @assign_urshift_expr
+| 56 = @assign_or_expr
+| 57 = @assign_xor_expr
+| 58 = @assign_and_expr
+| 59 = @preinc_expr
+| 60 = @postinc_expr
+| 61 = @predec_expr
+| 62 = @postdec_expr
+| 63 = @par_expr
+| 64 = @var_declarator
+| 65 = @arrow_function_expr
+| 66 = @spread_element
+| 67 = @array_pattern
+| 68 = @object_pattern
+| 69 = @yield_expr
+| 70 = @tagged_template_expr
+| 71 = @template_literal
+| 72 = @template_element
+| 73 = @array_comprehension_expr
+| 74 = @generator_expr
+| 75 = @for_in_comprehension_block
+| 76 = @for_of_comprehension_block
+| 77 = @legacy_letexpr
+| 78 = @var_decl
+| 79 = @proper_varaccess
+| 80 = @class_expr
+| 81 = @super_expr
+| 82 = @newtarget_expr
+| 83 = @named_import_specifier
+| 84 = @import_default_specifier
+| 85 = @import_namespace_specifier
+| 86 = @named_export_specifier
+| 87 = @exp_expr
+| 88 = @assign_exp_expr
+| 89 = @jsx_element
+| 90 = @jsx_qualified_name
+| 91 = @jsx_empty_expr
+| 92 = @await_expr
+| 93 = @function_sent_expr
+| 94 = @decorator
+| 95 = @export_default_specifier
+| 96 = @export_namespace_specifier
+| 97 = @bind_expr
+| 98 = @external_module_reference
+| 99 = @dynamic_import
+| 100 = @expression_with_type_arguments
+| 101 = @prefix_type_assertion
+| 102 = @as_type_assertion
+| 103 = @export_varaccess
+| 104 = @decorator_list
+| 105 = @non_null_assertion
+| 106 = @bigint_literal
+| 107 = @nullishcoalescing_expr
+| 108 = @e4x_xml_anyname
+| 109 = @e4x_xml_static_attribute_selector
+| 110 = @e4x_xml_dynamic_attribute_selector
+| 111 = @e4x_xml_filter_expression
+| 112 = @e4x_xml_static_qualident
+| 113 = @e4x_xml_dynamic_qualident
+| 114 = @e4x_xml_dotdotexpr
+| 115 = @import_meta_expr
+| 116 = @assignlogandexpr
+| 117 = @assignlogorexpr
+| 118 = @assignnullishcoalescingexpr
+| 119 = @template_pipe_ref
+| 120 = @generated_code_expr
+| 121 = @satisfies_expr
+;
+
+@varaccess = @proper_varaccess | @export_varaccess;
+@varref = @var_decl | @varaccess;
+
+@identifier = @label | @varref | @type_identifier;
+
+@literal = @null_literal | @boolean_literal | @number_literal | @string_literal | @regexp_literal | @bigint_literal;
+
+@propaccess = @dot_expr | @index_expr;
+
+@invokeexpr = @new_expr | @call_expr;
+
+@unaryexpr = @neg_expr | @plus_expr | @log_not_expr | @bit_not_expr | @typeof_expr | @void_expr | @delete_expr | @spread_element;
+
+@equality_test = @eq_expr | @neq_expr | @eqq_expr | @neqq_expr;
+
+@comparison = @equality_test | @lt_expr | @le_expr | @gt_expr | @ge_expr;
+
+@binaryexpr = @comparison | @lshift_expr | @rshift_expr | @urshift_expr | @add_expr | @sub_expr | @mul_expr | @div_expr | @mod_expr | @exp_expr | @bitor_expr | @xor_expr | @bitand_expr | @in_expr | @instanceof_expr | @logand_expr | @logor_expr | @nullishcoalescing_expr;
+
+@assignment = @assign_expr | @assign_add_expr | @assign_sub_expr | @assign_mul_expr | @assign_div_expr | @assign_mod_expr | @assign_exp_expr | @assign_lshift_expr | @assign_rshift_expr | @assign_urshift_expr | @assign_or_expr | @assign_xor_expr | @assign_and_expr | @assignlogandexpr | @assignlogorexpr | @assignnullishcoalescingexpr;
+
+@updateexpr = @preinc_expr | @postinc_expr | @predec_expr | @postdec_expr;
+
+@pattern = @varref | @array_pattern | @object_pattern;
+
+@comprehension_expr = @array_comprehension_expr | @generator_expr;
+
+@comprehension_block = @for_in_comprehension_block | @for_of_comprehension_block;
+
+@import_specifier = @named_import_specifier | @import_default_specifier | @import_namespace_specifier;
+
+@exportspecifier = @named_export_specifier | @export_default_specifier | @export_namespace_specifier;
+
+@type_keyword_operand = @import_declaration | @export_declaration | @import_specifier;
+
+@type_assertion = @as_type_assertion | @prefix_type_assertion;
+
+@class_definition = @class_decl_stmt | @class_expr;
+@interface_definition = @interface_declaration | @interface_typeexpr;
+@class_or_interface = @class_definition | @interface_definition;
+
+@lexical_decl = @var_decl | @type_decl;
+@lexical_access = @varaccess | @local_type_access | @local_var_type_access | @local_namespace_access;
+@lexical_ref = @lexical_decl | @lexical_access;
+
+@e4x_xml_attribute_selector = @e4x_xml_static_attribute_selector | @e4x_xml_dynamic_attribute_selector;
+@e4x_xml_qualident = @e4x_xml_static_qualident | @e4x_xml_dynamic_qualident;
+
+expr_contains_template_tag_location(
+ int expr: @expr ref,
+ int location: @location ref
+);
+
+@template_placeholder_tag_parent = @xmlelement | @xmlattribute | @file;
+
+template_placeholder_tag_info(
+ unique int node: @template_placeholder_tag,
+ int parentNode: @template_placeholder_tag_parent ref,
+ varchar(900) raw: string ref
+);
+
+// scopes
+scopes (unique int id: @scope,
+ int kind: int ref);
+
+case @scope.kind of
+ 0 = @global_scope
+| 1 = @function_scope
+| 2 = @catch_scope
+| 3 = @module_scope
+| 4 = @block_scope
+| 5 = @for_scope
+| 6 = @for_in_scope // for-of scopes work the same as for-in scopes
+| 7 = @comprehension_block_scope
+| 8 = @class_expr_scope
+| 9 = @namespace_scope
+| 10 = @class_decl_scope
+| 11 = @interface_scope
+| 12 = @type_alias_scope
+| 13 = @mapped_type_scope
+| 14 = @enum_scope
+| 15 = @external_module_scope
+| 16 = @conditional_type_scope;
+
+scopenodes (unique int node: @ast_node ref,
+ int scope: @scope ref);
+
+scopenesting (unique int inner: @scope ref,
+ int outer: @scope ref);
+
+// functions
+@function = @function_decl_stmt | @function_expr | @arrow_function_expr;
+
+@parameterized = @function | @catch_clause;
+@type_parameterized = @function | @class_or_interface | @type_alias_declaration | @mapped_typeexpr | @infer_typeexpr;
+
+is_generator (int fun: @function ref);
+has_rest_parameter (int fun: @function ref);
+is_async (int fun: @function ref);
+
+// variables and lexically scoped type names
+#keyset[scope, name]
+variables (unique int id: @variable,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_type_names (unique int id: @local_type_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_namespace_names (unique int id: @local_namespace_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+is_arguments_object (int id: @variable ref);
+
+@lexical_name = @variable | @local_type_name | @local_namespace_name;
+
+@bind_id = @varaccess | @local_var_type_access;
+bind (unique int id: @bind_id ref,
+ int decl: @variable ref);
+
+decl (unique int id: @var_decl ref,
+ int decl: @variable ref);
+
+@typebind_id = @local_type_access | @export_varaccess;
+typebind (unique int id: @typebind_id ref,
+ int decl: @local_type_name ref);
+
+@typedecl_id = @type_decl | @var_decl;
+typedecl (unique int id: @typedecl_id ref,
+ int decl: @local_type_name ref);
+
+namespacedecl (unique int id: @var_decl ref,
+ int decl: @local_namespace_name ref);
+
+@namespacebind_id = @local_namespace_access | @export_varaccess;
+namespacebind (unique int id: @namespacebind_id ref,
+ int decl: @local_namespace_name ref);
+
+
+// properties in object literals, property patterns in object patterns, and method declarations in classes
+#keyset[parent, index]
+properties (unique int id: @property,
+ int parent: @property_parent ref,
+ int index: int ref,
+ int kind: int ref,
+ varchar(900) tostring: string ref);
+
+case @property.kind of
+ 0 = @value_property
+| 1 = @property_getter
+| 2 = @property_setter
+| 3 = @jsx_attribute
+| 4 = @function_call_signature
+| 5 = @constructor_call_signature
+| 6 = @index_signature
+| 7 = @enum_member
+| 8 = @proper_field
+| 9 = @parameter_field
+| 10 = @static_initializer
+;
+
+@property_parent = @obj_expr | @object_pattern | @class_definition | @jsx_element | @interface_definition | @enum_declaration;
+@property_accessor = @property_getter | @property_setter;
+@call_signature = @function_call_signature | @constructor_call_signature;
+@field = @proper_field | @parameter_field;
+@field_or_vardeclarator = @field | @var_declarator;
+
+is_computed (int id: @property ref);
+is_method (int id: @property ref);
+is_static (int id: @property ref);
+is_abstract_member (int id: @property ref);
+is_const_enum (int id: @enum_declaration ref);
+is_abstract_class (int id: @class_decl_stmt ref);
+
+has_public_keyword (int id: @property ref);
+has_private_keyword (int id: @property ref);
+has_protected_keyword (int id: @property ref);
+has_readonly_keyword (int id: @property ref);
+has_type_keyword (int id: @type_keyword_operand ref);
+is_optional_member (int id: @property ref);
+has_definite_assignment_assertion (int id: @field_or_vardeclarator ref);
+is_optional_parameter_declaration (unique int parameter: @pattern ref);
+
+#keyset[constructor, param_index]
+parameter_fields(
+ unique int field: @parameter_field ref,
+ int constructor: @function_expr ref,
+ int param_index: int ref
+);
+
+// types
+#keyset[parent, idx]
+typeexprs (
+ unique int id: @typeexpr,
+ int kind: int ref,
+ int parent: @typeexpr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref
+);
+
+case @typeexpr.kind of
+ 0 = @local_type_access
+| 1 = @type_decl
+| 2 = @keyword_typeexpr
+| 3 = @string_literal_typeexpr
+| 4 = @number_literal_typeexpr
+| 5 = @boolean_literal_typeexpr
+| 6 = @array_typeexpr
+| 7 = @union_typeexpr
+| 8 = @indexed_access_typeexpr
+| 9 = @intersection_typeexpr
+| 10 = @parenthesized_typeexpr
+| 11 = @tuple_typeexpr
+| 12 = @keyof_typeexpr
+| 13 = @qualified_type_access
+| 14 = @generic_typeexpr
+| 15 = @type_label
+| 16 = @typeof_typeexpr
+| 17 = @local_var_type_access
+| 18 = @qualified_var_type_access
+| 19 = @this_var_type_access
+| 20 = @predicate_typeexpr
+| 21 = @interface_typeexpr
+| 22 = @type_parameter
+| 23 = @plain_function_typeexpr
+| 24 = @constructor_typeexpr
+| 25 = @local_namespace_access
+| 26 = @qualified_namespace_access
+| 27 = @mapped_typeexpr
+| 28 = @conditional_typeexpr
+| 29 = @infer_typeexpr
+| 30 = @import_type_access
+| 31 = @import_namespace_access
+| 32 = @import_var_type_access
+| 33 = @optional_typeexpr
+| 34 = @rest_typeexpr
+| 35 = @bigint_literal_typeexpr
+| 36 = @readonly_typeexpr
+| 37 = @template_literal_typeexpr
+;
+
+@typeref = @typeaccess | @type_decl;
+@type_identifier = @type_decl | @local_type_access | @type_label | @local_var_type_access | @local_namespace_access;
+@typeexpr_parent = @expr | @stmt | @property | @typeexpr;
+@literal_typeexpr = @string_literal_typeexpr | @number_literal_typeexpr | @boolean_literal_typeexpr | @bigint_literal_typeexpr;
+@typeaccess = @local_type_access | @qualified_type_access | @import_type_access;
+@vartypeaccess = @local_var_type_access | @qualified_var_type_access | @this_var_type_access | @import_var_type_access;
+@namespace_access = @local_namespace_access | @qualified_namespace_access | @import_namespace_access;
+@import_typeexpr = @import_type_access | @import_namespace_access | @import_var_type_access;
+
+@function_typeexpr = @plain_function_typeexpr | @constructor_typeexpr;
+
+// types
+types (
+ unique int id: @type,
+ int kind: int ref,
+ varchar(900) tostring: string ref
+);
+
+#keyset[parent, idx]
+type_child (
+ int child: @type ref,
+ int parent: @type ref,
+ int idx: int ref
+);
+
+case @type.kind of
+ 0 = @any_type
+| 1 = @string_type
+| 2 = @number_type
+| 3 = @union_type
+| 4 = @true_type
+| 5 = @false_type
+| 6 = @type_reference
+| 7 = @object_type
+| 8 = @canonical_type_variable_type
+| 9 = @typeof_type
+| 10 = @void_type
+| 11 = @undefined_type
+| 12 = @null_type
+| 13 = @never_type
+| 14 = @plain_symbol_type
+| 15 = @unique_symbol_type
+| 16 = @objectkeyword_type
+| 17 = @intersection_type
+| 18 = @tuple_type
+| 19 = @lexical_type_variable_type
+| 20 = @this_type
+| 21 = @number_literal_type
+| 22 = @string_literal_type
+| 23 = @unknown_type
+| 24 = @bigint_type
+| 25 = @bigint_literal_type
+;
+
+@boolean_literal_type = @true_type | @false_type;
+@symbol_type = @plain_symbol_type | @unique_symbol_type;
+@union_or_intersection_type = @union_type | @intersection_type;
+@typevariable_type = @canonical_type_variable_type | @lexical_type_variable_type;
+
+has_asserts_keyword(int node: @predicate_typeexpr ref);
+
+@typed_ast_node = @expr | @typeexpr | @function;
+ast_node_type(
+ unique int node: @typed_ast_node ref,
+ int typ: @type ref);
+
+declared_function_signature(
+ unique int node: @function ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_signature(
+ unique int node: @invokeexpr ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_overload_index(
+ unique int node: @invokeexpr ref,
+ int index: int ref
+);
+
+symbols (
+ unique int id: @symbol,
+ int kind: int ref,
+ varchar(900) name: string ref
+);
+
+symbol_parent (
+ unique int symbol: @symbol ref,
+ int parent: @symbol ref
+);
+
+symbol_module (
+ int symbol: @symbol ref,
+ varchar(900) moduleName: string ref
+);
+
+symbol_global (
+ int symbol: @symbol ref,
+ varchar(900) globalName: string ref
+);
+
+case @symbol.kind of
+ 0 = @root_symbol
+| 1 = @member_symbol
+| 2 = @other_symbol
+;
+
+@type_with_symbol = @type_reference | @typevariable_type | @typeof_type | @unique_symbol_type;
+@ast_node_with_symbol = @type_definition | @namespace_definition | @toplevel | @typeaccess | @namespace_access | @var_decl | @function | @invokeexpr | @import_declaration | @external_module_reference | @external_module_declaration;
+
+ast_node_symbol(
+ unique int node: @ast_node_with_symbol ref,
+ int symbol: @symbol ref);
+
+type_symbol(
+ unique int typ: @type_with_symbol ref,
+ int symbol: @symbol ref);
+
+#keyset[typ, name]
+type_property(
+ int typ: @type ref,
+ varchar(900) name: string ref,
+ int propertyType: @type ref);
+
+type_alias(
+ unique int aliasType: @type ref,
+ int underlyingType: @type ref);
+
+@literal_type = @string_literal_type | @number_literal_type | @boolean_literal_type | @bigint_literal_type;
+@type_with_literal_value = @string_literal_type | @number_literal_type | @bigint_literal_type;
+type_literal_value(
+ unique int typ: @type_with_literal_value ref,
+ varchar(900) value: string ref);
+
+signature_types (
+ unique int id: @signature_type,
+ int kind: int ref,
+ varchar(900) tostring: string ref,
+ int type_parameters: int ref,
+ int required_params: int ref
+);
+
+is_abstract_signature(
+ unique int sig: @signature_type ref
+);
+
+signature_rest_parameter(
+ unique int sig: @signature_type ref,
+ int rest_param_arra_type: @type ref
+);
+
+case @signature_type.kind of
+ 0 = @function_signature_type
+| 1 = @constructor_signature_type
+;
+
+#keyset[typ, kind, index]
+type_contains_signature (
+ int typ: @type ref,
+ int kind: int ref, // constructor/call/index
+ int index: int ref, // ordering of overloaded signatures
+ int sig: @signature_type ref
+);
+
+#keyset[parent, index]
+signature_contains_type (
+ int child: @type ref,
+ int parent: @signature_type ref,
+ int index: int ref
+);
+
+#keyset[sig, index]
+signature_parameter_name (
+ int sig: @signature_type ref,
+ int index: int ref,
+ varchar(900) name: string ref
+);
+
+number_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+string_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+base_type_names(
+ int typeName: @symbol ref,
+ int baseTypeName: @symbol ref
+);
+
+self_types(
+ int typeName: @symbol ref,
+ int selfType: @type_reference ref
+);
+
+tuple_type_min_length(
+ unique int typ: @type ref,
+ int minLength: int ref
+);
+
+tuple_type_rest_index(
+ unique int typ: @type ref,
+ int index: int ref
+);
+
+// comments
+comments (unique int id: @comment,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(900) tostring: string ref);
+
+case @comment.kind of
+ 0 = @slashslash_comment
+| 1 = @slashstar_comment
+| 2 = @doc_comment
+| 3 = @html_comment_start
+| 4 = @htmlcommentend;
+
+@html_comment = @html_comment_start | @htmlcommentend;
+@line_comment = @slashslash_comment | @html_comment;
+@block_comment = @slashstar_comment | @doc_comment;
+
+// source lines
+lines (unique int id: @line,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(2) terminator: string ref);
+indentation (int file: @file ref,
+ int lineno: int ref,
+ varchar(1) indentChar: string ref,
+ int indentDepth: int ref);
+
+// JavaScript parse errors
+js_parse_errors (unique int id: @js_parse_error,
+ int toplevel: @toplevel ref,
+ varchar(900) message: string ref,
+ varchar(900) line: string ref);
+
+// regular expressions
+#keyset[parent, idx]
+regexpterm (unique int id: @regexpterm,
+ int kind: int ref,
+ int parent: @regexpparent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+@regexpparent = @regexpterm | @regexp_literal | @string_literal | @add_expr;
+
+case @regexpterm.kind of
+ 0 = @regexp_alt
+| 1 = @regexp_seq
+| 2 = @regexp_caret
+| 3 = @regexp_dollar
+| 4 = @regexp_wordboundary
+| 5 = @regexp_nonwordboundary
+| 6 = @regexp_positive_lookahead
+| 7 = @regexp_negative_lookahead
+| 8 = @regexp_star
+| 9 = @regexp_plus
+| 10 = @regexp_opt
+| 11 = @regexp_range
+| 12 = @regexp_dot
+| 13 = @regexp_group
+| 14 = @regexp_normal_constant
+| 15 = @regexp_hex_escape
+| 16 = @regexp_unicode_escape
+| 17 = @regexp_dec_escape
+| 18 = @regexp_oct_escape
+| 19 = @regexp_ctrl_escape
+| 20 = @regexp_char_class_escape
+| 21 = @regexp_id_escape
+| 22 = @regexp_backref
+| 23 = @regexp_char_class
+| 24 = @regexp_char_range
+| 25 = @regexp_positive_lookbehind
+| 26 = @regexp_negative_lookbehind
+| 27 = @regexp_unicode_property_escape
+| 28 = @regexp_quoted_string
+| 29 = @regexp_intersection
+| 30 = @regexp_subtraction;
+
+regexp_parse_errors (unique int id: @regexp_parse_error,
+ int regexp: @regexpterm ref,
+ varchar(900) message: string ref);
+
+@regexp_quantifier = @regexp_star | @regexp_plus | @regexp_opt | @regexp_range;
+@regexp_escape = @regexp_char_escape | @regexp_char_class_escape | @regexp_unicode_property_escape;
+@regexp_char_escape = @regexp_hex_escape | @regexp_unicode_escape | @regexp_dec_escape | @regexp_oct_escape | @regexp_ctrl_escape | @regexp_id_escape;
+@regexp_constant = @regexp_normal_constant | @regexp_char_escape;
+@regexp_lookahead = @regexp_positive_lookahead | @regexp_negative_lookahead;
+@regexp_lookbehind = @regexp_positive_lookbehind | @regexp_negative_lookbehind;
+@regexp_subpattern = @regexp_lookahead | @regexp_lookbehind;
+@regexp_anchor = @regexp_dollar | @regexp_caret;
+
+is_greedy (int id: @regexp_quantifier ref);
+range_quantifier_lower_bound (unique int id: @regexp_range ref, int lo: int ref);
+range_quantifier_upper_bound (unique int id: @regexp_range ref, int hi: int ref);
+is_capture (unique int id: @regexp_group ref, int number: int ref);
+is_named_capture (unique int id: @regexp_group ref, string name: string ref);
+is_inverted (int id: @regexp_char_class ref);
+regexp_const_value (unique int id: @regexp_constant ref, varchar(1) value: string ref);
+char_class_escape (unique int id: @regexp_char_class_escape ref, varchar(1) value: string ref);
+backref (unique int id: @regexp_backref ref, int value: int ref);
+named_backref (unique int id: @regexp_backref ref, string name: string ref);
+unicode_property_escapename (unique int id: @regexp_unicode_property_escape ref, string name: string ref);
+unicode_property_escapevalue (unique int id: @regexp_unicode_property_escape ref, string value: string ref);
+
+// tokens
+#keyset[toplevel, idx]
+tokeninfo (unique int id: @token,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ int idx: int ref,
+ varchar(900) value: string ref);
+
+case @token.kind of
+ 0 = @token_eof
+| 1 = @token_null_literal
+| 2 = @token_boolean_literal
+| 3 = @token_numeric_literal
+| 4 = @token_string_literal
+| 5 = @token_regular_expression
+| 6 = @token_identifier
+| 7 = @token_keyword
+| 8 = @token_punctuator;
+
+// associate comments with the token immediately following them (which may be EOF)
+next_token (int comment: @comment ref, int token: @token ref);
+
+// JSON
+#keyset[parent, idx]
+json (unique int id: @json_value,
+ int kind: int ref,
+ int parent: @json_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+json_literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @json_value ref);
+
+json_properties (int obj: @json_object ref,
+ varchar(900) property: string ref,
+ int value: @json_value ref);
+
+json_errors (unique int id: @json_parse_error,
+ varchar(900) message: string ref);
+
+json_locations(unique int locatable: @json_locatable ref,
+ int location: @location_default ref);
+
+case @json_value.kind of
+ 0 = @json_null
+| 1 = @json_boolean
+| 2 = @json_number
+| 3 = @json_string
+| 4 = @json_array
+| 5 = @json_object;
+
+@json_parent = @json_object | @json_array | @file;
+
+@json_locatable = @json_value | @json_parse_error;
+
+// locations
+@ast_node = @toplevel | @stmt | @expr | @property | @typeexpr;
+
+@locatable = @file
+ | @ast_node
+ | @comment
+ | @line
+ | @js_parse_error | @regexp_parse_error
+ | @regexpterm
+ | @json_locatable
+ | @token
+ | @cfg_node
+ | @jsdoc | @jsdoc_type_expr | @jsdoc_tag
+ | @yaml_locatable
+ | @xmllocatable
+ | @configLocatable
+ | @template_placeholder_tag;
+
+hasLocation (unique int locatable: @locatable ref,
+ int location: @location ref);
+
+// CFG
+entry_cfg_node (unique int id: @entry_node, int container: @stmt_container ref);
+exit_cfg_node (unique int id: @exit_node, int container: @stmt_container ref);
+guard_node (unique int id: @guard_node, int kind: int ref, int test: @expr ref);
+case @guard_node.kind of
+ 0 = @falsy_guard
+| 1 = @truthy_guard;
+@condition_guard = @falsy_guard | @truthy_guard;
+
+@synthetic_cfg_node = @entry_node | @exit_node | @guard_node;
+@cfg_node = @synthetic_cfg_node | @expr_parent;
+
+successor (int pred: @cfg_node ref, int succ: @cfg_node ref);
+
+// JSDoc comments
+jsdoc (unique int id: @jsdoc, varchar(900) description: string ref, int comment: @comment ref);
+#keyset[parent, idx]
+jsdoc_tags (unique int id: @jsdoc_tag, varchar(900) title: string ref,
+ int parent: @jsdoc ref, int idx: int ref, varchar(900) tostring: string ref);
+jsdoc_tag_descriptions (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+jsdoc_tag_names (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+
+#keyset[parent, idx]
+jsdoc_type_exprs (unique int id: @jsdoc_type_expr,
+ int kind: int ref,
+ int parent: @jsdoc_type_expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+case @jsdoc_type_expr.kind of
+ 0 = @jsdoc_any_type_expr
+| 1 = @jsdoc_null_type_expr
+| 2 = @jsdoc_undefined_type_expr
+| 3 = @jsdoc_unknown_type_expr
+| 4 = @jsdoc_void_type_expr
+| 5 = @jsdoc_identifier_type_expr
+| 6 = @jsdoc_applied_type_expr
+| 7 = @jsdoc_nullable_type_expr
+| 8 = @jsdoc_non_nullable_type_expr
+| 9 = @jsdoc_record_type_expr
+| 10 = @jsdoc_array_type_expr
+| 11 = @jsdoc_union_type_expr
+| 12 = @jsdoc_function_type_expr
+| 13 = @jsdoc_optional_type_expr
+| 14 = @jsdoc_rest_type_expr
+| 15 = @jsdoc_qualified_type_expr
+;
+
+#keyset[id, idx]
+jsdoc_record_field_name (int id: @jsdoc_record_type_expr ref, int idx: int ref, varchar(900) name: string ref);
+jsdoc_prefix_qualifier (int id: @jsdoc_type_expr ref);
+jsdoc_has_new_parameter (int fn: @jsdoc_function_type_expr ref);
+
+@jsdoc_type_expr_parent = @jsdoc_type_expr | @jsdoc_tag;
+
+jsdoc_errors (unique int id: @jsdoc_error, int tag: @jsdoc_tag ref, varchar(900) message: string ref, varchar(900) tostring: string ref);
+
+@dataflownode = @expr | @function_decl_stmt | @class_decl_stmt | @namespace_declaration | @enum_declaration | @property;
+
+@optionalchainable = @call_expr | @propaccess;
+
+isOptionalChaining(int id: @optionalchainable ref);
+
+/**
+ * The time taken for the extraction of a file.
+ * This table contains non-deterministic content.
+ *
+ * The sum of the `time` column for each (`file`, `timerKind`) pair
+ * is the total time taken for extraction of `file`. The `extractionPhase`
+ * column provides a granular view of the extraction time of the file.
+ */
+extraction_time(
+ int file : @file ref,
+ // see `com.semmle.js.extractor.ExtractionMetrics.ExtractionPhase`.
+ int extractionPhase: int ref,
+ // 0 for the elapsed CPU time in nanoseconds, 1 for the elapsed wallclock time in nanoseconds
+ int timerKind: int ref,
+ float time: float ref
+)
+
+/**
+* Non-timing related data for the extraction of a single file.
+* This table contains non-deterministic content.
+*/
+extraction_data(
+ int file : @file ref,
+ // the absolute path to the cache file
+ varchar(900) cacheFile: string ref,
+ boolean fromCache: boolean ref,
+ int length: int ref
+)
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- XML Files -*/
+
+xmlEncoding(
+ unique int id: @file ref,
+ string encoding: string ref
+);
+
+xmlDTDs(
+ unique int id: @xmldtd,
+ string root: string ref,
+ string publicId: string ref,
+ string systemId: string ref,
+ int fileid: @file ref
+);
+
+xmlElements(
+ unique int id: @xmlelement,
+ string name: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlAttrs(
+ unique int id: @xmlattribute,
+ int elementid: @xmlelement ref,
+ string name: string ref,
+ string value: string ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlNs(
+ int id: @xmlnamespace,
+ string prefixName: string ref,
+ string URI: string ref,
+ int fileid: @file ref
+);
+
+xmlHasNs(
+ int elementId: @xmlnamespaceable ref,
+ int nsId: @xmlnamespace ref,
+ int fileid: @file ref
+);
+
+xmlComments(
+ unique int id: @xmlcomment,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int fileid: @file ref
+);
+
+xmlChars(
+ unique int id: @xmlcharacters,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int isCDATA: int ref,
+ int fileid: @file ref
+);
+
+@xmlparent = @file | @xmlelement;
+@xmlnamespaceable = @xmlelement | @xmlattribute;
+
+xmllocations(
+ int xmlElement: @xmllocatable ref,
+ int location: @location_default ref
+);
+
+@xmllocatable = @xmlcharacters | @xmlelement | @xmlcomment | @xmlattribute | @xmldtd | @file | @xmlnamespace;
+
+/*- Configuration files with key value pairs -*/
+
+configs(
+ unique int id: @config
+);
+
+configNames(
+ unique int id: @configName,
+ int config: @config ref,
+ string name: string ref
+);
+
+configValues(
+ unique int id: @configValue,
+ int config: @config ref,
+ string value: string ref
+);
+
+configLocations(
+ int locatable: @configLocatable ref,
+ int location: @location_default ref
+);
+
+@configLocatable = @config | @configName | @configValue;
diff --git a/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/semmlecode.javascript.dbscheme b/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/semmlecode.javascript.dbscheme
new file mode 100644
index 00000000000..76a926a00d5
--- /dev/null
+++ b/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/semmlecode.javascript.dbscheme
@@ -0,0 +1,1204 @@
+/*** Standard fragments ***/
+
+/*- Files and folders -*/
+
+/**
+ * The location of an element.
+ * The location spans column `startcolumn` of line `startline` to
+ * column `endcolumn` of line `endline` in file `file`.
+ * For more information, see
+ * [Locations](https://codeql.github.com/docs/writing-codeql-queries/providing-locations-in-codeql-queries/).
+ */
+locations_default(
+ unique int id: @location_default,
+ int file: @file ref,
+ int beginLine: int ref,
+ int beginColumn: int ref,
+ int endLine: int ref,
+ int endColumn: int ref
+);
+
+files(
+ unique int id: @file,
+ string name: string ref
+);
+
+folders(
+ unique int id: @folder,
+ string name: string ref
+);
+
+@container = @file | @folder
+
+containerparent(
+ int parent: @container ref,
+ unique int child: @container ref
+);
+
+/*- Lines of code -*/
+
+numlines(
+ int element_id: @sourceline ref,
+ int num_lines: int ref,
+ int num_code: int ref,
+ int num_comment: int ref
+);
+
+/*- External data -*/
+
+/**
+ * External data, loaded from CSV files during snapshot creation. See
+ * [Tutorial: Incorporating external data](https://help.semmle.com/wiki/display/SD/Tutorial%3A+Incorporating+external+data)
+ * for more information.
+ */
+externalData(
+ int id : @externalDataElement,
+ string path : string ref,
+ int column: int ref,
+ string value : string ref
+);
+
+/*- Source location prefix -*/
+
+/**
+ * The source location of the snapshot.
+ */
+sourceLocationPrefix(string prefix : string ref);
+
+/*- JavaScript-specific part -*/
+
+@location = @location_default
+
+@sourceline = @locatable;
+
+filetype(
+ int file: @file ref,
+ string filetype: string ref
+)
+
+// top-level code fragments
+toplevels (unique int id: @toplevel,
+ int kind: int ref);
+
+is_externs (int toplevel: @toplevel ref);
+
+case @toplevel.kind of
+ 0 = @script
+| 1 = @inline_script
+| 2 = @event_handler
+| 3 = @javascript_url
+| 4 = @template_toplevel;
+
+is_module (int tl: @toplevel ref);
+is_nodejs (int tl: @toplevel ref);
+is_es2015_module (int tl: @toplevel ref);
+is_closure_module (int tl: @toplevel ref);
+
+@xml_node_with_code = @xmlelement | @xmlattribute | @template_placeholder_tag;
+toplevel_parent_xml_node(
+ unique int toplevel: @toplevel ref,
+ int xmlnode: @xml_node_with_code ref);
+
+xml_element_parent_expression(
+ unique int xmlnode: @xmlelement ref,
+ int expression: @expr ref,
+ int index: int ref);
+
+// statements
+#keyset[parent, idx]
+stmts (unique int id: @stmt,
+ int kind: int ref,
+ int parent: @stmt_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+stmt_containers (unique int stmt: @stmt ref,
+ int container: @stmt_container ref);
+
+jump_targets (unique int jump: @stmt ref,
+ int target: @stmt ref);
+
+@stmt_parent = @stmt | @toplevel | @function_expr | @arrow_function_expr | @static_initializer;
+@stmt_container = @toplevel | @function | @namespace_declaration | @external_module_declaration | @global_augmentation_declaration;
+
+case @stmt.kind of
+ 0 = @empty_stmt
+| 1 = @block_stmt
+| 2 = @expr_stmt
+| 3 = @if_stmt
+| 4 = @labeled_stmt
+| 5 = @break_stmt
+| 6 = @continue_stmt
+| 7 = @with_stmt
+| 8 = @switch_stmt
+| 9 = @return_stmt
+| 10 = @throw_stmt
+| 11 = @try_stmt
+| 12 = @while_stmt
+| 13 = @do_while_stmt
+| 14 = @for_stmt
+| 15 = @for_in_stmt
+| 16 = @debugger_stmt
+| 17 = @function_decl_stmt
+| 18 = @var_decl_stmt
+| 19 = @case
+| 20 = @catch_clause
+| 21 = @for_of_stmt
+| 22 = @const_decl_stmt
+| 23 = @let_stmt
+| 24 = @legacy_let_stmt
+| 25 = @for_each_stmt
+| 26 = @class_decl_stmt
+| 27 = @import_declaration
+| 28 = @export_all_declaration
+| 29 = @export_default_declaration
+| 30 = @export_named_declaration
+| 31 = @namespace_declaration
+| 32 = @import_equals_declaration
+| 33 = @export_assign_declaration
+| 34 = @interface_declaration
+| 35 = @type_alias_declaration
+| 36 = @enum_declaration
+| 37 = @external_module_declaration
+| 38 = @export_as_namespace_declaration
+| 39 = @global_augmentation_declaration
+| 40 = @using_decl_stmt
+;
+
+@decl_stmt = @var_decl_stmt | @const_decl_stmt | @let_stmt | @legacy_let_stmt | @using_decl_stmt;
+
+@export_declaration = @export_all_declaration | @export_default_declaration | @export_named_declaration;
+
+@namespace_definition = @namespace_declaration | @enum_declaration;
+@type_definition = @class_definition | @interface_declaration | @enum_declaration | @type_alias_declaration | @enum_member;
+
+is_instantiated(unique int decl: @namespace_declaration ref);
+
+@declarable_node = @decl_stmt | @namespace_declaration | @class_decl_stmt | @function_decl_stmt | @enum_declaration | @external_module_declaration | @global_augmentation_declaration | @field;
+has_declare_keyword(unique int stmt: @declarable_node ref);
+
+is_for_await_of(unique int forof: @for_of_stmt ref);
+
+// expressions
+#keyset[parent, idx]
+exprs (unique int id: @expr,
+ int kind: int ref,
+ int parent: @expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @expr_or_type ref);
+
+enclosing_stmt (unique int expr: @expr_or_type ref,
+ int stmt: @stmt ref);
+
+expr_containers (unique int expr: @expr_or_type ref,
+ int container: @stmt_container ref);
+
+array_size (unique int ae: @arraylike ref,
+ int sz: int ref);
+
+is_delegating (int yield: @yield_expr ref);
+
+@expr_or_stmt = @expr | @stmt;
+@expr_or_type = @expr | @typeexpr;
+@expr_parent = @expr_or_stmt | @property | @function_typeexpr;
+@arraylike = @array_expr | @array_pattern;
+@type_annotation = @typeexpr | @jsdoc_type_expr;
+@node_in_stmt_container = @cfg_node | @type_annotation | @toplevel;
+
+case @expr.kind of
+ 0 = @label
+| 1 = @null_literal
+| 2 = @boolean_literal
+| 3 = @number_literal
+| 4 = @string_literal
+| 5 = @regexp_literal
+| 6 = @this_expr
+| 7 = @array_expr
+| 8 = @obj_expr
+| 9 = @function_expr
+| 10 = @seq_expr
+| 11 = @conditional_expr
+| 12 = @new_expr
+| 13 = @call_expr
+| 14 = @dot_expr
+| 15 = @index_expr
+| 16 = @neg_expr
+| 17 = @plus_expr
+| 18 = @log_not_expr
+| 19 = @bit_not_expr
+| 20 = @typeof_expr
+| 21 = @void_expr
+| 22 = @delete_expr
+| 23 = @eq_expr
+| 24 = @neq_expr
+| 25 = @eqq_expr
+| 26 = @neqq_expr
+| 27 = @lt_expr
+| 28 = @le_expr
+| 29 = @gt_expr
+| 30 = @ge_expr
+| 31 = @lshift_expr
+| 32 = @rshift_expr
+| 33 = @urshift_expr
+| 34 = @add_expr
+| 35 = @sub_expr
+| 36 = @mul_expr
+| 37 = @div_expr
+| 38 = @mod_expr
+| 39 = @bitor_expr
+| 40 = @xor_expr
+| 41 = @bitand_expr
+| 42 = @in_expr
+| 43 = @instanceof_expr
+| 44 = @logand_expr
+| 45 = @logor_expr
+| 47 = @assign_expr
+| 48 = @assign_add_expr
+| 49 = @assign_sub_expr
+| 50 = @assign_mul_expr
+| 51 = @assign_div_expr
+| 52 = @assign_mod_expr
+| 53 = @assign_lshift_expr
+| 54 = @assign_rshift_expr
+| 55 = @assign_urshift_expr
+| 56 = @assign_or_expr
+| 57 = @assign_xor_expr
+| 58 = @assign_and_expr
+| 59 = @preinc_expr
+| 60 = @postinc_expr
+| 61 = @predec_expr
+| 62 = @postdec_expr
+| 63 = @par_expr
+| 64 = @var_declarator
+| 65 = @arrow_function_expr
+| 66 = @spread_element
+| 67 = @array_pattern
+| 68 = @object_pattern
+| 69 = @yield_expr
+| 70 = @tagged_template_expr
+| 71 = @template_literal
+| 72 = @template_element
+| 73 = @array_comprehension_expr
+| 74 = @generator_expr
+| 75 = @for_in_comprehension_block
+| 76 = @for_of_comprehension_block
+| 77 = @legacy_letexpr
+| 78 = @var_decl
+| 79 = @proper_varaccess
+| 80 = @class_expr
+| 81 = @super_expr
+| 82 = @newtarget_expr
+| 83 = @named_import_specifier
+| 84 = @import_default_specifier
+| 85 = @import_namespace_specifier
+| 86 = @named_export_specifier
+| 87 = @exp_expr
+| 88 = @assign_exp_expr
+| 89 = @jsx_element
+| 90 = @jsx_qualified_name
+| 91 = @jsx_empty_expr
+| 92 = @await_expr
+| 93 = @function_sent_expr
+| 94 = @decorator
+| 95 = @export_default_specifier
+| 96 = @export_namespace_specifier
+| 97 = @bind_expr
+| 98 = @external_module_reference
+| 99 = @dynamic_import
+| 100 = @expression_with_type_arguments
+| 101 = @prefix_type_assertion
+| 102 = @as_type_assertion
+| 103 = @export_varaccess
+| 104 = @decorator_list
+| 105 = @non_null_assertion
+| 106 = @bigint_literal
+| 107 = @nullishcoalescing_expr
+| 108 = @e4x_xml_anyname
+| 109 = @e4x_xml_static_attribute_selector
+| 110 = @e4x_xml_dynamic_attribute_selector
+| 111 = @e4x_xml_filter_expression
+| 112 = @e4x_xml_static_qualident
+| 113 = @e4x_xml_dynamic_qualident
+| 114 = @e4x_xml_dotdotexpr
+| 115 = @import_meta_expr
+| 116 = @assignlogandexpr
+| 117 = @assignlogorexpr
+| 118 = @assignnullishcoalescingexpr
+| 119 = @template_pipe_ref
+| 120 = @generated_code_expr
+| 121 = @satisfies_expr
+;
+
+@varaccess = @proper_varaccess | @export_varaccess;
+@varref = @var_decl | @varaccess;
+
+@identifier = @label | @varref | @type_identifier;
+
+@literal = @null_literal | @boolean_literal | @number_literal | @string_literal | @regexp_literal | @bigint_literal;
+
+@propaccess = @dot_expr | @index_expr;
+
+@invokeexpr = @new_expr | @call_expr;
+
+@unaryexpr = @neg_expr | @plus_expr | @log_not_expr | @bit_not_expr | @typeof_expr | @void_expr | @delete_expr | @spread_element;
+
+@equality_test = @eq_expr | @neq_expr | @eqq_expr | @neqq_expr;
+
+@comparison = @equality_test | @lt_expr | @le_expr | @gt_expr | @ge_expr;
+
+@binaryexpr = @comparison | @lshift_expr | @rshift_expr | @urshift_expr | @add_expr | @sub_expr | @mul_expr | @div_expr | @mod_expr | @exp_expr | @bitor_expr | @xor_expr | @bitand_expr | @in_expr | @instanceof_expr | @logand_expr | @logor_expr | @nullishcoalescing_expr;
+
+@assignment = @assign_expr | @assign_add_expr | @assign_sub_expr | @assign_mul_expr | @assign_div_expr | @assign_mod_expr | @assign_exp_expr | @assign_lshift_expr | @assign_rshift_expr | @assign_urshift_expr | @assign_or_expr | @assign_xor_expr | @assign_and_expr | @assignlogandexpr | @assignlogorexpr | @assignnullishcoalescingexpr;
+
+@updateexpr = @preinc_expr | @postinc_expr | @predec_expr | @postdec_expr;
+
+@pattern = @varref | @array_pattern | @object_pattern;
+
+@comprehension_expr = @array_comprehension_expr | @generator_expr;
+
+@comprehension_block = @for_in_comprehension_block | @for_of_comprehension_block;
+
+@import_specifier = @named_import_specifier | @import_default_specifier | @import_namespace_specifier;
+
+@exportspecifier = @named_export_specifier | @export_default_specifier | @export_namespace_specifier;
+
+@type_keyword_operand = @import_declaration | @export_declaration | @import_specifier;
+
+@type_assertion = @as_type_assertion | @prefix_type_assertion;
+
+@class_definition = @class_decl_stmt | @class_expr;
+@interface_definition = @interface_declaration | @interface_typeexpr;
+@class_or_interface = @class_definition | @interface_definition;
+
+@lexical_decl = @var_decl | @type_decl;
+@lexical_access = @varaccess | @local_type_access | @local_var_type_access | @local_namespace_access;
+@lexical_ref = @lexical_decl | @lexical_access;
+
+@e4x_xml_attribute_selector = @e4x_xml_static_attribute_selector | @e4x_xml_dynamic_attribute_selector;
+@e4x_xml_qualident = @e4x_xml_static_qualident | @e4x_xml_dynamic_qualident;
+
+expr_contains_template_tag_location(
+ int expr: @expr ref,
+ int location: @location ref
+);
+
+@template_placeholder_tag_parent = @xmlelement | @xmlattribute | @file;
+
+template_placeholder_tag_info(
+ unique int node: @template_placeholder_tag,
+ int parentNode: @template_placeholder_tag_parent ref,
+ varchar(900) raw: string ref
+);
+
+// scopes
+scopes (unique int id: @scope,
+ int kind: int ref);
+
+case @scope.kind of
+ 0 = @global_scope
+| 1 = @function_scope
+| 2 = @catch_scope
+| 3 = @module_scope
+| 4 = @block_scope
+| 5 = @for_scope
+| 6 = @for_in_scope // for-of scopes work the same as for-in scopes
+| 7 = @comprehension_block_scope
+| 8 = @class_expr_scope
+| 9 = @namespace_scope
+| 10 = @class_decl_scope
+| 11 = @interface_scope
+| 12 = @type_alias_scope
+| 13 = @mapped_type_scope
+| 14 = @enum_scope
+| 15 = @external_module_scope
+| 16 = @conditional_type_scope;
+
+scopenodes (unique int node: @ast_node ref,
+ int scope: @scope ref);
+
+scopenesting (unique int inner: @scope ref,
+ int outer: @scope ref);
+
+// functions
+@function = @function_decl_stmt | @function_expr | @arrow_function_expr;
+
+@parameterized = @function | @catch_clause;
+@type_parameterized = @function | @class_or_interface | @type_alias_declaration | @mapped_typeexpr | @infer_typeexpr;
+
+is_generator (int fun: @function ref);
+has_rest_parameter (int fun: @function ref);
+is_async (int fun: @function ref);
+
+// variables and lexically scoped type names
+#keyset[scope, name]
+variables (unique int id: @variable,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_type_names (unique int id: @local_type_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+#keyset[scope, name]
+local_namespace_names (unique int id: @local_namespace_name,
+ varchar(900) name: string ref,
+ int scope: @scope ref);
+
+is_arguments_object (int id: @variable ref);
+
+@lexical_name = @variable | @local_type_name | @local_namespace_name;
+
+@bind_id = @varaccess | @local_var_type_access;
+bind (unique int id: @bind_id ref,
+ int decl: @variable ref);
+
+decl (unique int id: @var_decl ref,
+ int decl: @variable ref);
+
+@typebind_id = @local_type_access | @export_varaccess;
+typebind (unique int id: @typebind_id ref,
+ int decl: @local_type_name ref);
+
+@typedecl_id = @type_decl | @var_decl;
+typedecl (unique int id: @typedecl_id ref,
+ int decl: @local_type_name ref);
+
+namespacedecl (unique int id: @var_decl ref,
+ int decl: @local_namespace_name ref);
+
+@namespacebind_id = @local_namespace_access | @export_varaccess;
+namespacebind (unique int id: @namespacebind_id ref,
+ int decl: @local_namespace_name ref);
+
+
+// properties in object literals, property patterns in object patterns, and method declarations in classes
+#keyset[parent, index]
+properties (unique int id: @property,
+ int parent: @property_parent ref,
+ int index: int ref,
+ int kind: int ref,
+ varchar(900) tostring: string ref);
+
+case @property.kind of
+ 0 = @value_property
+| 1 = @property_getter
+| 2 = @property_setter
+| 3 = @jsx_attribute
+| 4 = @function_call_signature
+| 5 = @constructor_call_signature
+| 6 = @index_signature
+| 7 = @enum_member
+| 8 = @proper_field
+| 9 = @parameter_field
+| 10 = @static_initializer
+;
+
+@property_parent = @obj_expr | @object_pattern | @class_definition | @jsx_element | @interface_definition | @enum_declaration;
+@property_accessor = @property_getter | @property_setter;
+@call_signature = @function_call_signature | @constructor_call_signature;
+@field = @proper_field | @parameter_field;
+@field_or_vardeclarator = @field | @var_declarator;
+
+is_computed (int id: @property ref);
+is_method (int id: @property ref);
+is_static (int id: @property ref);
+is_abstract_member (int id: @property ref);
+is_const_enum (int id: @enum_declaration ref);
+is_abstract_class (int id: @class_decl_stmt ref);
+
+has_public_keyword (int id: @property ref);
+has_private_keyword (int id: @property ref);
+has_protected_keyword (int id: @property ref);
+has_readonly_keyword (int id: @property ref);
+has_type_keyword (int id: @type_keyword_operand ref);
+is_optional_member (int id: @property ref);
+has_definite_assignment_assertion (int id: @field_or_vardeclarator ref);
+is_optional_parameter_declaration (unique int parameter: @pattern ref);
+
+#keyset[constructor, param_index]
+parameter_fields(
+ unique int field: @parameter_field ref,
+ int constructor: @function_expr ref,
+ int param_index: int ref
+);
+
+// types
+#keyset[parent, idx]
+typeexprs (
+ unique int id: @typeexpr,
+ int kind: int ref,
+ int parent: @typeexpr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref
+);
+
+case @typeexpr.kind of
+ 0 = @local_type_access
+| 1 = @type_decl
+| 2 = @keyword_typeexpr
+| 3 = @string_literal_typeexpr
+| 4 = @number_literal_typeexpr
+| 5 = @boolean_literal_typeexpr
+| 6 = @array_typeexpr
+| 7 = @union_typeexpr
+| 8 = @indexed_access_typeexpr
+| 9 = @intersection_typeexpr
+| 10 = @parenthesized_typeexpr
+| 11 = @tuple_typeexpr
+| 12 = @keyof_typeexpr
+| 13 = @qualified_type_access
+| 14 = @generic_typeexpr
+| 15 = @type_label
+| 16 = @typeof_typeexpr
+| 17 = @local_var_type_access
+| 18 = @qualified_var_type_access
+| 19 = @this_var_type_access
+| 20 = @predicate_typeexpr
+| 21 = @interface_typeexpr
+| 22 = @type_parameter
+| 23 = @plain_function_typeexpr
+| 24 = @constructor_typeexpr
+| 25 = @local_namespace_access
+| 26 = @qualified_namespace_access
+| 27 = @mapped_typeexpr
+| 28 = @conditional_typeexpr
+| 29 = @infer_typeexpr
+| 30 = @import_type_access
+| 31 = @import_namespace_access
+| 32 = @import_var_type_access
+| 33 = @optional_typeexpr
+| 34 = @rest_typeexpr
+| 35 = @bigint_literal_typeexpr
+| 36 = @readonly_typeexpr
+| 37 = @template_literal_typeexpr
+;
+
+@typeref = @typeaccess | @type_decl;
+@type_identifier = @type_decl | @local_type_access | @type_label | @local_var_type_access | @local_namespace_access;
+@typeexpr_parent = @expr | @stmt | @property | @typeexpr;
+@literal_typeexpr = @string_literal_typeexpr | @number_literal_typeexpr | @boolean_literal_typeexpr | @bigint_literal_typeexpr;
+@typeaccess = @local_type_access | @qualified_type_access | @import_type_access;
+@vartypeaccess = @local_var_type_access | @qualified_var_type_access | @this_var_type_access | @import_var_type_access;
+@namespace_access = @local_namespace_access | @qualified_namespace_access | @import_namespace_access;
+@import_typeexpr = @import_type_access | @import_namespace_access | @import_var_type_access;
+
+@function_typeexpr = @plain_function_typeexpr | @constructor_typeexpr;
+
+// types
+types (
+ unique int id: @type,
+ int kind: int ref,
+ varchar(900) tostring: string ref
+);
+
+#keyset[parent, idx]
+type_child (
+ int child: @type ref,
+ int parent: @type ref,
+ int idx: int ref
+);
+
+case @type.kind of
+ 0 = @any_type
+| 1 = @string_type
+| 2 = @number_type
+| 3 = @union_type
+| 4 = @true_type
+| 5 = @false_type
+| 6 = @type_reference
+| 7 = @object_type
+| 8 = @canonical_type_variable_type
+| 9 = @typeof_type
+| 10 = @void_type
+| 11 = @undefined_type
+| 12 = @null_type
+| 13 = @never_type
+| 14 = @plain_symbol_type
+| 15 = @unique_symbol_type
+| 16 = @objectkeyword_type
+| 17 = @intersection_type
+| 18 = @tuple_type
+| 19 = @lexical_type_variable_type
+| 20 = @this_type
+| 21 = @number_literal_type
+| 22 = @string_literal_type
+| 23 = @unknown_type
+| 24 = @bigint_type
+| 25 = @bigint_literal_type
+;
+
+@boolean_literal_type = @true_type | @false_type;
+@symbol_type = @plain_symbol_type | @unique_symbol_type;
+@union_or_intersection_type = @union_type | @intersection_type;
+@typevariable_type = @canonical_type_variable_type | @lexical_type_variable_type;
+
+has_asserts_keyword(int node: @predicate_typeexpr ref);
+
+@typed_ast_node = @expr | @typeexpr | @function;
+ast_node_type(
+ unique int node: @typed_ast_node ref,
+ int typ: @type ref);
+
+declared_function_signature(
+ unique int node: @function ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_signature(
+ unique int node: @invokeexpr ref,
+ int sig: @signature_type ref
+);
+
+invoke_expr_overload_index(
+ unique int node: @invokeexpr ref,
+ int index: int ref
+);
+
+symbols (
+ unique int id: @symbol,
+ int kind: int ref,
+ varchar(900) name: string ref
+);
+
+symbol_parent (
+ unique int symbol: @symbol ref,
+ int parent: @symbol ref
+);
+
+symbol_module (
+ int symbol: @symbol ref,
+ varchar(900) moduleName: string ref
+);
+
+symbol_global (
+ int symbol: @symbol ref,
+ varchar(900) globalName: string ref
+);
+
+case @symbol.kind of
+ 0 = @root_symbol
+| 1 = @member_symbol
+| 2 = @other_symbol
+;
+
+@type_with_symbol = @type_reference | @typevariable_type | @typeof_type | @unique_symbol_type;
+@ast_node_with_symbol = @type_definition | @namespace_definition | @toplevel | @typeaccess | @namespace_access | @var_decl | @function | @invokeexpr | @import_declaration | @external_module_reference | @external_module_declaration;
+
+ast_node_symbol(
+ unique int node: @ast_node_with_symbol ref,
+ int symbol: @symbol ref);
+
+type_symbol(
+ unique int typ: @type_with_symbol ref,
+ int symbol: @symbol ref);
+
+#keyset[typ, name]
+type_property(
+ int typ: @type ref,
+ varchar(900) name: string ref,
+ int propertyType: @type ref);
+
+type_alias(
+ unique int aliasType: @type ref,
+ int underlyingType: @type ref);
+
+@literal_type = @string_literal_type | @number_literal_type | @boolean_literal_type | @bigint_literal_type;
+@type_with_literal_value = @string_literal_type | @number_literal_type | @bigint_literal_type;
+type_literal_value(
+ unique int typ: @type_with_literal_value ref,
+ varchar(900) value: string ref);
+
+signature_types (
+ unique int id: @signature_type,
+ int kind: int ref,
+ varchar(900) tostring: string ref,
+ int type_parameters: int ref,
+ int required_params: int ref
+);
+
+is_abstract_signature(
+ unique int sig: @signature_type ref
+);
+
+signature_rest_parameter(
+ unique int sig: @signature_type ref,
+ int rest_param_arra_type: @type ref
+);
+
+case @signature_type.kind of
+ 0 = @function_signature_type
+| 1 = @constructor_signature_type
+;
+
+#keyset[typ, kind, index]
+type_contains_signature (
+ int typ: @type ref,
+ int kind: int ref, // constructor/call/index
+ int index: int ref, // ordering of overloaded signatures
+ int sig: @signature_type ref
+);
+
+#keyset[parent, index]
+signature_contains_type (
+ int child: @type ref,
+ int parent: @signature_type ref,
+ int index: int ref
+);
+
+#keyset[sig, index]
+signature_parameter_name (
+ int sig: @signature_type ref,
+ int index: int ref,
+ varchar(900) name: string ref
+);
+
+number_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+string_index_type (
+ unique int baseType: @type ref,
+ int propertyType: @type ref
+);
+
+base_type_names(
+ int typeName: @symbol ref,
+ int baseTypeName: @symbol ref
+);
+
+self_types(
+ int typeName: @symbol ref,
+ int selfType: @type_reference ref
+);
+
+tuple_type_min_length(
+ unique int typ: @type ref,
+ int minLength: int ref
+);
+
+tuple_type_rest_index(
+ unique int typ: @type ref,
+ int index: int ref
+);
+
+// comments
+comments (unique int id: @comment,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(900) tostring: string ref);
+
+case @comment.kind of
+ 0 = @slashslash_comment
+| 1 = @slashstar_comment
+| 2 = @doc_comment
+| 3 = @html_comment_start
+| 4 = @htmlcommentend;
+
+@html_comment = @html_comment_start | @htmlcommentend;
+@line_comment = @slashslash_comment | @html_comment;
+@block_comment = @slashstar_comment | @doc_comment;
+
+// source lines
+lines (unique int id: @line,
+ int toplevel: @toplevel ref,
+ varchar(900) text: string ref,
+ varchar(2) terminator: string ref);
+indentation (int file: @file ref,
+ int lineno: int ref,
+ varchar(1) indentChar: string ref,
+ int indentDepth: int ref);
+
+// JavaScript parse errors
+js_parse_errors (unique int id: @js_parse_error,
+ int toplevel: @toplevel ref,
+ varchar(900) message: string ref,
+ varchar(900) line: string ref);
+
+// regular expressions
+#keyset[parent, idx]
+regexpterm (unique int id: @regexpterm,
+ int kind: int ref,
+ int parent: @regexpparent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+@regexpparent = @regexpterm | @regexp_literal | @string_literal | @add_expr;
+
+case @regexpterm.kind of
+ 0 = @regexp_alt
+| 1 = @regexp_seq
+| 2 = @regexp_caret
+| 3 = @regexp_dollar
+| 4 = @regexp_wordboundary
+| 5 = @regexp_nonwordboundary
+| 6 = @regexp_positive_lookahead
+| 7 = @regexp_negative_lookahead
+| 8 = @regexp_star
+| 9 = @regexp_plus
+| 10 = @regexp_opt
+| 11 = @regexp_range
+| 12 = @regexp_dot
+| 13 = @regexp_group
+| 14 = @regexp_normal_constant
+| 15 = @regexp_hex_escape
+| 16 = @regexp_unicode_escape
+| 17 = @regexp_dec_escape
+| 18 = @regexp_oct_escape
+| 19 = @regexp_ctrl_escape
+| 20 = @regexp_char_class_escape
+| 21 = @regexp_id_escape
+| 22 = @regexp_backref
+| 23 = @regexp_char_class
+| 24 = @regexp_char_range
+| 25 = @regexp_positive_lookbehind
+| 26 = @regexp_negative_lookbehind
+| 27 = @regexp_unicode_property_escape
+| 28 = @regexp_quoted_string
+| 29 = @regexp_intersection
+| 30 = @regexp_subtraction;
+
+regexp_parse_errors (unique int id: @regexp_parse_error,
+ int regexp: @regexpterm ref,
+ varchar(900) message: string ref);
+
+@regexp_quantifier = @regexp_star | @regexp_plus | @regexp_opt | @regexp_range;
+@regexp_escape = @regexp_char_escape | @regexp_char_class_escape | @regexp_unicode_property_escape;
+@regexp_char_escape = @regexp_hex_escape | @regexp_unicode_escape | @regexp_dec_escape | @regexp_oct_escape | @regexp_ctrl_escape | @regexp_id_escape;
+@regexp_constant = @regexp_normal_constant | @regexp_char_escape;
+@regexp_lookahead = @regexp_positive_lookahead | @regexp_negative_lookahead;
+@regexp_lookbehind = @regexp_positive_lookbehind | @regexp_negative_lookbehind;
+@regexp_subpattern = @regexp_lookahead | @regexp_lookbehind;
+@regexp_anchor = @regexp_dollar | @regexp_caret;
+
+is_greedy (int id: @regexp_quantifier ref);
+range_quantifier_lower_bound (unique int id: @regexp_range ref, int lo: int ref);
+range_quantifier_upper_bound (unique int id: @regexp_range ref, int hi: int ref);
+is_capture (unique int id: @regexp_group ref, int number: int ref);
+is_named_capture (unique int id: @regexp_group ref, string name: string ref);
+is_inverted (int id: @regexp_char_class ref);
+regexp_const_value (unique int id: @regexp_constant ref, varchar(1) value: string ref);
+char_class_escape (unique int id: @regexp_char_class_escape ref, varchar(1) value: string ref);
+backref (unique int id: @regexp_backref ref, int value: int ref);
+named_backref (unique int id: @regexp_backref ref, string name: string ref);
+unicode_property_escapename (unique int id: @regexp_unicode_property_escape ref, string name: string ref);
+unicode_property_escapevalue (unique int id: @regexp_unicode_property_escape ref, string value: string ref);
+
+// tokens
+#keyset[toplevel, idx]
+tokeninfo (unique int id: @token,
+ int kind: int ref,
+ int toplevel: @toplevel ref,
+ int idx: int ref,
+ varchar(900) value: string ref);
+
+case @token.kind of
+ 0 = @token_eof
+| 1 = @token_null_literal
+| 2 = @token_boolean_literal
+| 3 = @token_numeric_literal
+| 4 = @token_string_literal
+| 5 = @token_regular_expression
+| 6 = @token_identifier
+| 7 = @token_keyword
+| 8 = @token_punctuator;
+
+// associate comments with the token immediately following them (which may be EOF)
+next_token (int comment: @comment ref, int token: @token ref);
+
+// JSON
+#keyset[parent, idx]
+json (unique int id: @json_value,
+ int kind: int ref,
+ int parent: @json_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+
+json_literals (varchar(900) value: string ref,
+ varchar(900) raw: string ref,
+ unique int expr: @json_value ref);
+
+json_properties (int obj: @json_object ref,
+ varchar(900) property: string ref,
+ int value: @json_value ref);
+
+json_errors (unique int id: @json_parse_error,
+ varchar(900) message: string ref);
+
+json_locations(unique int locatable: @json_locatable ref,
+ int location: @location_default ref);
+
+case @json_value.kind of
+ 0 = @json_null
+| 1 = @json_boolean
+| 2 = @json_number
+| 3 = @json_string
+| 4 = @json_array
+| 5 = @json_object;
+
+@json_parent = @json_object | @json_array | @file;
+
+@json_locatable = @json_value | @json_parse_error;
+
+// locations
+@ast_node = @toplevel | @stmt | @expr | @property | @typeexpr;
+
+@locatable = @file
+ | @ast_node
+ | @comment
+ | @line
+ | @js_parse_error | @regexp_parse_error
+ | @regexpterm
+ | @json_locatable
+ | @token
+ | @cfg_node
+ | @jsdoc | @jsdoc_type_expr | @jsdoc_tag
+ | @yaml_locatable
+ | @xmllocatable
+ | @configLocatable
+ | @template_placeholder_tag;
+
+hasLocation (unique int locatable: @locatable ref,
+ int location: @location ref);
+
+// CFG
+entry_cfg_node (unique int id: @entry_node, int container: @stmt_container ref);
+exit_cfg_node (unique int id: @exit_node, int container: @stmt_container ref);
+guard_node (unique int id: @guard_node, int kind: int ref, int test: @expr ref);
+case @guard_node.kind of
+ 0 = @falsy_guard
+| 1 = @truthy_guard;
+@condition_guard = @falsy_guard | @truthy_guard;
+
+@synthetic_cfg_node = @entry_node | @exit_node | @guard_node;
+@cfg_node = @synthetic_cfg_node | @expr_parent;
+
+successor (int pred: @cfg_node ref, int succ: @cfg_node ref);
+
+// JSDoc comments
+jsdoc (unique int id: @jsdoc, varchar(900) description: string ref, int comment: @comment ref);
+#keyset[parent, idx]
+jsdoc_tags (unique int id: @jsdoc_tag, varchar(900) title: string ref,
+ int parent: @jsdoc ref, int idx: int ref, varchar(900) tostring: string ref);
+jsdoc_tag_descriptions (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+jsdoc_tag_names (unique int tag: @jsdoc_tag ref, varchar(900) text: string ref);
+
+#keyset[parent, idx]
+jsdoc_type_exprs (unique int id: @jsdoc_type_expr,
+ int kind: int ref,
+ int parent: @jsdoc_type_expr_parent ref,
+ int idx: int ref,
+ varchar(900) tostring: string ref);
+case @jsdoc_type_expr.kind of
+ 0 = @jsdoc_any_type_expr
+| 1 = @jsdoc_null_type_expr
+| 2 = @jsdoc_undefined_type_expr
+| 3 = @jsdoc_unknown_type_expr
+| 4 = @jsdoc_void_type_expr
+| 5 = @jsdoc_identifier_type_expr
+| 6 = @jsdoc_applied_type_expr
+| 7 = @jsdoc_nullable_type_expr
+| 8 = @jsdoc_non_nullable_type_expr
+| 9 = @jsdoc_record_type_expr
+| 10 = @jsdoc_array_type_expr
+| 11 = @jsdoc_union_type_expr
+| 12 = @jsdoc_function_type_expr
+| 13 = @jsdoc_optional_type_expr
+| 14 = @jsdoc_rest_type_expr
+| 15 = @jsdoc_qualified_type_expr
+;
+
+#keyset[id, idx]
+jsdoc_record_field_name (int id: @jsdoc_record_type_expr ref, int idx: int ref, varchar(900) name: string ref);
+jsdoc_prefix_qualifier (int id: @jsdoc_type_expr ref);
+jsdoc_has_new_parameter (int fn: @jsdoc_function_type_expr ref);
+
+@jsdoc_type_expr_parent = @jsdoc_type_expr | @jsdoc_tag;
+
+jsdoc_errors (unique int id: @jsdoc_error, int tag: @jsdoc_tag ref, varchar(900) message: string ref, varchar(900) tostring: string ref);
+
+@dataflownode = @expr | @function_decl_stmt | @class_decl_stmt | @namespace_declaration | @enum_declaration | @property;
+
+@optionalchainable = @call_expr | @propaccess;
+
+isOptionalChaining(int id: @optionalchainable ref);
+
+/**
+ * The time taken for the extraction of a file.
+ * This table contains non-deterministic content.
+ *
+ * The sum of the `time` column for each (`file`, `timerKind`) pair
+ * is the total time taken for extraction of `file`. The `extractionPhase`
+ * column provides a granular view of the extraction time of the file.
+ */
+extraction_time(
+ int file : @file ref,
+ // see `com.semmle.js.extractor.ExtractionMetrics.ExtractionPhase`.
+ int extractionPhase: int ref,
+ // 0 for the elapsed CPU time in nanoseconds, 1 for the elapsed wallclock time in nanoseconds
+ int timerKind: int ref,
+ float time: float ref
+)
+
+/**
+* Non-timing related data for the extraction of a single file.
+* This table contains non-deterministic content.
+*/
+extraction_data(
+ int file : @file ref,
+ // the absolute path to the cache file
+ varchar(900) cacheFile: string ref,
+ boolean fromCache: boolean ref,
+ int length: int ref
+)
+
+/*- YAML -*/
+
+#keyset[parent, idx]
+yaml (unique int id: @yaml_node,
+ int kind: int ref,
+ int parent: @yaml_node_parent ref,
+ int idx: int ref,
+ string tag: string ref,
+ string tostring: string ref);
+
+case @yaml_node.kind of
+ 0 = @yaml_scalar_node
+| 1 = @yaml_mapping_node
+| 2 = @yaml_sequence_node
+| 3 = @yaml_alias_node
+;
+
+@yaml_collection_node = @yaml_mapping_node | @yaml_sequence_node;
+
+@yaml_node_parent = @yaml_collection_node | @file;
+
+yaml_anchors (unique int node: @yaml_node ref,
+ string anchor: string ref);
+
+yaml_aliases (unique int alias: @yaml_alias_node ref,
+ string target: string ref);
+
+yaml_scalars (unique int scalar: @yaml_scalar_node ref,
+ int style: int ref,
+ string value: string ref);
+
+yaml_errors (unique int id: @yaml_error,
+ string message: string ref);
+
+yaml_locations(unique int locatable: @yaml_locatable ref,
+ int location: @location_default ref);
+
+@yaml_locatable = @yaml_node | @yaml_error;
+
+/*- XML Files -*/
+
+xmlEncoding(
+ unique int id: @file ref,
+ string encoding: string ref
+);
+
+xmlDTDs(
+ unique int id: @xmldtd,
+ string root: string ref,
+ string publicId: string ref,
+ string systemId: string ref,
+ int fileid: @file ref
+);
+
+xmlElements(
+ unique int id: @xmlelement,
+ string name: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlAttrs(
+ unique int id: @xmlattribute,
+ int elementid: @xmlelement ref,
+ string name: string ref,
+ string value: string ref,
+ int idx: int ref,
+ int fileid: @file ref
+);
+
+xmlNs(
+ int id: @xmlnamespace,
+ string prefixName: string ref,
+ string URI: string ref,
+ int fileid: @file ref
+);
+
+xmlHasNs(
+ int elementId: @xmlnamespaceable ref,
+ int nsId: @xmlnamespace ref,
+ int fileid: @file ref
+);
+
+xmlComments(
+ unique int id: @xmlcomment,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int fileid: @file ref
+);
+
+xmlChars(
+ unique int id: @xmlcharacters,
+ string text: string ref,
+ int parentid: @xmlparent ref,
+ int idx: int ref,
+ int isCDATA: int ref,
+ int fileid: @file ref
+);
+
+@xmlparent = @file | @xmlelement;
+@xmlnamespaceable = @xmlelement | @xmlattribute;
+
+xmllocations(
+ int xmlElement: @xmllocatable ref,
+ int location: @location_default ref
+);
+
+@xmllocatable = @xmlcharacters | @xmlelement | @xmlcomment | @xmlattribute | @xmldtd | @file | @xmlnamespace;
+
+/*- Configuration files with key value pairs -*/
+
+configs(
+ unique int id: @config
+);
+
+configNames(
+ unique int id: @configName,
+ int config: @config ref,
+ string name: string ref
+);
+
+configValues(
+ unique int id: @configValue,
+ int config: @config ref,
+ string value: string ref
+);
+
+configLocations(
+ int locatable: @configLocatable ref,
+ int location: @location_default ref
+);
+
+@configLocatable = @config | @configName | @configValue;
+
+/*- Database metadata -*/
+databaseMetadata(
+ string metadataKey: string ref,
+ string value: string ref
+);
+
+overlayChangedFiles(
+ string path: string ref
+);
diff --git a/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/upgrade.properties b/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/upgrade.properties
new file mode 100644
index 00000000000..4ff972031d7
--- /dev/null
+++ b/javascript/ql/lib/upgrades/ccefb5e2d49318eea4aeafd4c6ae2af9f94ac72a/upgrade.properties
@@ -0,0 +1,2 @@
+description: add overlay relations
+compatibility: full
From 678345621354a6c4cb0d900ece5dadd2aa1f2cf8 Mon Sep 17 00:00:00 2001
From: Asger F
Date: Wed, 2 Jul 2025 11:29:37 +0200
Subject: [PATCH 091/298] JS: Add discard predicates
---
javascript/ql/lib/javascript.qll | 1 +
.../semmle/javascript/internal/Overlay.qll | 30 +++++++++++++++++++
2 files changed, 31 insertions(+)
create mode 100644 javascript/ql/lib/semmle/javascript/internal/Overlay.qll
diff --git a/javascript/ql/lib/javascript.qll b/javascript/ql/lib/javascript.qll
index 88e46c77453..ad9cfe009b5 100644
--- a/javascript/ql/lib/javascript.qll
+++ b/javascript/ql/lib/javascript.qll
@@ -146,3 +146,4 @@ import semmle.javascript.linters.JSLint
import semmle.javascript.linters.Linting
import semmle.javascript.security.dataflow.RemoteFlowSources
import semmle.javascript.frameworks.UnderscoreDotString
+private import semmle.javascript.internal.Overlay
diff --git a/javascript/ql/lib/semmle/javascript/internal/Overlay.qll b/javascript/ql/lib/semmle/javascript/internal/Overlay.qll
new file mode 100644
index 00000000000..a20ac1868e6
--- /dev/null
+++ b/javascript/ql/lib/semmle/javascript/internal/Overlay.qll
@@ -0,0 +1,30 @@
+private import javascript
+
+/** Holds if the database is an overlay. */
+overlay[local]
+private predicate isOverlay() { databaseMetadata("isOverlay", "true") }
+
+overlay[local]
+private string getFileFromEntity(@locatable node) {
+ exists(@location loc, @file file |
+ hasLocation(node, loc) and
+ locations_default(loc, file, _, _, _, _) and
+ files(file, result)
+ )
+}
+
+/** Holds if `file` was changed or deleted in the overlay. */
+overlay[local]
+private predicate discardFile(string file) { isOverlay() and overlayChangedFiles(file) }
+
+/** Holds if `node` is in the `file` and is part of the overlay base database. */
+overlay[local]
+private predicate discardableEntity(string file, @locatable node) {
+ not isOverlay() and file = getFileFromEntity(node)
+}
+
+/** Holds if `node` should be discarded, because it is part of the overlay base and is in a file that was also extracted as part of the overlay database. */
+overlay[discard_entity]
+private predicate discardEntity(@locatable node) {
+ exists(string file | discardableEntity(file, node) and discardFile(file))
+}
From d38459a50a6df43d521fe162db0c2581611cd8f0 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 19 Aug 2025 12:46:16 +0200
Subject: [PATCH 092/298] Fix `ForTypeRepr` docs and test with proper instance
---
rust/ql/.generated.list | 8 ++++----
rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll | 7 +++----
.../lib/codeql/rust/elements/internal/ForTypeReprImpl.qll | 7 +++----
.../rust/elements/internal/generated/ForTypeRepr.qll | 7 +++----
.../lib/codeql/rust/elements/internal/generated/Raw.qll | 7 +++----
.../test/extractor-tests/generated/.generated_tests.list | 2 +-
.../generated/ForTypeRepr/ForTypeRepr.expected | 6 +++---
.../generated/ForTypeRepr/gen_for_type_repr.rs | 7 +++----
rust/schema/annotations.py | 7 +++----
9 files changed, 26 insertions(+), 32 deletions(-)
diff --git a/rust/ql/.generated.list b/rust/ql/.generated.list
index 96f12505868..86016b745f3 100644
--- a/rust/ql/.generated.list
+++ b/rust/ql/.generated.list
@@ -58,7 +58,7 @@ lib/codeql/rust/elements/FieldList.qll 72f3eace2f0c0600b1ad059819ae756f1feccd155
lib/codeql/rust/elements/FnPtrTypeRepr.qll d4586ac5ee2382b5ef9daafa77c7b3c1b7564647aa20d1efb1626299cde87ba9 48d9b63725c9cd89d79f9806fa5d5f22d7815e70bbd78d8da40a2359ac53fef5
lib/codeql/rust/elements/ForBinder.qll ee29b55cb4c1fa5180cc4ee1236ac089fe9f67ffa9e5a1474003b717f1ac6e0f 5b811c8cf9550cb675034315e03c5cbbfa7544ad3a696988e04d780037d434bf
lib/codeql/rust/elements/ForExpr.qll a050f60cf6fcc3ce66f5042be1b8096e5207fe2674d7477f9e299091ca99a4bd d7198495139649778894e930163add2d16b5588dd12bd6e094a9aec6863cb16f
-lib/codeql/rust/elements/ForTypeRepr.qll 32473eeafc32aabfda770d585fd77a19f4eb0b55f1d78ae78f220b6371b6169c a3c4d5d406abe5513f3ed7a80a3d1cbd4d5cdeec2704eb1c12081220ebe44618
+lib/codeql/rust/elements/ForTypeRepr.qll c85c5e368b9db4a308b55259b3e6b1f4d37050984de43b24971243d6ca6dcec5 51b1c3ddac2fb9616ec44816bcbb549df2c15bbbe674d045a7b1c352c1e335e3
lib/codeql/rust/elements/Format.qll 1b186730710e7e29ea47594998f0b359ad308927f84841adae0c0cb35fc8aeda d6f7bfdda60a529fb9e9a1975628d5bd11aa28a45e295c7526692ac662fd19f8
lib/codeql/rust/elements/FormatArgsArg.qll a2c23cd512d44dd60b7d65eba52cc3adf6e2fbbcd0588be375daa16002cd7741 d9c5fe183fb228375223d83f857b7a9ee686f1d3e341bcf323d7c6f39652f88b
lib/codeql/rust/elements/FormatArgsExpr.qll 8127cbe4082f7acc3d8a05298c2c9bea302519b8a6cd2d158a83c516d18fc487 88cf9b3bedd69a1150968f9a465c904bbb6805da0e0b90cfd1fc0dab1f6d9319
@@ -274,7 +274,7 @@ lib/codeql/rust/elements/internal/FnPtrTypeReprImpl.qll 6b66f9bda1b5deba50a02b6a
lib/codeql/rust/elements/internal/ForBinderConstructor.qll 98f16b0106a19210713404f4be8b1b9f70c88efb0b88bdf2f9ea9c8fbd129842 a7af9e75f11d824a60c367924542a31a0f46f7b1f88d3ee330d4dd26b2f29df5
lib/codeql/rust/elements/internal/ForExprConstructor.qll d79b88dac19256300b758ba0f37ce3f07e9f848d6ae0c1fdb87bd348e760aa3e 62123b11858293429aa609ea77d2f45cb8c8eebae80a1d81da6f3ad7d1dbc19b
lib/codeql/rust/elements/internal/ForTypeReprConstructor.qll eae141dbe9256ab0eb812a926ebf226075d150f6506dfecb56c85eb169cdc76b 721c2272193a6f9504fb780d40e316a93247ebfb1f302bb0a0222af689300245
-lib/codeql/rust/elements/internal/ForTypeReprImpl.qll d710208dfd3f54d973e86356f051e2938fed1025562965d6ecf6b19c0701de16 510baafa9ebc9b32969cefc5b68716fa02696f5814ae417b0cd2d9aece69f6ac
+lib/codeql/rust/elements/internal/ForTypeReprImpl.qll dbbcb86626dcba3d5534d461d7306c354a15f800ff37c1d039801b868179b387 f942eebb20fb2603b7bab0e90f3e3f7a3f87dd6229090fc011c692a52164ac90
lib/codeql/rust/elements/internal/FormatArgsArgConstructor.qll 8bd9b4e035ef8adeb3ac510dd68043934c0140facb933be1f240096d01cdfa11 74e9d3bbd8882ae59a7e88935d468e0a90a6529a4e2af6a3d83e93944470f0ee
lib/codeql/rust/elements/internal/FormatArgsArgImpl.qll 6a8f55e51e141e4875ed03a7cc65eea49daa349de370b957e1e8c6bc4478425c 7efab8981ccbe75a4843315404674793dda66dde02ba432edbca25c7d355778a
lib/codeql/rust/elements/internal/FormatArgsExprConstructor.qll ce29ff5a839b885b1ab7a02d6a381ae474ab1be3e6ee7dcfd7595bdf28e4b558 63bf957426871905a51ea319662a59e38104c197a1024360aca364dc145b11e8
@@ -514,7 +514,7 @@ lib/codeql/rust/elements/internal/generated/FieldList.qll 35bb72a673c02afafc1f61
lib/codeql/rust/elements/internal/generated/FnPtrTypeRepr.qll f218fa57a01ecc39b58fa15893d6499c15ff8ab8fd9f4ed3078f0ca8b3f15c7e 2d1a7325cf2bd0174ce6fc15e0cbe39c7c1d8b40db5f91e5329acb339a1ad1e8
lib/codeql/rust/elements/internal/generated/ForBinder.qll 7be6b8e3934db8cd4ac326625cf637dda4b175fd7573a52d2feb147769c4c6a1 234484b9b4cf3a20c97334417700db5029da65313410b3c9e929512c509e5c27
lib/codeql/rust/elements/internal/generated/ForExpr.qll 7c497d2c612fd175069037d6d7ff9339e8aec63259757bb56269e9ca8b0114ea dc48c0ad3945868d6bd5e41ca34a41f8ee74d8ba0adc62b440256f59c7f21096
-lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll 11f21528d55f41d28d2b1da71631da1c02053ac723e697b886e586572c919999 852b977fe46b87efd6741a2f3c7e3d22a7e2a55a75b9c26d9dc4ea2154fe3653
+lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll 7daa3b938592b590d604203e7d0fc5c34c2bffe6adcceee5a5e0c681ed16214c f1380179cbdc188ad133c946d9e17e85aed0d77771b319f663d8eada0f7cf17d
lib/codeql/rust/elements/internal/generated/Format.qll 934351f8a8ffd914cc3fd88aca8e81bf646236fe34d15e0df7aeeb0b942b203f da9f146e6f52bafd67dcfd3b916692cf8f66031e0b1d5d17fc8dda5eefb99ca0
lib/codeql/rust/elements/internal/generated/FormatArgsArg.qll c762a4af8609472e285dd1b1aec8251421aec49f8d0e5ce9df2cc5e2722326f8 c8c226b94b32447634b445c62bd9af7e11b93a706f8fa35d2de4fda3ce951926
lib/codeql/rust/elements/internal/generated/FormatArgsExpr.qll 8aed8715a27d3af3de56ded4610c6792a25216b1544eb7e57c8b0b37c14bd9c1 590a2b0063d2ecd00bbbd1ce29603c8fd69972e34e6daddf309c915ce4ec1375
@@ -589,7 +589,7 @@ lib/codeql/rust/elements/internal/generated/PtrTypeRepr.qll 8d0ea4f6c7f8203340bf
lib/codeql/rust/elements/internal/generated/PureSynthConstructors.qll e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f
lib/codeql/rust/elements/internal/generated/RangeExpr.qll 23cca03bf43535f33b22a38894f70d669787be4e4f5b8fe5c8f7b964d30e9027 18624cef6c6b679eeace2a98737e472432e0ead354cca02192b4d45330f047c9
lib/codeql/rust/elements/internal/generated/RangePat.qll 80826a6a6868a803aa2372e31c52a03e1811a3f1f2abdb469f91ca0bfdd9ecb6 34ee1e208c1690cba505dff2c588837c0cd91e185e2a87d1fe673191962276a9
-lib/codeql/rust/elements/internal/generated/Raw.qll e33ef2818c9bbdd5030903592ba07286c28b35b1952fa3f4ffb0ce27173fef04 fb0a5e30947e13a06d867049ced5547d5d7bc80ac2f55c6912b2c0d1d1446072
+lib/codeql/rust/elements/internal/generated/Raw.qll 1578a58b7115fed2bfdaf65c3a9e6ef8318660b11a9c8f1cc334114f9c38e0af a8ea88419f42be7a40d7419d07a0469380ba3c4706e6a580554a4c28e216fc00
lib/codeql/rust/elements/internal/generated/RefExpr.qll 7d995884e3dc1c25fc719f5d7253179344d63650e217e9ff6530285fe7a57f64 f2c3c12551deea4964b66553fb9b6423ee16fec53bd63db4796191aa60dc6c66
lib/codeql/rust/elements/internal/generated/RefPat.qll 456ede39837463ee22a630ec7ab6c8630d3664a8ea206fcc6e4f199e92fa564c 5622062765f32930465ba6b170e986706f159f6070f48adee3c20e24e8df4e05
lib/codeql/rust/elements/internal/generated/RefTypeRepr.qll 5b0663a6d234572fb3e467e276d019415caa95ef006438cc59b7af4e1783161e 0e27c8a8f0e323c0e4d6db01fca821bf07c0864d293cdf96fa891b10820c1e4b
diff --git a/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll b/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
index 6b58c0c70f6..4b882044d06 100644
--- a/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
+++ b/rust/ql/lib/codeql/rust/elements/ForTypeRepr.qll
@@ -8,13 +8,12 @@ import codeql.rust.elements.ForBinder
import codeql.rust.elements.TypeRepr
/**
- * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
- * only be applied to traits to form a `TypeBound`).
+ * A function pointer type with a `for` modifier.
*
* For example:
* ```rust
- * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
- * // ^^^^^^^^^^^^^
+ * type RefOp = for<'a> fn(&'a X) -> &'a X;
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^^^
* ```
*/
final class ForTypeRepr = Impl::ForTypeRepr;
diff --git a/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll
index 961085f026a..409c0d94c94 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/ForTypeReprImpl.qll
@@ -13,13 +13,12 @@ private import codeql.rust.elements.internal.generated.ForTypeRepr
*/
module Impl {
/**
- * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
- * only be applied to traits to form a `TypeBound`).
+ * A function pointer type with a `for` modifier.
*
* For example:
* ```rust
- * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
- * // ^^^^^^^^^^^^^
+ * type RefOp = for<'a> fn(&'a X) -> &'a X;
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^^^
* ```
*/
class ForTypeRepr extends Generated::ForTypeRepr { }
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
index 49e0f009c09..56745b56f00 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ForTypeRepr.qll
@@ -16,13 +16,12 @@ import codeql.rust.elements.internal.TypeReprImpl::Impl as TypeReprImpl
*/
module Generated {
/**
- * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
- * only be applied to traits to form a `TypeBound`).
+ * A function pointer type with a `for` modifier.
*
* For example:
* ```rust
- * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
- * // ^^^^^^^^^^^^^
+ * type RefOp = for<'a> fn(&'a X) -> &'a X;
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^^^
* ```
* INTERNAL: Do not reference the `Generated::ForTypeRepr` class directly.
* Use the subclass `ForTypeRepr`, where the following predicates are available.
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
index c689089be1e..d0aa59d583e 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
@@ -2204,13 +2204,12 @@ module Raw {
/**
* INTERNAL: Do not use.
- * A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
- * only be applied to traits to form a `TypeBound`).
+ * A function pointer type with a `for` modifier.
*
* For example:
* ```rust
- * fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
- * // ^^^^^^^^^^^^^
+ * type RefOp = for<'a> fn(&'a X) -> &'a X;
+ * // ^^^^^^^^^^^^^^^^^^^^^^^^^^
* ```
*/
class ForTypeRepr extends @for_type_repr, TypeRepr {
diff --git a/rust/ql/test/extractor-tests/generated/.generated_tests.list b/rust/ql/test/extractor-tests/generated/.generated_tests.list
index 2cfccde4c10..e41f01de20a 100644
--- a/rust/ql/test/extractor-tests/generated/.generated_tests.list
+++ b/rust/ql/test/extractor-tests/generated/.generated_tests.list
@@ -42,7 +42,7 @@ FieldExpr/gen_field_expr.rs 9a70500d592e0a071b03d974a55558b3bc0df531ff11bce5898f
FnPtrTypeRepr/gen_fn_ptr_type_repr.rs c154ec0cc43236d133f6b946374f3063b89e5cbf9e96d9ee66877be4f948888e c154ec0cc43236d133f6b946374f3063b89e5cbf9e96d9ee66877be4f948888e
ForBinder/gen_for_binder.rs e3c9e5ffd3f2a5a546af9ab6e2a2ed733baf9cf609e05850b70feb31478a0bae e3c9e5ffd3f2a5a546af9ab6e2a2ed733baf9cf609e05850b70feb31478a0bae
ForExpr/gen_for_expr.rs 003dc36e3dc4db6e3a4accd410c316f14334ba5b3d5d675c851a91dcd5185122 003dc36e3dc4db6e3a4accd410c316f14334ba5b3d5d675c851a91dcd5185122
-ForTypeRepr/gen_for_type_repr.rs d6dc10cdb4f505447805d24e83a24f876f2b6e6d8cdb193e786405f3ffbc7cda d6dc10cdb4f505447805d24e83a24f876f2b6e6d8cdb193e786405f3ffbc7cda
+ForTypeRepr/gen_for_type_repr.rs fdbcbce6065082f350f8d3f77c23424bec8883336e4cd69ce8f41b185a51dc50 fdbcbce6065082f350f8d3f77c23424bec8883336e4cd69ce8f41b185a51dc50
FormatArgsExpr/gen_format.rs e9d8e7b98d0050ad6053c2459cb21faab00078e74245336a5962438336f76d33 e9d8e7b98d0050ad6053c2459cb21faab00078e74245336a5962438336f76d33
FormatArgsExpr/gen_format_args_arg.rs 53ffd6abe4cd899c57d1973b31df0edc1d5eaa5835b19172ec4cda15bb3db28f 53ffd6abe4cd899c57d1973b31df0edc1d5eaa5835b19172ec4cda15bb3db28f
FormatArgsExpr/gen_format_args_expr.rs 72c806ed163e9dcce2d0c5c8664d409b2aa635c1022c91959f9e8ae084f05bf2 72c806ed163e9dcce2d0c5c8664d409b2aa635c1022c91959f9e8ae084f05bf2
diff --git a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
index 896894bcc06..11c4d0212a7 100644
--- a/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
+++ b/rust/ql/test/extractor-tests/generated/ForTypeRepr/ForTypeRepr.expected
@@ -1,6 +1,6 @@
instances
-| gen_for_type_repr.rs:8:19:8:31 | ForTypeRepr |
+| gen_for_type_repr.rs:7:21:7:46 | ForTypeRepr |
getForBinder
-| gen_for_type_repr.rs:8:19:8:31 | ForTypeRepr | gen_for_type_repr.rs:8:19:8:25 | for<...> |
+| gen_for_type_repr.rs:7:21:7:46 | ForTypeRepr | gen_for_type_repr.rs:7:21:7:27 | for<...> |
getTypeRepr
-| gen_for_type_repr.rs:8:19:8:31 | ForTypeRepr | gen_for_type_repr.rs:8:27:8:31 | usize |
+| gen_for_type_repr.rs:7:21:7:46 | ForTypeRepr | gen_for_type_repr.rs:7:29:7:46 | FnPtrTypeRepr |
diff --git a/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs b/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs
index 448cd5f615f..99072c25bcf 100644
--- a/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs
+++ b/rust/ql/test/extractor-tests/generated/ForTypeRepr/gen_for_type_repr.rs
@@ -1,10 +1,9 @@
// generated by codegen, do not edit
fn test_for_type_repr() -> () {
- // A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
- // only be applied to traits to form a `TypeBound`).
+ // A function pointer type with a `for` modifier.
//
// For example:
- fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
- // ^^^^^^^^^^^^^
+ type RefOp = for<'a> fn(&'a X) -> &'a X;
+ // ^^^^^^^^^^^^^^^^^^^^^^^^^^
}
diff --git a/rust/schema/annotations.py b/rust/schema/annotations.py
index 6b7cb3f4f76..bc07e1610f1 100644
--- a/rust/schema/annotations.py
+++ b/rust/schema/annotations.py
@@ -1158,13 +1158,12 @@ class _:
@annotate(ForTypeRepr)
class _:
"""
- A type with a higher-ranked `for` modifier. This is currently not valid Rust syntax (`for<...>` can
- only be applied to traits to form a `TypeBound`).
+ A function pointer type with a `for` modifier.
For example:
```rust
- fn foo(value: for<'a> usize) {} // DOESN'T COMPILE
- // ^^^^^^^^^^^^^
+ type RefOp = for<'a> fn(&'a X) -> &'a X;
+ // ^^^^^^^^^^^^^^^^^^^^^^^^^^
```
"""
From 49bf48eda167acc99f323e355c851c8286dcac96 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 19 Aug 2025 14:01:25 +0200
Subject: [PATCH 093/298] Rust: fix duplicate `asm!` expressions
---
rust/ast-generator/src/main.rs | 1 +
rust/extractor/src/generated/.generated.list | 2 +-
rust/extractor/src/generated/top.rs | 8 ++--
rust/extractor/src/translate/base.rs | 32 +++++++++++++++
rust/extractor/src/translate/generated.rs | 18 ---------
rust/ql/.generated.list | 14 +++----
.../internal/generated/CfgNodes.qll | 34 +++++++++-------
.../codeql/rust/elements/MacroBlockExpr.qll | 10 ++++-
.../elements/internal/MacroBlockExprImpl.qll | 10 ++++-
.../internal/generated/MacroBlockExpr.qll | 40 +++++++++++--------
.../internal/generated/ParentChild.qll | 12 +++---
.../rust/elements/internal/generated/Raw.qll | 20 ++++++----
rust/ql/lib/rust.dbscheme | 12 +++---
.../generated/.generated_tests.list | 2 +-
.../AsmClobberAbi/AsmClobberAbi.expected | 1 -
.../generated/AsmConst/AsmConst.expected | 2 -
.../generated/AsmDirSpec/AsmDirSpec.expected | 2 -
.../generated/AsmLabel/AsmLabel.expected | 2 -
.../AsmOperandExpr/AsmOperandExpr.expected | 6 ---
.../AsmOperandNamed/AsmOperandNamed.expected | 5 ---
.../generated/AsmOption/AsmOption.expected | 2 -
.../AsmOptionsList/AsmOptionsList.expected | 3 --
.../AsmRegOperand/AsmRegOperand.expected | 8 ----
.../generated/AsmRegSpec/AsmRegSpec.expected | 3 --
.../generated/AsmSym/AsmSym.expected | 2 -
.../MacroBlockExpr/MacroBlockExpr.expected | 8 ++--
.../MacroBlockExpr/MacroBlockExpr.ql | 8 ++--
.../MacroBlockExpr/gen_macro_block_expr.rs | 14 +++++--
rust/schema/annotations.py | 18 ++++++---
rust/schema/ast.py | 4 --
30 files changed, 163 insertions(+), 140 deletions(-)
diff --git a/rust/ast-generator/src/main.rs b/rust/ast-generator/src/main.rs
index d612985ff9f..e67152c3d0f 100644
--- a/rust/ast-generator/src/main.rs
+++ b/rust/ast-generator/src/main.rs
@@ -82,6 +82,7 @@ fn should_enum_be_skipped(name: &str) -> bool {
fn should_node_be_skipped(name: &str) -> bool {
name == "TypeAnchor" // we flatten TypeAnchor into PathSegment in the extractor
+ || name == "MacroStmts" // we workaround a getter bug in the extractor
}
fn should_node_be_skipped_in_extractor(name: &str) -> bool {
diff --git a/rust/extractor/src/generated/.generated.list b/rust/extractor/src/generated/.generated.list
index 62fb59a50ca..1ac7818e6a2 100644
--- a/rust/extractor/src/generated/.generated.list
+++ b/rust/extractor/src/generated/.generated.list
@@ -1,2 +1,2 @@
mod.rs 4bcb9def847469aae9d8649461546b7c21ec97cf6e63d3cf394e339915ce65d7 4bcb9def847469aae9d8649461546b7c21ec97cf6e63d3cf394e339915ce65d7
-top.rs a2b836f6f4c1332cdc2bcf7a4201765f22635f976892725aa424d7b306b6b586 a2b836f6f4c1332cdc2bcf7a4201765f22635f976892725aa424d7b306b6b586
+top.rs cf4f3f6b3fd0dee0d8b35f346695cfd3e080ca328ca1726ce851f6abfbabc631 cf4f3f6b3fd0dee0d8b35f346695cfd3e080ca328ca1726ce851f6abfbabc631
diff --git a/rust/extractor/src/generated/top.rs b/rust/extractor/src/generated/top.rs
index d8de082d024..806ee80d6ce 100644
--- a/rust/extractor/src/generated/top.rs
+++ b/rust/extractor/src/generated/top.rs
@@ -6148,8 +6148,8 @@ impl From> for trap::Label {
#[derive(Debug)]
pub struct MacroBlockExpr {
pub id: trap::TrapId,
- pub tail_expr: Option>,
pub statements: Vec>,
+ pub tail_expr: Option>,
}
impl trap::TrapEntry for MacroBlockExpr {
@@ -6159,12 +6159,12 @@ impl trap::TrapEntry for MacroBlockExpr {
fn emit(self, id: trap::Label, out: &mut trap::Writer) {
out.add_tuple("macro_block_exprs", vec![id.into()]);
- if let Some(v) = self.tail_expr {
- out.add_tuple("macro_block_expr_tail_exprs", vec![id.into(), v.into()]);
- }
for (i, v) in self.statements.into_iter().enumerate() {
out.add_tuple("macro_block_expr_statements", vec![id.into(), i.into(), v.into()]);
}
+ if let Some(v) = self.tail_expr {
+ out.add_tuple("macro_block_expr_tail_exprs", vec![id.into(), v.into()]);
+ }
}
}
diff --git a/rust/extractor/src/translate/base.rs b/rust/extractor/src/translate/base.rs
index ccd6143fb84..7433bf2138d 100644
--- a/rust/extractor/src/translate/base.rs
+++ b/rust/extractor/src/translate/base.rs
@@ -834,6 +834,38 @@ impl<'a> Translator<'a> {
}
}
+ pub(crate) fn emit_macro_stmts(
+ &mut self,
+ node: &ast::MacroStmts,
+ ) -> Option> {
+ // not generated to work around a bug in rust-analyzer AST generation machinery.
+ // Because an Expr can also be a Stmt (AsmExpr: Expr and AsmExpr: Item: Stmt)
+ // then such an element will be returned by both `expr()` and `statements()`
+ let mut statements = node.statements().collect::>();
+ let tail_expr = node.expr();
+ if tail_expr
+ .as_ref()
+ .is_some_and(|e| statements.last().is_some_and(|s| s.syntax() == e.syntax()))
+ {
+ // if the expression matched as both the tail_expr and the last of the statements,
+ // only take it as tail_expr
+ statements.pop();
+ }
+ let tail_expr = tail_expr.and_then(|e| self.emit_expr(&e));
+ let statements = statements
+ .iter()
+ .filter_map(|x| self.emit_stmt(x))
+ .collect();
+ let label = self.trap.emit(generated::MacroBlockExpr {
+ id: TrapId::Star,
+ tail_expr,
+ statements,
+ });
+ self.emit_location(label, node);
+ self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
+ Some(label)
+ }
+
fn is_attribute_macro_target(&self, node: &ast::Item) -> bool {
// rust-analyzer considers as an `attr_macro_call` also a plain macro call, but we want to
// process that differently (in `extract_macro_call_expanded`)
diff --git a/rust/extractor/src/translate/generated.rs b/rust/extractor/src/translate/generated.rs
index cbcb6f28c7b..402fdfaf6b0 100644
--- a/rust/extractor/src/translate/generated.rs
+++ b/rust/extractor/src/translate/generated.rs
@@ -1600,24 +1600,6 @@ impl Translator<'_> {
self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
Some(label)
}
- pub(crate) fn emit_macro_stmts(
- &mut self,
- node: &ast::MacroStmts,
- ) -> Option> {
- let tail_expr = node.expr().and_then(|x| self.emit_expr(&x));
- let statements = node
- .statements()
- .filter_map(|x| self.emit_stmt(&x))
- .collect();
- let label = self.trap.emit(generated::MacroBlockExpr {
- id: TrapId::Star,
- tail_expr,
- statements,
- });
- self.emit_location(label, node);
- self.emit_tokens(node, label.into(), node.syntax().children_with_tokens());
- Some(label)
- }
pub(crate) fn emit_macro_type(
&mut self,
node: &ast::MacroType,
diff --git a/rust/ql/.generated.list b/rust/ql/.generated.list
index 86016b745f3..f03cf69df07 100644
--- a/rust/ql/.generated.list
+++ b/rust/ql/.generated.list
@@ -1,4 +1,4 @@
-lib/codeql/rust/controlflow/internal/generated/CfgNodes.qll 6a103a6d04c951ca2f0c2989bed737cdbac56dd5ea9432b858da3416412bbf79 cf2bc67b65a1555de58bbd0a35b834b8867112a2f7c1951307c9416400ce70d0
+lib/codeql/rust/controlflow/internal/generated/CfgNodes.qll 06394c1314f09d65b8ade88732f1114202e1896ebeb8d687f8ee230cea01127b 7a9223854ec30cae886b237d7930120ce073ab49af486b0d3bc971df2a039e62
lib/codeql/rust/elements/Abi.qll 485a2e79f6f7bfd1c02a6e795a71e62dede3c3e150149d5f8f18b761253b7208 6159ba175e7ead0dd2e3f2788f49516c306ee11b1a443bd4bdc00b7017d559bd
lib/codeql/rust/elements/Addressable.qll 13011bfd2e1556694c3d440cc34af8527da4df49ad92b62f2939d3699ff2cea5 ddb25935f7553a1a384b1abe2e4b4fa90ab50b952dadec32fd867afcb054f4be
lib/codeql/rust/elements/Adt.qll c2afed4ac2e17039ccd98f74ea22111f4d765c4e232c50ccd3128da0d26da837 1380bde2eb667c6ec2ef5f8710aa24e926851c9e321ebc72ba514fa92c369dc3
@@ -90,7 +90,7 @@ lib/codeql/rust/elements/LiteralPat.qll daffb5f380a47543669c8cc92628b0e0de478c3a
lib/codeql/rust/elements/Locatable.qll 2855efa4a469b54e0ca85daa89309a8b991cded6f3f10db361010831ba1e11d3 00c3406d14603f90abea11bf074eaf2c0b623a30e29cf6afc3a247cb58b92f0f
lib/codeql/rust/elements/LoopExpr.qll ee171177650fa23eef102a9580765f4b6073a1cc41bab1ec31ad4f84ffe6c2c9 bfcf0cca4dc944270d9748a202829a38c64dfae167c0d3a4202788ceb9daf5f6
lib/codeql/rust/elements/LoopingExpr.qll 7ad7d4bbfd05adc0bb9b4ca90ff3377b8298121ca5360ffb45d5a7a1e20fe37a 964168b2045ee9bad827bba53f10a64d649b3513f2d1e3c17a1b1f11d0fc7f3a
-lib/codeql/rust/elements/MacroBlockExpr.qll fb81f067a142053b122e2875a15719565024cfb09326faf12e0f1017307deb58 3ee94ef7e56bd07a8f9304869b0a7b69971b02abbee46d0bebcacb4031760282
+lib/codeql/rust/elements/MacroBlockExpr.qll 077c968da099c10456be4b594675a074e9a4e43b5c5145e1b1ae1fa47ae6d570 99586e3766ee0c80364998128e067cab2639ac25c1dcbe13e0247d629490af6f
lib/codeql/rust/elements/MacroCall.qll 452aee152b655cdd5a69bf973977072f000a6451f626469a3f7313f0468ffc18 a8652d0de1c6c2118d683d5465ba4115dd4c65031896440269a2a0522d90fceb
lib/codeql/rust/elements/MacroDef.qll 5bcf2bba7ba40879fe47370bfeb65b23c67c463be20535327467338a1e2e04bb c3d28416fc08e5d79149fccd388fea2bc3097bce074468a323383056404926db
lib/codeql/rust/elements/MacroExpr.qll 640554f4964def19936a16ce88a03fb12f74ec2bcfe38b88d32742b79f85d909 a284fb66e012664a33a4e9c8fd3e38d3ffd588fccd6b16b02270da55fc025f7a
@@ -306,7 +306,7 @@ lib/codeql/rust/elements/internal/LiteralPatConstructor.qll b660cb428a0cba0b713f
lib/codeql/rust/elements/internal/LoopExprConstructor.qll 45f3f8f7441fcab6adc58831421679ee07bac68ac0417f3cbc90c97426cc805b f7ab3361b4a11e898126378ea277d76949466946762cd6cb5e9e9b4bb9860420
lib/codeql/rust/elements/internal/LoopingExprImpl.qll 17885c1bcf7b5a3f9c7bbad3d4d55e24372af0dedd5e7fc0efcfc0a8b2cdad70 104dc45ca399b9f6e8227ad561679f728d60170398a52b31fc90cb2a2dd3c33c
lib/codeql/rust/elements/internal/MacroBlockExprConstructor.qll 90097c0d2c94083e997396e01cf24349af5eb1788060368dc21ae8cd8ce90d93 e067904a734356e38fbadbc4277629c5987adce6d8f7737f7458ac07e9b264af
-lib/codeql/rust/elements/internal/MacroBlockExprImpl.qll f7a8dd1dcde2355353e17d06bb197e2d6e321ea64a39760a074d1887e68d63d6 8d429be9b6aa9f711e050b6b07f35637de22e8635a559e06dd9153a8b7947274
+lib/codeql/rust/elements/internal/MacroBlockExprImpl.qll 323c0695ab1d8ee7d88a678eabdb6ac9d92293b9ae0846ec2c7ed8d76a591369 7b662b77cf2d885423d8734ff322c199650c1ea59a2c3371a1370efd7966e0c9
lib/codeql/rust/elements/internal/MacroCallConstructor.qll 707fee4fba1fd632cd00128f493e8919eaaea552ad653af4c1b7a138e362907d b49e7e36bf9306199f2326af042740ff858871b5c79f6aeddf3d5037044dbf1f
lib/codeql/rust/elements/internal/MacroDefConstructor.qll 382a3bdf46905d112ee491620cc94f87d584d72f49e01eb1483f749e4709c055 eb61b90d8d8d655c2b00ff576ae20c8da9709eeef754212bc64d8e1558ad05ce
lib/codeql/rust/elements/internal/MacroDefImpl.qll 73db95ff82834e0063699c7d31349b65e95ba7436fe0a8914dbdd3a383f8b1c9 cd2f078f84ce73fdc88b207df105b297f2cd3b780428968214443af3a2719e8f
@@ -546,7 +546,7 @@ lib/codeql/rust/elements/internal/generated/LiteralPat.qll f36b09cf39330019c111e
lib/codeql/rust/elements/internal/generated/Locatable.qll c897dc1bdd4dfcb6ded83a4a93332ca3d8f421bae02493ea2a0555023071775e b32d242f8c9480dc9b53c1e13a5cb8dcfce575b0373991c082c1db460a3e37b8
lib/codeql/rust/elements/internal/generated/LoopExpr.qll db6bc87e795c9852426ec661fa2c2c54106805897408b43a67f5b82fb4657afd 1492866ccf8213469be85bbdbcae0142f4e2a39df305d4c0d664229ecd1ebdb9
lib/codeql/rust/elements/internal/generated/LoopingExpr.qll 0792c38d84b8c68114da2bbdfef32ef803b696cb0fd06e10e101756d5c46976c 111fe961fad512722006323c3f2a075fddf59bd3eb5c7afc349835fcec8eb102
-lib/codeql/rust/elements/internal/generated/MacroBlockExpr.qll 778376cdfa4caaa9df0b9c21bda5ff0f1037b730aa43efb9fb0a08998ef3999b 6df39efe7823ce590ef6f4bdfa60957ba067205a77d94ac089b2c6a7f6b7b561
+lib/codeql/rust/elements/internal/generated/MacroBlockExpr.qll 7705de831e797c8742726a3c28dd8f87f6c1b9e2cccd20f01839d161f7ca37c7 ac79c5c95befc82f53b620ccc8a28fd9cc0f9e00c585ed4032bd75f99e0935fa
lib/codeql/rust/elements/internal/generated/MacroCall.qll 1a7ee9c782ebc9ab0a807762aabebc9e0a7ef10c6eb945679737598630b20af2 782a437654cb316355c020e89d50b07c93ba7817715fa5d42a9e807cf12d1a43
lib/codeql/rust/elements/internal/generated/MacroDef.qll 90393408d9e10ff6167789367c30f9bfe1d3e8ac3b83871c6cb30a8ae37eef47 f022d1df45bc9546cb9fd7059f20e16a3acfaae2053bbd10075fe467c96e2379
lib/codeql/rust/elements/internal/generated/MacroExpr.qll 5a86ae36a28004ce5e7eb30addf763eef0f1c614466f4507a3935b0dab2c7ce3 11c15e8ebd36455ec9f6b7819134f6b22a15a3644678ca96b911ed0eb1181873
@@ -574,7 +574,7 @@ lib/codeql/rust/elements/internal/generated/ParamList.qll eaa0cd4402d3665013d47e
lib/codeql/rust/elements/internal/generated/ParenExpr.qll 812d2ff65079277f39f15c084657a955a960a7c1c0e96dd60472a58d56b945eb eb8c607f43e1fcbb41f37a10de203a1db806690e10ff4f04d48ed874189cb0eb
lib/codeql/rust/elements/internal/generated/ParenPat.qll 24f9dc7fce75827d6fddb856cd48f80168143151b27295c0bab6db5a06567a09 ebadbc6f5498e9ed754b39893ce0763840409a0721036a25b56e1ead7dcc09aa
lib/codeql/rust/elements/internal/generated/ParenTypeRepr.qll 03f5c5b96a37adeb845352d7fcea3e098da9050e534972d14ac0f70d60a2d776 ed3d6e5d02086523087adebce4e89e35461eb95f2a66d1d4100fe23fc691b126
-lib/codeql/rust/elements/internal/generated/ParentChild.qll 389ee1eea791f9d2a5eb9ae49d2aa61607f8cdb3f3d5752d5c067122029de66a 50875ace3751c001acc11fa596ea1cd8c8b17dd925344c2d91d338b3f864df0d
+lib/codeql/rust/elements/internal/generated/ParentChild.qll d43d7486ed04a3930fa476694fc74d972f4413992968de425573ccf823343c87 3d4245aee40a38bff658f2c0cb220d5276ae751194c5b728b65054ec98c841e4
lib/codeql/rust/elements/internal/generated/ParenthesizedArgList.qll d901fdc8142a5b8847cc98fc2afcfd16428b8ace4fbffb457e761b5fd3901a77 5dbb0aea5a13f937da666ccb042494af8f11e776ade1459d16b70a4dd193f9fb
lib/codeql/rust/elements/internal/generated/Pat.qll 3605ac062be2f294ee73336e9669027b8b655f4ad55660e1eab35266275154ee 7f9400db2884d336dd1d21df2a8093759c2a110be9bf6482ce8e80ae0fd74ed4
lib/codeql/rust/elements/internal/generated/Path.qll 9b12afb46fc5a9ad3a811b05472621bbecccb900c47504feb7f29d96b28421ca bcacbffc36fb3e0c9b26523b5963af0ffa9fd6b19f00a2a31bdb2316071546bd
@@ -589,7 +589,7 @@ lib/codeql/rust/elements/internal/generated/PtrTypeRepr.qll 8d0ea4f6c7f8203340bf
lib/codeql/rust/elements/internal/generated/PureSynthConstructors.qll e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f e5b8e69519012bbaae29dcb82d53f7f7ecce368c0358ec27ef6180b228a0057f
lib/codeql/rust/elements/internal/generated/RangeExpr.qll 23cca03bf43535f33b22a38894f70d669787be4e4f5b8fe5c8f7b964d30e9027 18624cef6c6b679eeace2a98737e472432e0ead354cca02192b4d45330f047c9
lib/codeql/rust/elements/internal/generated/RangePat.qll 80826a6a6868a803aa2372e31c52a03e1811a3f1f2abdb469f91ca0bfdd9ecb6 34ee1e208c1690cba505dff2c588837c0cd91e185e2a87d1fe673191962276a9
-lib/codeql/rust/elements/internal/generated/Raw.qll 1578a58b7115fed2bfdaf65c3a9e6ef8318660b11a9c8f1cc334114f9c38e0af a8ea88419f42be7a40d7419d07a0469380ba3c4706e6a580554a4c28e216fc00
+lib/codeql/rust/elements/internal/generated/Raw.qll a608725b53de8509b1b5f2a29e1636bda2e6baaa5d4218397f690f43f3c89011 6c09465d83f71e9e54917f2d4436eeb865c9abaf7a941e8a8cfc2faf29c794f4
lib/codeql/rust/elements/internal/generated/RefExpr.qll 7d995884e3dc1c25fc719f5d7253179344d63650e217e9ff6530285fe7a57f64 f2c3c12551deea4964b66553fb9b6423ee16fec53bd63db4796191aa60dc6c66
lib/codeql/rust/elements/internal/generated/RefPat.qll 456ede39837463ee22a630ec7ab6c8630d3664a8ea206fcc6e4f199e92fa564c 5622062765f32930465ba6b170e986706f159f6070f48adee3c20e24e8df4e05
lib/codeql/rust/elements/internal/generated/RefTypeRepr.qll 5b0663a6d234572fb3e467e276d019415caa95ef006438cc59b7af4e1783161e 0e27c8a8f0e323c0e4d6db01fca821bf07c0864d293cdf96fa891b10820c1e4b
@@ -724,7 +724,7 @@ test/extractor-tests/generated/LifetimeParam/LifetimeParam.ql a96f586af332969878
test/extractor-tests/generated/LiteralExpr/LiteralExpr.ql 00570642966d233a10ec3106ae65e6ea865c29d0776fdbc452815f528301117c adb286ad3bd763f1b1b350cac91bc2615869dcb9b0faf29276ace9a99d31f0cc
test/extractor-tests/generated/LiteralPat/LiteralPat.ql 863d4902e7e22de3176398cbb908e6f5f487b3d22c0f9f7a5498a1ebc112c0fd 47e3f70c5c32f17050d3ca8c8b42d94ecd38e378627880d8100b7ca182cfa793
test/extractor-tests/generated/LoopExpr/LoopExpr.ql a178e25f63b4d517482ec63e5dfb6903dd41dadd8db39be2dd2a831e8456811f f34165f78179960cc7e5876dac26a1d0f6f67933eff9a015b92ca0e2872b63e8
-test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.ql 62859a25b88c93db1d47055f682f1b8ed97ef227c870bc14041af106cb9593fd 14c5831920249ef2e0799ddacca62805e2e2d8b8a6cbd244acb3a20c4542bf7b
+test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.ql 936920b5b609b1e62b201004055bbce449d2d7c1f8016f57d9b27d3ea8107f07 21493009ed3b1810aa4fd8af4d8c7b7794982da032dfb6b7e9048445d651eecb
test/extractor-tests/generated/MacroCall/MacroCall.ql f98017f6070e2a5e4b191d5380cc0491d7358c456e8459b313235e44eb368794 437129210d9b7f6850adf4d2c8ef7d0644193418645d631b8edf229656fc57ac
test/extractor-tests/generated/MacroDef/MacroDef.ql 9e3647a92713d32f87e876f37d703081855ea88a7a3104757f90bd94eb382fa9 b50e9797c1b8ea5491267ddb6778862f0541617ee60bd8e167cc23a499e36733
test/extractor-tests/generated/MacroExpr/MacroExpr.ql 83fadb88fd8f913bb1b1cda26d21b173bdc94bb6682a74eaddce650ebf72aa41 1c502cde6a95ec637e43d348c613be3dec4092b69d2c8692abdc5a9377e37f5f
diff --git a/rust/ql/lib/codeql/rust/controlflow/internal/generated/CfgNodes.qll b/rust/ql/lib/codeql/rust/controlflow/internal/generated/CfgNodes.qll
index 36dd0fb304f..811ddf4978a 100644
--- a/rust/ql/lib/codeql/rust/controlflow/internal/generated/CfgNodes.qll
+++ b/rust/ql/lib/codeql/rust/controlflow/internal/generated/CfgNodes.qll
@@ -1797,9 +1797,15 @@ module MakeCfgNodes Input> {
/**
* A sequence of statements generated by a `MacroCall`. For example:
* ```rust
- * fn main() {
- * println!("Hello, world!"); // This macro expands into a list of statements
+ * macro_rules! my_macro {
+ * () => {
+ * let mut x = 40;
+ * x += 2;
+ * x
+ * };
* }
+ *
+ * my_macro!(); // this macro expands to a sequence of statements (and an expression)
* ```
*/
final class MacroBlockExprCfgNode extends CfgNodeFinal, ExprCfgNode {
@@ -1810,18 +1816,6 @@ module MakeCfgNodes Input> {
/** Gets the underlying `MacroBlockExpr`. */
MacroBlockExpr getMacroBlockExpr() { result = node }
- /**
- * Gets the tail expression of this macro block expression, if it exists.
- */
- ExprCfgNode getTailExpr() {
- any(ChildMapping mapping).hasCfgChild(node, node.getTailExpr(), this, result)
- }
-
- /**
- * Holds if `getTailExpr()` exists.
- */
- predicate hasTailExpr() { exists(this.getTailExpr()) }
-
/**
* Gets the `index`th statement of this macro block expression (0-based).
*/
@@ -1836,6 +1830,18 @@ module MakeCfgNodes Input> {
* Gets the number of statements of this macro block expression.
*/
int getNumberOfStatements() { result = count(int i | exists(this.getStatement(i))) }
+
+ /**
+ * Gets the tail expression of this macro block expression, if it exists.
+ */
+ ExprCfgNode getTailExpr() {
+ any(ChildMapping mapping).hasCfgChild(node, node.getTailExpr(), this, result)
+ }
+
+ /**
+ * Holds if `getTailExpr()` exists.
+ */
+ predicate hasTailExpr() { exists(this.getTailExpr()) }
}
final private class ParentMacroCall extends ParentAstNode, MacroCall {
diff --git a/rust/ql/lib/codeql/rust/elements/MacroBlockExpr.qll b/rust/ql/lib/codeql/rust/elements/MacroBlockExpr.qll
index 8fcd2119a0a..0ad76f8a973 100644
--- a/rust/ql/lib/codeql/rust/elements/MacroBlockExpr.qll
+++ b/rust/ql/lib/codeql/rust/elements/MacroBlockExpr.qll
@@ -10,9 +10,15 @@ import codeql.rust.elements.Stmt
/**
* A sequence of statements generated by a `MacroCall`. For example:
* ```rust
- * fn main() {
- * println!("Hello, world!"); // This macro expands into a list of statements
+ * macro_rules! my_macro {
+ * () => {
+ * let mut x = 40;
+ * x += 2;
+ * x
+ * };
* }
+ *
+ * my_macro!(); // this macro expands to a sequence of statements (and an expression)
* ```
*/
final class MacroBlockExpr = Impl::MacroBlockExpr;
diff --git a/rust/ql/lib/codeql/rust/elements/internal/MacroBlockExprImpl.qll b/rust/ql/lib/codeql/rust/elements/internal/MacroBlockExprImpl.qll
index 60030dd6f27..289e6c33a30 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/MacroBlockExprImpl.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/MacroBlockExprImpl.qll
@@ -15,9 +15,15 @@ module Impl {
/**
* A sequence of statements generated by a `MacroCall`. For example:
* ```rust
- * fn main() {
- * println!("Hello, world!"); // This macro expands into a list of statements
+ * macro_rules! my_macro {
+ * () => {
+ * let mut x = 40;
+ * x += 2;
+ * x
+ * };
* }
+ *
+ * my_macro!(); // this macro expands to a sequence of statements (and an expression)
* ```
*/
class MacroBlockExpr extends Generated::MacroBlockExpr { }
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/MacroBlockExpr.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/MacroBlockExpr.qll
index 3dd6411e20e..e7b94d9f04c 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/MacroBlockExpr.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/MacroBlockExpr.qll
@@ -18,9 +18,15 @@ module Generated {
/**
* A sequence of statements generated by a `MacroCall`. For example:
* ```rust
- * fn main() {
- * println!("Hello, world!"); // This macro expands into a list of statements
+ * macro_rules! my_macro {
+ * () => {
+ * let mut x = 40;
+ * x += 2;
+ * x
+ * };
* }
+ *
+ * my_macro!(); // this macro expands to a sequence of statements (and an expression)
* ```
* INTERNAL: Do not reference the `Generated::MacroBlockExpr` class directly.
* Use the subclass `MacroBlockExpr`, where the following predicates are available.
@@ -28,21 +34,6 @@ module Generated {
class MacroBlockExpr extends Synth::TMacroBlockExpr, ExprImpl::Expr {
override string getAPrimaryQlClass() { result = "MacroBlockExpr" }
- /**
- * Gets the tail expression of this macro block expression, if it exists.
- */
- Expr getTailExpr() {
- result =
- Synth::convertExprFromRaw(Synth::convertMacroBlockExprToRaw(this)
- .(Raw::MacroBlockExpr)
- .getTailExpr())
- }
-
- /**
- * Holds if `getTailExpr()` exists.
- */
- final predicate hasTailExpr() { exists(this.getTailExpr()) }
-
/**
* Gets the `index`th statement of this macro block expression (0-based).
*/
@@ -62,5 +53,20 @@ module Generated {
* Gets the number of statements of this macro block expression.
*/
final int getNumberOfStatements() { result = count(int i | exists(this.getStatement(i))) }
+
+ /**
+ * Gets the tail expression of this macro block expression, if it exists.
+ */
+ Expr getTailExpr() {
+ result =
+ Synth::convertExprFromRaw(Synth::convertMacroBlockExprToRaw(this)
+ .(Raw::MacroBlockExpr)
+ .getTailExpr())
+ }
+
+ /**
+ * Holds if `getTailExpr()` exists.
+ */
+ final predicate hasTailExpr() { exists(this.getTailExpr()) }
}
}
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll
index 3011eccbee4..4aff5eec64d 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/ParentChild.qll
@@ -1489,17 +1489,17 @@ private module Impl {
private Element getImmediateChildOfMacroBlockExpr(
MacroBlockExpr e, int index, string partialPredicateCall
) {
- exists(int n, int nTailExpr, int nStatement |
+ exists(int n, int nStatement, int nTailExpr |
n = 0 and
- nTailExpr = n + 1 and
- nStatement = nTailExpr + 1 + max(int i | i = -1 or exists(e.getStatement(i)) | i) and
+ nStatement = n + 1 + max(int i | i = -1 or exists(e.getStatement(i)) | i) and
+ nTailExpr = nStatement + 1 and
(
none()
or
- index = n and result = e.getTailExpr() and partialPredicateCall = "TailExpr()"
+ result = e.getStatement(index - n) and
+ partialPredicateCall = "Statement(" + (index - n).toString() + ")"
or
- result = e.getStatement(index - nTailExpr) and
- partialPredicateCall = "Statement(" + (index - nTailExpr).toString() + ")"
+ index = nStatement and result = e.getTailExpr() and partialPredicateCall = "TailExpr()"
)
)
}
diff --git a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
index d0aa59d583e..3b8860b6f7c 100644
--- a/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
+++ b/rust/ql/lib/codeql/rust/elements/internal/generated/Raw.qll
@@ -2619,23 +2619,29 @@ module Raw {
* INTERNAL: Do not use.
* A sequence of statements generated by a `MacroCall`. For example:
* ```rust
- * fn main() {
- * println!("Hello, world!"); // This macro expands into a list of statements
+ * macro_rules! my_macro {
+ * () => {
+ * let mut x = 40;
+ * x += 2;
+ * x
+ * };
* }
+ *
+ * my_macro!(); // this macro expands to a sequence of statements (and an expression)
* ```
*/
class MacroBlockExpr extends @macro_block_expr, Expr {
override string toString() { result = "MacroBlockExpr" }
- /**
- * Gets the tail expression of this macro block expression, if it exists.
- */
- Expr getTailExpr() { macro_block_expr_tail_exprs(this, result) }
-
/**
* Gets the `index`th statement of this macro block expression (0-based).
*/
Stmt getStatement(int index) { macro_block_expr_statements(this, index, result) }
+
+ /**
+ * Gets the tail expression of this macro block expression, if it exists.
+ */
+ Expr getTailExpr() { macro_block_expr_tail_exprs(this, result) }
}
/**
diff --git a/rust/ql/lib/rust.dbscheme b/rust/ql/lib/rust.dbscheme
index 3c1990e7f1d..b41e55c0dba 100644
--- a/rust/ql/lib/rust.dbscheme
+++ b/rust/ql/lib/rust.dbscheme
@@ -2049,12 +2049,6 @@ macro_block_exprs(
unique int id: @macro_block_expr
);
-#keyset[id]
-macro_block_expr_tail_exprs(
- int id: @macro_block_expr ref,
- int tail_expr: @expr ref
-);
-
#keyset[id, index]
macro_block_expr_statements(
int id: @macro_block_expr ref,
@@ -2062,6 +2056,12 @@ macro_block_expr_statements(
int statement: @stmt ref
);
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
macro_exprs(
unique int id: @macro_expr
);
diff --git a/rust/ql/test/extractor-tests/generated/.generated_tests.list b/rust/ql/test/extractor-tests/generated/.generated_tests.list
index e41f01de20a..f23ccd30563 100644
--- a/rust/ql/test/extractor-tests/generated/.generated_tests.list
+++ b/rust/ql/test/extractor-tests/generated/.generated_tests.list
@@ -67,7 +67,7 @@ LifetimeParam/gen_lifetime_param.rs e3f9a417ae7a88a4d81d9cb747b361a3246d270d142f
LiteralExpr/gen_literal_expr.rs 2db01ad390e5c0c63a957c043230a462cb4cc25715eea6ede15d43c55d35976d 2db01ad390e5c0c63a957c043230a462cb4cc25715eea6ede15d43c55d35976d
LiteralPat/gen_literal_pat.rs a471b481b6989001817a3988696f445d9a4dea784e543c346536dacbee1e96f3 a471b481b6989001817a3988696f445d9a4dea784e543c346536dacbee1e96f3
LoopExpr/gen_loop_expr.rs 35deaf35e765db4ae3124a11284266d8f341d1ce7b700030efada0dda8878619 35deaf35e765db4ae3124a11284266d8f341d1ce7b700030efada0dda8878619
-MacroBlockExpr/gen_macro_block_expr.rs 2e45dcf44bf2e8404b49ce9abeee4931572693174b5d96f3fd81eb40ea8e7b4b 2e45dcf44bf2e8404b49ce9abeee4931572693174b5d96f3fd81eb40ea8e7b4b
+MacroBlockExpr/gen_macro_block_expr.rs 4284a6e6ad81827d8616a00fec7f5bc21104eed40d93e3acc2b933ee22cb8577 4284a6e6ad81827d8616a00fec7f5bc21104eed40d93e3acc2b933ee22cb8577
MacroCall/gen_macro_call.rs c30added613d9edb3cb1321ae46fc6a088a2f22d2cc979119466ec02f6e09ed6 c30added613d9edb3cb1321ae46fc6a088a2f22d2cc979119466ec02f6e09ed6
MacroDef/gen_macro_def.rs 6f895ecab8c13a73c28ce67fcee39baf7928745a80fb440811014f6d31b22378 6f895ecab8c13a73c28ce67fcee39baf7928745a80fb440811014f6d31b22378
MacroExpr/gen_macro_expr.rs 5e1748356f431eea343a2aad2798c22073151940ea2cda0f0cce78c3d96104f0 5e1748356f431eea343a2aad2798c22073151940ea2cda0f0cce78c3d96104f0
diff --git a/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected b/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected
index 3fa93611a58..10f3409cc79 100644
--- a/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmClobberAbi/AsmClobberAbi.expected
@@ -1,2 +1 @@
| gen_asm_clobber_abi.rs:8:14:8:29 | AsmClobberAbi |
-| gen_asm_clobber_abi.rs:8:14:8:29 | AsmClobberAbi |
diff --git a/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected b/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected
index f87adbca9bd..30ed42e46f9 100644
--- a/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmConst/AsmConst.expected
@@ -1,6 +1,4 @@
instances
| gen_asm_const.rs:8:30:8:37 | AsmConst | isConst: | yes |
-| gen_asm_const.rs:8:30:8:37 | AsmConst | isConst: | yes |
getExpr
| gen_asm_const.rs:8:30:8:37 | AsmConst | gen_asm_const.rs:8:36:8:37 | 42 |
-| gen_asm_const.rs:8:30:8:37 | AsmConst | gen_asm_const.rs:8:36:8:37 | 42 |
diff --git a/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected b/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected
index dc6fb69446b..977c8504c0e 100644
--- a/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmDirSpec/AsmDirSpec.expected
@@ -1,4 +1,2 @@
| gen_asm_dir_spec.rs:8:47:8:49 | AsmDirSpec |
-| gen_asm_dir_spec.rs:8:47:8:49 | AsmDirSpec |
-| gen_asm_dir_spec.rs:8:67:8:68 | AsmDirSpec |
| gen_asm_dir_spec.rs:8:67:8:68 | AsmDirSpec |
diff --git a/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected b/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected
index cdc2abe7bed..cbd9eac398a 100644
--- a/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmLabel/AsmLabel.expected
@@ -1,6 +1,4 @@
instances
| gen_asm_label.rs:10:9:10:47 | AsmLabel |
-| gen_asm_label.rs:10:9:10:47 | AsmLabel |
getBlockExpr
| gen_asm_label.rs:10:9:10:47 | AsmLabel | gen_asm_label.rs:10:15:10:47 | { ... } |
-| gen_asm_label.rs:10:9:10:47 | AsmLabel | gen_asm_label.rs:10:15:10:47 | { ... } |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected b/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected
index f252705d0d9..262ca3ada57 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOperandExpr/AsmOperandExpr.expected
@@ -1,15 +1,9 @@
instances
| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr |
-| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr |
-| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr |
| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr |
getInExpr
| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
-| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
-| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
getOutExpr
| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
-| gen_asm_operand_expr.rs:8:35:8:35 | AsmOperandExpr | gen_asm_operand_expr.rs:8:35:8:35 | x |
-| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
| gen_asm_operand_expr.rs:8:46:8:46 | AsmOperandExpr | gen_asm_operand_expr.rs:8:46:8:46 | y |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected b/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected
index 66dcd7eb7d0..c8aec731ff8 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOperandNamed/AsmOperandNamed.expected
@@ -1,13 +1,8 @@
instances
| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed |
-| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed |
-| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed |
| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed |
getAsmOperand
| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed | gen_asm_operand_named.rs:8:34:8:43 | AsmRegOperand |
-| gen_asm_operand_named.rs:8:34:8:43 | AsmOperandNamed | gen_asm_operand_named.rs:8:34:8:43 | AsmRegOperand |
-| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:54:8:62 | AsmRegOperand |
| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:54:8:62 | AsmRegOperand |
getName
| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:46:8:50 | input |
-| gen_asm_operand_named.rs:8:46:8:62 | AsmOperandNamed | gen_asm_operand_named.rs:8:46:8:50 | input |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected b/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected
index 4bb6ff00140..ddd5bc880b9 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOption/AsmOption.expected
@@ -1,4 +1,2 @@
| gen_asm_option.rs:8:22:8:28 | AsmOption | isRaw: | no |
-| gen_asm_option.rs:8:22:8:28 | AsmOption | isRaw: | no |
-| gen_asm_option.rs:8:31:8:35 | AsmOption | isRaw: | no |
| gen_asm_option.rs:8:31:8:35 | AsmOption | isRaw: | no |
diff --git a/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected b/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected
index db19616d779..cf9ec35d070 100644
--- a/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmOptionsList/AsmOptionsList.expected
@@ -1,8 +1,5 @@
instances
| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList |
-| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList |
getAsmOption
| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 0 | gen_asm_options_list.rs:8:22:8:28 | AsmOption |
-| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 0 | gen_asm_options_list.rs:8:22:8:28 | AsmOption |
-| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 1 | gen_asm_options_list.rs:8:31:8:35 | AsmOption |
| gen_asm_options_list.rs:8:14:8:36 | AsmOptionsList | 1 | gen_asm_options_list.rs:8:31:8:35 | AsmOption |
diff --git a/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected b/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected
index 62aa617aa8d..a141f1a25c2 100644
--- a/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmRegOperand/AsmRegOperand.expected
@@ -1,20 +1,12 @@
instances
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand |
-| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand |
-| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand |
getAsmDirSpec
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:26:8:28 | AsmDirSpec |
-| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:26:8:28 | AsmDirSpec |
-| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:38:8:39 | AsmDirSpec |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:38:8:39 | AsmDirSpec |
getAsmOperandExpr
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:35:8:35 | AsmOperandExpr |
-| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:35:8:35 | AsmOperandExpr |
-| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:46:8:46 | AsmOperandExpr |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:46:8:46 | AsmOperandExpr |
getAsmRegSpec
| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:30:8:32 | AsmRegSpec |
-| gen_asm_reg_operand.rs:8:26:8:35 | AsmRegOperand | gen_asm_reg_operand.rs:8:30:8:32 | AsmRegSpec |
-| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:41:8:43 | AsmRegSpec |
| gen_asm_reg_operand.rs:8:38:8:46 | AsmRegOperand | gen_asm_reg_operand.rs:8:41:8:43 | AsmRegSpec |
diff --git a/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected b/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected
index 31fb38d585f..120ba8d2093 100644
--- a/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmRegSpec/AsmRegSpec.expected
@@ -1,8 +1,5 @@
instances
| gen_asm_reg_spec.rs:8:30:8:34 | AsmRegSpec |
-| gen_asm_reg_spec.rs:8:30:8:34 | AsmRegSpec |
-| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec |
| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec |
getIdentifier
| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec | gen_asm_reg_spec.rs:8:43:8:45 | EBX |
-| gen_asm_reg_spec.rs:8:43:8:45 | AsmRegSpec | gen_asm_reg_spec.rs:8:43:8:45 | EBX |
diff --git a/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected b/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected
index 688d38c5ac6..e3f8fbc9ec7 100644
--- a/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected
+++ b/rust/ql/test/extractor-tests/generated/AsmSym/AsmSym.expected
@@ -1,6 +1,4 @@
instances
| gen_asm_sym.rs:8:30:8:44 | AsmSym |
-| gen_asm_sym.rs:8:30:8:44 | AsmSym |
getPath
| gen_asm_sym.rs:8:30:8:44 | AsmSym | gen_asm_sym.rs:8:34:8:44 | my_function |
-| gen_asm_sym.rs:8:30:8:44 | AsmSym | gen_asm_sym.rs:8:34:8:44 | my_function |
diff --git a/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.expected b/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.expected
index 67d330d937e..d6887babe7e 100644
--- a/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.expected
+++ b/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.expected
@@ -1,5 +1,7 @@
instances
-| gen_macro_block_expr.rs:5:14:5:28 | MacroBlockExpr |
-getTailExpr
-| gen_macro_block_expr.rs:5:14:5:28 | MacroBlockExpr | gen_macro_block_expr.rs:5:14:5:28 | { ... } |
+| gen_macro_block_expr.rs:13:5:13:13 | MacroBlockExpr |
getStatement
+| gen_macro_block_expr.rs:13:5:13:13 | MacroBlockExpr | 0 | gen_macro_block_expr.rs:13:5:13:13 | let ... = 40 |
+| gen_macro_block_expr.rs:13:5:13:13 | MacroBlockExpr | 1 | gen_macro_block_expr.rs:13:5:13:13 | ExprStmt |
+getTailExpr
+| gen_macro_block_expr.rs:13:5:13:13 | MacroBlockExpr | gen_macro_block_expr.rs:13:5:13:13 | x |
diff --git a/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.ql b/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.ql
index 82502ad4ec0..bae6d7d1f62 100644
--- a/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.ql
+++ b/rust/ql/test/extractor-tests/generated/MacroBlockExpr/MacroBlockExpr.ql
@@ -4,10 +4,10 @@ import TestUtils
query predicate instances(MacroBlockExpr x) { toBeTested(x) and not x.isUnknown() }
-query predicate getTailExpr(MacroBlockExpr x, Expr getTailExpr) {
- toBeTested(x) and not x.isUnknown() and getTailExpr = x.getTailExpr()
-}
-
query predicate getStatement(MacroBlockExpr x, int index, Stmt getStatement) {
toBeTested(x) and not x.isUnknown() and getStatement = x.getStatement(index)
}
+
+query predicate getTailExpr(MacroBlockExpr x, Expr getTailExpr) {
+ toBeTested(x) and not x.isUnknown() and getTailExpr = x.getTailExpr()
+}
diff --git a/rust/ql/test/extractor-tests/generated/MacroBlockExpr/gen_macro_block_expr.rs b/rust/ql/test/extractor-tests/generated/MacroBlockExpr/gen_macro_block_expr.rs
index 035b7ddc98c..62a408411e8 100644
--- a/rust/ql/test/extractor-tests/generated/MacroBlockExpr/gen_macro_block_expr.rs
+++ b/rust/ql/test/extractor-tests/generated/MacroBlockExpr/gen_macro_block_expr.rs
@@ -1,6 +1,14 @@
// generated by codegen, do not edit
-// A sequence of statements generated by a `MacroCall`. For example:
-fn main() {
- println!("Hello, world!"); // This macro expands into a list of statements
+fn test_macro_block_expr() -> () {
+ // A sequence of statements generated by a `MacroCall`. For example:
+ macro_rules! my_macro {
+ () => {
+ let mut x = 40;
+ x += 2;
+ x
+ };
+ }
+
+ my_macro!(); // this macro expands to a sequence of statements (and an expression)
}
diff --git a/rust/schema/annotations.py b/rust/schema/annotations.py
index bc07e1610f1..7313255b144 100644
--- a/rust/schema/annotations.py
+++ b/rust/schema/annotations.py
@@ -1404,17 +1404,25 @@ class _:
"""
-@annotate(MacroBlockExpr, replace_bases={AstNode: Expr}, cfg=True)
-@rust.doc_test_signature(None)
-class _:
+class MacroBlockExpr(Expr):
"""
A sequence of statements generated by a `MacroCall`. For example:
```rust
- fn main() {
- println!("Hello, world!"); // This macro expands into a list of statements
+ macro_rules! my_macro {
+ () => {
+ let mut x = 40;
+ x += 2;
+ x
+ };
}
+
+ my_macro!(); // this macro expands to a sequence of statements (and an expression)
```
"""
+ __cfg__ = True
+
+ statements: list[Stmt] | child
+ tail_expr: optional[Expr] | child
@annotate(MacroTypeRepr)
diff --git a/rust/schema/ast.py b/rust/schema/ast.py
index e527d318b66..c9c0d4e7ddb 100644
--- a/rust/schema/ast.py
+++ b/rust/schema/ast.py
@@ -399,10 +399,6 @@ class MacroRules(Item, ):
token_tree: optional["TokenTree"] | child
visibility: optional["Visibility"] | child
-class MacroBlockExpr(AstNode, ):
- tail_expr: optional["Expr"] | child
- statements: list["Stmt"] | child
-
class MacroTypeRepr(TypeRepr, ):
macro_call: optional["MacroCall"] | child
From 8ed277d6ee6474e467f29a624de9d95896ae639d Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 19 Aug 2025 14:03:18 +0200
Subject: [PATCH 094/298] Rust: adapt upgrade/downgrade scripts to new hash
---
.../downgrade.ql | 0
.../old.dbscheme | 0
.../rust.dbscheme | 0
.../upgrade.properties | 0
.../rust.dbscheme | 12 ++++++------
5 files changed, 6 insertions(+), 6 deletions(-)
rename rust/downgrades/{3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325 => b41e55c0dba14a139d01dbee713aca5efe5b818a}/downgrade.ql (100%)
rename rust/downgrades/{3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325 => b41e55c0dba14a139d01dbee713aca5efe5b818a}/old.dbscheme (100%)
rename rust/downgrades/{3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325 => b41e55c0dba14a139d01dbee713aca5efe5b818a}/rust.dbscheme (100%)
rename rust/downgrades/{3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325 => b41e55c0dba14a139d01dbee713aca5efe5b818a}/upgrade.properties (100%)
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/downgrade.ql b/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/downgrade.ql
similarity index 100%
rename from rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/downgrade.ql
rename to rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/downgrade.ql
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/old.dbscheme b/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/old.dbscheme
similarity index 100%
rename from rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/old.dbscheme
rename to rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/old.dbscheme
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/rust.dbscheme b/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/rust.dbscheme
similarity index 100%
rename from rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/rust.dbscheme
rename to rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/rust.dbscheme
diff --git a/rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties b/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/upgrade.properties
similarity index 100%
rename from rust/downgrades/3c1990e7f1da60ff6c53ee4f1ab85e1e7457e325/upgrade.properties
rename to rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/upgrade.properties
diff --git a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme
index 3c1990e7f1d..b41e55c0dba 100644
--- a/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme
+++ b/rust/ql/lib/upgrades/319c933d9615ccf40f363548cafd51d08c74a534/rust.dbscheme
@@ -2049,12 +2049,6 @@ macro_block_exprs(
unique int id: @macro_block_expr
);
-#keyset[id]
-macro_block_expr_tail_exprs(
- int id: @macro_block_expr ref,
- int tail_expr: @expr ref
-);
-
#keyset[id, index]
macro_block_expr_statements(
int id: @macro_block_expr ref,
@@ -2062,6 +2056,12 @@ macro_block_expr_statements(
int statement: @stmt ref
);
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
macro_exprs(
unique int id: @macro_expr
);
From 680b4abae2627c62ae3dab016eee33dd9a12f001 Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 19 Aug 2025 14:37:45 +0200
Subject: [PATCH 095/298] Rust: accept test changes
---
.../macro-expansion/PrintAst.expected | 140 +++++++++---------
.../CWE-825/AccessAfterLifetime.expected | 7 +-
2 files changed, 76 insertions(+), 71 deletions(-)
diff --git a/rust/ql/test/extractor-tests/macro-expansion/PrintAst.expected b/rust/ql/test/extractor-tests/macro-expansion/PrintAst.expected
index 79576902a43..fbd7a97918a 100644
--- a/rust/ql/test/extractor-tests/macro-expansion/PrintAst.expected
+++ b/rust/ql/test/extractor-tests/macro-expansion/PrintAst.expected
@@ -1532,16 +1532,6 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] quote_tokens_with_context
# 16| getTokenTree(): [TokenTree] TokenTree
# 16| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 16| getTailExpr(): [MacroExpr] MacroExpr
-# 16| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
-# 15| getPath(): [Path] ...::quote_token_with_context
-# 15| getQualifier(): [Path] $crate
-# 15| getSegment(): [PathSegment] $crate
-# 15| getIdentifier(): [NameRef] $crate
-# 15| getSegment(): [PathSegment] quote_token_with_context
-# 15| getIdentifier(): [NameRef] quote_token_with_context
-# 16| getTokenTree(): [TokenTree] TokenTree
-# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 16| getStatement(0): [ExprStmt] ExprStmt
# 16| getExpr(): [MacroExpr] MacroExpr
# 16| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
@@ -1633,16 +1623,6 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] pounded_var_names_with_context
# 16| getTokenTree(): [TokenTree] TokenTree
# 16| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 16| getTailExpr(): [MacroExpr] MacroExpr
-# 16| getMacroCall(): [MacroCall] ...::pounded_var_with_context!...
-# 15| getPath(): [Path] ...::pounded_var_with_context
-# 15| getQualifier(): [Path] $crate
-# 15| getSegment(): [PathSegment] $crate
-# 15| getIdentifier(): [NameRef] $crate
-# 15| getSegment(): [PathSegment] pounded_var_with_context
-# 15| getIdentifier(): [NameRef] pounded_var_with_context
-# 16| getTokenTree(): [TokenTree] TokenTree
-# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 15| getStatement(0): [ExprStmt] ExprStmt
# 15| getExpr(): [MacroExpr] MacroExpr
# 15| getMacroCall(): [MacroCall] ...::pounded_var_with_context!...
@@ -1748,6 +1728,16 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] i
# 15| getPat(): [IdentPat] has_iter
# 15| getName(): [Name] has_iter
+# 16| getTailExpr(): [MacroExpr] MacroExpr
+# 16| getMacroCall(): [MacroCall] ...::pounded_var_with_context!...
+# 15| getPath(): [Path] ...::pounded_var_with_context
+# 15| getQualifier(): [Path] $crate
+# 15| getSegment(): [PathSegment] $crate
+# 15| getIdentifier(): [NameRef] $crate
+# 15| getSegment(): [PathSegment] pounded_var_with_context
+# 15| getIdentifier(): [NameRef] pounded_var_with_context
+# 16| getTokenTree(): [TokenTree] TokenTree
+# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 15| getStatement(3): [LetStmt] let _ = has_iter
# 15| getInitializer(): [PathExpr,VariableAccess] has_iter
# 15| getPath(): [Path] has_iter
@@ -1788,16 +1778,6 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] pounded_var_names_with_context
# 16| getTokenTree(): [TokenTree] TokenTree
# 16| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 16| getTailExpr(): [MacroExpr] MacroExpr
-# 16| getMacroCall(): [MacroCall] ...::pounded_var_with_context!...
-# 15| getPath(): [Path] ...::pounded_var_with_context
-# 15| getQualifier(): [Path] $crate
-# 15| getSegment(): [PathSegment] $crate
-# 15| getIdentifier(): [NameRef] $crate
-# 15| getSegment(): [PathSegment] pounded_var_with_context
-# 15| getIdentifier(): [NameRef] pounded_var_with_context
-# 16| getTokenTree(): [TokenTree] TokenTree
-# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 15| getStatement(0): [ExprStmt] ExprStmt
# 15| getExpr(): [MacroExpr] MacroExpr
# 15| getMacroCall(): [MacroCall] ...::pounded_var_with_context!...
@@ -1911,6 +1891,16 @@ proc_macro.rs:
# 15| getName(): [Name] None
# 16| getPat(): [IdentPat] items
# 16| getName(): [Name] items
+# 16| getTailExpr(): [MacroExpr] MacroExpr
+# 16| getMacroCall(): [MacroCall] ...::pounded_var_with_context!...
+# 15| getPath(): [Path] ...::pounded_var_with_context
+# 15| getQualifier(): [Path] $crate
+# 15| getSegment(): [PathSegment] $crate
+# 15| getIdentifier(): [NameRef] $crate
+# 15| getSegment(): [PathSegment] pounded_var_with_context
+# 15| getIdentifier(): [NameRef] pounded_var_with_context
+# 16| getTokenTree(): [TokenTree] TokenTree
+# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 16| getTailExpr(): [MacroExpr] MacroExpr
# 16| getMacroCall(): [MacroCall] ...::quote_each_token!...
# 15| getPath(): [Path] ...::quote_each_token
@@ -1931,16 +1921,6 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] quote_tokens_with_context
# 16| getTokenTree(): [TokenTree] TokenTree
# 16| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 16| getTailExpr(): [MacroExpr] MacroExpr
-# 16| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
-# 15| getPath(): [Path] ...::quote_token_with_context
-# 15| getQualifier(): [Path] $crate
-# 15| getSegment(): [PathSegment] $crate
-# 15| getIdentifier(): [NameRef] $crate
-# 15| getSegment(): [PathSegment] quote_token_with_context
-# 15| getIdentifier(): [NameRef] quote_token_with_context
-# 16| getTokenTree(): [TokenTree] TokenTree
-# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 16| getStatement(0): [ExprStmt] ExprStmt
# 16| getExpr(): [MacroExpr] MacroExpr
# 16| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
@@ -2041,6 +2021,16 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] quote_token_with_context
# 16| getTokenTree(): [TokenTree] TokenTree
# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
+# 16| getTailExpr(): [MacroExpr] MacroExpr
+# 16| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
+# 15| getPath(): [Path] ...::quote_token_with_context
+# 15| getQualifier(): [Path] $crate
+# 15| getSegment(): [PathSegment] $crate
+# 15| getIdentifier(): [NameRef] $crate
+# 15| getSegment(): [PathSegment] quote_token_with_context
+# 15| getIdentifier(): [NameRef] quote_token_with_context
+# 16| getTokenTree(): [TokenTree] TokenTree
+# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 15| getCondition(): [BooleanLiteralExpr] true
# 16| getStatement(4): [ExprStmt] ExprStmt
# 16| getExpr(): [MacroExpr] MacroExpr
@@ -2086,6 +2076,16 @@ proc_macro.rs:
# 15| getIdentifier(): [NameRef] quote_token_with_context
# 16| getTokenTree(): [TokenTree] TokenTree
# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
+# 16| getTailExpr(): [MacroExpr] MacroExpr
+# 16| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
+# 15| getPath(): [Path] ...::quote_token_with_context
+# 15| getQualifier(): [Path] $crate
+# 15| getSegment(): [PathSegment] $crate
+# 15| getIdentifier(): [NameRef] $crate
+# 15| getSegment(): [PathSegment] quote_token_with_context
+# 15| getIdentifier(): [NameRef] quote_token_with_context
+# 16| getTokenTree(): [TokenTree] TokenTree
+# 15| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 15| getTailExpr(): [PathExpr] _s
# 15| getPath(): [Path] _s
# 15| getSegment(): [PathSegment] _s
@@ -2369,16 +2369,6 @@ proc_macro.rs:
# 25| getIdentifier(): [NameRef] quote_tokens_with_context
# 26| getTokenTree(): [TokenTree] TokenTree
# 26| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 27| getTailExpr(): [MacroExpr] MacroExpr
-# 27| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
-# 25| getPath(): [Path] ...::quote_token_with_context
-# 25| getQualifier(): [Path] $crate
-# 25| getSegment(): [PathSegment] $crate
-# 25| getIdentifier(): [NameRef] $crate
-# 25| getSegment(): [PathSegment] quote_token_with_context
-# 25| getIdentifier(): [NameRef] quote_token_with_context
-# 27| getTokenTree(): [TokenTree] TokenTree
-# 25| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 26| getStatement(0): [ExprStmt] ExprStmt
# 26| getExpr(): [MacroExpr] MacroExpr
# 26| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
@@ -2524,6 +2514,16 @@ proc_macro.rs:
# 25| getIdentifier(): [NameRef] quote_token_with_context
# 27| getTokenTree(): [TokenTree] TokenTree
# 25| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
+# 27| getTailExpr(): [MacroExpr] MacroExpr
+# 27| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
+# 25| getPath(): [Path] ...::quote_token_with_context
+# 25| getQualifier(): [Path] $crate
+# 25| getSegment(): [PathSegment] $crate
+# 25| getIdentifier(): [NameRef] $crate
+# 25| getSegment(): [PathSegment] quote_token_with_context
+# 25| getIdentifier(): [NameRef] quote_token_with_context
+# 27| getTokenTree(): [TokenTree] TokenTree
+# 25| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 25| getTailExpr(): [PathExpr] _s
# 25| getPath(): [Path] _s
# 25| getSegment(): [PathSegment] _s
@@ -2825,16 +2825,6 @@ proc_macro.rs:
# 41| getIdentifier(): [NameRef] quote_tokens_with_context
# 42| getTokenTree(): [TokenTree] TokenTree
# 42| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 44| getTailExpr(): [MacroExpr] MacroExpr
-# 44| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
-# 41| getPath(): [Path] ...::quote_token_with_context
-# 41| getQualifier(): [Path] $crate
-# 41| getSegment(): [PathSegment] $crate
-# 41| getIdentifier(): [NameRef] $crate
-# 41| getSegment(): [PathSegment] quote_token_with_context
-# 41| getIdentifier(): [NameRef] quote_token_with_context
-# 44| getTokenTree(): [TokenTree] TokenTree
-# 41| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 42| getStatement(0): [ExprStmt] ExprStmt
# 42| getExpr(): [MacroExpr] MacroExpr
# 42| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
@@ -3443,16 +3433,6 @@ proc_macro.rs:
# 41| getIdentifier(): [NameRef] quote_tokens_with_context
# 45| getTokenTree(): [TokenTree] TokenTree
# 45| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
-# 45| getTailExpr(): [MacroExpr] MacroExpr
-# 45| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
-# 41| getPath(): [Path] ...::quote_token_with_context
-# 41| getQualifier(): [Path] $crate
-# 41| getSegment(): [PathSegment] $crate
-# 41| getIdentifier(): [NameRef] $crate
-# 41| getSegment(): [PathSegment] quote_token_with_context
-# 41| getIdentifier(): [NameRef] quote_token_with_context
-# 45| getTokenTree(): [TokenTree] TokenTree
-# 41| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 45| getStatement(0): [ExprStmt] ExprStmt
# 45| getExpr(): [MacroExpr] MacroExpr
# 45| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
@@ -3869,6 +3849,16 @@ proc_macro.rs:
# 41| getIdentifier(): [NameRef] quote_token_with_context
# 45| getTokenTree(): [TokenTree] TokenTree
# 41| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
+# 45| getTailExpr(): [MacroExpr] MacroExpr
+# 45| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
+# 41| getPath(): [Path] ...::quote_token_with_context
+# 41| getQualifier(): [Path] $crate
+# 41| getSegment(): [PathSegment] $crate
+# 41| getIdentifier(): [NameRef] $crate
+# 41| getSegment(): [PathSegment] quote_token_with_context
+# 41| getIdentifier(): [NameRef] quote_token_with_context
+# 45| getTokenTree(): [TokenTree] TokenTree
+# 41| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 41| getTailExpr(): [PathExpr] _s
# 41| getPath(): [Path] _s
# 41| getSegment(): [PathSegment] _s
@@ -3905,6 +3895,16 @@ proc_macro.rs:
# 41| getIdentifier(): [NameRef] quote_token_with_context
# 44| getTokenTree(): [TokenTree] TokenTree
# 41| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
+# 44| getTailExpr(): [MacroExpr] MacroExpr
+# 44| getMacroCall(): [MacroCall] ...::quote_token_with_context!...
+# 41| getPath(): [Path] ...::quote_token_with_context
+# 41| getQualifier(): [Path] $crate
+# 41| getSegment(): [PathSegment] $crate
+# 41| getIdentifier(): [NameRef] $crate
+# 41| getSegment(): [PathSegment] quote_token_with_context
+# 41| getIdentifier(): [NameRef] quote_token_with_context
+# 44| getTokenTree(): [TokenTree] TokenTree
+# 41| getMacroCallExpansion(): [MacroBlockExpr] MacroBlockExpr
# 41| getTailExpr(): [PathExpr] _s
# 41| getPath(): [Path] _s
# 41| getSegment(): [PathSegment] _s
diff --git a/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected b/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected
index eb81a7c1ebc..25f8643f073 100644
--- a/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected
+++ b/rust/ql/test/query-tests/security/CWE-825/AccessAfterLifetime.expected
@@ -198,7 +198,9 @@ edges
| lifetime.rs:730:6:730:7 | r1 | lifetime.rs:734:12:734:13 | r1 | provenance | |
| lifetime.rs:730:11:730:25 | e1.test_match() | lifetime.rs:730:6:730:7 | r1 | provenance | |
| lifetime.rs:766:2:766:11 | &val | lifetime.rs:766:2:766:11 | ptr | provenance | |
-| lifetime.rs:766:2:766:11 | ptr | lifetime.rs:767:2:767:11 | ptr | provenance | |
+| lifetime.rs:766:2:766:11 | ptr | lifetime.rs:766:2:766:11 | ptr | provenance | |
+| lifetime.rs:767:2:767:11 | &val | lifetime.rs:767:2:767:11 | ptr | provenance | |
+| lifetime.rs:767:2:767:11 | ptr | lifetime.rs:767:2:767:11 | ptr | provenance | |
| lifetime.rs:769:6:769:8 | ptr | lifetime.rs:771:12:771:14 | ptr | provenance | |
| lifetime.rs:769:12:769:21 | &val | lifetime.rs:769:12:769:21 | ptr | provenance | |
| lifetime.rs:769:12:769:21 | ptr | lifetime.rs:769:6:769:8 | ptr | provenance | |
@@ -420,6 +422,9 @@ nodes
| lifetime.rs:734:12:734:13 | r1 | semmle.label | r1 |
| lifetime.rs:766:2:766:11 | &val | semmle.label | &val |
| lifetime.rs:766:2:766:11 | ptr | semmle.label | ptr |
+| lifetime.rs:766:2:766:11 | ptr | semmle.label | ptr |
+| lifetime.rs:767:2:767:11 | &val | semmle.label | &val |
+| lifetime.rs:767:2:767:11 | ptr | semmle.label | ptr |
| lifetime.rs:767:2:767:11 | ptr | semmle.label | ptr |
| lifetime.rs:769:6:769:8 | ptr | semmle.label | ptr |
| lifetime.rs:769:12:769:21 | &val | semmle.label | &val |
From fbeebd7d3cfc27a0cd165c054b45f87e90d7794a Mon Sep 17 00:00:00 2001
From: Paolo Tranquilli
Date: Tue, 19 Aug 2025 14:38:39 +0200
Subject: [PATCH 096/298] Rust: fix `old.dbscheme` in downgrade script
---
.../old.dbscheme | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/old.dbscheme b/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/old.dbscheme
index 3c1990e7f1d..b41e55c0dba 100644
--- a/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/old.dbscheme
+++ b/rust/downgrades/b41e55c0dba14a139d01dbee713aca5efe5b818a/old.dbscheme
@@ -2049,12 +2049,6 @@ macro_block_exprs(
unique int id: @macro_block_expr
);
-#keyset[id]
-macro_block_expr_tail_exprs(
- int id: @macro_block_expr ref,
- int tail_expr: @expr ref
-);
-
#keyset[id, index]
macro_block_expr_statements(
int id: @macro_block_expr ref,
@@ -2062,6 +2056,12 @@ macro_block_expr_statements(
int statement: @stmt ref
);
+#keyset[id]
+macro_block_expr_tail_exprs(
+ int id: @macro_block_expr ref,
+ int tail_expr: @expr ref
+);
+
macro_exprs(
unique int id: @macro_expr
);
From 46a2de69cdfeeae970d0826bf6ac3baf76dc31d4 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Thu, 21 Aug 2025 13:21:17 +0200
Subject: [PATCH 097/298] Update java/ql/src/Violations of Best
Practice/Undesirable Calls/CallsToSystemExit.ql
Co-authored-by: Michael Nebel
---
.../Undesirable Calls/CallsToSystemExit.ql | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql b/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql
index c17141122d1..d974c704098 100644
--- a/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql
+++ b/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql
@@ -44,7 +44,7 @@ class ExitOrHaltMethodCall extends MethodCall {
/**
* An intentional `MethodCall` to a system or runtime "exit" method, such as for
- * functions which exist for the purpose of exiting the program. Assumes that a an exit method
+ * functions which exist for the purpose of exiting the program. Assumes that an exit method
* call within a method is intentional if the exit code is passed from a parameter of the
* enclosing method.
*/
From 41a78a0c3dd7d4e0418479d747dd1a5c3fe4f357 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Thu, 21 Aug 2025 14:00:44 +0000
Subject: [PATCH 098/298] Java: Added nested local class test case
---
.../CallsToSystemExit.expected | 4 +++
.../LocalClassInTestMethod.java | 26 +++++++++++++++++++
2 files changed, 30 insertions(+)
create mode 100644 java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java
diff --git a/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected b/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected
index cad6d0097c7..eeabf3446bf 100644
--- a/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected
+++ b/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected
@@ -4,3 +4,7 @@
| ExampleRuntimeHalt.java:21:17:21:44 | halt(...) | Avoid calls to Runtime.halt() as this prevents runtime cleanup and makes code harder to reuse. |
| ExampleSystemExit.java:22:17:22:30 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
| ExampleSystemExit.java:25:17:25:30 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
+| LocalClassInTestMethod.java:7:25:7:38 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
+| LocalClassInTestMethod.java:8:25:8:52 | halt(...) | Avoid calls to Runtime.halt() as this prevents runtime cleanup and makes code harder to reuse. |
+| LocalClassInTestMethod.java:20:21:20:34 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
+| LocalClassInTestMethod.java:21:21:21:48 | halt(...) | Avoid calls to Runtime.halt() as this prevents runtime cleanup and makes code harder to reuse. |
diff --git a/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java b/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java
new file mode 100644
index 00000000000..0a4dc8c80f6
--- /dev/null
+++ b/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java
@@ -0,0 +1,26 @@
+public class LocalClassInTestMethod {
+ public void testNestedCase() {
+ class OuterLocalClass {
+ void func() {
+ class NestedLocalClass {
+ void nestedMethod() {
+ System.exit(4); // $ SPURIOUS: Alert
+ Runtime.getRuntime().halt(5); // $ SPURIOUS: Alert
+ }
+ }
+ }
+ }
+ OuterLocalClass outer = new OuterLocalClass();
+ outer.func();
+ }
+ public void testNestedCase2() {
+ class OuterLocalClass {
+ class NestedLocalClass {
+ void nestedMethod() {
+ System.exit(4); // $ SPURIOUS: Alert
+ Runtime.getRuntime().halt(5); // $ SPURIOUS: Alert
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
From eb6e9b8fe6f50d5c232d2292e6fdcc4522a2eecd Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Thu, 21 Aug 2025 14:12:54 +0000
Subject: [PATCH 099/298] Java: Fix java/jvm-exit false positives for local
nested classes in test methods
---
.../Undesirable Calls/CallsToSystemExit.ql | 10 +++++++++-
.../CallsToSystemExit/CallsToSystemExit.expected | 4 ----
.../CallsToSystemExit/LocalClassInTestMethod.java | 8 ++++----
3 files changed, 13 insertions(+), 9 deletions(-)
diff --git a/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql b/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql
index d974c704098..2653f197ae2 100644
--- a/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql
+++ b/java/ql/src/Violations of Best Practice/Undesirable Calls/CallsToSystemExit.ql
@@ -63,7 +63,15 @@ class SourceMethodNotMainOrTest extends Method {
this.fromSource() and
not this instanceof MainMethod and
not this instanceof LikelyTestMethod and
- not this.getEnclosingCallable() instanceof LikelyTestMethod
+ not (
+ this.getEnclosingCallable*() instanceof LikelyTestMethod
+ or
+ this.getDeclaringType()
+ .getEnclosingType*()
+ .(LocalClassOrInterface)
+ .getLocalTypeDeclStmt()
+ .getEnclosingCallable() instanceof LikelyTestMethod
+ )
}
}
diff --git a/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected b/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected
index eeabf3446bf..cad6d0097c7 100644
--- a/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected
+++ b/java/ql/test/query-tests/CallsToSystemExit/CallsToSystemExit.expected
@@ -4,7 +4,3 @@
| ExampleRuntimeHalt.java:21:17:21:44 | halt(...) | Avoid calls to Runtime.halt() as this prevents runtime cleanup and makes code harder to reuse. |
| ExampleSystemExit.java:22:17:22:30 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
| ExampleSystemExit.java:25:17:25:30 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
-| LocalClassInTestMethod.java:7:25:7:38 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
-| LocalClassInTestMethod.java:8:25:8:52 | halt(...) | Avoid calls to Runtime.halt() as this prevents runtime cleanup and makes code harder to reuse. |
-| LocalClassInTestMethod.java:20:21:20:34 | exit(...) | Avoid calls to System.exit() as this prevents runtime cleanup and makes code harder to reuse. |
-| LocalClassInTestMethod.java:21:21:21:48 | halt(...) | Avoid calls to Runtime.halt() as this prevents runtime cleanup and makes code harder to reuse. |
diff --git a/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java b/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java
index 0a4dc8c80f6..459f944d798 100644
--- a/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java
+++ b/java/ql/test/query-tests/CallsToSystemExit/LocalClassInTestMethod.java
@@ -4,8 +4,8 @@ public class LocalClassInTestMethod {
void func() {
class NestedLocalClass {
void nestedMethod() {
- System.exit(4); // $ SPURIOUS: Alert
- Runtime.getRuntime().halt(5); // $ SPURIOUS: Alert
+ System.exit(4);
+ Runtime.getRuntime().halt(5);
}
}
}
@@ -17,8 +17,8 @@ public class LocalClassInTestMethod {
class OuterLocalClass {
class NestedLocalClass {
void nestedMethod() {
- System.exit(4); // $ SPURIOUS: Alert
- Runtime.getRuntime().halt(5); // $ SPURIOUS: Alert
+ System.exit(4);
+ Runtime.getRuntime().halt(5);
}
}
}
From 5da296d77fed96ab72a022307711905355a81f93 Mon Sep 17 00:00:00 2001
From: Geoffrey White <40627776+geoffw0@users.noreply.github.com>
Date: Wed, 6 Aug 2025 14:15:25 +0100
Subject: [PATCH 100/298] Rust: Add tests for std::fs::OpenOptions and similar.
---
.../dataflow/sources/TaintSources.expected | 28 +-
.../library-tests/dataflow/sources/test.rs | 53 ++
.../query-tests/security/CWE-022/Cargo.lock | 515 +++++++++++++++++-
.../security/CWE-022/TaintedPath.expected | 26 +-
.../query-tests/security/CWE-022/options.yml | 2 +
.../query-tests/security/CWE-022/src/main.rs | 4 +
6 files changed, 589 insertions(+), 39 deletions(-)
diff --git a/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected b/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected
index 66d909f2e1b..d8787604ff4 100644
--- a/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected
+++ b/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected
@@ -67,20 +67,20 @@
| test.rs:457:31:457:39 | file_name | Flow source 'FileSource' of type file (DEFAULT). |
| test.rs:463:22:463:41 | ...::read_link | Flow source 'FileSource' of type file (DEFAULT). |
| test.rs:473:20:473:38 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:507:21:507:39 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:508:21:508:39 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:516:21:516:39 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:528:20:528:40 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:575:21:575:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:576:21:576:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:584:21:584:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:601:26:601:53 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:620:26:620:61 | ...::connect_timeout | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:672:28:672:57 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:754:22:754:49 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:780:22:780:50 | ...::new | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:807:16:807:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
-| test.rs:807:16:807:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
+| test.rs:530:21:530:39 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:531:21:531:39 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:539:21:539:39 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:551:20:551:40 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:607:21:607:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:608:21:608:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:616:21:616:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
+| test.rs:648:26:648:53 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:667:26:667:61 | ...::connect_timeout | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:719:28:719:57 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:801:22:801:49 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:827:22:827:50 | ...::new | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:854:16:854:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
+| test.rs:854:16:854:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
| test_futures_io.rs:19:15:19:32 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
| web_frameworks.rs:11:31:11:31 | a | Flow source 'RemoteSource' of type remote (DEFAULT). |
| web_frameworks.rs:11:31:11:31 | a | Flow source 'RemoteSource' of type remote (DEFAULT). |
diff --git a/rust/ql/test/library-tests/dataflow/sources/test.rs b/rust/ql/test/library-tests/dataflow/sources/test.rs
index baa2062a910..4ace4c56b06 100644
--- a/rust/ql/test/library-tests/dataflow/sources/test.rs
+++ b/rust/ql/test/library-tests/dataflow/sources/test.rs
@@ -500,6 +500,29 @@ fn test_io_file() -> std::io::Result<()> {
sink(byte); // $ hasTaintFlow="file.txt"
}
+ // --- OpenOptions ---
+
+ {
+ let mut f1 = std::fs::OpenOptions::new().open("f1.txt").unwrap(); // $ MISSING: Alert[rust/summary/taint-sources]
+ let mut buffer = [0u8; 1024];
+ let _bytes = f1.read(&mut buffer)?;
+ sink(&buffer); // $ MISSING: hasTaintFlow="f1.txt"
+ }
+
+ {
+ let mut f2 = std::fs::OpenOptions::new().create_new(true).open("f2.txt").unwrap(); // $ MISSING: Alert[rust/summary/taint-sources]
+ let mut buffer = [0u8; 1024];
+ let _bytes = f2.read(&mut buffer)?;
+ sink(&buffer); // $ MISSING: hasTaintFlow="f2.txt"
+ }
+
+ {
+ let mut f3 = std::fs::OpenOptions::new().read(true).write(true).truncate(true).create(true).open("f3.txt").unwrap(); // $ MISSING: Alert[rust/summary/taint-sources]
+ let mut buffer = [0u8; 1024];
+ let _bytes = f3.read(&mut buffer)?;
+ sink(&buffer); // $ MISSING: hasTaintFlow="f3.txt"
+ }
+
// --- misc operations ---
{
@@ -568,6 +591,15 @@ async fn test_tokio_file() -> std::io::Result<()> {
sink(&buffer); // $ MISSING: hasTaintFlow="file.txt" -- we cannot resolve the `read_buf` call above, which comes from `impl AsyncReadExt for R {}` in `async_read_ext.rs`
}
+ // --- OpenOptions ---
+
+ {
+ let mut f1 = tokio::fs::OpenOptions::new().open("f1.txt").await?; // $ MISSING: Alert[rust/summary/taint-sources]
+ let mut buffer = [0u8; 1024];
+ let _bytes = f1.read(&mut buffer).await?;
+ sink(&buffer); // $ MISSING: hasTaintFlow="f1.txt"
+ }
+
// --- misc operations ---
{
@@ -590,6 +622,21 @@ async fn test_tokio_file() -> std::io::Result<()> {
Ok(())
}
+use async_std::io::ReadExt;
+
+async fn test_async_std_file() -> std::io::Result<()> {
+ // --- OpenOptions ---
+
+ {
+ let mut f1 = async_std::fs::OpenOptions::new().open("f1.txt").await?; // $ MISSING: Alert[rust/summary/taint-sources]
+ let mut buffer = [0u8; 1024];
+ let _bytes = f1.read(&mut buffer).await?;
+ sink(&buffer); // $ MISSING: hasTaintFlow="f1.txt"
+ }
+
+ Ok(())
+}
+
use std::net::ToSocketAddrs;
async fn test_std_tcpstream(case: i64) -> std::io::Result<()> {
@@ -863,6 +910,12 @@ async fn main() -> Result<(), Box> {
Err(e) => println!("error: {}", e),
}
+ println!("test_async_std_file...");
+ match futures::executor::block_on(test_async_std_file()) {
+ Ok(_) => println!("complete"),
+ Err(e) => println!("error: {}", e),
+ }
+
println!("test_std_tcpstream...");
match futures::executor::block_on(test_std_tcpstream(case)) {
Ok(_) => println!("complete"),
diff --git a/rust/ql/test/query-tests/security/CWE-022/Cargo.lock b/rust/ql/test/query-tests/security/CWE-022/Cargo.lock
index 29fb6823657..f6b8cfc2c4b 100644
--- a/rust/ql/test/query-tests/security/CWE-022/Cargo.lock
+++ b/rust/ql/test/query-tests/security/CWE-022/Cargo.lock
@@ -26,6 +26,119 @@ dependencies = [
"memchr",
]
+[[package]]
+name = "async-channel"
+version = "1.9.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "81953c529336010edd6d8e358f886d9581267795c61b19475b71314bffa46d35"
+dependencies = [
+ "concurrent-queue",
+ "event-listener 2.5.3",
+ "futures-core",
+]
+
+[[package]]
+name = "async-channel"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "924ed96dd52d1b75e9c1a3e6275715fd320f5f9439fb5a4a11fa51f4221158d2"
+dependencies = [
+ "concurrent-queue",
+ "event-listener-strategy",
+ "futures-core",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "async-executor"
+version = "1.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bb812ffb58524bdd10860d7d974e2f01cc0950c2438a74ee5ec2e2280c6c4ffa"
+dependencies = [
+ "async-task",
+ "concurrent-queue",
+ "fastrand",
+ "futures-lite",
+ "pin-project-lite",
+ "slab",
+]
+
+[[package]]
+name = "async-global-executor"
+version = "2.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "05b1b633a2115cd122d73b955eadd9916c18c8f510ec9cd1686404c60ad1c29c"
+dependencies = [
+ "async-channel 2.5.0",
+ "async-executor",
+ "async-io",
+ "async-lock",
+ "blocking",
+ "futures-lite",
+ "once_cell",
+]
+
+[[package]]
+name = "async-io"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "19634d6336019ef220f09fd31168ce5c184b295cbf80345437cc36094ef223ca"
+dependencies = [
+ "async-lock",
+ "cfg-if",
+ "concurrent-queue",
+ "futures-io",
+ "futures-lite",
+ "parking",
+ "polling",
+ "rustix",
+ "slab",
+ "windows-sys 0.60.2",
+]
+
+[[package]]
+name = "async-lock"
+version = "3.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5fd03604047cee9b6ce9de9f70c6cd540a0520c813cbd49bae61f33ab80ed1dc"
+dependencies = [
+ "event-listener 5.4.1",
+ "event-listener-strategy",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "async-std"
+version = "1.13.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2c8e079a4ab67ae52b7403632e4618815d6db36d2a010cfe41b02c1b1578f93b"
+dependencies = [
+ "async-channel 1.9.0",
+ "async-global-executor",
+ "async-io",
+ "async-lock",
+ "crossbeam-utils",
+ "futures-channel",
+ "futures-core",
+ "futures-io",
+ "futures-lite",
+ "gloo-timers",
+ "kv-log-macro",
+ "log",
+ "memchr",
+ "once_cell",
+ "pin-project-lite",
+ "pin-utils",
+ "slab",
+ "wasm-bindgen-futures",
+]
+
+[[package]]
+name = "async-task"
+version = "4.7.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8b75356056920673b02621b35afd0f7dda9306d03c79a30f5c56c44cf256e3de"
+
[[package]]
name = "atomic-waker"
version = "1.1.2"
@@ -50,7 +163,7 @@ dependencies = [
"miniz_oxide",
"object",
"rustc-demangle",
- "windows-targets",
+ "windows-targets 0.52.6",
]
[[package]]
@@ -74,6 +187,25 @@ dependencies = [
"generic-array",
]
+[[package]]
+name = "blocking"
+version = "1.6.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e83f8d02be6967315521be875afa792a316e28d57b5a2d401897e2a7921b7f21"
+dependencies = [
+ "async-channel 2.5.0",
+ "async-task",
+ "futures-io",
+ "futures-lite",
+ "piper",
+]
+
+[[package]]
+name = "bumpalo"
+version = "3.19.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "46c5e41b57b8bba42a04676d81cb89e9ee8e859a1a66f80a5a72e1cb76b34d43"
+
[[package]]
name = "bytes"
version = "1.10.1"
@@ -92,6 +224,15 @@ version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "613afe47fcd5fac7ccf1db93babcb082c5994d996f20b8b159f2ad1658eb5724"
+[[package]]
+name = "concurrent-queue"
+version = "2.5.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "4ca0197aee26d1ae37445ee532fefce43251d24cc7c166799f4d46817f1d3973"
+dependencies = [
+ "crossbeam-utils",
+]
+
[[package]]
name = "cpufeatures"
version = "0.2.17"
@@ -101,6 +242,12 @@ dependencies = [
"libc",
]
+[[package]]
+name = "crossbeam-utils"
+version = "0.8.21"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d0a5c400df2834b80a4c3327b3aad3a4c4cd4de0629063962b03235697506a28"
+
[[package]]
name = "crypto-common"
version = "0.1.6"
@@ -127,6 +274,49 @@ version = "1.0.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "877a4ace8713b0bcf2a4e7eec82529c029f1d0619886d18145fea96c3ffe5c0f"
+[[package]]
+name = "errno"
+version = "0.3.13"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "778e2ac28f6c47af28e4907f13ffd1e1ddbd400980a9abd7c8df189bf578a5ad"
+dependencies = [
+ "libc",
+ "windows-sys 0.59.0",
+]
+
+[[package]]
+name = "event-listener"
+version = "2.5.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0206175f82b8d6bf6652ff7d71a1e27fd2e4efde587fd368662814d6ec1d9ce0"
+
+[[package]]
+name = "event-listener"
+version = "5.4.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "e13b66accf52311f30a0db42147dadea9850cb48cd070028831ae5f5d4b856ab"
+dependencies = [
+ "concurrent-queue",
+ "parking",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "event-listener-strategy"
+version = "0.5.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8be9f3dfaaffdae2972880079a491a1a8bb7cbed0b8dd7a347f668b4150a3b93"
+dependencies = [
+ "event-listener 5.4.1",
+ "pin-project-lite",
+]
+
+[[package]]
+name = "fastrand"
+version = "2.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "37909eebbb50d72f9059c3b6d82c0463f2ff062c9e95845c43a6c9c0355411be"
+
[[package]]
name = "fnv"
version = "1.0.7"
@@ -157,6 +347,25 @@ version = "0.3.31"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "05f29059c0c2090612e8d742178b0580d2dc940c837851ad723096f87af6663e"
+[[package]]
+name = "futures-io"
+version = "0.3.31"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9e5c1b78ca4aae1ac06c48a526a655760685149f0d465d21f37abfe57ce075c6"
+
+[[package]]
+name = "futures-lite"
+version = "2.6.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f78e10609fe0e0b3f4157ffab1876319b5b0db102a2c60dc4626306dc46b44ad"
+dependencies = [
+ "fastrand",
+ "futures-core",
+ "futures-io",
+ "parking",
+ "pin-project-lite",
+]
+
[[package]]
name = "futures-macro"
version = "0.3.31"
@@ -211,6 +420,18 @@ version = "0.31.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "07e28edb80900c19c28f1072f2e8aeca7fa06b23cd4169cefe1af5aa3260783f"
+[[package]]
+name = "gloo-timers"
+version = "0.3.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "bbb143cf96099802033e0d4f4963b19fd2e0b728bcf076cd9cf7f6634f092994"
+dependencies = [
+ "futures-channel",
+ "futures-core",
+ "js-sys",
+ "wasm-bindgen",
+]
+
[[package]]
name = "h2"
version = "0.4.10"
@@ -260,6 +481,12 @@ dependencies = [
"http",
]
+[[package]]
+name = "hermit-abi"
+version = "0.5.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "fc0fef456e4baa96da950455cd02c081ca953b141298e41db3fc7e36b1da849c"
+
[[package]]
name = "http"
version = "1.3.1"
@@ -357,12 +584,37 @@ version = "1.0.15"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "4a5f13b858c8d314ee3e8f639011f7ccefe71f97f96e50151fb991f267928e2c"
+[[package]]
+name = "js-sys"
+version = "0.3.77"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1cfaf33c695fc6e08064efbc1f72ec937429614f25eef83af942d0e227c3a28f"
+dependencies = [
+ "once_cell",
+ "wasm-bindgen",
+]
+
+[[package]]
+name = "kv-log-macro"
+version = "1.0.7"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0de8b303297635ad57c9f5059fd9cee7a47f8e8daa09df0fcd07dd39fb22977f"
+dependencies = [
+ "log",
+]
+
[[package]]
name = "libc"
version = "0.2.173"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d8cfeafaffdbc32176b64fb251369d52ea9f0a8fbc6f8759edffef7b525d64bb"
+[[package]]
+name = "linux-raw-sys"
+version = "0.9.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "cd945864f07fe9f5371a27ad7b52a172b4b499999f1d97574c9fa68373937e12"
+
[[package]]
name = "lock_api"
version = "0.4.13"
@@ -373,6 +625,15 @@ dependencies = [
"scopeguard",
]
+[[package]]
+name = "log"
+version = "0.4.27"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "13dc2df351e3202783a1fe0d44375f7295ffb4049267b0f3018346dc122a1d94"
+dependencies = [
+ "value-bag",
+]
+
[[package]]
name = "memchr"
version = "2.7.5"
@@ -432,6 +693,12 @@ version = "1.21.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "42f5e15c9953c5e4ccceeb2e7382a716482c34515315f7b03532b8b4e8393d2d"
+[[package]]
+name = "parking"
+version = "2.2.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f38d5652c16fde515bb1ecef450ab0f6a219d619a7274976324d5e377f7dceba"
+
[[package]]
name = "parking_lot"
version = "0.12.4"
@@ -452,7 +719,7 @@ dependencies = [
"libc",
"redox_syscall",
"smallvec",
- "windows-targets",
+ "windows-targets 0.52.6",
]
[[package]]
@@ -473,6 +740,17 @@ version = "0.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184"
+[[package]]
+name = "piper"
+version = "0.2.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "96c8c490f422ef9a4efd2cb5b42b76c8613d7e7dfc1caf667b8a3350a5acc066"
+dependencies = [
+ "atomic-waker",
+ "fastrand",
+ "futures-io",
+]
+
[[package]]
name = "poem"
version = "3.1.11"
@@ -518,6 +796,20 @@ dependencies = [
"syn",
]
+[[package]]
+name = "polling"
+version = "3.10.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b5bd19146350fe804f7cb2669c851c03d69da628803dab0d98018142aaa5d829"
+dependencies = [
+ "cfg-if",
+ "concurrent-queue",
+ "hermit-abi",
+ "pin-project-lite",
+ "rustix",
+ "windows-sys 0.60.2",
+]
+
[[package]]
name = "proc-macro-crate"
version = "3.3.0"
@@ -598,6 +890,25 @@ version = "0.1.25"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "989e6739f80c4ad5b13e0fd7fe89531180375b18520cc8c82080e4dc4035b84f"
+[[package]]
+name = "rustix"
+version = "1.0.8"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "11181fbabf243db407ef8df94a6ce0b2f9a733bd8be4ad02b4eda9602296cac8"
+dependencies = [
+ "bitflags",
+ "errno",
+ "libc",
+ "linux-raw-sys",
+ "windows-sys 0.59.0",
+]
+
+[[package]]
+name = "rustversion"
+version = "1.0.22"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b39cdef0fa800fc44525c84ccb54a029961a8215f9619753635a9c0d2538d46d"
+
[[package]]
name = "ryu"
version = "1.0.20"
@@ -665,6 +976,15 @@ dependencies = [
"digest",
]
+[[package]]
+name = "signal-hook-registry"
+version = "1.4.6"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "b2a4719bff48cee6b39d12c020eeb490953ad2443b7055bd0b21fca26bd8c28b"
+dependencies = [
+ "libc",
+]
+
[[package]]
name = "slab"
version = "0.4.10"
@@ -711,7 +1031,9 @@ dependencies = [
name = "test"
version = "0.0.1"
dependencies = [
+ "async-std",
"poem",
+ "tokio",
]
[[package]]
@@ -744,7 +1066,9 @@ dependencies = [
"bytes",
"libc",
"mio",
+ "parking_lot",
"pin-project-lite",
+ "signal-hook-registry",
"socket2",
"tokio-macros",
"windows-sys 0.52.0",
@@ -843,6 +1167,12 @@ version = "1.0.18"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5a5f39404a5da50712a4c1eecf25e90dd62b613502b7e925fd4e4d19b5c96512"
+[[package]]
+name = "value-bag"
+version = "1.11.1"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "943ce29a8a743eb10d6082545d861b24f9d1b160b7d741e0f2cdf726bec909c5"
+
[[package]]
name = "version_check"
version = "0.9.5"
@@ -855,19 +1185,106 @@ version = "0.11.1+wasi-snapshot-preview1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ccf3ec651a847eb01de73ccad15eb7d99f80485de043efb2f370cd654f4ea44b"
+[[package]]
+name = "wasm-bindgen"
+version = "0.2.100"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1edc8929d7499fc4e8f0be2262a241556cfc54a0bea223790e71446f2aab1ef5"
+dependencies = [
+ "cfg-if",
+ "once_cell",
+ "rustversion",
+ "wasm-bindgen-macro",
+]
+
+[[package]]
+name = "wasm-bindgen-backend"
+version = "0.2.100"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2f0a0651a5c2bc21487bde11ee802ccaf4c51935d0d3d42a6101f98161700bc6"
+dependencies = [
+ "bumpalo",
+ "log",
+ "proc-macro2",
+ "quote",
+ "syn",
+ "wasm-bindgen-shared",
+]
+
+[[package]]
+name = "wasm-bindgen-futures"
+version = "0.4.50"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "555d470ec0bc3bb57890405e5d4322cc9ea83cebb085523ced7be4144dac1e61"
+dependencies = [
+ "cfg-if",
+ "js-sys",
+ "once_cell",
+ "wasm-bindgen",
+ "web-sys",
+]
+
+[[package]]
+name = "wasm-bindgen-macro"
+version = "0.2.100"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "7fe63fc6d09ed3792bd0897b314f53de8e16568c2b3f7982f468c0bf9bd0b407"
+dependencies = [
+ "quote",
+ "wasm-bindgen-macro-support",
+]
+
+[[package]]
+name = "wasm-bindgen-macro-support"
+version = "0.2.100"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "8ae87ea40c9f689fc23f209965b6fb8a99ad69aeeb0231408be24920604395de"
+dependencies = [
+ "proc-macro2",
+ "quote",
+ "syn",
+ "wasm-bindgen-backend",
+ "wasm-bindgen-shared",
+]
+
+[[package]]
+name = "wasm-bindgen-shared"
+version = "0.2.100"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "1a05d73b933a847d6cccdda8f838a22ff101ad9bf93e33684f39c1f5f0eece3d"
+dependencies = [
+ "unicode-ident",
+]
+
+[[package]]
+name = "web-sys"
+version = "0.3.77"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "33b6dd2ef9186f1f2072e409e99cd22a975331a6b3591b12c764e0e55c60d5d2"
+dependencies = [
+ "js-sys",
+ "wasm-bindgen",
+]
+
[[package]]
name = "wildmatch"
version = "2.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "68ce1ab1f8c62655ebe1350f589c61e505cf94d385bc6a12899442d9081e71fd"
+[[package]]
+name = "windows-link"
+version = "0.1.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "5e6ad25900d524eaabdbbb96d20b4311e1e7ae1699af4fb28c17ae66c80d798a"
+
[[package]]
name = "windows-sys"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d"
dependencies = [
- "windows-targets",
+ "windows-targets 0.52.6",
]
[[package]]
@@ -876,7 +1293,16 @@ version = "0.59.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b"
dependencies = [
- "windows-targets",
+ "windows-targets 0.52.6",
+]
+
+[[package]]
+name = "windows-sys"
+version = "0.60.2"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "f2f500e4d28234f72040990ec9d39e3a6b950f9f22d3dba18416c35882612bcb"
+dependencies = [
+ "windows-targets 0.53.3",
]
[[package]]
@@ -885,14 +1311,31 @@ version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973"
dependencies = [
- "windows_aarch64_gnullvm",
- "windows_aarch64_msvc",
- "windows_i686_gnu",
- "windows_i686_gnullvm",
- "windows_i686_msvc",
- "windows_x86_64_gnu",
- "windows_x86_64_gnullvm",
- "windows_x86_64_msvc",
+ "windows_aarch64_gnullvm 0.52.6",
+ "windows_aarch64_msvc 0.52.6",
+ "windows_i686_gnu 0.52.6",
+ "windows_i686_gnullvm 0.52.6",
+ "windows_i686_msvc 0.52.6",
+ "windows_x86_64_gnu 0.52.6",
+ "windows_x86_64_gnullvm 0.52.6",
+ "windows_x86_64_msvc 0.52.6",
+]
+
+[[package]]
+name = "windows-targets"
+version = "0.53.3"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "d5fe6031c4041849d7c496a8ded650796e7b6ecc19df1a431c1a363342e5dc91"
+dependencies = [
+ "windows-link",
+ "windows_aarch64_gnullvm 0.53.0",
+ "windows_aarch64_msvc 0.53.0",
+ "windows_i686_gnu 0.53.0",
+ "windows_i686_gnullvm 0.53.0",
+ "windows_i686_msvc 0.53.0",
+ "windows_x86_64_gnu 0.53.0",
+ "windows_x86_64_gnullvm 0.53.0",
+ "windows_x86_64_msvc 0.53.0",
]
[[package]]
@@ -901,48 +1344,96 @@ version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3"
+[[package]]
+name = "windows_aarch64_gnullvm"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "86b8d5f90ddd19cb4a147a5fa63ca848db3df085e25fee3cc10b39b6eebae764"
+
[[package]]
name = "windows_aarch64_msvc"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469"
+[[package]]
+name = "windows_aarch64_msvc"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c7651a1f62a11b8cbd5e0d42526e55f2c99886c77e007179efff86c2b137e66c"
+
[[package]]
name = "windows_i686_gnu"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b"
+[[package]]
+name = "windows_i686_gnu"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c1dc67659d35f387f5f6c479dc4e28f1d4bb90ddd1a5d3da2e5d97b42d6272c3"
+
[[package]]
name = "windows_i686_gnullvm"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66"
+[[package]]
+name = "windows_i686_gnullvm"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "9ce6ccbdedbf6d6354471319e781c0dfef054c81fbc7cf83f338a4296c0cae11"
+
[[package]]
name = "windows_i686_msvc"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66"
+[[package]]
+name = "windows_i686_msvc"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "581fee95406bb13382d2f65cd4a908ca7b1e4c2f1917f143ba16efe98a589b5d"
+
[[package]]
name = "windows_x86_64_gnu"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78"
+[[package]]
+name = "windows_x86_64_gnu"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "2e55b5ac9ea33f2fc1716d1742db15574fd6fc8dadc51caab1c16a3d3b4190ba"
+
[[package]]
name = "windows_x86_64_gnullvm"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d"
+[[package]]
+name = "windows_x86_64_gnullvm"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "0a6e035dd0599267ce1ee132e51c27dd29437f63325753051e71dd9e42406c57"
+
[[package]]
name = "windows_x86_64_msvc"
version = "0.52.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec"
+[[package]]
+name = "windows_x86_64_msvc"
+version = "0.53.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "271414315aff87387382ec3d271b52d7ae78726f5d44ac98b4f4030c91880486"
+
[[package]]
name = "winnow"
version = "0.7.11"
diff --git a/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected b/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected
index 60847b71b79..8b757e5a4bf 100644
--- a/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected
+++ b/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected
@@ -1,20 +1,20 @@
#select
-| src/main.rs:10:5:10:22 | ...::read_to_string | src/main.rs:6:11:6:19 | file_name | src/main.rs:10:5:10:22 | ...::read_to_string | This path depends on a $@. | src/main.rs:6:11:6:19 | file_name | user-provided value |
+| src/main.rs:11:5:11:22 | ...::read_to_string | src/main.rs:7:11:7:19 | file_name | src/main.rs:11:5:11:22 | ...::read_to_string | This path depends on a $@. | src/main.rs:7:11:7:19 | file_name | user-provided value |
edges
-| src/main.rs:6:11:6:19 | file_name | src/main.rs:8:35:8:43 | file_name | provenance | |
-| src/main.rs:8:9:8:17 | file_path | src/main.rs:10:24:10:32 | file_path | provenance | |
-| src/main.rs:8:21:8:44 | ...::from(...) | src/main.rs:8:9:8:17 | file_path | provenance | |
-| src/main.rs:8:35:8:43 | file_name | src/main.rs:8:21:8:44 | ...::from(...) | provenance | MaD:2 |
-| src/main.rs:8:35:8:43 | file_name | src/main.rs:8:21:8:44 | ...::from(...) | provenance | MaD:2 |
-| src/main.rs:10:24:10:32 | file_path | src/main.rs:10:5:10:22 | ...::read_to_string | provenance | MaD:1 Sink:MaD:1 |
+| src/main.rs:7:11:7:19 | file_name | src/main.rs:9:35:9:43 | file_name | provenance | |
+| src/main.rs:9:9:9:17 | file_path | src/main.rs:11:24:11:32 | file_path | provenance | |
+| src/main.rs:9:21:9:44 | ...::from(...) | src/main.rs:9:9:9:17 | file_path | provenance | |
+| src/main.rs:9:35:9:43 | file_name | src/main.rs:9:21:9:44 | ...::from(...) | provenance | MaD:2 |
+| src/main.rs:9:35:9:43 | file_name | src/main.rs:9:21:9:44 | ...::from(...) | provenance | MaD:2 |
+| src/main.rs:11:24:11:32 | file_path | src/main.rs:11:5:11:22 | ...::read_to_string | provenance | MaD:1 Sink:MaD:1 |
models
| 1 | Sink: std::fs::read_to_string; Argument[0]; path-injection |
| 2 | Summary: ::from; Argument[0]; ReturnValue; taint |
nodes
-| src/main.rs:6:11:6:19 | file_name | semmle.label | file_name |
-| src/main.rs:8:9:8:17 | file_path | semmle.label | file_path |
-| src/main.rs:8:21:8:44 | ...::from(...) | semmle.label | ...::from(...) |
-| src/main.rs:8:35:8:43 | file_name | semmle.label | file_name |
-| src/main.rs:10:5:10:22 | ...::read_to_string | semmle.label | ...::read_to_string |
-| src/main.rs:10:24:10:32 | file_path | semmle.label | file_path |
+| src/main.rs:7:11:7:19 | file_name | semmle.label | file_name |
+| src/main.rs:9:9:9:17 | file_path | semmle.label | file_path |
+| src/main.rs:9:21:9:44 | ...::from(...) | semmle.label | ...::from(...) |
+| src/main.rs:9:35:9:43 | file_name | semmle.label | file_name |
+| src/main.rs:11:5:11:22 | ...::read_to_string | semmle.label | ...::read_to_string |
+| src/main.rs:11:24:11:32 | file_path | semmle.label | file_path |
subpaths
diff --git a/rust/ql/test/query-tests/security/CWE-022/options.yml b/rust/ql/test/query-tests/security/CWE-022/options.yml
index e0b9bbfb5cf..18392052c7c 100644
--- a/rust/ql/test/query-tests/security/CWE-022/options.yml
+++ b/rust/ql/test/query-tests/security/CWE-022/options.yml
@@ -1,3 +1,5 @@
qltest_use_nightly: true
qltest_dependencies:
- poem = { version = "3.1.7" }
+ - tokio = { version = "1.43.0", features = ["full"] }
+ - async-std = { version = "1.13.1" }
diff --git a/rust/ql/test/query-tests/security/CWE-022/src/main.rs b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
index 6f8c73654c5..233a6996746 100644
--- a/rust/ql/test/query-tests/security/CWE-022/src/main.rs
+++ b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
@@ -1,6 +1,7 @@
#![feature(file_buffered)]
use poem::{error::InternalServerError, handler, http::StatusCode, web::Query, Error, Result};
use std::{fs, path::Path, path::PathBuf};
+
//#[handler]
fn tainted_path_handler_bad(
Query(file_name): Query, // $ Source=remote1
@@ -122,6 +123,9 @@ fn sinks(path1: &Path, path2: &Path) {
let _ = std::fs::File::create_new(path1); // $ path-injection-sink
let _ = std::fs::File::open(path1); // $ path-injection-sink
let _ = std::fs::File::open_buffered(path1); // $ path-injection-sink
+ let _ = std::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
+ let _ = tokio::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
+ let _ = async_std::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
}
fn main() {}
From bc226e21170b6ef315fdf571d1df471a0f578562 Mon Sep 17 00:00:00 2001
From: Geoffrey White <40627776+geoffw0@users.noreply.github.com>
Date: Tue, 19 Aug 2025 16:39:59 +0100
Subject: [PATCH 101/298] Rust: Add more general test cases for async_std::fs
and tokio::fs.
---
.../dataflow/sources/TaintSources.expected | 14 +++++++-------
.../ql/test/library-tests/dataflow/sources/test.rs | 10 ++++++++++
.../test/query-tests/security/CWE-022/src/main.rs | 8 ++++++++
3 files changed, 25 insertions(+), 7 deletions(-)
diff --git a/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected b/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected
index d8787604ff4..942d810caab 100644
--- a/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected
+++ b/rust/ql/test/library-tests/dataflow/sources/TaintSources.expected
@@ -74,13 +74,13 @@
| test.rs:607:21:607:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
| test.rs:608:21:608:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
| test.rs:616:21:616:41 | ...::open | Flow source 'FileSource' of type file (DEFAULT). |
-| test.rs:648:26:648:53 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:667:26:667:61 | ...::connect_timeout | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:719:28:719:57 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:801:22:801:49 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:827:22:827:50 | ...::new | Flow source 'RemoteSource' of type remote (DEFAULT). |
-| test.rs:854:16:854:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
-| test.rs:854:16:854:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
+| test.rs:658:26:658:53 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:677:26:677:61 | ...::connect_timeout | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:729:28:729:57 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:811:22:811:49 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:837:22:837:50 | ...::new | Flow source 'RemoteSource' of type remote (DEFAULT). |
+| test.rs:864:16:864:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
+| test.rs:864:16:864:29 | ...::args | Flow source 'CommandLineArgs' of type commandargs (DEFAULT). |
| test_futures_io.rs:19:15:19:32 | ...::connect | Flow source 'RemoteSource' of type remote (DEFAULT). |
| web_frameworks.rs:11:31:11:31 | a | Flow source 'RemoteSource' of type remote (DEFAULT). |
| web_frameworks.rs:11:31:11:31 | a | Flow source 'RemoteSource' of type remote (DEFAULT). |
diff --git a/rust/ql/test/library-tests/dataflow/sources/test.rs b/rust/ql/test/library-tests/dataflow/sources/test.rs
index 4ace4c56b06..d0ef30d334e 100644
--- a/rust/ql/test/library-tests/dataflow/sources/test.rs
+++ b/rust/ql/test/library-tests/dataflow/sources/test.rs
@@ -625,6 +625,16 @@ async fn test_tokio_file() -> std::io::Result<()> {
use async_std::io::ReadExt;
async fn test_async_std_file() -> std::io::Result<()> {
+ // --- file ---
+
+ let mut file = async_std::fs::File::open("file.txt").await?; // $ MISSING: Alert[rust/summary/taint-sources]
+
+ {
+ let mut buffer = [0u8; 100];
+ let _bytes = file.read(&mut buffer).await?;
+ sink(&buffer); // $ MISSING: hasTaintFlow="file.txt"
+ }
+
// --- OpenOptions ---
{
diff --git a/rust/ql/test/query-tests/security/CWE-022/src/main.rs b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
index 233a6996746..15e0791bf2d 100644
--- a/rust/ql/test/query-tests/security/CWE-022/src/main.rs
+++ b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
@@ -124,7 +124,15 @@ fn sinks(path1: &Path, path2: &Path) {
let _ = std::fs::File::open(path1); // $ path-injection-sink
let _ = std::fs::File::open_buffered(path1); // $ path-injection-sink
let _ = std::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
+
+ let _ = tokio::fs::read(path1); // $ MISSING: path-injection-sink
+ let _ = tokio::fs::read_to_string(path1); // $ MISSING: path-injection-sink
+ let _ = tokio::fs::remove_file(path1); // $ MISSING: path-injection-sink
let _ = tokio::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
+
+ let _ = async_std::fs::read(path1); // $ MISSING: path-injection-sink
+ let _ = async_std::fs::read_to_string(path1); // $ MISSING: path-injection-sink
+ let _ = async_std::fs::remove_file(path1); // $ MISSING: path-injection-sink
let _ = async_std::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
}
From 801be8fbbd12656a3486a1d54ae35fdb8c79c147 Mon Sep 17 00:00:00 2001
From: Geoffrey White <40627776+geoffw0@users.noreply.github.com>
Date: Wed, 20 Aug 2025 15:33:49 +0100
Subject: [PATCH 102/298] Rust: Add more tests for std::fs::DirBuilder and
similar.
---
rust/ql/test/query-tests/security/CWE-022/src/main.rs | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/rust/ql/test/query-tests/security/CWE-022/src/main.rs b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
index 15e0791bf2d..bdaa9dcfa56 100644
--- a/rust/ql/test/query-tests/security/CWE-022/src/main.rs
+++ b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
@@ -117,22 +117,27 @@ fn sinks(path1: &Path, path2: &Path) {
let _ = std::fs::soft_link(path1, path2); // $ path-injection-sink
let _ = std::fs::symlink_metadata(path1); // $ path-injection-sink
let _ = std::fs::write(path1, "contents"); // $ path-injection-sink
- let _ = std::fs::DirBuilder::new().create(path1); // $ path-injection-sink
let _ = std::fs::File::create(path1); // $ path-injection-sink
let _ = std::fs::File::create_buffered(path1); // $ path-injection-sink
let _ = std::fs::File::create_new(path1); // $ path-injection-sink
let _ = std::fs::File::open(path1); // $ path-injection-sink
let _ = std::fs::File::open_buffered(path1); // $ path-injection-sink
+ let _ = std::fs::DirBuilder::new().create(path1); // $ path-injection-sink
+ let _ = std::fs::DirBuilder::new().recursive(true).create(path1); // $ path-injection-sink
let _ = std::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
let _ = tokio::fs::read(path1); // $ MISSING: path-injection-sink
let _ = tokio::fs::read_to_string(path1); // $ MISSING: path-injection-sink
let _ = tokio::fs::remove_file(path1); // $ MISSING: path-injection-sink
+ let _ = tokio::fs::DirBuilder::new().create(path1); // $ MISSING: path-injection-sink
+ let _ = tokio::fs::DirBuilder::new().recursive(true).create(path1); // $ MISSING: path-injection-sink
let _ = tokio::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
let _ = async_std::fs::read(path1); // $ MISSING: path-injection-sink
let _ = async_std::fs::read_to_string(path1); // $ MISSING: path-injection-sink
let _ = async_std::fs::remove_file(path1); // $ MISSING: path-injection-sink
+ let _ = async_std::fs::DirBuilder::new().create(path1); // $ MISSING: path-injection-sink
+ let _ = async_std::fs::DirBuilder::new().recursive(true).create(path1); // $ MISSING: path-injection-sink
let _ = async_std::fs::OpenOptions::new().open(path1); // $ MISSING: path-injection-sink
}
From 8da44828a642467bde9bbcfb80997fedf3d2f0a7 Mon Sep 17 00:00:00 2001
From: Geoffrey White <40627776+geoffw0@users.noreply.github.com>
Date: Wed, 20 Aug 2025 15:18:54 +0100
Subject: [PATCH 103/298] Rust: Add tests for std::fs::canonicalize and
similar.
---
.../security/CWE-022/TaintedPath.expected | 31 ++++++++++++++++---
.../query-tests/security/CWE-022/src/main.rs | 20 ++++++++++++
2 files changed, 46 insertions(+), 5 deletions(-)
diff --git a/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected b/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected
index 8b757e5a4bf..0f8832188e6 100644
--- a/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected
+++ b/rust/ql/test/query-tests/security/CWE-022/TaintedPath.expected
@@ -1,15 +1,28 @@
#select
| src/main.rs:11:5:11:22 | ...::read_to_string | src/main.rs:7:11:7:19 | file_name | src/main.rs:11:5:11:22 | ...::read_to_string | This path depends on a $@. | src/main.rs:7:11:7:19 | file_name | user-provided value |
+| src/main.rs:104:13:104:31 | ...::open | src/main.rs:103:17:103:30 | ...::args | src/main.rs:104:13:104:31 | ...::open | This path depends on a $@. | src/main.rs:103:17:103:30 | ...::args | user-provided value |
edges
| src/main.rs:7:11:7:19 | file_name | src/main.rs:9:35:9:43 | file_name | provenance | |
| src/main.rs:9:9:9:17 | file_path | src/main.rs:11:24:11:32 | file_path | provenance | |
| src/main.rs:9:21:9:44 | ...::from(...) | src/main.rs:9:9:9:17 | file_path | provenance | |
-| src/main.rs:9:35:9:43 | file_name | src/main.rs:9:21:9:44 | ...::from(...) | provenance | MaD:2 |
-| src/main.rs:9:35:9:43 | file_name | src/main.rs:9:21:9:44 | ...::from(...) | provenance | MaD:2 |
-| src/main.rs:11:24:11:32 | file_path | src/main.rs:11:5:11:22 | ...::read_to_string | provenance | MaD:1 Sink:MaD:1 |
+| src/main.rs:9:35:9:43 | file_name | src/main.rs:9:21:9:44 | ...::from(...) | provenance | MaD:7 |
+| src/main.rs:9:35:9:43 | file_name | src/main.rs:9:21:9:44 | ...::from(...) | provenance | MaD:7 |
+| src/main.rs:11:24:11:32 | file_path | src/main.rs:11:5:11:22 | ...::read_to_string | provenance | MaD:2 Sink:MaD:2 |
+| src/main.rs:103:9:103:13 | path1 | src/main.rs:104:33:104:37 | path1 | provenance | |
+| src/main.rs:103:17:103:30 | ...::args | src/main.rs:103:17:103:32 | ...::args(...) [element] | provenance | Src:MaD:3 |
+| src/main.rs:103:17:103:32 | ...::args(...) [element] | src/main.rs:103:17:103:39 | ... .nth(...) [Some] | provenance | MaD:5 |
+| src/main.rs:103:17:103:39 | ... .nth(...) [Some] | src/main.rs:103:17:103:48 | ... .unwrap() | provenance | MaD:6 |
+| src/main.rs:103:17:103:48 | ... .unwrap() | src/main.rs:103:9:103:13 | path1 | provenance | |
+| src/main.rs:104:33:104:37 | path1 | src/main.rs:104:33:104:45 | path1.clone() | provenance | MaD:4 |
+| src/main.rs:104:33:104:45 | path1.clone() | src/main.rs:104:13:104:31 | ...::open | provenance | MaD:1 Sink:MaD:1 |
models
-| 1 | Sink: std::fs::read_to_string; Argument[0]; path-injection |
-| 2 | Summary: ::from; Argument[0]; ReturnValue; taint |
+| 1 | Sink: ::open; Argument[0]; path-injection |
+| 2 | Sink: std::fs::read_to_string; Argument[0]; path-injection |
+| 3 | Source: std::env::args; ReturnValue.Element; commandargs |
+| 4 | Summary: <_ as core::clone::Clone>::clone; Argument[self].Reference; ReturnValue; value |
+| 5 | Summary: <_ as core::iter::traits::iterator::Iterator>::nth; Argument[self].Element; ReturnValue.Field[core::option::Option::Some(0)]; value |
+| 6 | Summary: ::unwrap; Argument[self].Field[core::option::Option::Some(0)]; ReturnValue; value |
+| 7 | Summary: ::from; Argument[0]; ReturnValue; taint |
nodes
| src/main.rs:7:11:7:19 | file_name | semmle.label | file_name |
| src/main.rs:9:9:9:17 | file_path | semmle.label | file_path |
@@ -17,4 +30,12 @@ nodes
| src/main.rs:9:35:9:43 | file_name | semmle.label | file_name |
| src/main.rs:11:5:11:22 | ...::read_to_string | semmle.label | ...::read_to_string |
| src/main.rs:11:24:11:32 | file_path | semmle.label | file_path |
+| src/main.rs:103:9:103:13 | path1 | semmle.label | path1 |
+| src/main.rs:103:17:103:30 | ...::args | semmle.label | ...::args |
+| src/main.rs:103:17:103:32 | ...::args(...) [element] | semmle.label | ...::args(...) [element] |
+| src/main.rs:103:17:103:39 | ... .nth(...) [Some] | semmle.label | ... .nth(...) [Some] |
+| src/main.rs:103:17:103:48 | ... .unwrap() | semmle.label | ... .unwrap() |
+| src/main.rs:104:13:104:31 | ...::open | semmle.label | ...::open |
+| src/main.rs:104:33:104:37 | path1 | semmle.label | path1 |
+| src/main.rs:104:33:104:45 | path1.clone() | semmle.label | path1.clone() |
subpaths
diff --git a/rust/ql/test/query-tests/security/CWE-022/src/main.rs b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
index bdaa9dcfa56..15d38660517 100644
--- a/rust/ql/test/query-tests/security/CWE-022/src/main.rs
+++ b/rust/ql/test/query-tests/security/CWE-022/src/main.rs
@@ -99,6 +99,26 @@ fn tainted_path_handler_folder_almost_good3(
fs::read_to_string(file_path).map_err(InternalServerError) // $ path-injection-sink MISSING: Alert[rust/path-injection]=remote5
}
+async fn more_simple_cases() {
+ let path1 = std::env::args().nth(1).unwrap(); // $ Source=arg1
+ let _ = std::fs::File::open(path1.clone()); // $ path-injection-sink Alert[rust/path-injection]=arg1
+
+ let path2 = std::fs::canonicalize(path1.clone()).unwrap();
+ let _ = std::fs::File::open(path2); // $ path-injection-sink MISSING: Alert[rust/path-injection]=arg1
+
+ let path3 = tokio::fs::canonicalize(path1.clone()).await.unwrap();
+ let _ = tokio::fs::File::open(path3); // $ MISSING: path-injection-sink Alert[rust/path-injection]=arg1
+
+ let path4 = async_std::fs::canonicalize(path1.clone()).await.unwrap();
+ let _ = async_std::fs::File::open(path4); // $ MISSING: path-injection-sink Alert[rust/path-injection]=arg1
+
+ let path5 = std::path::Path::new(&path1);
+ let _ = std::fs::File::open(path5); // $ path-injection-sink MISSING: Alert[rust/path-injection]=arg1
+
+ let path6 = path5.canonicalize().unwrap();
+ let _ = std::fs::File::open(path6); // $ path-injection-sink MISSING: Alert[rust/path-injection]=arg1
+}
+
fn sinks(path1: &Path, path2: &Path) {
let _ = std::fs::copy(path1, path2); // $ path-injection-sink
let _ = std::fs::create_dir(path1); // $ path-injection-sink
From 0c14d93bc678319a70da5e1a0c2cc26815a6d30b Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Wed, 6 Aug 2025 10:53:59 +0200
Subject: [PATCH 104/298] Java: Added new query
`java/visible-for-testing-abuse`
---
.../VisibleForTestingAbuse.md | 39 ++++++
.../VisibleForTestingAbuse.ql | 128 ++++++++++++++++++
.../VisibleForTestingAbuse.expected | 4 +
.../VisibleForTestingAbuse.qlref | 1 +
.../packageone/AnnotatedClass.java | 6 +
.../packageone/SourcePackage.java | 10 ++
.../packageone/VisibleForTesting.java | 4 +
.../packagetwo/Annotated.java | 15 ++
.../packagetwo/Source.java | 12 ++
.../packagetwo/Test.java | 12 ++
10 files changed, 231 insertions(+)
create mode 100644 java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.md
create mode 100644 java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/packageone/AnnotatedClass.java
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/packageone/VisibleForTesting.java
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
create mode 100644 java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java
diff --git a/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.md b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.md
new file mode 100644
index 00000000000..bbda346aa9a
--- /dev/null
+++ b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.md
@@ -0,0 +1,39 @@
+# J-T-003: Accessing any method, field or class annotated with `@VisibleForTesting` from production code is discouraged
+
+Accessing class members annotated with `@VisibleForTesting` from production code goes against the intention of the annotation and may indicate programmer error.
+
+## Overview
+
+The `@VisibleForTesting` serves to increase visibility of methods, fields or classes for the purposes of testing. Accessing methods, fields or classes that are annotated with `@VisibleForTesting` in production code (not test code) abuses the intention of the annotation.
+
+## Recommendation
+
+Only access methods, fields or classes annotated with `@VisibleForTesting` from test code. If the visibility of the methods, fields or classes should generally be relaxed, use Java language access modifiers.
+
+## Example
+
+```java
+public class Annotated {
+@VisibleForTesting static int f(){}
+}
+
+/* src/test/java/Test.java */
+int i = Annotated.f(); // COMPLIANT
+
+/* src/main/Source.java */
+ int i = Annotated.f(); // NON_COMPLIANT
+
+```
+
+## Implementation notes
+
+This rule alerts on any implementation of the annotation `VisibleForTesting`, regardless of where it is provided from.
+
+The rule also uses the following logic to determine what an abuse of the annotation is:
+
+ 1) If public or protected member/type is annotated with `VisibleForTesting`, it's assumed that package-private access is enough for production code. Therefore the rule alerts when a public or protected member/type annotated with `VisibleForTesting` is used outside of its declaring package.
+ 2) If package-private member/type is annotated with `VisibleForTesting`, it's assumed that private access is enough for production code. Therefore the rule alerts when a package-private member/type annotated with `VisibleForTesting` is used outside its declaring class.
+
+## References
+- Example Specific Implementation of a VisibleForTesting Annotation: [AssertJ VisibleForTesting](https://javadoc.io/doc/org.assertj/assertj-core/latest/org/assertj/core/util/VisibleForTesting.html)
+- Assumptions of what level of access is permittable for each access modifier and the annotation: [JetBrains VisibleForTesting](https://javadoc.io/doc/org.jetbrains/annotations/22.0.0/org/jetbrains/annotations/VisibleForTesting.html)
\ No newline at end of file
diff --git a/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
new file mode 100644
index 00000000000..3900f847448
--- /dev/null
+++ b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
@@ -0,0 +1,128 @@
+/**
+ * @id java/visible-for-testing-abuse
+ * @name Accessing any method, field or class annotated with `@VisibleForTesting` from production code is discouraged
+ * @description Accessing any method, field or class annotated with `@VisibleForTesting` from
+ * production code goes against the intention of the annotation and may indicate
+ * programmer error.
+ * @kind problem
+ * @precision high
+ * @problem.severity warning
+ * @tags maintainability
+ * readability
+ */
+
+import java
+
+/**
+ * A `Callable` is within some `RefType`
+ */
+predicate isWithinType(Callable c, RefType t) { c.getDeclaringType() = t }
+
+/**
+ * A `Callable` is within same package as the `RefType`
+ */
+predicate isWithinPackage(Callable c, RefType t) {
+ c.getDeclaringType().getPackage() = t.getPackage()
+}
+
+predicate withinStaticContext(NestedClass c) {
+ c.isStatic() or
+ c.(AnonymousClass).getClassInstanceExpr().getEnclosingCallable().isStatic() // JLS 15.9.2
+}
+
+RefType enclosingInstanceType(Class inner) {
+ not withinStaticContext(inner) and
+ result = inner.(NestedClass).getEnclosingType()
+}
+
+class OuterClass extends Class {
+ OuterClass() { this = enclosingInstanceType+(_) }
+}
+
+/**
+ * An innerclass is accessed outside of its outerclass
+ * and also outside of its fellow inner parallel classes
+ */
+predicate isWithinDirectOuterClassOrSiblingInner(
+ Callable classInstanceEnclosing, RefType typeBeingConstructed
+) {
+ exists(NestedClass inner, OuterClass outer |
+ outer = enclosingInstanceType(inner) and
+ typeBeingConstructed = inner and
+ // where the inner is called from the outer class
+ classInstanceEnclosing.getDeclaringType() = outer
+ )
+ or
+ // and inner is called from the a parallel inner
+ exists(NestedClass inner, OuterClass outer, NestedClass otherinner |
+ typeBeingConstructed = inner and
+ outer = enclosingInstanceType(otherinner) and
+ outer = enclosingInstanceType(inner) and
+ classInstanceEnclosing.getDeclaringType() = otherinner
+ )
+}
+
+from Annotatable annotated, Annotation annotation, Expr e
+where
+ annotation.getType().hasName("VisibleForTesting") and
+ annotated.getAnAnnotation() = annotation and
+ (
+ // field access
+ exists(FieldAccess v |
+ v = e and
+ v.getField() = annotated and
+ // depending on the visiblity of the field, using the annotation to abuse the visibility may/may not be occurring
+ (
+ // if its package protected report when its used outside its class bc it should have been private (class only permitted)
+ v.getField().isPackageProtected() and
+ not isWithinType(v.getEnclosingCallable(), v.getField().getDeclaringType())
+ or
+ // if public or protected report when its used outside its package because package protected should have been enough (package only permitted)
+ (v.getField().isPublic() or v.getField().isProtected()) and
+ not isWithinPackage(v.getEnclosingCallable(), v.getField().getDeclaringType())
+ )
+ )
+ or
+ // class instantiation
+ exists(ClassInstanceExpr c |
+ c = e and
+ c.getConstructedType() = annotated and
+ // depending on the visiblity of the class, using the annotation to abuse the visibility may/may not be occurring
+ // if public report when its used outside its package because package protected should have been enough (package only permitted)
+ (
+ c.getConstructedType().isPublic() and
+ not isWithinPackage(c.getEnclosingCallable(), c.getConstructedType())
+ or
+ // if its package protected report when its used outside its outer class bc it should have been private (outer class only permitted)
+ c.getConstructedType().hasNoModifier() and
+ // and the class is an innerclass, because otherwise recommending a lower accessibility makes no sense (only inner classes can be private)
+ exists(enclosingInstanceType(c.getConstructedType())) and
+ not isWithinDirectOuterClassOrSiblingInner(c.getEnclosingCallable(), c.getConstructedType())
+ )
+ )
+ or
+ // method access
+ exists(MethodCall c |
+ c = e and
+ c.getMethod() = annotated and
+ // depending on the visiblity of the method, using the annotation to abuse the visibility may/may not be occurring
+ (
+ // if its package protected report when its used outside its class bc it should have been private (class only permitted)
+ c.getMethod().isPackageProtected() and
+ not isWithinType(c.getEnclosingCallable(), c.getMethod().getDeclaringType())
+ or
+ // if public or protected report when its used outside its package because package protected should have been enough (package only permitted)
+ (c.getMethod().isPublic() or c.getMethod().isProtected()) and
+ not isWithinPackage(c.getEnclosingCallable(), c.getMethod().getDeclaringType())
+ )
+ )
+ ) and
+ // not in a test where use is appropriate
+ not e.getEnclosingCallable() instanceof LikelyTestMethod and
+ // also omit our own ql unit test where it is acceptable
+ not e.getEnclosingCallable()
+ .getFile()
+ .getAbsolutePath()
+ .matches("%java/ql/test/query-tests/%Test.java")
+select e, "Access of $@ annotated with VisibleForTesting found in production code.", annotated,
+ "element"
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
new file mode 100644
index 00000000000..3d1278c1418
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
@@ -0,0 +1,4 @@
+| packageone/SourcePackage.java:8:21:8:32 | Annotated.m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
+| packagetwo/Source.java:7:17:7:29 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:12:16:12:16 | f | element |
+| packagetwo/Source.java:8:20:8:30 | Annotated.m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
+| packagetwo/Source.java:9:28:9:47 | new AnnotatedClass(...) | Access of $@ annotated with VisibleForTesting found in production code. | packageone/AnnotatedClass.java:4:14:4:27 | AnnotatedClass | element |
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref
new file mode 100644
index 00000000000..6f789e7b47b
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref
@@ -0,0 +1 @@
+Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/AnnotatedClass.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/AnnotatedClass.java
new file mode 100644
index 00000000000..1fdbea1571e
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/AnnotatedClass.java
@@ -0,0 +1,6 @@
+package packageone;
+
+@VisibleForTesting
+public class AnnotatedClass {
+ public AnnotatedClass() {}
+}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
new file mode 100644
index 00000000000..118d021c277
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
@@ -0,0 +1,10 @@
+package packageone;
+
+import packagetwo.Annotated;
+
+public class SourcePackage extends Annotated {
+ void f() {
+ AnnotatedClass a = new AnnotatedClass(); // COMPLIANT - same package
+ String s1 = Annotated.m1; // NON_COMPLIANT
+ }
+}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/VisibleForTesting.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/VisibleForTesting.java
new file mode 100644
index 00000000000..28aedbf4e53
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/VisibleForTesting.java
@@ -0,0 +1,4 @@
+package packageone;
+
+public @interface VisibleForTesting {
+}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
new file mode 100644
index 00000000000..e253e4a2cdd
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
@@ -0,0 +1,15 @@
+package packagetwo;
+
+import packageone.*;
+
+public class Annotated {
+ @VisibleForTesting
+ static String m;
+ @VisibleForTesting
+ static protected String m1;
+
+ @VisibleForTesting
+ static int f() {
+ return 1;
+ }
+}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
new file mode 100644
index 00000000000..9d60b2cc5a7
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
@@ -0,0 +1,12 @@
+package packagetwo;
+
+import packageone.*;
+
+public class Source {
+ void f() {
+ int i = Annotated.f(); // NON_COMPLIANT
+ String s = Annotated.m; // NON_COMPLIANT
+ AnnotatedClass a = new AnnotatedClass(); // NON_COMPLIANT
+ String s1 = Annotated.m1; // COMPLIANT - same package
+ }
+}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java
new file mode 100644
index 00000000000..d4552657f15
--- /dev/null
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java
@@ -0,0 +1,12 @@
+package packagetwo;
+
+import packageone.*;
+
+public class Test {
+ void f() {
+ int i = Annotated.f(); // COMPLIANT
+ String s = Annotated.m; // COMPLIANT
+ AnnotatedClass a = new AnnotatedClass(); // COMPLIANT
+ String s1 = Annotated.m1; // COMPLIANT
+ }
+}
From 652e9cba3d8a1fcb3a54a69b63826e2a2715f134 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Wed, 6 Aug 2025 11:23:02 +0200
Subject: [PATCH 105/298] Java: Added inline test expectations for
`java/visible-for-testing-abuse`
---
.../VisibleForTestingAbuse/VisibleForTestingAbuse.qlref | 3 ++-
.../VisibleForTestingAbuse/packageone/SourcePackage.java | 2 +-
.../VisibleForTestingAbuse/packagetwo/Source.java | 6 +++---
3 files changed, 6 insertions(+), 5 deletions(-)
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref
index 6f789e7b47b..57947f80431 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.qlref
@@ -1 +1,2 @@
-Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
+query: Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
+postprocess: utils/test/InlineExpectationsTestQuery.ql
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
index 118d021c277..5198555d689 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
@@ -5,6 +5,6 @@ import packagetwo.Annotated;
public class SourcePackage extends Annotated {
void f() {
AnnotatedClass a = new AnnotatedClass(); // COMPLIANT - same package
- String s1 = Annotated.m1; // NON_COMPLIANT
+ String s1 = Annotated.m1; // $ Alert
}
}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
index 9d60b2cc5a7..d513b9dd47f 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
@@ -4,9 +4,9 @@ import packageone.*;
public class Source {
void f() {
- int i = Annotated.f(); // NON_COMPLIANT
- String s = Annotated.m; // NON_COMPLIANT
- AnnotatedClass a = new AnnotatedClass(); // NON_COMPLIANT
+ int i = Annotated.f(); // $ Alert
+ String s = Annotated.m; // $ Alert
+ AnnotatedClass a = new AnnotatedClass(); // $ Alert
String s1 = Annotated.m1; // COMPLIANT - same package
}
}
From ff6ddd2893432f2b260455324af7f644a049864b Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Wed, 6 Aug 2025 11:28:01 +0200
Subject: [PATCH 106/298] Java: Promoted `java/visible-for-testing-abuse` to
quality
---
.../java/query-suite/java-code-quality-extended.qls.expected | 1 +
.../java/query-suite/java-code-quality.qls.expected | 1 +
.../Implementation Hiding/VisibleForTestingAbuse.ql | 3 ++-
3 files changed, 4 insertions(+), 1 deletion(-)
diff --git a/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected b/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected
index 4a736437995..23bf29d21df 100644
--- a/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected
+++ b/java/ql/integration-tests/java/query-suite/java-code-quality-extended.qls.expected
@@ -73,6 +73,7 @@ ql/java/ql/src/Violations of Best Practice/Exception Handling/IgnoreExceptionalR
ql/java/ql/src/Violations of Best Practice/Exception Handling/NumberFormatException.ql
ql/java/ql/src/Violations of Best Practice/Implementation Hiding/AbstractToConcreteCollection.ql
ql/java/ql/src/Violations of Best Practice/Implementation Hiding/ExposeRepresentation.ql
+ql/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
ql/java/ql/src/Violations of Best Practice/Naming Conventions/AmbiguousOuterSuper.ql
ql/java/ql/src/Violations of Best Practice/Naming Conventions/ConfusingMethodNames.ql
ql/java/ql/src/Violations of Best Practice/Naming Conventions/ConfusingOverloading.ql
diff --git a/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected b/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected
index 17253dbe0f8..8a6a605fdae 100644
--- a/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected
+++ b/java/ql/integration-tests/java/query-suite/java-code-quality.qls.expected
@@ -71,6 +71,7 @@ ql/java/ql/src/Violations of Best Practice/Exception Handling/IgnoreExceptionalR
ql/java/ql/src/Violations of Best Practice/Exception Handling/NumberFormatException.ql
ql/java/ql/src/Violations of Best Practice/Implementation Hiding/AbstractToConcreteCollection.ql
ql/java/ql/src/Violations of Best Practice/Implementation Hiding/ExposeRepresentation.ql
+ql/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
ql/java/ql/src/Violations of Best Practice/Naming Conventions/AmbiguousOuterSuper.ql
ql/java/ql/src/Violations of Best Practice/Naming Conventions/ConfusingMethodNames.ql
ql/java/ql/src/Violations of Best Practice/Naming Conventions/ConfusingOverloading.ql
diff --git a/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
index 3900f847448..54ce53fcd4c 100644
--- a/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
+++ b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
@@ -7,7 +7,8 @@
* @kind problem
* @precision high
* @problem.severity warning
- * @tags maintainability
+ * @tags quality
+ * maintainability
* readability
*/
From 2a16f4829ec658c8181bd35b960aa30a19720023 Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Wed, 6 Aug 2025 12:55:08 +0200
Subject: [PATCH 107/298] Java: Expanded test suite of
`java/visible-for-testing-abuse`
---
.../VisibleForTestingAbuse.expected | 27 ++++++++-
.../packageone/SourcePackage.java | 26 +++++++-
.../packagetwo/Annotated.java | 60 +++++++++++++++++++
.../packagetwo/Source.java | 26 +++++++-
.../packagetwo/Test.java | 26 +++++++-
5 files changed, 157 insertions(+), 8 deletions(-)
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
index 3d1278c1418..6dd775b2802 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
@@ -1,4 +1,25 @@
-| packageone/SourcePackage.java:8:21:8:32 | Annotated.m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
-| packagetwo/Source.java:7:17:7:29 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:12:16:12:16 | f | element |
+| packageone/SourcePackage.java:9:21:9:32 | Annotated.m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
+| packageone/SourcePackage.java:10:21:10:32 | Annotated.m2 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:11:26:11:27 | m2 | element |
+| packageone/SourcePackage.java:16:18:16:36 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
+| packageone/SourcePackage.java:17:18:17:39 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
+| packageone/SourcePackage.java:25:31:25:42 | Annotated.m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
+| packageone/SourcePackage.java:26:31:26:42 | Annotated.m2 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:11:26:11:27 | m2 | element |
+| packageone/SourcePackage.java:29:28:29:46 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
+| packageone/SourcePackage.java:30:28:30:49 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
+| packagetwo/Annotated.java:49:31:49:31 | m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
+| packagetwo/Annotated.java:50:32:50:33 | m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
+| packagetwo/Annotated.java:51:32:51:33 | m2 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:11:26:11:27 | m2 | element |
+| packagetwo/Annotated.java:54:26:54:28 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
+| packagetwo/Annotated.java:56:32:56:40 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
+| packagetwo/Annotated.java:57:35:57:46 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
+| packagetwo/Annotated.java:64:28:64:28 | m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
+| packagetwo/Annotated.java:69:26:69:28 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
| packagetwo/Source.java:8:20:8:30 | Annotated.m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
-| packagetwo/Source.java:9:28:9:47 | new AnnotatedClass(...) | Access of $@ annotated with VisibleForTesting found in production code. | packageone/AnnotatedClass.java:4:14:4:27 | AnnotatedClass | element |
+| packagetwo/Source.java:14:17:14:29 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
+| packagetwo/Source.java:20:28:20:47 | new AnnotatedClass(...) | Access of $@ annotated with VisibleForTesting found in production code. | packageone/AnnotatedClass.java:4:14:4:27 | AnnotatedClass | element |
+| packagetwo/Source.java:24:30:24:40 | Annotated.m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
+| packagetwo/Source.java:25:31:25:42 | Annotated.m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
+| packagetwo/Source.java:26:31:26:42 | Annotated.m2 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:11:26:11:27 | m2 | element |
+| packagetwo/Source.java:28:27:28:39 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
+| packagetwo/Source.java:29:28:29:46 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
+| packagetwo/Source.java:30:28:30:49 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
index 5198555d689..96363da79c9 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packageone/SourcePackage.java
@@ -4,7 +4,31 @@ import packagetwo.Annotated;
public class SourcePackage extends Annotated {
void f() {
- AnnotatedClass a = new AnnotatedClass(); // COMPLIANT - same package
+ // Fields - cross-package access (only accessible ones)
+ // String s = Annotated.m; // Cannot access package-private from different package
String s1 = Annotated.m1; // $ Alert
+ String s2 = Annotated.m2; // $ Alert
+ // String s3 = Annotated.m3; // Cannot access private field
+
+ // Methods - cross-package access (only accessible ones)
+ // int i = Annotated.f(); // Cannot access package-private from different package
+ // int i1 = Annotated.fPrivate(); // Cannot access private method
+ int i2 = Annotated.fPublic(); // $ Alert
+ int i3 = Annotated.fProtected(); // $ Alert
+
+ // Same package class
+ AnnotatedClass a = new AnnotatedClass(); // COMPLIANT - same package
+
+ // Lambda usage - cross-package (only accessible members)
+ Runnable lambda = () -> {
+ // String lambdaS = Annotated.m; // Cannot access package-private
+ String lambdaS1 = Annotated.m1; // $ Alert
+ String lambdaS2 = Annotated.m2; // $ Alert
+
+ // int lambdaI = Annotated.f(); // Cannot access package-private
+ int lambdaI2 = Annotated.fPublic(); // $ Alert
+ int lambdaI3 = Annotated.fProtected(); // $ Alert
+ };
+ lambda.run();
}
}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
index e253e4a2cdd..cdf0cfeae51 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
@@ -7,9 +7,69 @@ public class Annotated {
static String m;
@VisibleForTesting
static protected String m1;
+ @VisibleForTesting
+ static public String m2;
+ @VisibleForTesting
+ static private String m3;
@VisibleForTesting
static int f() {
return 1;
}
+
+ @VisibleForTesting
+ static private int fPrivate() {
+ return 1;
+ }
+
+ @VisibleForTesting
+ static public int fPublic() {
+ return 1;
+ }
+
+ @VisibleForTesting
+ static protected int fProtected() {
+ return 1;
+ }
+
+ private static void resetPriorities() {
+ String priority = m;
+ String priority1 = m1;
+ String priority2 = m2;
+ String priority3 = m3;
+
+ int result = f();
+ int resultPrivate = fPrivate();
+ int resultPublic = fPublic();
+ int resultProtected = fProtected();
+ }
+
+ private static void resetPriorities2() {
+ Runnable task = () -> {
+ String priority = m; // $ SPURIOUS: Alert
+ String priority1 = m1; // $ SPURIOUS: Alert
+ String priority2 = m2; // $ SPURIOUS: Alert
+ String priority3 = m3;
+
+ int result = f(); // $ SPURIOUS: Alert
+ int resultPrivate = fPrivate();
+ int resultPublic = fPublic(); // $ SPURIOUS: Alert
+ int resultProtected = fProtected(); // $ SPURIOUS: Alert
+ };
+ task.run();
+ }
+
+ private static class InnerClass {
+ void useVisibleForMembers() {
+ String field = m; // $ SPURIOUS: Alert
+ String field1 = m1;
+ String field2 = m2;
+ String field3 = m3;
+
+ int method = f(); // $ SPURIOUS: Alert
+ int methodPrivate = fPrivate();
+ int methodPublic = fPublic();
+ int methodProtected = fProtected();
+ }
+ }
}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
index d513b9dd47f..358e145022c 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
@@ -4,9 +4,31 @@ import packageone.*;
public class Source {
void f() {
- int i = Annotated.f(); // $ Alert
+ // Fields
String s = Annotated.m; // $ Alert
- AnnotatedClass a = new AnnotatedClass(); // $ Alert
String s1 = Annotated.m1; // COMPLIANT - same package
+ String s2 = Annotated.m2;
+ // String s3 = Annotated.m3; // Cannot access private field
+
+ // Methods
+ int i = Annotated.f(); // $ Alert
+ // int i1 = Annotated.fPrivate(); // Cannot access private method
+ int i2 = Annotated.fPublic();
+ int i3 = Annotated.fProtected();
+
+ // Other class
+ AnnotatedClass a = new AnnotatedClass(); // $ Alert
+
+ // Lambda usage
+ Runnable lambda = () -> {
+ String lambdaS = Annotated.m; // $ Alert
+ String lambdaS1 = Annotated.m1; // $ SPURIOUS: Alert
+ String lambdaS2 = Annotated.m2; // $ SPURIOUS: Alert
+
+ int lambdaI = Annotated.f(); // $ Alert
+ int lambdaI2 = Annotated.fPublic(); // $ SPURIOUS: Alert
+ int lambdaI3 = Annotated.fProtected(); // $ SPURIOUS: Alert
+ };
+ lambda.run();
}
}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java
index d4552657f15..b861d921e9a 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Test.java
@@ -4,9 +4,31 @@ import packageone.*;
public class Test {
void f() {
- int i = Annotated.f(); // COMPLIANT
+ // Fields
String s = Annotated.m; // COMPLIANT
- AnnotatedClass a = new AnnotatedClass(); // COMPLIANT
String s1 = Annotated.m1; // COMPLIANT
+ String s2 = Annotated.m2; // COMPLIANT
+ // String s3 = Annotated.m3; // Cannot access private field
+
+ // Methods
+ int i = Annotated.f(); // COMPLIANT
+ // int i1 = Annotated.fPrivate(); // Cannot access private method
+ int i2 = Annotated.fPublic(); // COMPLIANT
+ int i3 = Annotated.fProtected(); // COMPLIANT
+
+ // Other class
+ AnnotatedClass a = new AnnotatedClass(); // COMPLIANT
+
+ // Lambda usage
+ Runnable lambda = () -> {
+ String lambdaS = Annotated.m; // COMPLIANT
+ String lambdaS1 = Annotated.m1; // COMPLIANT
+ String lambdaS2 = Annotated.m2; // COMPLIANT
+
+ int lambdaI = Annotated.f(); // COMPLIANT
+ int lambdaI2 = Annotated.fPublic(); // COMPLIANT
+ int lambdaI3 = Annotated.fProtected(); // COMPLIANT
+ };
+ lambda.run();
}
}
From fbf18af076129df000de83343475ed2372c7499c Mon Sep 17 00:00:00 2001
From: Napalys Klicius
Date: Wed, 6 Aug 2025 13:20:18 +0200
Subject: [PATCH 108/298] Java: enchanced check if it is within same package
---
.../Implementation Hiding/VisibleForTestingAbuse.ql | 10 +++++-----
.../VisibleForTestingAbuse.expected | 8 --------
.../VisibleForTestingAbuse/packagetwo/Annotated.java | 8 ++++----
.../VisibleForTestingAbuse/packagetwo/Source.java | 8 ++++----
4 files changed, 13 insertions(+), 21 deletions(-)
diff --git a/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
index 54ce53fcd4c..e41e1b897c4 100644
--- a/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
+++ b/java/ql/src/Violations of Best Practice/Implementation Hiding/VisibleForTestingAbuse.ql
@@ -22,8 +22,8 @@ predicate isWithinType(Callable c, RefType t) { c.getDeclaringType() = t }
/**
* A `Callable` is within same package as the `RefType`
*/
-predicate isWithinPackage(Callable c, RefType t) {
- c.getDeclaringType().getPackage() = t.getPackage()
+predicate isWithinPackage(Expr e, RefType t) {
+ e.getCompilationUnit().getPackage() = t.getPackage()
}
predicate withinStaticContext(NestedClass c) {
@@ -80,7 +80,7 @@ where
or
// if public or protected report when its used outside its package because package protected should have been enough (package only permitted)
(v.getField().isPublic() or v.getField().isProtected()) and
- not isWithinPackage(v.getEnclosingCallable(), v.getField().getDeclaringType())
+ not isWithinPackage(v, v.getField().getDeclaringType())
)
)
or
@@ -92,7 +92,7 @@ where
// if public report when its used outside its package because package protected should have been enough (package only permitted)
(
c.getConstructedType().isPublic() and
- not isWithinPackage(c.getEnclosingCallable(), c.getConstructedType())
+ not isWithinPackage(c, c.getConstructedType())
or
// if its package protected report when its used outside its outer class bc it should have been private (outer class only permitted)
c.getConstructedType().hasNoModifier() and
@@ -114,7 +114,7 @@ where
or
// if public or protected report when its used outside its package because package protected should have been enough (package only permitted)
(c.getMethod().isPublic() or c.getMethod().isProtected()) and
- not isWithinPackage(c.getEnclosingCallable(), c.getMethod().getDeclaringType())
+ not isWithinPackage(c, c.getMethod().getDeclaringType())
)
)
) and
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
index 6dd775b2802..044960e97af 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/VisibleForTestingAbuse.expected
@@ -7,19 +7,11 @@
| packageone/SourcePackage.java:29:28:29:46 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
| packageone/SourcePackage.java:30:28:30:49 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
| packagetwo/Annotated.java:49:31:49:31 | m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
-| packagetwo/Annotated.java:50:32:50:33 | m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
-| packagetwo/Annotated.java:51:32:51:33 | m2 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:11:26:11:27 | m2 | element |
| packagetwo/Annotated.java:54:26:54:28 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
-| packagetwo/Annotated.java:56:32:56:40 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
-| packagetwo/Annotated.java:57:35:57:46 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
| packagetwo/Annotated.java:64:28:64:28 | m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
| packagetwo/Annotated.java:69:26:69:28 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
| packagetwo/Source.java:8:20:8:30 | Annotated.m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
| packagetwo/Source.java:14:17:14:29 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
| packagetwo/Source.java:20:28:20:47 | new AnnotatedClass(...) | Access of $@ annotated with VisibleForTesting found in production code. | packageone/AnnotatedClass.java:4:14:4:27 | AnnotatedClass | element |
| packagetwo/Source.java:24:30:24:40 | Annotated.m | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:7:19:7:19 | m | element |
-| packagetwo/Source.java:25:31:25:42 | Annotated.m1 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:9:29:9:30 | m1 | element |
-| packagetwo/Source.java:26:31:26:42 | Annotated.m2 | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:11:26:11:27 | m2 | element |
| packagetwo/Source.java:28:27:28:39 | f(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:16:16:16:16 | f | element |
-| packagetwo/Source.java:29:28:29:46 | fPublic(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:26:23:26:29 | fPublic | element |
-| packagetwo/Source.java:30:28:30:49 | fProtected(...) | Access of $@ annotated with VisibleForTesting found in production code. | packagetwo/Annotated.java:31:26:31:35 | fProtected | element |
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
index cdf0cfeae51..de0085cedb4 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Annotated.java
@@ -47,14 +47,14 @@ public class Annotated {
private static void resetPriorities2() {
Runnable task = () -> {
String priority = m; // $ SPURIOUS: Alert
- String priority1 = m1; // $ SPURIOUS: Alert
- String priority2 = m2; // $ SPURIOUS: Alert
+ String priority1 = m1;
+ String priority2 = m2;
String priority3 = m3;
int result = f(); // $ SPURIOUS: Alert
int resultPrivate = fPrivate();
- int resultPublic = fPublic(); // $ SPURIOUS: Alert
- int resultProtected = fProtected(); // $ SPURIOUS: Alert
+ int resultPublic = fPublic();
+ int resultProtected = fProtected();
};
task.run();
}
diff --git a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
index 358e145022c..94a5cccfd43 100644
--- a/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
+++ b/java/ql/test/query-tests/VisibleForTestingAbuse/packagetwo/Source.java
@@ -22,12 +22,12 @@ public class Source {
// Lambda usage
Runnable lambda = () -> {
String lambdaS = Annotated.m; // $ Alert
- String lambdaS1 = Annotated.m1; // $ SPURIOUS: Alert
- String lambdaS2 = Annotated.m2; // $ SPURIOUS: Alert
+ String lambdaS1 = Annotated.m1;
+ String lambdaS2 = Annotated.m2;
int lambdaI = Annotated.f(); // $ Alert
- int lambdaI2 = Annotated.fPublic(); // $ SPURIOUS: Alert
- int lambdaI3 = Annotated.fProtected(); // $ SPURIOUS: Alert
+ int lambdaI2 = Annotated.fPublic();
+ int lambdaI3 = Annotated.fProtected();
};
lambda.run();
}
From 9dfb4d4301ae8b53a1fc29a360605e1a133e15cc Mon Sep 17 00:00:00 2001
From: Napalys Klicius