From f080e7ceefd8ab0a5991b522c40b7b35f8215803 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=93lafur=20P=C3=A1ll=20Geirsson?= Date: Thu, 27 Apr 2023 15:35:05 +0200 Subject: [PATCH 1/2] Emit inverse relationships Fixes #413. Previously, "find references" and "find implementations" didn't work as expected with Sourcegraph 5.0 due to https://github.com/sourcegraph/sourcegraph/issues/50927. This PR is a workaround until that issue gets fixed so that users can index with scip-java and get the best possible navigation experience. --- .../commands/IndexSemanticdbCommand.scala | 7 ++- .../scip_semanticdb/BazelBuildTool.java | 4 +- .../scip_semanticdb/ScipSemanticdb.java | 63 ++++++++++++++++++- .../ScipSemanticdbOptions.java | 5 +- .../scip_semanticdb/SymbolRelationship.java | 19 ++++++ .../src/main/generated/ByteParser.scala | 3 + .../src/main/generated/CharParser.scala | 2 + .../com/airbnb/epoxy/AsyncEpoxyDiffer.java | 1 + .../com/airbnb/epoxy/BaseEpoxyAdapter.java | 18 ++++++ .../airbnb/epoxy/BaseEpoxyTouchCallback.java | 8 +++ .../com/airbnb/epoxy/ControllerHelper.java | 1 + .../com/airbnb/epoxy/EpoxyAdapter.java | 21 +++++++ .../com/airbnb/epoxy/EpoxyController.java | 18 ++++++ .../com/airbnb/epoxy/EpoxyDragCallback.java | 6 ++ .../com/airbnb/epoxy/EpoxyModel.java | 32 ++++++++++ .../airbnb/epoxy/EpoxyModelWithHolder.java | 7 +++ .../com/airbnb/epoxy/EpoxySwipeCallback.java | 8 +++ .../epoxy/EpoxyTouchHelperCallback.java | 14 +++++ .../generated/com/airbnb/epoxy/Timer.java | 4 ++ .../src/main/scala/minimized/Issue413.scala | 2 + .../main/java/minimized/AbstractClasses.java | 1 + .../src/main/java/minimized/InnerClasses.java | 1 + .../src/main/java/minimized/Interfaces.java | 1 + .../main/java/minimized/TypeVariables.java | 1 + .../main/generated/ujson/IndexedValue.scala | 8 +++ .../src/main/generated/ujson/JsVisitor.scala | 4 ++ .../src/main/generated/ujson/Readable.scala | 2 + .../main/generated/ujson/Transformer.scala | 7 +++ .../src/main/generated/ujson/Value.scala | 14 +++++ 29 files changed, 276 insertions(+), 6 deletions(-) create mode 100644 scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/SymbolRelationship.java diff --git a/scip-java/src/main/scala/com/sourcegraph/scip_java/commands/IndexSemanticdbCommand.scala b/scip-java/src/main/scala/com/sourcegraph/scip_java/commands/IndexSemanticdbCommand.scala index 6c3fd2aa..a8c959a4 100644 --- a/scip-java/src/main/scala/com/sourcegraph/scip_java/commands/IndexSemanticdbCommand.scala +++ b/scip-java/src/main/scala/com/sourcegraph/scip_java/commands/IndexSemanticdbCommand.scala @@ -36,6 +36,10 @@ final case class IndexSemanticdbCommand( @Description( "Whether to infer the location of SemanticDB files based as produced by Bazel" ) bazel: Boolean = true, + @Description( + "Whether to emit parent->child relationships for 'Find references' and 'Find implementations'. " + + "This flag exists as a workaround for the issue https://github.com/sourcegraph/sourcegraph/issues/50927" + ) emitInverseRelationships: Boolean = true, @Description("URL to a PackageHub instance") @Hidden packagehub: Option[String] = None, @@ -85,7 +89,8 @@ final case class IndexSemanticdbCommand( format, parallel, packages.map(_.toPackageInformation).asJava, - buildKind + buildKind, + emitInverseRelationships ) ScipSemanticdb.run(options) postPackages(packages) diff --git a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/BazelBuildTool.java b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/BazelBuildTool.java index 5539bbb5..78a0a923 100644 --- a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/BazelBuildTool.java +++ b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/BazelBuildTool.java @@ -8,7 +8,6 @@ import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.PathMatcher; -import java.sql.Array; import java.util.*; import java.util.stream.Collectors; import java.util.stream.Stream; @@ -48,7 +47,8 @@ public void error(Throwable e) { ScipOutputFormat.TYPED_PROTOBUF, options.parallel, mavenPackages, - ""); + "", + true); ScipSemanticdb.run(scipOptions); if (!scipOptions.reporter.hasErrors()) { System.out.println("done: " + scipOptions.output); diff --git a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java index 5272e1e9..548f5473 100644 --- a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java +++ b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java @@ -65,7 +65,8 @@ private void run() throws IOException { private void runTyped(List files, PackageTable packages) { writer.emitTyped(typedMetadata()); - filesStream(files).forEach(document -> processTypedDocument(document, packages)); + InverseReferenceRelationships references = inverseReferenceRelationships(files); + filesStream(files).forEach(document -> processTypedDocument(document, packages, references)); } private String typedSymbol(String symbol, Package pkg) { @@ -82,7 +83,8 @@ public static boolean isDefinitionRole(Role role) { return role == Role.DEFINITION || role == Role.SYNTHETIC_DEFINITION; } - private void processTypedDocument(Path path, PackageTable packages) { + private void processTypedDocument( + Path path, PackageTable packages, InverseReferenceRelationships references) { for (ScipTextDocument doc : parseTextDocument(path).collect(Collectors.toList())) { if (doc.semanticdb.getOccurrencesCount() == 0) { continue; @@ -130,6 +132,19 @@ private void processTypedDocument(Path path, PackageTable packages) { Scip.SymbolInformation.Builder scipInfo = Scip.SymbolInformation.newBuilder().setSymbol(typedSymbol(info.getSymbol(), pkg)); + // TODO: this can be removed once https://github.com/sourcegraph/sourcegraph/issues/50927 is + // fixed. + ArrayList inverseReferences = references.map.get(info.getSymbol()); + if (inverseReferences != null) { + for (String inverseReference : inverseReferences) { + scipInfo.addRelationships( + Scip.Relationship.newBuilder() + .setSymbol(inverseReference) + .setIsImplementation(true) + .setIsReference(true)); + } + } + for (int i = 0; i < info.getDefinitionRelationshipsCount(); i++) { String definitionSymbol = info.getDefinitionRelationships(i); if (definitionSymbol.isEmpty()) { @@ -245,6 +260,50 @@ private Stream filesStream(List files) { return options.parallel ? files.parallelStream() : files.stream(); } + private static class InverseReferenceRelationships { + public final Map> map; + + private InverseReferenceRelationships(Map> map) { + this.map = map; + } + } + + private InverseReferenceRelationships inverseReferenceRelationships(List files) { + if (!options.emitInverseRelationships) { + return new InverseReferenceRelationships(Collections.emptyMap()); + } + return new InverseReferenceRelationships( + filesStream(files) + .flatMap(this::parseTextDocument) + .flatMap(this::referenceRelationships) + .collect( + Collectors.groupingBy( + SymbolRelationship::getTo, + Collectors.mapping( + SymbolRelationship::getFrom, Collectors.toCollection(ArrayList::new))))); + } + + private Stream referenceRelationships(ScipTextDocument document) { + ArrayList relationships = new ArrayList<>(); + for (int i = 0; i < document.semanticdb.getSymbolsCount(); i++) { + SymbolInformation info = document.semanticdb.getSymbols(i); + if (!supportsReferenceRelationship(info)) { + continue; + } + if (info.getSymbol().isEmpty() || SemanticdbSymbols.isLocal(info.getSymbol())) { + continue; + } + for (int j = 0; j < info.getOverriddenSymbolsCount(); j++) { + String overriddenSymbol = info.getOverriddenSymbols(j); + if (SemanticdbSymbols.isLocal(overriddenSymbol)) { + continue; + } + relationships.add(new SymbolRelationship(info.getSymbol(), overriddenSymbol)); + } + } + return relationships.stream(); + } + private Set exportSymbols(List files) { return filesStream(files) .flatMap(this::parseTextDocument) diff --git a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdbOptions.java b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdbOptions.java index dfc61c4a..f5a40a59 100644 --- a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdbOptions.java +++ b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdbOptions.java @@ -17,6 +17,7 @@ public class ScipSemanticdbOptions { public final boolean parallel; public final List packages; public final String buildKind; + public final boolean emitInverseRelationships; public ScipSemanticdbOptions( List targetroots, @@ -28,7 +29,8 @@ public ScipSemanticdbOptions( ScipOutputFormat format, boolean parallel, List packages, - String buildKind) { + String buildKind, + boolean emitInverseRelationships) { this.targetroots = targetroots; this.output = output; this.sourceroot = sourceroot; @@ -39,5 +41,6 @@ public ScipSemanticdbOptions( this.parallel = parallel; this.packages = packages; this.buildKind = buildKind; + this.emitInverseRelationships = emitInverseRelationships; } } diff --git a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/SymbolRelationship.java b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/SymbolRelationship.java new file mode 100644 index 00000000..66eb1ae4 --- /dev/null +++ b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/SymbolRelationship.java @@ -0,0 +1,19 @@ +package com.sourcegraph.scip_semanticdb; + +public class SymbolRelationship { + public final String from; + public final String to; + + public SymbolRelationship(String from, String to) { + this.from = from; + this.to = to; + } + + public String getFrom() { + return from; + } + + public String getTo() { + return to; + } +} diff --git a/tests/snapshots/src/main/generated/ByteParser.scala b/tests/snapshots/src/main/generated/ByteParser.scala index be092090..b737cb66 100644 --- a/tests/snapshots/src/main/generated/ByteParser.scala +++ b/tests/snapshots/src/main/generated/ByteParser.scala @@ -107,6 +107,9 @@ abstract class ByteParser[J] extends upickle.core.BufferingByteParser{ protected[this] def close(): Unit // ^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/ByteParser#close(). // documentation ```scala\ndef close(): Unit\n``` +// relationship is_reference is_implementation ujson/ByteArrayParser#close(). +// relationship is_reference is_implementation ujson/ByteBufferParser#close(). +// relationship is_reference is_implementation ujson/InputStreamParser#close(). // ^^^^ reference semanticdb maven maven/org.scala-lang/scala-library 2.13.10 scala/Unit# /** diff --git a/tests/snapshots/src/main/generated/CharParser.scala b/tests/snapshots/src/main/generated/CharParser.scala index a84f3921..d6c35015 100644 --- a/tests/snapshots/src/main/generated/CharParser.scala +++ b/tests/snapshots/src/main/generated/CharParser.scala @@ -107,6 +107,8 @@ abstract class CharParser[J] extends upickle.core.BufferingCharParser{ protected[this] def close(): Unit // ^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/CharParser#close(). // documentation ```scala\ndef close(): Unit\n``` +// relationship is_reference is_implementation ujson/CharSequenceParser#close(). +// relationship is_reference is_implementation ujson/StringParser#close(). // ^^^^ reference semanticdb maven maven/org.scala-lang/scala-library 2.13.10 scala/Unit# /** diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/AsyncEpoxyDiffer.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/AsyncEpoxyDiffer.java index 0f11aae7..08e72313 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/AsyncEpoxyDiffer.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/AsyncEpoxyDiffer.java @@ -60,6 +60,7 @@ interface ResultCallback { void onResult(@NonNull DiffResult result); // ^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/AsyncEpoxyDiffer#ResultCallback#onResult(). // documentation ```java\npublic abstract void onResult(DiffResult result)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onResult(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/DiffResult# // ^^^^^^ definition local 0 diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyAdapter.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyAdapter.java index 1a04d88a..f54862fe 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyAdapter.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyAdapter.java @@ -145,6 +145,7 @@ protected void onExceptionSwallowed(RuntimeException exception) { // ^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#onExceptionSwallowed(). // documentation ```java\nprotected void onExceptionSwallowed(RuntimeException exception)\n``` // documentation This is called when recoverable exceptions happen at runtime. They can be ignored and Epoxy\n will recover, but you can override this to be aware of when they happen.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onExceptionSwallowed(). // ^^^^^^^^^^^^^^^^ reference semanticdb maven jdk 11 java/lang/RuntimeException# // ^^^^^^^^^ definition local 0 // documentation ```java\nRuntimeException exception\n``` @@ -156,6 +157,7 @@ protected void onExceptionSwallowed(RuntimeException exception) { public int getItemCount() { // ^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#getItemCount(). // documentation ```java\n@Override\npublic int getItemCount()\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#getItemCount(). return getCurrentModels().size(); // ^^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#getCurrentModels(). // ^^^^ reference semanticdb maven jdk 11 java/util/List#size(). @@ -168,6 +170,8 @@ public int getItemCount() { // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#getCurrentModels(). // documentation ```java\nabstract List> getCurrentModels()\n``` // documentation Return the models currently being used by the adapter to populate the recyclerview. +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyAdapter#getCurrentModels(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#getCurrentModels(). public boolean isEmpty() { // ^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#isEmpty(). @@ -341,6 +345,7 @@ public void onBindViewHolder(EpoxyViewHolder holder, int position, List boolean diffPayloadsEnabled() { // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#diffPayloadsEnabled(). // documentation ```java\nboolean diffPayloadsEnabled()\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#diffPayloadsEnabled(). return false; } @@ -376,6 +381,7 @@ protected void onModelBound(EpoxyViewHolder holder, EpoxyModel model, int pos void onModelBound(EpoxyViewHolder holder, EpoxyModel model, int position, // ^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#onModelBound(+1). // documentation ```java\nvoid onModelBound(EpoxyViewHolder holder, EpoxyModel model, int position, EpoxyModel previouslyBoundModel)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onModelBound(). // ^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyViewHolder# // ^^^^^^ definition local 18 // documentation ```java\nEpoxyViewHolder holder\n``` @@ -425,6 +431,8 @@ protected BoundViewHolders getBoundViewHolders() { // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#getBoundViewHolders(). // documentation ```java\nprotected BoundViewHolders getBoundViewHolders()\n``` // documentation Returns an object that manages the view holders currently bound to the RecyclerView. This\n object is mainly used by the base Epoxy adapter to save view states, but you may find it useful\n to help access views or models currently shown in the RecyclerView.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#getBoundViewHolders(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#getBoundViewHolders(). return boundViewHolders; // ^^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#boundViewHolders. } @@ -433,6 +441,7 @@ EpoxyModel getModelForPosition(int position) { //^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#getModelForPosition(). // documentation ```java\nEpoxyModel getModelForPosition(int position)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyAdapter#getModelForPosition(). // ^^^^^^^^ definition local 25 // documentation ```java\nint position\n``` return getCurrentModels().get(position); @@ -480,6 +489,7 @@ public void onViewRecycled(EpoxyViewHolder holder) { public void onDetachedFromRecyclerView(@NonNull RecyclerView recyclerView) { // ^^^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#onDetachedFromRecyclerView(). // documentation ```java\n@CallSuper\n@Override\npublic void onDetachedFromRecyclerView(unresolved_type recyclerView)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onDetachedFromRecyclerView(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 28 @@ -500,6 +510,7 @@ protected void onModelUnbound(EpoxyViewHolder holder, EpoxyModel model) { // ^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#onModelUnbound(). // documentation ```java\nprotected void onModelUnbound(EpoxyViewHolder holder, EpoxyModel model)\n``` // documentation Called immediately after a model is unbound from a view holder. Subclasses can override this if\n they want alerts on when a model is unbound.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onModelUnbound(). // ^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyViewHolder# // ^^^^^^ definition local 29 // documentation ```java\nEpoxyViewHolder holder\n``` @@ -536,6 +547,7 @@ public boolean onFailedToRecycleView(EpoxyViewHolder holder) { public void onViewAttachedToWindow(EpoxyViewHolder holder) { // ^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#onViewAttachedToWindow(). // documentation ```java\n@CallSuper\n@Override\npublic void onViewAttachedToWindow(EpoxyViewHolder holder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onViewAttachedToWindow(). // ^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyViewHolder# // ^^^^^^ definition local 32 // documentation ```java\nEpoxyViewHolder holder\n``` @@ -556,6 +568,7 @@ public void onViewAttachedToWindow(EpoxyViewHolder holder) { public void onViewDetachedFromWindow(EpoxyViewHolder holder) { // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#onViewDetachedFromWindow(). // documentation ```java\n@CallSuper\n@Override\npublic void onViewDetachedFromWindow(EpoxyViewHolder holder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#onViewDetachedFromWindow(). // ^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyViewHolder# // ^^^^^^ definition local 33 // documentation ```java\nEpoxyViewHolder holder\n``` @@ -649,6 +662,8 @@ protected int getModelPosition(EpoxyModel model) { // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#getModelPosition(). // documentation ```java\nprotected int getModelPosition(EpoxyModel model)\n``` // documentation Finds the position of the given model in the list. Doesn't use indexOf to avoid unnecessary\n equals() calls since we're looking for the same object instance.\n\n @return The position of the given model in the current models list, or -1 if the model can't be\n found.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#getModelPosition(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#getModelPosition(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 37 // documentation ```java\nEpoxyModel model\n``` @@ -738,6 +753,7 @@ public void setupStickyHeaderView(@NotNull View stickyHeader) { // ^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#setupStickyHeaderView(). // documentation ```java\n@Override\npublic void setupStickyHeaderView(unresolved_type stickyHeader)\n``` // documentation Optional callback to setup the sticky view,\n by default it doesn't do anything.\n

