From a00740b0eb45f99c631ffce47688e7698dc7c62f Mon Sep 17 00:00:00 2001 From: ice1000 Date: Tue, 21 Nov 2023 00:37:19 -0500 Subject: [PATCH 1/7] doc: undo flattening --- pretty/src/main/java/org/aya/pretty/doc/Doc.java | 15 ++------------- 1 file changed, 2 insertions(+), 13 deletions(-) diff --git a/pretty/src/main/java/org/aya/pretty/doc/Doc.java b/pretty/src/main/java/org/aya/pretty/doc/Doc.java index 215cccbc5e..d8a1cce911 100644 --- a/pretty/src/main/java/org/aya/pretty/doc/Doc.java +++ b/pretty/src/main/java/org/aya/pretty/doc/Doc.java @@ -47,10 +47,6 @@ default boolean isEmpty() { @Override default @NotNull Doc toDoc() { return this; } - /** @return a seq with cats flattened */ - default @NotNull SeqLike asSeq() { - return Seq.of(this); - } //region Doc APIs default @NotNull String renderToString(@NotNull StringPrinterConfig config) { @@ -127,11 +123,7 @@ default boolean isEmpty() { /** The empty document; conceptually the unit of 'Cat' */ enum Empty implements Doc { - INSTANCE; - - @Override public @NotNull SeqLike asSeq() { - return Seq.empty(); - } + INSTANCE } /** @@ -215,9 +207,6 @@ record FlatAlt(@NotNull Doc defaultDoc, @NotNull Doc preferWhenFlatten) implemen * Concatenation of two documents */ record Cat(@NotNull ImmutableSeq inner) implements Doc { - @Override public @NotNull SeqLike asSeq() { - return inner.view().flatMap(Doc::asSeq); - } } record List(boolean isOrdered, @NotNull ImmutableSeq items) implements Doc { @@ -796,6 +785,6 @@ record PageWidth(@NotNull IntFunction docBuilder) implements Doc { //endregion private static @NotNull Doc simpleCat(@NotNull SeqLike<@NotNull Doc> xs) { - return new Cat(xs.view().flatMap(Doc::asSeq).toImmutableArray()); + return new Cat(xs.toImmutableSeq()); } } From 34012c2b9027d7a4e783fb937d25f9255fad67be Mon Sep 17 00:00:00 2001 From: ice1000 Date: Tue, 21 Nov 2023 23:45:39 -0500 Subject: [PATCH 2/7] html: update js to the one from Agda --- .../main/resources/aya-html/highlight-fn.js | 55 ++++++++++++------- .../aya-html/highlight-occurrences.js | 2 +- 2 files changed, 35 insertions(+), 22 deletions(-) diff --git a/pretty/src/main/resources/aya-html/highlight-fn.js b/pretty/src/main/resources/aya-html/highlight-fn.js index fa90c21779..5835b265d4 100644 --- a/pretty/src/main/resources/aya-html/highlight-fn.js +++ b/pretty/src/main/resources/aya-html/highlight-fn.js @@ -1,26 +1,39 @@ -/* - * Copyright (c) 2020-2023 Tesla (Yinsen) Zhang. - * Use of this source code is governed by the MIT license that can be found in the LICENSE.md file. - */ +// Copyright 2023, Andreas Abel. +// Falls under the Agda license at https://github.com/agda/agda/blob/master/LICENSE -function highlight(on) { - return function () { - let links = document.getElementsByTagName('a'); - for (let i = 0; i < links.length; i++) { - let that = links[i]; - if (this.href !== that.href) continue; - if (on) that.classList.add("hover-highlight"); - else that.classList.remove("hover-highlight"); - } +// When we hover over an Agda identifier, we highlight all occurrences of this identifier on the page. +// To this end, we create a map from identifier to all of its occurrences in the beginning. + +// A dictionary from hrefs to 'a'-elements that have this href. +const dict = new Map(); + +function highlightFn() { + // Get all 'a' tags with an 'href' attribute. + // We call those "objects". + const objs = document.querySelectorAll('a[href]'); + + // Build a dictionary mapping a href to a set of objects that have this href. + for (const obj of objs) { + const key = obj.href; + const set = dict.get(key) ?? new Set(); + set.add(obj); + dict.set(key, set); } -} -function setupHighlight(dom) { - let links = dom.getElementsByTagName('a'); - for (let i = 0; i < links.length; i++) { - let link = links[i]; - if (!link.hasAttribute("href")) continue; - link.onmouseover = highlight(true); - link.onmouseout = highlight(false); + // Install 'onmouseover' and 'onmouseout' event handlers for all objects. + for (const obj of objs) { + // 'onmouseover' for an object adds attribute 'hover-highlight' to all objects with the same href. + obj.onmouseover = function () { + for (const o of dict.get(this.href)) { + o.classList.add('hover-highlight'); + } + } + // 'onmouseover' removes the added 'hover-highlight' attributes again. + obj.onmouseout = function () { + for (const o of dict.get(this.href)) { + o.classList.remove('hover-highlight'); + } + } } } + diff --git a/pretty/src/main/resources/aya-html/highlight-occurrences.js b/pretty/src/main/resources/aya-html/highlight-occurrences.js index adba033ee0..1bd0700edd 100644 --- a/pretty/src/main/resources/aya-html/highlight-occurrences.js +++ b/pretty/src/main/resources/aya-html/highlight-occurrences.js @@ -3,4 +3,4 @@ * Use of this source code is governed by the MIT license that can be found in the LICENSE.md file. */ -setupHighlight(document); +highlightFn(); From 6d5ab5239bafe781e74dac6c4100cee0dfcc09f6 Mon Sep 17 00:00:00 2001 From: ice1000 Date: Thu, 23 Nov 2023 13:50:22 -0500 Subject: [PATCH 3/7] misc: fix deprecations --- base/src/test/java/org/aya/experiments/NormalizeHugeChurch.java | 2 +- base/src/test/java/org/aya/literate/HighlighterTester.java | 2 +- base/src/test/java/org/aya/repr/ShapeMatcherTest.java | 2 +- base/src/test/java/org/aya/tyck/PatCCTest.java | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/base/src/test/java/org/aya/experiments/NormalizeHugeChurch.java b/base/src/test/java/org/aya/experiments/NormalizeHugeChurch.java index 7a696ccc80..55b654735e 100644 --- a/base/src/test/java/org/aya/experiments/NormalizeHugeChurch.java +++ b/base/src/test/java/org/aya/experiments/NormalizeHugeChurch.java @@ -31,7 +31,7 @@ def mul (a b : Num) : Num => \\A f x => a A (b A f) x """); var state = new TyckState(res.component1()); var decls = res.component2(); - var last = ((FnDef) decls.last()).body.getLeftValue(); + var last = ((FnDef) decls.getLast()).body.getLeftValue(); println("Tyck: " + (System.currentTimeMillis() - startup)); startup = System.currentTimeMillis(); var nf = last.normalize(state, NormalizeMode.NF); diff --git a/base/src/test/java/org/aya/literate/HighlighterTester.java b/base/src/test/java/org/aya/literate/HighlighterTester.java index 76d12f3e5f..42a5b56d21 100644 --- a/base/src/test/java/org/aya/literate/HighlighterTester.java +++ b/base/src/test/java/org/aya/literate/HighlighterTester.java @@ -91,7 +91,7 @@ public HighlighterTester(@NotNull String sourceCode, @NotNull ImmutableSeq match(@NotNull ImmutableSeq> shouldBe, @Language("Aya") @NonNls @NotNull String code) { diff --git a/base/src/test/java/org/aya/tyck/PatCCTest.java b/base/src/test/java/org/aya/tyck/PatCCTest.java index 07439e7d96..983d2941f7 100644 --- a/base/src/test/java/org/aya/tyck/PatCCTest.java +++ b/base/src/test/java/org/aya/tyck/PatCCTest.java @@ -63,7 +63,7 @@ def nm (e : CExp) (nmAcc e) : CExp nm (if u (nm (if v y z) h1) (nm (if w y z) h2)) h3 """); var decls = res.component2(); - var classified = testClassify(res.component1(), (FnDef) decls.last()); + var classified = testClassify(res.component1(), (FnDef) decls.getLast()); assertEquals(3, classified.size()); classified.forEach(cls -> assertEquals(1, cls.cls().size())); From 6be83e9693c52d1d4e4b8da1a57d33b99fd16872 Mon Sep 17 00:00:00 2001 From: ice1000 Date: Thu, 23 Nov 2023 13:58:23 -0500 Subject: [PATCH 4/7] misc: more fixes ig? --- base/src/test/java/org/aya/concrete/ParseTest.java | 7 +++---- pretty/src/main/java/org/aya/pretty/error/PrettyError.java | 2 +- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/base/src/test/java/org/aya/concrete/ParseTest.java b/base/src/test/java/org/aya/concrete/ParseTest.java index cb7d3d495f..35b7e1bc56 100644 --- a/base/src/test/java/org/aya/concrete/ParseTest.java +++ b/base/src/test/java/org/aya/concrete/ParseTest.java @@ -24,8 +24,7 @@ import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; -import static org.junit.jupiter.api.Assertions.assertEquals; -import static org.junit.jupiter.api.Assertions.assertTrue; +import static org.junit.jupiter.api.Assertions.*; @SuppressWarnings("UnknownLanguage") public class ParseTest { @@ -176,7 +175,7 @@ private void parseImport(@Language("Aya") String code) { } private void parseOpen(@Language("Aya") String code) { - assertTrue(parseStmt(code).last() instanceof Command.Open s && !s.toDoc(AyaPrettierOptions.debug()).debugRender().isEmpty()); + assertTrue(parseStmt(code).getLast() instanceof Command.Open s && !s.toDoc(AyaPrettierOptions.debug()).debugRender().isEmpty()); } private void parseFn(@Language("Aya") String code) { @@ -184,7 +183,7 @@ private void parseFn(@Language("Aya") String code) { } private void parseData(@Language("Aya") String code) { - assertTrue(parseDecl(code).getFirst() instanceof TeleDecl.DataDecl); + assertInstanceOf(TeleDecl.DataDecl.class, parseDecl(code).getFirst()); } @Test diff --git a/pretty/src/main/java/org/aya/pretty/error/PrettyError.java b/pretty/src/main/java/org/aya/pretty/error/PrettyError.java index f9e4d3bf19..674d7ba724 100644 --- a/pretty/src/main/java/org/aya/pretty/error/PrettyError.java +++ b/pretty/src/main/java/org/aya/pretty/error/PrettyError.java @@ -121,7 +121,7 @@ void add(int currentLine, @NotNull Doc code) { } void add(@NotNull Doc code) { - lineDocs.append(Doc.plain(" ")); // cannot use `empty()` or `plain("")` + lineDocs.append(Doc.ONE_WS); // cannot use `empty()` or `plain("")` codeDocs.append(code); } } From 55103130cdfd4fe8ce81d1ed7c8a02ab06171d3d Mon Sep 17 00:00:00 2001 From: ice1000 Date: Sun, 26 Nov 2023 14:27:51 -0500 Subject: [PATCH 5/7] js: fix @imkiva's reviews --- pretty/src/main/resources/aya-html/highlight-fn.js | 10 ++++++---- .../main/resources/aya-html/highlight-occurrences.js | 2 +- pretty/src/main/resources/aya-html/show-tooltip-fn.js | 2 +- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/pretty/src/main/resources/aya-html/highlight-fn.js b/pretty/src/main/resources/aya-html/highlight-fn.js index 5835b265d4..c0fbc3c025 100644 --- a/pretty/src/main/resources/aya-html/highlight-fn.js +++ b/pretty/src/main/resources/aya-html/highlight-fn.js @@ -1,5 +1,7 @@ -// Copyright 2023, Andreas Abel. -// Falls under the Agda license at https://github.com/agda/agda/blob/master/LICENSE +/* + * Copyright (c) 2020-2023 Tesla (Yinsen) Zhang. + * Use of this source code is governed by the MIT license that can be found in the LICENSE.md file. + */ // When we hover over an Agda identifier, we highlight all occurrences of this identifier on the page. // To this end, we create a map from identifier to all of its occurrences in the beginning. @@ -7,10 +9,10 @@ // A dictionary from hrefs to 'a'-elements that have this href. const dict = new Map(); -function highlightFn() { +function highlightFn(root) { // Get all 'a' tags with an 'href' attribute. // We call those "objects". - const objs = document.querySelectorAll('a[href]'); + const objs = root.querySelectorAll('a[href]'); // Build a dictionary mapping a href to a set of objects that have this href. for (const obj of objs) { diff --git a/pretty/src/main/resources/aya-html/highlight-occurrences.js b/pretty/src/main/resources/aya-html/highlight-occurrences.js index 1bd0700edd..3f2e182e28 100644 --- a/pretty/src/main/resources/aya-html/highlight-occurrences.js +++ b/pretty/src/main/resources/aya-html/highlight-occurrences.js @@ -3,4 +3,4 @@ * Use of this source code is governed by the MIT license that can be found in the LICENSE.md file. */ -highlightFn(); +highlightFn(document); diff --git a/pretty/src/main/resources/aya-html/show-tooltip-fn.js b/pretty/src/main/resources/aya-html/show-tooltip-fn.js index 1d93ecf9a2..fa62b7938f 100644 --- a/pretty/src/main/resources/aya-html/show-tooltip-fn.js +++ b/pretty/src/main/resources/aya-html/show-tooltip-fn.js @@ -110,7 +110,7 @@ class HoverStack { newHover.classList.add("AyaTooltipPopup"); // Hover to highlight occurrences is done by adding mouse event listeners to the elements in the tooltip. // The inserted tooltip is not a child of `document` when the page was loaded, so a manual setup is needed. - setupHighlight(newHover); + highlightFn(newHover); // Auto-dismissal setup let self = this; From 374917b7a535701a99c8d78984cfc18be0740c4d Mon Sep 17 00:00:00 2001 From: ice1000 Date: Sun, 26 Nov 2023 14:29:03 -0500 Subject: [PATCH 6/7] doc: yml -> yaml Co-authored-by: skylee03 --- .github/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/README.md b/.github/README.md index a6b333fdda..2eb427a93e 100644 --- a/.github/README.md +++ b/.github/README.md @@ -1,4 +1,4 @@ -[![actions]](https://github.com/aya-prover/aya-dev/actions/workflows/gradle-check.yml) +[![actions]](https://github.com/aya-prover/aya-dev/actions/workflows/gradle-check.yaml) [![maven]][maven-repo] [![gitter]](https://gitter.im/aya-prover/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) [![codecov]](https://codecov.io/gh/aya-prover/aya-dev) @@ -66,7 +66,7 @@ of IDE is IntelliJ IDEA, version 2023.2 or higher is required. We value your time and enthusiasm, so we don't want to close your PRs :) [@ice1000]: https://github.com/ice1000 -[actions]: https://github.com/aya-prover/aya-dev/actions/workflows/gradle-check.yml/badge.svg +[actions]: https://github.com/aya-prover/aya-dev/actions/workflows/gradle-check.yaml/badge.svg [codecov]: https://img.shields.io/codecov/c/github/aya-prover/aya-dev?logo=codecov&logoColor=white [gitter]: https://img.shields.io/gitter/room/aya-prover/community?color=cyan&logo=gitter [maven]: https://img.shields.io/maven-central/v/org.aya-prover/base?logo=gradle From 126d410eaec3857ec736f3e6b000aad7ad4c282c Mon Sep 17 00:00:00 2001 From: ice1000 Date: Mon, 27 Nov 2023 11:44:01 -0500 Subject: [PATCH 7/7] doc: smol cat --- pretty/src/main/java/org/aya/pretty/doc/Doc.java | 5 ++++- pretty/src/main/java/org/aya/pretty/error/PrettyError.java | 2 +- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/pretty/src/main/java/org/aya/pretty/doc/Doc.java b/pretty/src/main/java/org/aya/pretty/doc/Doc.java index d8a1cce911..1a3bec45e7 100644 --- a/pretty/src/main/java/org/aya/pretty/doc/Doc.java +++ b/pretty/src/main/java/org/aya/pretty/doc/Doc.java @@ -785,6 +785,9 @@ record PageWidth(@NotNull IntFunction docBuilder) implements Doc { //endregion private static @NotNull Doc simpleCat(@NotNull SeqLike<@NotNull Doc> xs) { - return new Cat(xs.toImmutableSeq()); + var seq = xs.toImmutableSeq(); + if (seq.isEmpty()) return empty(); + if (seq.sizeEquals(1)) return seq.getFirst(); + return new Cat(seq); } } diff --git a/pretty/src/main/java/org/aya/pretty/error/PrettyError.java b/pretty/src/main/java/org/aya/pretty/error/PrettyError.java index 674d7ba724..52c62b0faf 100644 --- a/pretty/src/main/java/org/aya/pretty/error/PrettyError.java +++ b/pretty/src/main/java/org/aya/pretty/error/PrettyError.java @@ -260,7 +260,7 @@ private void renderHints( .skip(Math.max(startLine - 1 - showMore, 0)) .limit(endLine - startLine + 1 + showMore) .map(line -> visualizeLine(config, line)) - .collect(MutableList.factory()); + .toList(); final int minLineNo = Math.max(startLine - showMore, 1); final int maxLineNo = minLineNo + lines.size();