Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Class resolver #1134

Open
wants to merge 5 commits into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
90 changes: 90 additions & 0 deletions base/src/main/java/org/aya/tyck/ClassResolver.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
// Copyright (c) 2020-2025 Tesla (Yinsen) Zhang.
// Use of this source code is governed by the MIT license that can be found in the LICENSE.md file.
package org.aya.tyck;

import kala.collection.immutable.ImmutableMap;
import kala.collection.immutable.ImmutableSeq;
import kala.collection.mutable.MutableList;
import kala.collection.mutable.MutableMap;
import org.aya.resolve.context.Candidate;
import org.aya.resolve.context.ModuleContext;
import org.aya.syntax.core.Jdg;
import org.aya.syntax.core.def.AnyDef;
import org.aya.syntax.core.def.ClassDefLike;
import org.aya.syntax.core.def.MemberDefLike;
import org.aya.syntax.core.term.call.ClassCall;
import org.aya.syntax.ref.AnyDefVar;
import org.aya.syntax.ref.AnyVar;
import org.aya.syntax.ref.LocalCtx;
import org.aya.syntax.ref.LocalVar;
import org.aya.tyck.tycker.Stateful;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

public final class ClassResolver {
/**
* The module context we are in, it is considered immutable during the lifetime of this resolver.
*/
public final @NotNull ModuleContext env;
public @Nullable ImmutableMap<ClassDefLike, ImmutableSeq<AnyDefVar>> envCache;

public ClassResolver(@NotNull ModuleContext env) {
this.env = env;
}

Check warning on line 33 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L31-L33

Added lines #L31 - L33 were not covered by tests

public @NotNull ImmutableMap<ClassDefLike, ImmutableSeq<AnyDefVar>> getEnvClassInstance() {
if (envCache != null) return envCache;
var result = env.symbols().table()
.valuesView()
.flatMap(Candidate::getAll)
.filterIsInstance(AnyDefVar.class);

Check warning on line 40 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L37-L40

Added lines #L37 - L40 were not covered by tests

var builder = MutableMap.<ClassDefLike, ImmutableSeq<AnyDefVar>>create();
throw new UnsupportedOperationException("TODO");

Check warning on line 43 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L42-L43

Added lines #L42 - L43 were not covered by tests

// TODO: we cannot use the instance that is defined in the same file,
// cause they are tycked in the same cycle, which might:
// * Add unexpected dependencies
// * May not have core

// return envCache;
}

public void resolve(
@NotNull MemberDefLike field,
@NotNull ImmutableSeq<Jdg> args,
@NotNull LocalCtx ctx,
@NotNull Stateful normalizerProvider
) {
var candies = findCandidates(field, ctx, normalizerProvider);
var matches = MutableList.<AnyVar>create();

Check warning on line 60 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L59-L60

Added lines #L59 - L60 were not covered by tests


}

Check warning on line 63 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L63

Added line #L63 was not covered by tests

/**
* Find the candidate for the invocation of {@code field args}
*
* @return the candidates, either {@link AnyDefVar} or {@link LocalVar}
*/
public @NotNull ImmutableSeq<AnyVar> findCandidates(
@NotNull MemberDefLike field,
@NotNull LocalCtx ctx,
@NotNull Stateful normalizerProvider
) {
var candies = MutableList.<AnyVar>create();

Check warning on line 75 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L75

Added line #L75 was not covered by tests
// find from localCtx
// can be improved by forEach and extractLocal (if there is)
ctx.extract().forEach(v -> {

Check warning on line 78 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L78

Added line #L78 was not covered by tests
if (normalizerProvider.whnf(ctx.get(v)) instanceof ClassCall call && field.classRef().equals(call.ref())) {
candies.append(AnyDef.toVar(call.ref()));

Check warning on line 80 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L80

Added line #L80 was not covered by tests
}
});

Check warning on line 82 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L82

Added line #L82 was not covered by tests

// find from environment
getEnvClassInstance().getOption(field.classRef())
.forEach(candies::appendAll);

Check warning on line 86 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L85-L86

Added lines #L85 - L86 were not covered by tests

return candies.toImmutableSeq();

Check warning on line 88 in base/src/main/java/org/aya/tyck/ClassResolver.java

View check run for this annotation

Codecov / codecov/patch

base/src/main/java/org/aya/tyck/ClassResolver.java#L88

Added line #L88 was not covered by tests
}
}
Loading