From bb1f36da71b30fa4e9b7dbef6d0aaa15571a1f39 Mon Sep 17 00:00:00 2001
From: Gavin Gray <20209337+gavinleroy@users.noreply.github.com>
Date: Thu, 12 Sep 2024 22:14:59 -0400
Subject: [PATCH] V0.1.13 (#37)
* Add high-contrast Shiki themes, disable Help Me panel
* Tree Wrappers at 20% opacity by default
* Note on bottom up view obligations
---
Cargo.lock | 8 +++---
book/src/trait-debugging-101.md | 4 +++
crates/argus-cli/Cargo.toml | 6 ++---
crates/argus-ext/Cargo.toml | 2 +-
crates/argus-ser/Cargo.toml | 4 +--
crates/argus/Cargo.toml | 8 +++---
ide/packages/extension/package.json | 2 +-
ide/packages/panoptes/src/Code.css | 25 ++++++++++++++++++-
ide/packages/panoptes/src/Code.tsx | 24 ++++++++++++------
.../panoptes/src/TreeView/TreeApp.tsx | 4 +--
.../panoptes/src/TreeView/Wrappers.css | 7 ++++--
11 files changed, 66 insertions(+), 28 deletions(-)
diff --git a/Cargo.lock b/Cargo.lock
index 35db49d..9517757 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -25,7 +25,7 @@ checksum = "080e9890a082662b09c1ad45f567faeeb47f22b5fb23895fbe1e651e718e25ca"
[[package]]
name = "argus-cli"
-version = "0.1.12"
+version = "0.1.13"
dependencies = [
"anyhow",
"argus-ext",
@@ -42,7 +42,7 @@ dependencies = [
[[package]]
name = "argus-ext"
-version = "0.1.12"
+version = "0.1.13"
dependencies = [
"anyhow",
"fluid-let",
@@ -55,7 +55,7 @@ dependencies = [
[[package]]
name = "argus-lib"
-version = "0.1.12"
+version = "0.1.13"
dependencies = [
"anyhow",
"argus-ext",
@@ -80,7 +80,7 @@ dependencies = [
[[package]]
name = "argus-ser"
-version = "0.1.12"
+version = "0.1.13"
dependencies = [
"anyhow",
"argus-ext",
diff --git a/book/src/trait-debugging-101.md b/book/src/trait-debugging-101.md
index 02936f0..3e3a513 100644
--- a/book/src/trait-debugging-101.md
+++ b/book/src/trait-debugging-101.md
@@ -155,6 +155,10 @@ Argus sorts the failing leaves in the Bottom-Up view by which are "most-likely"
The above demonstrates that Argus identifies `Res: IntoResponse` as a root cause of the overall failure in addition to the second failure: `LoginAttempt: FromRequestParts<_, _>`. The note icon in the Bottom-Up view indicates that the two failures must be resolved together if you want to us the function as a handler.
+It's always important to **read** and **understand** the failing obligation(s) that Argus presents first in the Bottom Up view. These errors are the *leaves* of the search tree, in other words, the *root cause* of the overall error; if you satisfy these bounds, then the root bound will also be satisfied.
+
+If additional failing bounds are present under "Other failures," you need to only resolve a single set of these failures. Argus shows you the set it believes was your intent, but as the developer with intent double check for yourself that it makes sense.
+
diff --git a/crates/argus-cli/Cargo.toml b/crates/argus-cli/Cargo.toml
index a5fad65..368a4b8 100644
--- a/crates/argus-cli/Cargo.toml
+++ b/crates/argus-cli/Cargo.toml
@@ -1,6 +1,6 @@
[package]
name = "argus-cli"
-version = "0.1.12"
+version = "0.1.13"
edition = "2021"
authors = ["Gavin Gray "]
repository = "https://github.com/cognitive-engineering-lab/argus"
@@ -10,8 +10,8 @@ license = "MIT"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
-argus-lib = { version = "0.1.12", path = "../argus" }
-argus-ext = { version = "0.1.12", path = "../argus-ext" }
+argus-lib = { version = "0.1.13", path = "../argus" }
+argus-ext = { version = "0.1.13", path = "../argus-ext" }
rustc_plugin = "=0.10.0-nightly-2024-05-20"
rustc_utils.workspace = true
diff --git a/crates/argus-ext/Cargo.toml b/crates/argus-ext/Cargo.toml
index bd2f422..bc694f0 100644
--- a/crates/argus-ext/Cargo.toml
+++ b/crates/argus-ext/Cargo.toml
@@ -1,6 +1,6 @@
[package]
name = "argus-ext"
-version = "0.1.12"
+version = "0.1.13"
edition = "2021"
authors = ["Gavin Gray "]
repository = "https://github.com/cognitive-engineering-lab/argus"
diff --git a/crates/argus-ser/Cargo.toml b/crates/argus-ser/Cargo.toml
index cfdda30..6311baf 100644
--- a/crates/argus-ser/Cargo.toml
+++ b/crates/argus-ser/Cargo.toml
@@ -1,6 +1,6 @@
[package]
name = "argus-ser"
-version = "0.1.12"
+version = "0.1.13"
edition = "2021"
authors = ["Gavin Gray "]
repository = "https://github.com/cognitive-engineering-lab/argus"
@@ -28,7 +28,7 @@ smallvec = "1.11.2"
itertools = "0.12.0"
ts-rs = { version = "7.1.1", features = ["indexmap-impl"], optional = true }
index_vec = { version = "0.1.3", features = ["serde"] }
-argus-ext = { version = "0.1.12", path = "../argus-ext" }
+argus-ext = { version = "0.1.13", path = "../argus-ext" }
[dev-dependencies]
argus-ser = { path = ".", features = ["testing"] }
diff --git a/crates/argus/Cargo.toml b/crates/argus/Cargo.toml
index 3c15564..aa92489 100644
--- a/crates/argus/Cargo.toml
+++ b/crates/argus/Cargo.toml
@@ -1,6 +1,6 @@
[package]
name = "argus-lib"
-version = "0.1.12"
+version = "0.1.13"
edition = "2021"
authors = ["Gavin Gray "]
repository = "https://github.com/cognitive-engineering-lab/argus"
@@ -21,8 +21,8 @@ fluid-let.workspace = true
serde.workspace = true
serde_json.workspace = true
-argus-ext = { version = "0.1.12", path = "../argus-ext" }
-argus-ser = { version = "0.1.12", path = "../argus-ser" }
+argus-ext = { version = "0.1.13", path = "../argus-ext" }
+argus-ser = { version = "0.1.13", path = "../argus-ser" }
index_vec = { version = "0.1.3", features = ["serde"] }
smallvec = "1.11.2"
itertools = "0.12.0"
@@ -35,7 +35,7 @@ ts-rs = { version = "7.1.1", features = ["indexmap-impl"], optional = true }
[dev-dependencies]
argus-lib = { path = ".", features = ["testing"] }
-argus-ser = { version = "0.1.12", path = "../argus-ser", features = ["testing"] }
+argus-ser = { version = "0.1.13", path = "../argus-ser", features = ["testing"] }
rustc_utils = { version = "=0.10.0-nightly-2024-05-20", features = ["serde", "ts-rs"] }
test-log = "0.2.11"
env_logger = "0.9.3"
diff --git a/ide/packages/extension/package.json b/ide/packages/extension/package.json
index f7872f7..34d7b52 100644
--- a/ide/packages/extension/package.json
+++ b/ide/packages/extension/package.json
@@ -5,7 +5,7 @@
"description": "A trait debugger for Rust",
"license": "MIT",
"icon": "argus-logo-128.png",
- "version": "0.1.12",
+ "version": "0.1.13",
"engines": {
"vscode": "^1.79.0"
},
diff --git a/ide/packages/panoptes/src/Code.css b/ide/packages/panoptes/src/Code.css
index 5632c63..5eb46d7 100644
--- a/ide/packages/panoptes/src/Code.css
+++ b/ide/packages/panoptes/src/Code.css
@@ -13,7 +13,30 @@ pre.shiki {
font-family: var(--vscode-editor-font-family);
}
+
/* Change the code colors based on VSCode exported body classes */
+/* Light is the default, we need to catch dark and high-contrast themes. */
+
+body.vscode-high-contrast .shiki,
+body.vscode-high-contrast .shiki span {
+ color: var(--shiki-contrast-dark) !important;
+ background-color: transparent !important;
+ /* Optional, if you also want font styles */
+ font-style: var(--shiki-contrast-dark-font-style) !important;
+ font-weight: var(--shiki-contrast-dark-font-weight) !important;
+ text-decoration: var(--shiki-contrast-dark-text-decoration) !important;
+}
+
+body.vscode-high-contrast-light .shiki,
+body.vscode-high-contrast-light .shiki span {
+ color: var(--shiki-contrast-light) !important;
+ background-color: transparent !important;
+ /* Optional, if you also want font styles */
+ font-style: var(--shiki-contrast-light-font-style) !important;
+ font-weight: var(--shiki-contrast-light-font-weight) !important;
+ text-decoration: var(--shiki-contrast-light-text-decoration) !important;
+}
+
body.vscode-dark .shiki,
body.vscode-dark .shiki span {
color: var(--shiki-dark) !important;
@@ -22,4 +45,4 @@ body.vscode-dark .shiki span {
font-style: var(--shiki-dark-font-style) !important;
font-weight: var(--shiki-dark-font-weight) !important;
text-decoration: var(--shiki-dark-text-decoration) !important;
-}
\ No newline at end of file
+}
diff --git a/ide/packages/panoptes/src/Code.tsx b/ide/packages/panoptes/src/Code.tsx
index 151b3b4..f279c7a 100644
--- a/ide/packages/panoptes/src/Code.tsx
+++ b/ide/packages/panoptes/src/Code.tsx
@@ -1,15 +1,23 @@
import MonoSpace from "@argus/print/MonoSpace";
import { VSCodeProgressRing } from "@vscode/webview-ui-toolkit/react";
+import _ from "lodash";
import React, { useEffect, useState } from "react";
import { type Highlighter, getHighlighter } from "shiki";
import "./Code.css";
+const ARGUS_THEMES = {
+ dark: "dark-plus",
+ light: "light-plus",
+ "contrast-dark": "synthwave-84",
+ "contrast-light": "github-light-default"
+};
+
const mkHighlighter = (() => {
let h: Promise;
try {
h = getHighlighter({
- themes: ["dark-plus", "light-plus"],
+ themes: _.values(ARGUS_THEMES),
langs: ["rust"]
});
} catch (e: any) {
@@ -21,18 +29,18 @@ const mkHighlighter = (() => {
})();
const codeToHtml = async ({ code, lang }: { code: string; lang: string }) => {
- const highlighter = await mkHighlighter();
- // TODO: I haven't tested that this works because Shiki has yet to fail :)
- if (!highlighter) {
+ let highlighter: Highlighter | undefined;
+
+ try {
+ highlighter = await mkHighlighter();
+ if (!highlighter) throw new Error("Highlighter not initialized");
+ } catch (e: any) {
return `${code}
`;
}
return highlighter.codeToHtml(code, {
lang,
- themes: {
- dark: "dark-plus",
- light: "light-plus"
- },
+ themes: ARGUS_THEMES,
defaultColor: "light"
});
};
diff --git a/ide/packages/panoptes/src/TreeView/TreeApp.tsx b/ide/packages/panoptes/src/TreeView/TreeApp.tsx
index 0006c70..0341ec3 100644
--- a/ide/packages/panoptes/src/TreeView/TreeApp.tsx
+++ b/ide/packages/panoptes/src/TreeView/TreeApp.tsx
@@ -5,7 +5,6 @@ import { TyCtxt } from "@argus/print/context";
import React from "react";
import BottomUp from "./BottomUp";
-import Erotisi from "./Erotisi";
import Panels, { type PanelDescription, usePanelState } from "./Panels";
import TopDown from "./TopDown";
import "./TreeApp.css";
@@ -72,8 +71,9 @@ const TreeApp = ({
)
});
+ // FIXME: we will want to include this eventually, but not right now.
// Push to place this last
- tabs.push({ title: "Help Me", Content: Erotisi });
+ // tabs.push({ title: "Help Me", Content: Erotisi });
}
// HACK: we shouldn't test for eval mode here but Playwright is off on the button click.
diff --git a/ide/packages/panoptes/src/TreeView/Wrappers.css b/ide/packages/panoptes/src/TreeView/Wrappers.css
index 552f03e..4a560b6 100644
--- a/ide/packages/panoptes/src/TreeView/Wrappers.css
+++ b/ide/packages/panoptes/src/TreeView/Wrappers.css
@@ -23,12 +23,15 @@
}
.WrapperBox {
- display: none;
+ /* display: none; */
+ display: inline;
+ opacity: 0.20;
padding-left: 0.5em;
}
.WrapperBox.is-hovered {
- display: inline;
+ /* display: inline; */
+ opacity: 100;
}
.WrapperBox i.codicon {