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 {