diff --git a/lib/docs/main.js b/lib/docs/main.js index e2b5162beb..0a99432c67 100644 --- a/lib/docs/main.js +++ b/lib/docs/main.js @@ -51,8 +51,10 @@ var zigAnalysis; const domHdrName = document.getElementById("hdrName"); const domHelpModal = document.getElementById("helpModal"); const domSearchPlaceholder = document.getElementById("searchPlaceholder"); + const sourceFileUrlTemplate = "/src-viewer/{{file}}#L{{line}}" const domLangRefLink = document.getElementById("langRefLink"); + let lineCounter = 1; let searchTimer = null; let searchTrimResults = true; @@ -411,6 +413,8 @@ var zigAnalysis; if (curNavSearch !== "") { return renderSearch(); } + + lineCounter = 1; let rootPkg = zigAnalysis.packages[zigAnalysis.rootPkg]; let pkg = rootPkg; @@ -441,6 +445,10 @@ var zigAnalysis; } currentType = childDecl; + if ("src" in currentType) { + const ast_node = zigAnalysis.astNodes[currentType.src]; + lineCounter += ast_node.line; + } curNav.declObjs.push(currentType); } @@ -981,7 +989,7 @@ var zigAnalysis; "switch(" + cond + ") {" + - '[src]"; + } function renderContainer(container) { let typesList = []; @@ -2386,13 +2401,12 @@ var zigAnalysis; let declType = resolveValue(decl.value); console.assert("type" in declType.expr); - tdFnCode.innerHTML = exprName(declType.expr, { wantHtml: true, wantLink: true, fnDecl: decl, linkFnNameDecl: navLinkDecl(decl.name), - }); + }) + renderSourceFileLink(decl); let docs = zigAnalysis.astNodes[decl.src].docs; if (docs != null) { diff --git a/src/Autodoc.zig b/src/Autodoc.zig index ef2579a8e4..d90ebc3de8 100644 --- a/src/Autodoc.zig +++ b/src/Autodoc.zig @@ -2824,8 +2824,8 @@ fn walkDecls( const ast_node_index = idx: { const idx = self.ast_nodes.items.len; try self.ast_nodes.append(self.arena, .{ - .file = 0, - .line = line, + .file = self.files.getIndex(file) orelse unreachable, + .line = line, // TODO: calculate absolute line .col = 0, .docs = doc_comment, .fields = null, // walkInstruction will fill `fields` if necessary @@ -3902,13 +3902,13 @@ fn cteTodo(self: *Autodoc, msg: []const u8) error{OutOfMemory}!DocData.WalkResul } fn writeFileTableToJson(map: std.AutoArrayHashMapUnmanaged(*File, usize), jsw: anytype) !void { - try jsw.beginObject(); + try jsw.beginArray(); var it = map.iterator(); while (it.next()) |entry| { - try jsw.objectField(entry.key_ptr.*.sub_file_path); - try jsw.emitNumber(entry.value_ptr.*); + try jsw.arrayElem(); + try jsw.emitString(entry.key_ptr.*.sub_file_path); } - try jsw.endObject(); + try jsw.endArray(); } fn writePackageTableToJson(