texlab-patched
All checks were successful
CI / Build Packages (default) (push) Successful in 52s
CI / Build Packages (example-a) (push) Successful in 49s
CI / Nix Flake Check (push) Successful in 1m58s
CI / Build Packages (example-b) (push) Successful in 48s
CI / Build Packages (pyzotero) (push) Successful in 53s
CI / Build Packages (pyzotero-cli) (push) Successful in 56s

This commit is contained in:
2026-03-06 15:17:45 +01:00
parent 2eb4492b55
commit 0e3a73a20e
6 changed files with 77 additions and 3 deletions

1
.gitignore vendored
View File

@@ -2,3 +2,4 @@ result
result-* result-*
.direnv .direnv
/.envrc /.envrc
/.agent-shell/

View File

@@ -1,4 +1,3 @@
{ {
pkgs, pkgs,
system, system,
@@ -12,6 +11,7 @@ pkgs.mkShell {
nixfmt-rfc-style nixfmt-rfc-style
nil nil
nix-tree nix-tree
nix
(jailed-agents.lib.${system}.makeJailed system { (jailed-agents.lib.${system}.makeJailed system {
agentTool = "opencode"; agentTool = "opencode";
extraPkgs = extraPkgs =

View File

@@ -15,6 +15,10 @@
flake-utils.url = "github:numtide/flake-utils"; flake-utils.url = "github:numtide/flake-utils";
jailed-agents.url = "git+https://gitea@gitea.bueso.eu/luis/jailed-agents"; jailed-agents.url = "git+https://gitea@gitea.bueso.eu/luis/jailed-agents";
mcp-servers.url = "git+https://gitea@gitea.bueso.eu/luis/mcp-servers"; mcp-servers.url = "git+https://gitea@gitea.bueso.eu/luis/mcp-servers";
texlab-src = {
url = "github:latex-lsp/texlab/v5.25.1";
flake = false;
};
}; };
outputs = outputs =
@@ -24,6 +28,7 @@
flake-utils, flake-utils,
jailed-agents, jailed-agents,
mcp-servers, mcp-servers,
texlab-src,
}: }:
flake-utils.lib.eachDefaultSystem ( flake-utils.lib.eachDefaultSystem (
system: system:
@@ -31,7 +36,9 @@
pkgs = nixpkgs.legacyPackages.${system}; pkgs = nixpkgs.legacyPackages.${system};
in in
{ {
packages = import ./pkgs { inherit pkgs; }; packages = import ./pkgs {
inherit pkgs texlab-src;
};
devShells.default = import ./devshells { devShells.default = import ./devshells {
inherit pkgs system; inherit pkgs system;

View File

@@ -1,4 +1,7 @@
{ pkgs }: {
pkgs,
texlab-src,
}:
let let
self = { self = {
example-a = pkgs.callPackage ./example-a { }; example-a = pkgs.callPackage ./example-a { };
@@ -9,6 +12,9 @@ let
}; };
khal-export = pkgs.callPackage ./khal-export { }; khal-export = pkgs.callPackage ./khal-export { };
org-zotero-export = pkgs.callPackage ./org-zotero-export { }; org-zotero-export = pkgs.callPackage ./org-zotero-export { };
texlab = pkgs.callPackage ./texlab {
inherit texlab-src;
};
}; };
in in
self // { default = self.example-a; } self // { default = self.example-a; }

24
pkgs/texlab/default.nix Normal file
View File

@@ -0,0 +1,24 @@
{
lib,
rustPlatform,
pkg-config,
openssl,
texlab-src,
}:
rustPlatform.buildRustPackage {
pname = "texlab";
version = "5.25.1-patched";
src = texlab-src;
cargoLock.lockFile = "${texlab-src}/Cargo.lock";
patches = [ ./patches/subfile-diagnostics.patch ];
nativeBuildInputs = [ pkg-config ];
buildInputs = [ openssl ];
meta = {
description = "Texlab with subfile diagnostic fix";
mainProgram = "texlab";
license = lib.licenses.mit;
platforms = lib.platforms.all;
};
}

View File

@@ -0,0 +1,36 @@
diff --git a/crates/diagnostics/src/build_log.rs b/crates/diagnostics/src/build_log.rs
index 1234567..abcdefg 100644
--- a/crates/diagnostics/src/build_log.rs
+++ b/crates/diagnostics/src/build_log.rs
@@ -14,8 +14,13 @@ pub fn update(
let data = log_document.data.as_log()?;
- let parents = deps::parents(workspace, log_document);
- let root_document = parents.iter().next()?;
+ // Try to find the compiled .tex file from the log file name first.
+ // This handles subfile compilation where the subfile is the actual root.
+ let root_document = find_compiled_document(workspace, log_document)
+ .or_else(|| {
+ // Fallback to original behavior: find parent via dependency graph
+ deps::parents(workspace, log_document).into_iter().next()
+ })?;
let base_path = root_document
.path
@@ -57,3 +62,14 @@ fn find_range_of_hint(document: &Document, error: &BuildError) -> Option<TextRan
let hint_end = hint_start + hint.text_len();
Some(TextRange::new(hint_start, hint_end))
}
+
+/// Given a .log file, find the corresponding .tex file that was compiled.
+/// E.g., `/path/to/chapter.log` -> `/path/to/chapter.tex`
+fn find_compiled_document<'a>(
+ workspace: &'a Workspace,
+ log_document: &Document,
+) -> Option<&'a Document> {
+ let log_path = log_document.path.as_ref()?;
+ let tex_path = log_path.with_extension("tex");
+ let tex_uri = Url::from_file_path(&tex_path).ok()?;
+ workspace.lookup(&tex_uri)
+}