\n The sub-classes should override the function if they are\n using sticky header feature.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#setupStickyHeaderView(). // ^^^^^^^ reference semanticdb maven maven/org.jetbrains/annotations 13.0 org/jetbrains/annotations/NotNull# // ^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 41 @@ -758,6 +774,7 @@ public void teardownStickyHeaderView(@NotNull View stickyHeader) { // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#teardownStickyHeaderView(). // documentation ```java\n@Override\npublic void teardownStickyHeaderView(unresolved_type stickyHeader)\n``` // documentation Optional callback to perform tear down operation on the\n sticky view, by default it doesn't do anything.\n

\n The sub-classes should override the function if they are\n using sticky header feature.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#teardownStickyHeaderView(). // ^^^^^^^ reference semanticdb maven maven/org.jetbrains/annotations 13.0 org/jetbrains/annotations/NotNull# // ^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 42 @@ -778,6 +795,7 @@ public boolean isStickyHeader(int position) { // ^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyAdapter#isStickyHeader(). // documentation ```java\n@Override\npublic boolean isStickyHeader(int position)\n``` // documentation Called to check if the item at the position is a sticky item,\n by default returns false.\n

\n The sub-classes should override the function if they are\n using sticky header feature.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyControllerAdapter#isStickyHeader(). // ^^^^^^^^ definition local 43 // documentation ```java\nint position\n``` return false; diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyTouchCallback.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyTouchCallback.java index 07e90dd5..8c3e498f 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyTouchCallback.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/BaseEpoxyTouchCallback.java @@ -8,6 +8,8 @@ interface BaseEpoxyTouchCallback { // ^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyTouchCallback# // documentation ```java\ninterface BaseEpoxyTouchCallback\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyDragCallback# +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxySwipeCallback# // ^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyTouchCallback#[T] // documentation ```java\nT extends EpoxyModel\n``` // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# @@ -26,6 +28,8 @@ interface BaseEpoxyTouchCallback { // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyTouchCallback#getMovementFlagsForModel(). // documentation ```java\npublic abstract int getMovementFlagsForModel(T model, int adapterPosition)\n``` // documentation Should return a composite flag which defines the enabled move directions in each state\n (idle, swiping, dragging) for the given model.\n

