summaryrefslogtreecommitdiff
path: root/src/terminal_link.rs
diff options
context:
space:
mode:
authorMo <76752051+mo8it@users.noreply.github.com>2024-04-24 02:56:20 +0200
committerGitHub <noreply@github.com>2024-04-24 02:56:20 +0200
commit53fdb9044d54dbdf5f0aa6c309cd285829a04b3a (patch)
treeb45b6f11597130690232b2eaa9621f25ecf98200 /src/terminal_link.rs
parent86684b7fc9dd5e8bedad6056565645d1d980925c (diff)
parent8a085a0a85c759029cd57c28364867bde817e738 (diff)
Merge pull request #1955 from rust-lang/solutions
Solutions
Diffstat (limited to 'src/terminal_link.rs')
-rw-r--r--src/terminal_link.rs23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/terminal_link.rs b/src/terminal_link.rs
new file mode 100644
index 0000000..c9e6bce
--- /dev/null
+++ b/src/terminal_link.rs
@@ -0,0 +1,23 @@
+use std::{
+ fmt::{self, Display, Formatter},
+ fs,
+};
+
+pub struct TerminalFileLink<'a>(pub &'a str);
+
+impl<'a> Display for TerminalFileLink<'a> {
+ fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
+ if let Ok(Some(canonical_path)) = fs::canonicalize(self.0)
+ .as_deref()
+ .map(|path| path.to_str())
+ {
+ write!(
+ f,
+ "\x1b]8;;file://{}\x1b\\{}\x1b]8;;\x1b\\",
+ canonical_path, self.0,
+ )
+ } else {
+ write!(f, "{}", self.0)
+ }
+ }
+}