\n Return 0 to disable movement for the model.\n\n @param model The model being targeted for movement.\n @param adapterPosition The current adapter position of the targeted model\n @see androidx.recyclerview.widget.ItemTouchHelper.Callback#getMovementFlags\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#DragCallbacks#getMovementFlagsForModel(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#SwipeCallbacks#getMovementFlagsForModel(). // ^ reference semanticdb maven . . com/airbnb/epoxy/BaseEpoxyTouchCallback#[T] // ^^^^^ definition local 0 // documentation ```java\nT model\n``` @@ -46,6 +50,10 @@ interface BaseEpoxyTouchCallback { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/BaseEpoxyTouchCallback#clearView(). // documentation ```java\npublic abstract void clearView(T model, unresolved_type itemView)\n``` // documentation Called when the user interaction with a view is over and the view has\n completed its animation. This is a good place to clear all changes on the view that were done\n in other previous touch callbacks (such as on touch start, change, release, etc).\n

\n This is the last callback in the lifecycle of a touch event.\n\n @param model The model whose view is being cleared.\n @param itemView The view being cleared.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#clearView(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#clearView(+1). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#DragCallbacks#clearView(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#SwipeCallbacks#clearView(). // ^ reference semanticdb maven . . com/airbnb/epoxy/BaseEpoxyTouchCallback#[T] // ^^^^^ definition local 2 // documentation ```java\nT model\n``` diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/ControllerHelper.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/ControllerHelper.java index 38038d87..f1484375 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/ControllerHelper.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/ControllerHelper.java @@ -22,6 +22,7 @@ public abstract class ControllerHelper { public abstract void resetAutoModels(); // ^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/ControllerHelper#resetAutoModels(). // documentation ```java\npublic abstract void resetAutoModels()\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/NoOpControllerHelper#resetAutoModels(). protected void validateModelHashCodesHaveNotChanged(T controller) { // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/ControllerHelper#validateModelHashCodesHaveNotChanged(). diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyAdapter.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyAdapter.java index 305bc540..c40059ec 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyAdapter.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyAdapter.java @@ -88,6 +88,7 @@ protected void enableDiffing() { // ^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#enableDiffing(). // documentation ```java\nprotected void enableDiffing()\n``` // documentation Enables support for automatically notifying model changes via {@link #notifyModelsChanged()}.\n If used, this should be called in the constructor, before any models are changed.\n\n @see #notifyModelsChanged()\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#enableDiffing(). if (diffHelper != null) { // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#diffHelper. throw new IllegalStateException("Diffing was already enabled"); @@ -152,6 +153,7 @@ protected void notifyModelsChanged() { // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#notifyModelsChanged(). // documentation ```java\nprotected void notifyModelsChanged()\n``` // documentation Intelligently notify item changes by comparing the current {@link #models} list against the\n previous so you don't have to micromanage notification calls yourself. This may be\n prohibitively slow for large model lists (in the hundreds), in which case consider doing\n notification calls yourself. If you use this, all your view models must implement {@link\n EpoxyModel#hashCode()} and {@link EpoxyModel#equals(Object)} to completely identify their\n state, so that changes to a model's content can be detected. Before using this you must enable\n it with {@link #enableDiffing()}, since keeping track of the model state adds extra computation\n time to all other data change notifications.\n\n @see #enableDiffing()\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#notifyModelsChanged(). if (diffHelper == null) { // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#diffHelper. throw new IllegalStateException("You must enable diffing before notifying models changed"); @@ -171,6 +173,7 @@ protected void notifyModelChanged(EpoxyModel model) { // ^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#notifyModelChanged(). // documentation ```java\nprotected void notifyModelChanged(EpoxyModel model)\n``` // documentation Notify that the given model has had its data changed. It should only be called if the model\n retained the same position.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#notifyModelChanged(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 2 // documentation ```java\nEpoxyModel model\n``` @@ -246,6 +249,7 @@ protected void addModels(EpoxyModel... modelsToAdd) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#addModels(). // documentation ```java\nprotected void addModels(EpoxyModel[] modelsToAdd)\n``` // documentation Adds the models to the end of the {@link #models} list and notifies that the items were\n inserted.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#addModels(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^^^^^^ definition local 8 // documentation ```java\nEpoxyModel[] modelsToAdd\n``` @@ -291,6 +295,7 @@ protected void addModels(Collection> modelsToAdd) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#addModels(+1). // documentation ```java\nprotected void addModels(Collection> modelsToAdd)\n``` // documentation Adds the models to the end of the {@link #models} list and notifies that the items were\n inserted.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#addModels(+1). // ^^^^^^^^^^ reference semanticdb maven jdk 11 java/util/Collection# // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^^^^^^ definition local 11 @@ -325,6 +330,7 @@ protected void insertModelBefore(EpoxyModel modelToInsert, EpoxyModel mode // ^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#insertModelBefore(). // documentation ```java\nprotected void insertModelBefore(EpoxyModel modelToInsert, EpoxyModel modelToInsertBefore)\n``` // documentation Inserts the given model before the other in the {@link #models} list, and notifies that the\n item was inserted.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#insertModelBefore(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^^^^^^^^ definition local 13 // documentation ```java\nEpoxyModel modelToInsert\n``` @@ -366,6 +372,7 @@ protected void insertModelAfter(EpoxyModel modelToInsert, EpoxyModel model // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#insertModelAfter(). // documentation ```java\nprotected void insertModelAfter(EpoxyModel modelToInsert, EpoxyModel modelToInsertAfter)\n``` // documentation Inserts the given model after the other in the {@link #models} list, and notifies that the item\n was inserted.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#insertModelAfter(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^^^^^^^^ definition local 16 // documentation ```java\nEpoxyModel modelToInsert\n``` @@ -411,6 +418,7 @@ protected void removeModel(EpoxyModel model) { // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#removeModel(). // documentation ```java\nprotected void removeModel(EpoxyModel model)\n``` // documentation If the given model exists it is removed and an item removal is notified. Otherwise this does\n nothing.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#removeModel(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 20 // documentation ```java\nEpoxyModel model\n``` @@ -443,6 +451,7 @@ protected void removeAllModels() { // ^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#removeAllModels(). // documentation ```java\nprotected void removeAllModels()\n``` // documentation Removes all models\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#removeAllModels(). int numModelsRemoved = models.size(); // ^^^^^^^^^^^^^^^^ definition local 22 // documentation ```java\nint numModelsRemoved\n``` @@ -471,6 +480,7 @@ protected void removeAllAfterModel(EpoxyModel model) { // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#removeAllAfterModel(). // documentation ```java\nprotected void removeAllAfterModel(EpoxyModel model)\n``` // documentation Removes all models after the given model, which must have already been added. An example use\n case is you want to keep a header but clear everything else, like in the case of refreshing\n data.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#removeAllAfterModel(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 23 // documentation ```java\nEpoxyModel model\n``` @@ -519,6 +529,7 @@ protected void showModel(EpoxyModel model, boolean show) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#showModel(). // documentation ```java\nprotected void showModel(EpoxyModel model, boolean show)\n``` // documentation Sets the visibility of the given model, and notifies that the item changed if the new\n visibility is different from the previous.\n\n @param model The model to show. It should already be added to the {@link #models} list.\n @param show True to show the model, false to hide it.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#showModel(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 27 // documentation ```java\nEpoxyModel model\n``` @@ -549,6 +560,7 @@ protected void showModel(EpoxyModel model) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#showModel(+1). // documentation ```java\nprotected void showModel(EpoxyModel model)\n``` // documentation Shows the given model, and notifies that the item changed if the item wasn't already shown.\n\n @param model The model to show. It should already be added to the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#showModel(+1). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 29 // documentation ```java\nEpoxyModel model\n``` @@ -566,6 +578,7 @@ protected void showModels(EpoxyModel... models) { // ^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#showModels(). // documentation ```java\nprotected void showModels(EpoxyModel[] models)\n``` // documentation Shows the given models, and notifies that each item changed if the item wasn't already shown.\n\n @param models The models to show. They should already be added to the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#showModels(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^ definition local 30 // documentation ```java\nEpoxyModel[] models\n``` @@ -587,6 +600,7 @@ protected void showModels(boolean show, EpoxyModel... models) { // ^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#showModels(+1). // documentation ```java\nprotected void showModels(boolean show, EpoxyModel[] models)\n``` // documentation Sets the visibility of the given models, and notifies that the items changed if the new\n visibility is different from the previous.\n\n @param models The models to show. They should already be added to the {@link #models} list.\n @param show True to show the models, false to hide them.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#showModels(+1). // ^^^^ definition local 31 // documentation ```java\nboolean show\n``` // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# @@ -609,6 +623,7 @@ protected void showModels(Iterable> models) { // ^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#showModels(+2). // documentation ```java\nprotected void showModels(Iterable> models)\n``` // documentation Shows the given models, and notifies that each item changed if the item wasn't already shown.\n\n @param models The models to show. They should already be added to the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#showModels(+2). // ^^^^^^^^ reference semanticdb maven jdk 11 java/lang/Iterable# // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^ definition local 33 @@ -629,6 +644,7 @@ protected void showModels(Iterable> models, boolean show) { // ^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#showModels(+3). // documentation ```java\nprotected void showModels(Iterable> models, boolean show)\n``` // documentation Sets the visibility of the given models, and notifies that the items changed if the new\n visibility is different from the previous.\n\n @param models The models to show. They should already be added to the {@link #models} list.\n @param show True to show the models, false to hide them.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#showModels(+3). // ^^^^^^^^ reference semanticdb maven jdk 11 java/lang/Iterable# // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^ definition local 34 @@ -656,6 +672,7 @@ protected void hideModel(EpoxyModel model) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#hideModel(). // documentation ```java\nprotected void hideModel(EpoxyModel model)\n``` // documentation Hides the given model, and notifies that the item changed if the item wasn't already hidden.\n\n @param model The model to hide. This should already be added to the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#hideModel(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 37 // documentation ```java\nEpoxyModel model\n``` @@ -673,6 +690,7 @@ protected void hideModels(Iterable> models) { // ^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#hideModels(). // documentation ```java\nprotected void hideModels(Iterable> models)\n``` // documentation Hides the given models, and notifies that each item changed if the item wasn't already hidden.\n\n @param models The models to hide. They should already be added to the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#hideModels(). // ^^^^^^^^ reference semanticdb maven jdk 11 java/lang/Iterable# // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^ definition local 38 @@ -691,6 +709,7 @@ protected void hideModels(EpoxyModel... models) { // ^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#hideModels(+1). // documentation ```java\nprotected void hideModels(EpoxyModel[] models)\n``` // documentation Hides the given models, and notifies that each item changed if the item wasn't already hidden.\n\n @param models The models to hide. They should already be added to the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#hideModels(+1). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^^ definition local 39 // documentation ```java\nEpoxyModel[] models\n``` @@ -710,6 +729,7 @@ protected void hideAllAfterModel(EpoxyModel model) { // ^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#hideAllAfterModel(). // documentation ```java\nprotected void hideAllAfterModel(EpoxyModel model)\n``` // documentation Hides all models currently located after the given model in the {@link #models} list.\n\n @param model The model after which to hide. It must exist in the {@link #models} list.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#hideAllAfterModel(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 40 // documentation ```java\nEpoxyModel model\n``` @@ -732,6 +752,7 @@ protected List> getAllModelsAfter(EpoxyModel model) { // ^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyAdapter#getAllModelsAfter(). // documentation ```java\nprotected List> getAllModelsAfter(EpoxyModel model)\n``` // documentation Returns a sub list of all items in {@link #models} that occur after the given model. This list\n is backed by the original models list, any changes to the returned list will be reflected in\n the original {@link #models} list.\n\n @param model Must exist in {@link #models}.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyAdapter#getAllModelsAfter(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel# // ^^^^^ definition local 41 // documentation ```java\nEpoxyModel model\n``` diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyController.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyController.java index b66a74f5..1f693210 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyController.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyController.java @@ -344,6 +344,11 @@ public void requestModelBuild() { // ^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyController#requestModelBuild(). // documentation ```java\npublic void requestModelBuild()\n``` // documentation Call this to request a model update. The controller will schedule a call to {@link\n #buildModels()} so that models can be rebuilt for the current data. Once a build is requested\n all subsequent requests are ignored until the model build runs. Therefore, the calling code\n need not worry about calling this multiple times in a row.\n

\n The exception is that the first time this is called on a new instance of {@link\n EpoxyController} it is run synchronously. This allows state to be restored and the initial view\n to be draw quicker.\n

\n If you would like to be alerted when models have finished building use\n {@link #addModelBuildListener(OnModelBuildFinishedListener)}\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyController#requestModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed2EpoxyController#requestModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed3EpoxyController#requestModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed4EpoxyController#requestModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/TypedEpoxyController#requestModelBuild(). if (isBuildingModels()) { // ^^^^^^^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyController#isBuildingModels(). throw new IllegalEpoxyUsage("Cannot call `requestModelBuild` from inside `buildModels`"); @@ -450,6 +455,10 @@ public synchronized void requestDelayedModelBuild(int delayMs) { // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyController#requestDelayedModelBuild(). // documentation ```java\npublic void requestDelayedModelBuild(int delayMs)\n``` // documentation Call this to request a delayed model update. The controller will schedule a call to {@link\n #buildModels()} so that models can be rebuilt for the current data.\n

\n Using this to delay a model update may be helpful in cases where user input is causing many\n rapid changes in the models, such as typing. In that case, the view is already updated on\n screen and constantly rebuilding models is potentially slow and unnecessary. The downside to\n delaying the model build too long is that models will not be in sync with the data or view, and\n scrolling the view offscreen and back onscreen will cause the model to bind old data.\n

\n If a previous request is still pending it will be removed in favor of this new delay\n

\n Any call to {@link #requestModelBuild()} will override a delayed request.\n

\n In most cases you should use {@link #requestModelBuild()} instead of this.\n\n @param delayMs The time in milliseconds to delay the model build by. Should be greater than or\n equal to 0. A value of 0 is equivalent to calling {@link #requestModelBuild()}\n +// relationship is_reference is_implementation com/airbnb/epoxy/Typed2EpoxyController#requestDelayedModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed3EpoxyController#requestDelayedModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed4EpoxyController#requestDelayedModelBuild(). +// relationship is_reference is_implementation com/airbnb/epoxy/TypedEpoxyController#requestDelayedModelBuild(). // ^^^^^^^ definition local 4 // documentation ```java\nint delayMs\n``` if (isBuildingModels()) { @@ -648,6 +657,11 @@ private int getExpectedModelCount() { // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyController#buildModels(). // documentation ```java\nprotected abstract void buildModels()\n``` // documentation Subclasses should implement this to describe what models should be shown for the current state.\n Implementations should call either {@link #add(EpoxyModel)}, {@link\n EpoxyModel#addTo(EpoxyController)}, or {@link EpoxyModel#addIf(boolean, EpoxyController)} with\n the models that should be shown, in the order that is desired.\n

\n Once a model is added to the controller it should be treated as immutable and never modified\n again. This is necessary for adapter updates to be accurate. If "validateEpoxyModelUsage" is\n enabled then runtime validations will be done to make sure models are not changed.\n

\n You CANNOT call this method directly. Instead, call {@link #requestModelBuild()} to have the\n controller schedule an update.\n +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyController#buildModels(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed2EpoxyController#buildModels(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed3EpoxyController#buildModels(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed4EpoxyController#buildModels(). +// relationship is_reference is_implementation com/airbnb/epoxy/TypedEpoxyController#buildModels(). int getFirstIndexOfModelInBuildingList(EpoxyModel model) { // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyController#getFirstIndexOfModelInBuildingList(). @@ -1397,6 +1411,10 @@ public void moveModel(int fromPosition, int toPosition) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyController#moveModel(). // documentation ```java\npublic void moveModel(int fromPosition, int toPosition)\n``` // documentation An optimized way to move a model from one position to another without rebuilding all models.\n This is intended to be used with {@link androidx.recyclerview.widget.ItemTouchHelper} to\n allow for efficient item dragging and rearranging. It cannot be\n

\n If you call this you MUST also update the data backing your models as necessary.\n

\n This will immediately change the model's position and notify the change to the RecyclerView.\n However, a delayed request to rebuild models will be scheduled for the future to guarantee that\n models are in sync with data.\n\n @param fromPosition Previous position of the item.\n @param toPosition New position of the item.\n +// relationship is_reference is_implementation com/airbnb/epoxy/Typed2EpoxyController#moveModel(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed3EpoxyController#moveModel(). +// relationship is_reference is_implementation com/airbnb/epoxy/Typed4EpoxyController#moveModel(). +// relationship is_reference is_implementation com/airbnb/epoxy/TypedEpoxyController#moveModel(). // ^^^^^^^^^^^^ definition local 50 // documentation ```java\nint fromPosition\n``` // ^^^^^^^^^^ definition local 51 diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyDragCallback.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyDragCallback.java index dc8da0cd..d8503c81 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyDragCallback.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyDragCallback.java @@ -34,6 +34,8 @@ public interface EpoxyDragCallback extends BaseEpoxyTouchC // ^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyDragCallback#onDragStarted(). // documentation ```java\npublic abstract void onDragStarted(T model, unresolved_type itemView, int adapterPosition)\n``` // documentation Called when the view switches from an idle state to a dragged state, as the user begins a drag\n interaction with it. You can use this callback to modify the view to indicate it is being\n dragged.\n

\n This is the first callback in the lifecycle of a drag event.\n\n @param model The model representing the view that is being dragged\n @param itemView The view that is being dragged\n @param adapterPosition The adapter position of the model\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onDragStarted(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#DragCallbacks#onDragStarted(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyDragCallback#[T] // ^^^^^ definition local 0 // documentation ```java\nT model\n``` @@ -61,6 +63,8 @@ public interface EpoxyDragCallback extends BaseEpoxyTouchC // ^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyDragCallback#onModelMoved(). // documentation ```java\npublic abstract void onModelMoved(int fromPosition, int toPosition, T modelBeingMoved, unresolved_type itemView)\n``` // documentation Called after {@link #onDragStarted(EpoxyModel, View, int)} when the dragged view is dropped to\n a new position. The EpoxyController will be updated automatically for you to reposition the\n models and notify the RecyclerView of the change.\n

\n You MUST use this callback to modify your data backing the models to reflect the change.\n

\n The next callback in the drag lifecycle will be {@link #onDragStarted(EpoxyModel, View, int)}\n\n @param modelBeingMoved The model representing the view that was moved\n @param itemView The view that was moved\n @param fromPosition The adapter position that the model came from\n @param toPosition The new adapter position of the model\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onModelMoved(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#DragCallbacks#onModelMoved(). // ^^^^^^^^^^^^ definition local 3 // documentation ```java\nint fromPosition\n``` // ^^^^^^^^^^ definition local 4 @@ -90,6 +94,8 @@ public interface EpoxyDragCallback extends BaseEpoxyTouchC // ^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyDragCallback#onDragReleased(). // documentation ```java\npublic abstract void onDragReleased(T model, unresolved_type itemView)\n``` // documentation Called after {@link #onDragStarted(EpoxyModel, View, int)} when the view being dragged is\n released. If the view was dragged to a new, valid location then {@link #onModelMoved(int, int,\n EpoxyModel, View)} will be called before this and the view will settle to the new location.\n Otherwise the view will animate back to its original position.\n

\n You can use this callback to modify the view as it animates back into position.\n

\n {@link BaseEpoxyTouchCallback#clearView(EpoxyModel, View)} will be called after this, when the\n view has finished animating. Final cleanup of the view should be done there.\n\n @param model The model representing the view that is being released\n @param itemView The view that was being dragged\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onDragReleased(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#DragCallbacks#onDragReleased(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyDragCallback#[T] // ^^^^^ definition local 7 // documentation ```java\nT model\n``` diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModel.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModel.java index 14b42256..f6fb6815 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModel.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModel.java @@ -185,6 +185,7 @@ protected int getViewType() { // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#getViewType(). // documentation ```java\nprotected int getViewType()\n``` // documentation Get the view type to associate with this model in the recyclerview. For models that use a\n layout resource, the view type is simply the layout resource value by default.\n

\n If this returns 0 Epoxy will assign a unique view type for this model at run time.\n\n @see androidx.recyclerview.widget.RecyclerView.Adapter#getItemViewType(int)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithView#getViewType(). return getLayout(); // ^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#getLayout(). } @@ -198,6 +199,7 @@ protected View buildView(@NonNull ViewGroup parent) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#buildView(). // documentation ```java\nprotected unresolved_type buildView(unresolved_type parent)\n``` // documentation Create and return a new instance of a view for this model. By default a view is created by\n inflating the layout resource.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithView#buildView(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^ definition local 1 @@ -220,6 +222,9 @@ public void bind(@NonNull T view) { // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#bind(). // documentation ```java\npublic void bind(T view)\n``` // documentation Binds the current data to the given view. You should bind all fields including unset/empty\n fields to ensure proper recycling.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#bind(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#bind(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyModel#bind(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 2 @@ -239,6 +244,8 @@ public void bind(@NonNull T view, @NonNull List payloads) { // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#bind(+1). // documentation ```java\npublic void bind(T view, List payloads)\n``` // documentation Similar to {@link #bind(Object)}, but provides a non null, non empty list of payloads\n describing what changed. This is the payloads list specified in the adapter's notifyItemChanged\n method. This is a useful optimization to allow you to only change part of a view instead of\n updating the whole thing, which may prevent unnecessary layout calls. If there are no payloads\n then {@link #bind(Object)} is called instead. This will only be used if the model is used with\n an {@link EpoxyAdapter}\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#bind(+1). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#bind(+1). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 3 @@ -288,6 +295,8 @@ public void bind(@NonNull T view, @NonNull EpoxyModel previouslyBoundModel) { // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#bind(+2). // documentation ```java\npublic void bind(T view, EpoxyModel previouslyBoundModel)\n``` // documentation Similar to {@link #bind(Object)}, but provides a non null model which was previously bound to\n this view. This will only be called if the model is used with an {@link EpoxyController}.\n\n @param previouslyBoundModel This is a model with the same id that was previously bound. You can\n compare this previous model with the current one to see exactly\n what changed.\n

\n This model and the previously bound model are guaranteed to have\n the same id, but will not necessarily be of the same type depending\n on your implementation of {@link EpoxyController#buildModels()}.\n With common usage patterns of Epoxy they should be the same type,\n and will only differ if you are using different model classes with\n the same id.\n

\n Comparing the newly bound model with the previous model allows you\n to be more intelligent when binding your view. This may help you\n optimize view binding, or make it easier to work with animations.\n

\n If the new model and the previous model have the same view type\n (given by {@link EpoxyModel#getViewType()}), and if you are using\n the default ReyclerView item animator, the same view will be\n reused. This means that you only need to update the view to reflect\n the data that changed. If you are using a custom item animator then\n the view will be the same if the animator returns true in\n canReuseUpdatedViewHolder.\n

\n This previously bound model is taken as a payload from the diffing\n process, and follows the same general conditions for all\n recyclerview change payloads.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#bind(+2). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#bind(+2). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 5 @@ -315,6 +324,9 @@ public void unbind(@NonNull T view) { // ^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#unbind(). // documentation ```java\npublic void unbind(T view)\n``` // documentation Called when the view bound to this model is recycled. Subclasses can override this if their\n view should release resources when it's recycled.\n

\n Note that {@link #bind(Object)} can be called multiple times without an unbind call in between\n if the view has remained on screen to be reused across item changes. This means that you should\n not rely on unbind to clear a view or model's state before bind is called again.\n\n @see EpoxyAdapter#onViewRecycled(EpoxyViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#unbind(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#unbind(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyModel#unbind(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 7 @@ -330,6 +342,7 @@ public void onVisibilityStateChanged(@Visibility int visibilityState, @NonNull T // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onVisibilityStateChanged(). // documentation ```java\npublic void onVisibilityStateChanged(int visibilityState, T view)\n``` // documentation TODO link to the wiki\n\n @see OnVisibilityStateChanged annotation\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#onVisibilityStateChanged(). // ^^^^^^^^^^ reference semanticdb maven . . com/airbnb/epoxy/VisibilityState#Visibility# // ^^^^^^^^^^^^^^^ definition local 8 // documentation ```java\n@Visibility\nint visibilityState\n``` @@ -348,6 +361,7 @@ public void onVisibilityChanged( // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onVisibilityChanged(). // documentation ```java\npublic void onVisibilityChanged(float percentVisibleHeight, float percentVisibleWidth, int visibleHeight, int visibleWidth, T view)\n``` // documentation TODO link to the wiki\n\n @see OnVisibilityChanged annotation\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#onVisibilityChanged(). @FloatRange(from = 0.0f, to = 100.0f) float percentVisibleHeight, // ^^^^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/FloatRange# // ^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/FloatRange#from(). @@ -615,6 +629,10 @@ public EpoxyModel id(@Nullable CharSequence key, long id) { // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#getDefaultLayout(). // documentation ```java\n@LayoutRes\nprotected abstract int getDefaultLayout()\n``` // documentation Return the default layout resource to be used when creating views for this model. The resource\n will be inflated to create a view for the model; additionally the layout int is used as the\n views type in the RecyclerView.\n

\n This can be left unimplemented if you use the {@link EpoxyModelClass} annotation to define a\n layout.\n

\n This default value can be overridden with {@link #layout(int)} at runtime to change the layout\n dynamically.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#getDefaultLayout(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithView#getDefaultLayout(). +// relationship is_reference is_implementation com/airbnb/epoxy/HiddenEpoxyModel#getDefaultLayout(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyModel#getDefaultLayout(). @NonNull // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# @@ -623,6 +641,7 @@ public EpoxyModel layout(@LayoutRes int layoutRes) { // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#layout(). // documentation ```java\n@NonNull\npublic EpoxyModel layout(int layoutRes)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithView#layout(). // ^^^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/LayoutRes# // ^^^^^^^^^ definition local 30 // documentation ```java\n@LayoutRes\nint layoutRes\n``` @@ -949,6 +968,8 @@ protected final void validateStateHasNotChangedSinceAdded(String descriptionOfCh public boolean equals(Object o) { // ^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#equals(). // documentation ```java\n@Override\npublic boolean equals(Object o)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#equals(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyModel#equals(). // relationship is_reference is_implementation semanticdb maven jdk 11 java/lang/Object#equals(). // ^^^^^^ reference semanticdb maven jdk 11 java/lang/Object# // ^ definition local 47 @@ -993,6 +1014,8 @@ public boolean equals(Object o) { public int hashCode() { // ^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#hashCode(). // documentation ```java\n@Override\npublic int hashCode()\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#hashCode(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyModel#hashCode(). // relationship is_reference is_implementation semanticdb maven jdk 11 java/lang/Object#hashCode(). int result = (int) (id ^ (id >>> 32)); // ^^^^^^ definition local 49 @@ -1023,6 +1046,9 @@ public int getSpanSize(int totalSpanCount, int position, int itemCount) { // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#getSpanSize(). // documentation ```java\npublic int getSpanSize(int totalSpanCount, int position, int itemCount)\n``` // documentation Subclasses can override this if they want their view to take up more than one span in a grid\n layout.\n\n @param totalSpanCount The number of spans in the grid\n @param position The position of the model\n @param itemCount The total number of items in the adapter\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#getSpanSize(). +// relationship is_reference is_implementation com/airbnb/epoxy/HiddenEpoxyModel#getSpanSize(). +// relationship is_reference is_implementation com/airbnb/epoxy/SimpleEpoxyModel#getSpanSize(). // ^^^^^^^^^^^^^^ definition local 50 // documentation ```java\nint totalSpanCount\n``` // ^^^^^^^^ definition local 51 @@ -1168,6 +1194,7 @@ public boolean shouldSaveViewState() { // ^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#shouldSaveViewState(). // documentation ```java\npublic boolean shouldSaveViewState()\n``` // documentation Whether the adapter should save the state of the view bound to this model.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#shouldSaveViewState(+1). return false; } @@ -1184,6 +1211,7 @@ public boolean onFailedToRecycleView(@NonNull T view) { // ^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onFailedToRecycleView(). // documentation ```java\npublic boolean onFailedToRecycleView(T view)\n``` // documentation Called if the RecyclerView failed to recycle this model's view. You can take this opportunity\n to clear the animation(s) that affect the View's transient state and return true\n so that the View can be recycled. Keep in mind that the View in question is already removed\n from the RecyclerView.\n\n @return True if the View should be recycled, false otherwise\n @see EpoxyAdapter#onFailedToRecycleView(androidx.recyclerview.widget.RecyclerView.ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#onFailedToRecycleView(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 61 @@ -1200,6 +1228,8 @@ public void onViewAttachedToWindow(@NonNull T view) { // ^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onViewAttachedToWindow(). // documentation ```java\npublic void onViewAttachedToWindow(T view)\n``` // documentation Called when this model's view is attached to the window.\n\n @see EpoxyAdapter#onViewAttachedToWindow(androidx.recyclerview.widget.RecyclerView.ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#onViewAttachedToWindow(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#onViewAttachedToWindow(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 62 @@ -1217,6 +1247,8 @@ public void onViewDetachedFromWindow(@NonNull T view) { // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onViewDetachedFromWindow(). // documentation ```java\npublic void onViewDetachedFromWindow(T view)\n``` // documentation Called when this model's view is detached from the the window.\n\n @see EpoxyAdapter#onViewDetachedFromWindow(androidx.recyclerview.widget.RecyclerView\n .ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#onViewDetachedFromWindow(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelWithHolder#onViewDetachedFromWindow(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModel#[T] // ^^^^ definition local 63 diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModelWithHolder.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModelWithHolder.java index 03162da2..9aebfbca 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModelWithHolder.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyModelWithHolder.java @@ -66,6 +66,7 @@ public EpoxyModelWithHolder(long id) { // ^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#createNewHolder(). // documentation ```java\nprotected abstract T createNewHolder(unresolved_type parent)\n``` // documentation This should return a new instance of your {@link com.airbnb.epoxy.EpoxyHolder} class. +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#createNewHolder(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^ definition local 1 @@ -76,6 +77,7 @@ public EpoxyModelWithHolder(long id) { public void bind(@NonNull T holder) { // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#bind(). // documentation ```java\n@Override\npublic void bind(T holder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#bind(). // relationship is_reference is_implementation semanticdb maven . . com/airbnb/epoxy/EpoxyModel#bind(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#[T] @@ -92,6 +94,7 @@ public void bind(@NonNull T holder) { public void bind(@NonNull T holder, @NonNull List payloads) { // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#bind(+1). // documentation ```java\n@Override\npublic void bind(T holder, List payloads)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#bind(+1). // relationship is_reference is_implementation semanticdb maven . . com/airbnb/epoxy/EpoxyModel#bind(+1). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#[T] @@ -114,6 +117,7 @@ public void bind(@NonNull T holder, @NonNull List payloads) { public void bind(@NonNull T holder, @NonNull EpoxyModel previouslyBoundModel) { // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#bind(+2). // documentation ```java\n@Override\npublic void bind(T holder, EpoxyModel previouslyBoundModel)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#bind(+2). // relationship is_reference is_implementation semanticdb maven . . com/airbnb/epoxy/EpoxyModel#bind(+2). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#[T] @@ -135,6 +139,7 @@ public void bind(@NonNull T holder, @NonNull EpoxyModel previouslyBoundModel) public void unbind(@NonNull T holder) { // ^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#unbind(). // documentation ```java\n@Override\npublic void unbind(T holder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#unbind(). // relationship is_reference is_implementation semanticdb maven . . com/airbnb/epoxy/EpoxyModel#unbind(). // ^^^^^^^ reference semanticdb maven maven/androidx.annotation/annotation 1.1.0 androidx/annotation/NonNull# // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#[T] @@ -230,6 +235,7 @@ public boolean onFailedToRecycleView(T holder) { public void onViewAttachedToWindow(T holder) { // ^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#onViewAttachedToWindow(). // documentation ```java\n@Override\npublic void onViewAttachedToWindow(T holder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#onViewAttachedToWindow(). // relationship is_reference is_implementation semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onViewAttachedToWindow(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#[T] // ^^^^^^ definition local 16 @@ -245,6 +251,7 @@ public void onViewAttachedToWindow(T holder) { public void onViewDetachedFromWindow(T holder) { // ^^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#onViewDetachedFromWindow(). // documentation ```java\n@Override\npublic void onViewDetachedFromWindow(T holder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelGroup#onViewDetachedFromWindow(). // relationship is_reference is_implementation semanticdb maven . . com/airbnb/epoxy/EpoxyModel#onViewDetachedFromWindow(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxyModelWithHolder#[T] // ^^^^^^ definition local 17 diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxySwipeCallback.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxySwipeCallback.java index fd0545a5..8c5bdf94 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxySwipeCallback.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxySwipeCallback.java @@ -44,6 +44,8 @@ public interface EpoxySwipeCallback extends BaseEpoxyTouch // ^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#onSwipeStarted(). // documentation ```java\npublic abstract void onSwipeStarted(T model, unresolved_type itemView, int adapterPosition)\n``` // documentation Called when the view switches from an idle state to a swiped state, as the user begins a swipe\n interaction with it. You can use this callback to modify the view to indicate it is being\n swiped.\n

\n This is the first callback made in the lifecycle of a swipe event.\n\n @param model The model representing the view that is being swiped\n @param itemView The view that is being swiped\n @param adapterPosition The adapter position of the model\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onSwipeStarted(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#SwipeCallbacks#onSwipeStarted(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#[T] // ^^^^^ definition local 0 // documentation ```java\nT model\n``` @@ -71,6 +73,8 @@ void onSwipeProgressChanged(T model, View itemView, float swipeProgress, // ^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#onSwipeProgressChanged(). // documentation ```java\npublic abstract void onSwipeProgressChanged(T model, unresolved_type itemView, float swipeProgress, unresolved_type canvas)\n``` // documentation Once a view has begun swiping with {@link #onSwipeStarted(EpoxyModel, View, int)} it will\n receive this callback as the swipe distance changes. This can be called multiple times as the\n swipe interaction progresses.\n\n @param model The model representing the view that is being swiped\n @param itemView The view that is being swiped\n @param swipeProgress A float from -1 to 1 representing the percentage that the view has been\n swiped relative to its width. This will be positive if the view is being\n swiped to the right and negative if it is swiped to the left. For\n example,\n @param canvas The canvas on which RecyclerView is drawing its children. You can draw to\n this to support custom swipe animations.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onSwipeProgressChanged(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#SwipeCallbacks#onSwipeProgressChanged(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#[T] // ^^^^^ definition local 3 // documentation ```java\nT model\n``` @@ -97,6 +101,8 @@ void onSwipeProgressChanged(T model, View itemView, float swipeProgress, // ^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#onSwipeReleased(). // documentation ```java\npublic abstract void onSwipeReleased(T model, unresolved_type itemView)\n``` // documentation Called when the user has released their touch on the view. If the displacement passed the swipe\n threshold then {@link #onSwipeCompleted(EpoxyModel, View, int, int)} will be called after this\n and the view will be animated off screen. Otherwise the view will animate back to its original\n position.\n\n @param model The model representing the view that was being swiped\n @param itemView The view that was being swiped\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onSwipeReleased(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#SwipeCallbacks#onSwipeReleased(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#[T] // ^^^^^ definition local 7 // documentation ```java\nT model\n``` @@ -125,6 +131,8 @@ void onSwipeProgressChanged(T model, View itemView, float swipeProgress, // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#onSwipeCompleted(). // documentation ```java\npublic abstract void onSwipeCompleted(T model, unresolved_type itemView, int position, int direction)\n``` // documentation Called after {@link #onSwipeReleased(EpoxyModel, View)} if the swipe surpassed the threshold to\n be considered a full swipe. The view will now be animated off screen.\n

\n You MUST use this callback to remove this item from your backing data and request a model\n update.\n

\n {@link #clearView(EpoxyModel, View)} will be called after this.\n\n @param model The model representing the view that was being swiped\n @param itemView The view that was being swiped\n @param position The adapter position of the model\n @param direction The direction that the view was swiped. Can be any of {@link\n ItemTouchHelper#LEFT}, {@link ItemTouchHelper#RIGHT}, {@link\n ItemTouchHelper#UP}, {@link ItemTouchHelper#DOWN} depending on what swipe\n directions were enabled.\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onSwipeCompleted(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyTouchHelper#SwipeCallbacks#onSwipeCompleted(). // ^ reference semanticdb maven . . com/airbnb/epoxy/EpoxySwipeCallback#[T] // ^^^^^ definition local 9 // documentation ```java\nT model\n``` diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyTouchHelperCallback.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyTouchHelperCallback.java index 41e1a2fe..40121f3c 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyTouchHelperCallback.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/EpoxyTouchHelperCallback.java @@ -46,6 +46,7 @@ public abstract class EpoxyTouchHelperCallback extends ItemTouchHelper.Callback public final int getMovementFlags(RecyclerView recyclerView, ViewHolder viewHolder) { // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#getMovementFlags(). // documentation ```java\n@Override\npublic final int getMovementFlags(unresolved_type recyclerView, unresolved_type viewHolder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#getMovementFlags(). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 0 // documentation ```java\nunresolved_type recyclerView\n``` @@ -66,6 +67,7 @@ public final int getMovementFlags(RecyclerView recyclerView, ViewHolder viewHold // ^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#getMovementFlags(+1). // documentation ```java\nprotected abstract int getMovementFlags(unresolved_type recyclerView, EpoxyViewHolder viewHolder)\n``` // documentation @see #getMovementFlags(RecyclerView, ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#getMovementFlags(). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 2 // documentation ```java\nunresolved_type recyclerView\n``` @@ -78,6 +80,7 @@ public final int getMovementFlags(RecyclerView recyclerView, ViewHolder viewHold public final boolean onMove(RecyclerView recyclerView, ViewHolder viewHolder, ViewHolder target) { // ^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#onMove(). // documentation ```java\n@Override\npublic final boolean onMove(unresolved_type recyclerView, unresolved_type viewHolder, unresolved_type target)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onMove(). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 4 // documentation ```java\nunresolved_type recyclerView\n``` @@ -103,6 +106,7 @@ protected abstract boolean onMove(RecyclerView recyclerView, EpoxyViewHolder vie // ^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#onMove(+1). // documentation ```java\nprotected abstract boolean onMove(unresolved_type recyclerView, EpoxyViewHolder viewHolder, EpoxyViewHolder target)\n``` // documentation @see #onMove(RecyclerView, ViewHolder, ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onMove(). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 7 // documentation ```java\nunresolved_type recyclerView\n``` @@ -119,6 +123,7 @@ protected abstract boolean onMove(RecyclerView recyclerView, EpoxyViewHolder vie public final void onSwiped(ViewHolder viewHolder, int direction) { // ^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#onSwiped(). // documentation ```java\n@Override\npublic final void onSwiped(unresolved_type viewHolder, int direction)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onSwiped(). // ^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^ definition local 10 // documentation ```java\nunresolved_type viewHolder\n``` @@ -149,6 +154,7 @@ public final void onSwiped(ViewHolder viewHolder, int direction) { public final boolean canDropOver(RecyclerView recyclerView, ViewHolder current, // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#canDropOver(). // documentation ```java\n@Override\npublic final boolean canDropOver(unresolved_type recyclerView, unresolved_type current, unresolved_type target)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#canDropOver(). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 14 // documentation ```java\nunresolved_type recyclerView\n``` @@ -175,6 +181,7 @@ protected boolean canDropOver(RecyclerView recyclerView, EpoxyViewHolder current // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#canDropOver(+1). // documentation ```java\nprotected boolean canDropOver(unresolved_type recyclerView, EpoxyViewHolder current, EpoxyViewHolder target)\n``` // documentation @see #canDropOver(RecyclerView, ViewHolder, ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#canDropOver(). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 17 // documentation ```java\nunresolved_type recyclerView\n``` @@ -321,6 +328,7 @@ protected EpoxyViewHolder chooseDropTarget(EpoxyViewHolder selected, public final void onSelectedChanged(ViewHolder viewHolder, int actionState) { // ^^^^^^^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#onSelectedChanged(). // documentation ```java\n@Override\npublic final void onSelectedChanged(unresolved_type viewHolder, int actionState)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onSelectedChanged(). // ^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^ definition local 32 // documentation ```java\nunresolved_type viewHolder\n``` @@ -432,6 +440,8 @@ protected void onMoved(RecyclerView recyclerView, EpoxyViewHolder viewHolder, in public final void clearView(RecyclerView recyclerView, ViewHolder viewHolder) { // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#clearView(). // documentation ```java\n@Override\npublic final void clearView(unresolved_type recyclerView, unresolved_type viewHolder)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#clearView(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#clearView(+1). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 50 // documentation ```java\nunresolved_type recyclerView\n``` @@ -452,6 +462,8 @@ protected void clearView(RecyclerView recyclerView, EpoxyViewHolder viewHolder) // ^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#clearView(+1). // documentation ```java\nprotected void clearView(unresolved_type recyclerView, EpoxyViewHolder viewHolder)\n``` // documentation @see #clearView(RecyclerView, ViewHolder)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#clearView(). +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#clearView(+1). // ^^^^^^^^^^^^ reference semanticdb maven . . _root_/ // ^^^^^^^^^^^^ definition local 52 // documentation ```java\nunresolved_type recyclerView\n``` @@ -470,6 +482,7 @@ protected void clearView(RecyclerView recyclerView, EpoxyViewHolder viewHolder) public final void onChildDraw(Canvas c, RecyclerView recyclerView, ViewHolder viewHolder, // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#onChildDraw(). // documentation ```java\n@Override\npublic final void onChildDraw(unresolved_type c, unresolved_type recyclerView, unresolved_type viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onChildDraw(). // ^^^^^^ reference semanticdb maven . . _root_/ // ^ definition local 54 // documentation ```java\nunresolved_type c\n``` @@ -510,6 +523,7 @@ protected void onChildDraw(Canvas c, RecyclerView recyclerView, EpoxyViewHolder // ^^^^^^^^^^^ definition semanticdb maven . . com/airbnb/epoxy/EpoxyTouchHelperCallback#onChildDraw(+1). // documentation ```java\nprotected void onChildDraw(unresolved_type c, unresolved_type recyclerView, EpoxyViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive)\n``` // documentation @see #onChildDraw(Canvas, RecyclerView, ViewHolder, float, float, int, boolean)\n +// relationship is_reference is_implementation com/airbnb/epoxy/EpoxyModelTouchCallback#onChildDraw(). // ^^^^^^ reference semanticdb maven . . _root_/ // ^ definition local 61 // documentation ```java\nunresolved_type c\n``` diff --git a/tests/snapshots/src/main/generated/com/airbnb/epoxy/Timer.java b/tests/snapshots/src/main/generated/com/airbnb/epoxy/Timer.java index bdcb7503..473821e0 100644 --- a/tests/snapshots/src/main/generated/com/airbnb/epoxy/Timer.java +++ b/tests/snapshots/src/main/generated/com/airbnb/epoxy/Timer.java @@ -6,10 +6,14 @@ interface Timer { void start(String sectionName); // ^^^^^ definition semanticdb maven . . com/airbnb/epoxy/Timer#start(). // documentation ```java\npublic abstract void start(String sectionName)\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/DebugTimer#start(). +// relationship is_reference is_implementation com/airbnb/epoxy/NoOpTimer#start(). // ^^^^^^ reference semanticdb maven jdk 11 java/lang/String# // ^^^^^^^^^^^ definition local 0 // documentation ```java\nString sectionName\n``` void stop(); // ^^^^ definition semanticdb maven . . com/airbnb/epoxy/Timer#stop(). // documentation ```java\npublic abstract void stop()\n``` +// relationship is_reference is_implementation com/airbnb/epoxy/DebugTimer#stop(). +// relationship is_reference is_implementation com/airbnb/epoxy/NoOpTimer#stop(). } diff --git a/tests/snapshots/src/main/generated/tests/minimized-scala/src/main/scala/minimized/Issue413.scala b/tests/snapshots/src/main/generated/tests/minimized-scala/src/main/scala/minimized/Issue413.scala index 84fca9f3..2352107f 100644 --- a/tests/snapshots/src/main/generated/tests/minimized-scala/src/main/scala/minimized/Issue413.scala +++ b/tests/snapshots/src/main/generated/tests/minimized-scala/src/main/scala/minimized/Issue413.scala @@ -7,10 +7,12 @@ trait Issue413 { val b: Int // ^ definition semanticdb maven . . minimized/Issue413#b. // documentation ```scala\nval b: Int\n``` +// relationship is_reference is_implementation minimized/Issue413Subclass#b. // ^^^ reference semanticdb maven . . scala/Int# val c: Int // ^ definition semanticdb maven . . minimized/Issue413#c. // documentation ```scala\nval c: Int\n``` +// relationship is_reference is_implementation minimized/Issue413Subclass#c. // ^^^ reference semanticdb maven . . scala/Int# } object Issue413 { diff --git a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/AbstractClasses.java b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/AbstractClasses.java index 25e5410d..1d2a12a1 100644 --- a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/AbstractClasses.java +++ b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/AbstractClasses.java @@ -16,4 +16,5 @@ public String defaultImplementation() { // ^^^^^^ reference semanticdb maven jdk 11 java/lang/String# // ^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . minimized/AbstractClasses#abstractImplementation(). // documentation ```java\npublic abstract String abstractImplementation()\n``` +// relationship is_reference is_implementation minimized/SubClasses#abstractImplementation(). } diff --git a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/InnerClasses.java b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/InnerClasses.java index 71ca702b..3d89def4 100644 --- a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/InnerClasses.java +++ b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/InnerClasses.java @@ -60,6 +60,7 @@ public interface InnerInterface { // ^ reference semanticdb maven . . minimized/InnerClasses#InnerInterface#[B] // ^^^^^ definition semanticdb maven . . minimized/InnerClasses#InnerInterface#apply(). // documentation ```java\npublic abstract B apply(A a)\n``` +// relationship is_reference is_implementation minimized/InnerClasses#InnerClass#apply(). // ^ reference semanticdb maven . . minimized/InnerClasses#InnerInterface#[A] // ^ definition local 1 // documentation ```java\nA a\n``` diff --git a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/Interfaces.java b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/Interfaces.java index ceae3fe7..fc37a282 100644 --- a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/Interfaces.java +++ b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/Interfaces.java @@ -11,6 +11,7 @@ static void staticInterfaceMethod() {} //^^^^^^ reference semanticdb maven jdk 11 java/lang/String# // ^^^^^^^^^^^^^^^^^^^^^^^ definition semanticdb maven . . minimized/Interfaces#abstractInterfaceMethod(). // documentation ```java\npublic abstract String abstractInterfaceMethod()\n``` +// relationship is_reference is_implementation minimized/SubClasses#abstractInterfaceMethod(). default String defaultInterfaceMethod() { // ^^^^^^ reference semanticdb maven jdk 11 java/lang/String# diff --git a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/TypeVariables.java b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/TypeVariables.java index 7723fb9d..076476e5 100644 --- a/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/TypeVariables.java +++ b/tests/snapshots/src/main/generated/tests/minimized/src/main/java/minimized/TypeVariables.java @@ -31,6 +31,7 @@ interface I { void mI(); // ^^ definition semanticdb maven . . minimized/TypeVariables#I#mI(). // documentation ```java\npublic abstract void mI()\n``` +// relationship is_reference is_implementation minimized/TypeVariables#CT#mI(). } static class CT extends C implements I { diff --git a/tests/snapshots/src/main/generated/ujson/IndexedValue.scala b/tests/snapshots/src/main/generated/ujson/IndexedValue.scala index fd8ad3d4..ca62f3b0 100644 --- a/tests/snapshots/src/main/generated/ujson/IndexedValue.scala +++ b/tests/snapshots/src/main/generated/ujson/IndexedValue.scala @@ -34,6 +34,14 @@ sealed trait IndexedValue { def index: Int // ^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/IndexedValue#index(). // documentation ```scala\ndef index: Int\n``` +// relationship is_reference is_implementation ujson/IndexedValue.Arr#index. +// relationship is_reference is_implementation ujson/IndexedValue.False#index. +// relationship is_reference is_implementation ujson/IndexedValue.Null#index. +// relationship is_reference is_implementation ujson/IndexedValue.Num#index. +// relationship is_reference is_implementation ujson/IndexedValue.NumRaw#index. +// relationship is_reference is_implementation ujson/IndexedValue.Obj#index. +// relationship is_reference is_implementation ujson/IndexedValue.Str#index. +// relationship is_reference is_implementation ujson/IndexedValue.True#index. // ^^^ reference semanticdb maven maven/org.scala-lang/scala-library 2.13.10 scala/Int# } diff --git a/tests/snapshots/src/main/generated/ujson/JsVisitor.scala b/tests/snapshots/src/main/generated/ujson/JsVisitor.scala index 502a052a..b98d92ce 100644 --- a/tests/snapshots/src/main/generated/ujson/JsVisitor.scala +++ b/tests/snapshots/src/main/generated/ujson/JsVisitor.scala @@ -27,6 +27,10 @@ trait JsVisitor[-T, +J] extends Visitor[T, J]{ // ^^^^^^^^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/JsVisitor#visitFloat64(). // documentation ```scala\ndef visitFloat64(d: Double, index: Int): J\n``` // relationship is_reference is_implementation semanticdb maven maven/com.lihaoyi/upickle-core_2.13 1.4.0 upickle/core/Visitor#visitFloat64(). +// relationship is_reference is_implementation ujson/BaseByteRenderer#visitFloat64(). +// relationship is_reference is_implementation ujson/BaseCharRenderer#visitFloat64(). +// relationship is_reference is_implementation ujson/IndexedValue.Builder.visitFloat64(). +// relationship is_reference is_implementation ujson/Value.visitFloat64(). // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/JsVisitor#visitFloat64().(d) // documentation ```scala\nd: Double \n``` // ^^^^^^ reference semanticdb maven maven/org.scala-lang/scala-library 2.13.10 scala/Double# diff --git a/tests/snapshots/src/main/generated/ujson/Readable.scala b/tests/snapshots/src/main/generated/ujson/Readable.scala index 51b98064..ef46315d 100644 --- a/tests/snapshots/src/main/generated/ujson/Readable.scala +++ b/tests/snapshots/src/main/generated/ujson/Readable.scala @@ -22,6 +22,8 @@ trait Readable { def transform[T](f: Visitor[_, T]): T // ^^^^^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Readable#transform(). // documentation ```scala\ndef transform(f: Visitor[local0, T[): T\n``` +// relationship is_reference is_implementation ujson/Readable.fromTransformer#transform(). +// relationship is_reference is_implementation ujson/Value#transform(). // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Readable#transform().[T] // documentation ```scala\nT\n``` // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Readable#transform().(f) diff --git a/tests/snapshots/src/main/generated/ujson/Transformer.scala b/tests/snapshots/src/main/generated/ujson/Transformer.scala index e54e4d11..493971ec 100644 --- a/tests/snapshots/src/main/generated/ujson/Transformer.scala +++ b/tests/snapshots/src/main/generated/ujson/Transformer.scala @@ -14,6 +14,13 @@ trait Transformer[I] { def transform[T](j: I, f: Visitor[_, T]): T // ^^^^^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Transformer#transform(). // documentation ```scala\ndef transform(j: I, f: Visitor[local0, T[): T\n``` +// relationship is_reference is_implementation ujson/ByteArrayParser.transform(). +// relationship is_reference is_implementation ujson/ByteBufferParser.transform(). +// relationship is_reference is_implementation ujson/CharSequenceParser.transform(). +// relationship is_reference is_implementation ujson/IndexedValue.transform(). +// relationship is_reference is_implementation ujson/InputStreamParser.transform(). +// relationship is_reference is_implementation ujson/StringParser.transform(). +// relationship is_reference is_implementation ujson/Value.transform(). // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Transformer#transform().[T] // documentation ```scala\nT\n``` // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Transformer#transform().(j) diff --git a/tests/snapshots/src/main/generated/ujson/Value.scala b/tests/snapshots/src/main/generated/ujson/Value.scala index 58a588dc..ba52f9a1 100644 --- a/tests/snapshots/src/main/generated/ujson/Value.scala +++ b/tests/snapshots/src/main/generated/ujson/Value.scala @@ -43,6 +43,14 @@ sealed trait Value extends Readable with geny.Writable{ def value: Any // ^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value#value(). // documentation ```scala\ndef value: Any\n``` +// relationship is_reference is_implementation ujson/Arr#value. +// relationship is_reference is_implementation ujson/Bool#value(). +// relationship is_reference is_implementation ujson/False.value(). +// relationship is_reference is_implementation ujson/Null.value(). +// relationship is_reference is_implementation ujson/Num#value. +// relationship is_reference is_implementation ujson/Obj#value. +// relationship is_reference is_implementation ujson/Str#value. +// relationship is_reference is_implementation ujson/True.value(). // ^^^ reference semanticdb maven . . scala/Any# /** @@ -360,6 +368,8 @@ object Value extends AstTransformer[Value]{ def apply(x: Value): Value // ^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value.Selector#apply(). // documentation ```scala\ndef apply(x: Value): Value\n``` +// relationship is_reference is_implementation ujson/Value.Selector.IntSelector#apply(). +// relationship is_reference is_implementation ujson/Value.Selector.StringSelector#apply(). // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value.Selector#apply().(x) // documentation ```scala\nx: Value \n``` // ^^^^^ reference semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value.Value# @@ -367,6 +377,8 @@ object Value extends AstTransformer[Value]{ def update(x: Value, y: Value): Unit // ^^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value.Selector#update(). // documentation ```scala\ndef update(x: Value, y: Value): Unit\n``` +// relationship is_reference is_implementation ujson/Value.Selector.IntSelector#update(). +// relationship is_reference is_implementation ujson/Value.Selector.StringSelector#update(). // ^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value.Selector#update().(x) // documentation ```scala\nx: Value \n``` // ^^^^^ reference semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value.Value# @@ -1355,6 +1367,8 @@ sealed abstract class Bool extends Value{ // ^^^^^ definition semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Bool#value(). // documentation ```scala\ndef value: Boolean\n``` // relationship is_reference is_implementation semanticdb maven maven/com.lihaoyi/ujson_2.13 1.4.0 ujson/Value#value(). +// relationship is_reference is_implementation ujson/False.value(). +// relationship is_reference is_implementation ujson/True.value(). // ^^^^^^^ reference semanticdb maven maven/org.scala-lang/scala-library 2.13.10 scala/Boolean# } object Bool{ From ef1e175a9fc95881f6ee4d3c82d8480c1813ee1f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=93lafur=20P=C3=A1ll=20Geirsson?= Date: Mon, 1 May 2023 08:56:39 +0200 Subject: [PATCH 2/2] Reformat --- .../java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java index 548f5473..680b0ede 100644 --- a/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java +++ b/scip-semanticdb/src/main/java/com/sourcegraph/scip_semanticdb/ScipSemanticdb.java @@ -270,7 +270,7 @@ private InverseReferenceRelationships(Map> map) { private InverseReferenceRelationships inverseReferenceRelationships(List files) { if (!options.emitInverseRelationships) { - return new InverseReferenceRelationships(Collections.emptyMap()); + return new InverseReferenceRelationships(Collections.emptyMap()); } return new InverseReferenceRelationships( filesStream(files)