Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

this code very faster #539

Open
wants to merge 73 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
8b312ac
rusty breadcrumbs
mProjectsCode Apr 26, 2024
8d01fe0
working graph building; mermaid
mProjectsCode Apr 27, 2024
f822607
minor changes
mProjectsCode Apr 27, 2024
de02fb4
progress on tree view
mProjectsCode Apr 28, 2024
563bde6
edge sorting
mProjectsCode Apr 29, 2024
f18ee4f
fix list index
mProjectsCode Apr 29, 2024
583ff36
fix edge link class
mProjectsCode Apr 29, 2024
e12f0e1
Builders accumulate GraphConstructionData immediately, instead of int…
SkepticMystic Apr 29, 2024
f77c813
Merge branch 'master' into mProjectsCode/master
SkepticMystic Apr 29, 2024
4002de3
Merge pull request #1 from SkepticMystic/mProjectsCode/master
mProjectsCode Apr 29, 2024
6eb258e
first half of mermaid options
mProjectsCode Apr 29, 2024
c127789
Merge branch 'master' of https://github.com/mProjectsCode/breadcrumbs
mProjectsCode Apr 29, 2024
2233557
mermaid code block collapse edge option
mProjectsCode Apr 29, 2024
ad0aca8
split up rust code
mProjectsCode May 1, 2024
dac9130
traversal options
mProjectsCode May 1, 2024
e67b4ba
fix more views
mProjectsCode May 1, 2024
fcd533b
it kind of works
mProjectsCode May 2, 2024
dd6029a
fix traversal bug with trail view
mProjectsCode May 2, 2024
7d62722
fix more trail view things
mProjectsCode May 2, 2024
c47575f
fix more bugs
mProjectsCode May 2, 2024
f895f71
rust performance improvements due to vector based set
mProjectsCode May 2, 2024
062194d
fix lot's of clippy lint issues
mProjectsCode May 2, 2024
5ba7883
fixes; rust sorting; settings rule previews
mProjectsCode May 3, 2024
ea2e5f5
better sorting
mProjectsCode May 4, 2024
8452bf8
fix(command:threading): Reimplement
SkepticMystic May 7, 2024
6e764b1
Merge pull request #2 from mProjectsCode/mProjectsCode/master
SkepticMystic May 7, 2024
8a89247
fix(builders): Swap source and target when creating GraphConstruction…
SkepticMystic May 7, 2024
0262bcd
fix(builders): Rather push an error than show a notice if Dataview is…
SkepticMystic May 7, 2024
8dfd92c
test: Delete irrelevant TS tests
SkepticMystic May 7, 2024
7fbfb31
fix: Edge sort field is neighbour-field, not neighbour
SkepticMystic May 7, 2024
aa91e86
Reimplement trim_lone_param in get_attribute_label
SkepticMystic May 7, 2024
bbe3913
Merge pull request #3 from mProjectsCode/mProjectsCode/master
SkepticMystic May 7, 2024
ea00553
Merge branch 'master' into master
SkepticMystic May 7, 2024
a7f662f
Remove some old TODOs + Add (RUST) label to existing ones
SkepticMystic May 7, 2024
5568e84
fix: Resolve merge-conflict conflicts
SkepticMystic May 7, 2024
2f2179f
wasm logging; rust script in package json
mProjectsCode May 7, 2024
1e9ce56
Merge branch 'master' of https://github.com/mProjectsCode/breadcrumbs
mProjectsCode May 7, 2024
0596d96
adress some todos
mProjectsCode May 7, 2024
523793b
more minor fixes
mProjectsCode May 7, 2024
73eb309
refactor: TraversalOptions.fields being undefined is the same as allo…
SkepticMystic May 8, 2024
b1dc8bc
fix review comments
mProjectsCode May 8, 2024
33199aa
feat: Implement basic flatten rec_traversal_data func + switch to bre…
SkepticMystic May 9, 2024
b2b8526
Merge branch 'master' of https://github.com/mProjectsCode/breadcrumbs
SkepticMystic May 9, 2024
62678a7
Reimplement `flat` option on CodeblockTree
SkepticMystic May 9, 2024
25e118b
make clippy happy; work on todos
mProjectsCode May 10, 2024
134eda2
mermaid edge sorting
mProjectsCode May 10, 2024
8f3ec65
Update src/components/side_views/MatrixEdgeField.svelte
mProjectsCode May 13, 2024
1909ecb
Update wasm/src/graph_mermaid.rs
mProjectsCode May 13, 2024
52f6b2f
performance improvements to views
mProjectsCode May 15, 2024
aecbf93
some small improvements
mProjectsCode May 25, 2024
d668311
do node stringification in rust
mProjectsCode May 27, 2024
1932175
fix error, add debounce
mProjectsCode May 27, 2024
6ba43c5
update graph on vault events and code cleanup
mProjectsCode Dec 15, 2024
bcdcd55
change update flow
mProjectsCode Dec 20, 2024
62c2653
more cleanup; improve EdgeStruct perf
mProjectsCode Dec 21, 2024
0e9265c
optimizations, use Rc<str> instead of String
mProjectsCode Jan 3, 2025
9589470
clean up rust code
mProjectsCode Jan 5, 2025
cb39be0
checkpoint before running svelte 5 migration
mProjectsCode Jan 6, 2025
26c2c5f
migration to Svelte 5
mProjectsCode Jan 6, 2025
2bf37a8
fix svelte migration
mProjectsCode Jan 6, 2025
c0d4627
run prettier
mProjectsCode Jan 6, 2025
97836ee
split rust code into multiple files
mProjectsCode Jan 8, 2025
4e6536f
clean rust code; fix some svelte bugs
mProjectsCode Jan 8, 2025
51b94d5
some code comments
mProjectsCode Jan 9, 2025
a8ad005
fix build errors; more comments
mProjectsCode Jan 9, 2025
d349365
markmind codeblock
mProjectsCode Jan 10, 2025
ba37ec8
improve tree rendering performance
mProjectsCode Jan 11, 2025
2c741da
more tests and bug fixes
mProjectsCode Jan 12, 2025
0b5c559
make js tests run
mProjectsCode Jan 12, 2025
0da89b4
add back mermaid testing
mProjectsCode Jan 12, 2025
8036281
fix build
mProjectsCode Jan 12, 2025
a23b8e4
update to wasm-bindgen 0.2.100
mProjectsCode Jan 13, 2025
8ab4cdc
minor improvements
mProjectsCode Jan 13, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,10 @@
"version:beta": "node version-bump-beta.mjs && git add manifest-beta.json versions.json package.json",
"release:beta": "npm run version:beta && git commit -m 'release:beta' && git push origin master:master && git tag -a $npm_package_version -m \"$npm_package_version\" && git push --tags",
"test": "vitest",
"coverage:ui": "vitest run --coverage --coverage.include 'src/**' --coverage.reporter html && npx vite preview --outDir ./coverage --open"
"coverage:ui": "vitest run --coverage --coverage.include 'src/**' --coverage.reporter html && npx vite preview --outDir ./coverage --open",
"wasm:build": "cd wasm && wasm-pack build --target web",
"wasm:fmt": "cd wasm && cargo fmt",
"wasm:test": "cd wasm && wasm-pack test --node --features test"
},
"keywords": [],
"author": "SkepticMystic",
Expand Down
14 changes: 7 additions & 7 deletions src/api/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,14 +23,14 @@ export class BCAPI {
await this.plugin.refresh();
}
/** @deprecated Use refresh */
public async refreshIndex() {
await this.refresh();
public async refreshIndex() {
await this.refresh();
}

/** @deprecated Filter edges of plugin.graph instead */
public getSubForFields(fields: string[], g = this.plugin.graph) {};
public getSubForFields(fields: string[], g = this.plugin.graph) {}

// TODO
// TODO(RUST)
// public build_tree = Traverse.build_tree;
// public breadth_first_traversal = Traverse.breadth_first;

Expand All @@ -45,11 +45,11 @@ export class BCAPI {
start_node,
Object.assign({ ...ListIndex.DEFAULT_OPTIONS }, options),
);
};
}

// BREAKING
/** @deprecated Use flatten_all_paths and flat_paths_to_index_list instead. Or, create_list_index */
public createIndex() {};
public createIndex() {}

public get_neighbours(source = get(active_file_store)?.path) {
return source && this.plugin.graph.has_node(source)
Expand All @@ -58,7 +58,7 @@ export class BCAPI {
}

/** @deprecated Use get_neighbours instead */
public getMatrixNeighbours() {
public getMatrixNeighbours() {
return this.get_neighbours();
}
}
7 changes: 2 additions & 5 deletions src/commands/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -141,10 +141,7 @@ export const init_all_commands = (plugin: BreadcrumbsPlugin) => {
plugin.addCommand({
id: `breadcrumbs:jump-to-first-neighbour-group:${group.label}`,
name: `Jump to first neighbour by group:${group.label}`,
callback: () =>
jump_to_neighbour(plugin, {
attr: { $or_fields: group.fields },
}),
callback: () => jump_to_neighbour(plugin, { fields: group.fields }),
});
});

Expand All @@ -156,7 +153,7 @@ export const init_all_commands = (plugin: BreadcrumbsPlugin) => {
callback: () =>
thread(
plugin,
{ field: label },
label,
plugin.settings.commands.thread.default_options,
),
});
Expand Down
1 change: 1 addition & 0 deletions src/commands/list_index/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@ export namespace ListIndex {
);

return edge_tree_to_list_index(
// TODO
Traverse.sort_edge_tree(
// Traverse.build_tree(graph, start_node, options, (e) =>
// has_edge_attrs(e, { $or_fields: options.fields }),
Expand Down
43 changes: 25 additions & 18 deletions src/components/codeblocks/CodeblockMermaid.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,12 @@
import CopyToClipboardButton from "../button/CopyToClipboardButton.svelte";
import RenderExternalCodeblock from "../obsidian/RenderExternalCodeblock.svelte";
import CodeblockErrors from "./CodeblockErrors.svelte";
import { MermaidGraphOptions, NodeData, NoteGraphError, TraversalOptions } from "wasm/pkg/breadcrumbs_graph_wasm";
import {
MermaidGraphOptions,
NodeData,
NoteGraphError,
TraversalOptions,
} from "wasm/pkg/breadcrumbs_graph_wasm";
import { remove_nullish_keys } from "src/utils/objects";
import { Paths } from "src/utils/paths";
import { Links } from "src/utils/links";
Expand All @@ -20,17 +25,19 @@
export let errors: BreadcrumbsError[];
export let file_path: string;

let mermaid: string = "";
const DEFAULT_MAX_DEPTH = 100;

let code: string = "";
let error: NoteGraphError | undefined = undefined;

export const update = () => {
const max_depth = options.depth[1] ?? 100;
const max_depth = options.depth[1] ?? DEFAULT_MAX_DEPTH;

const traversal_options = new TraversalOptions(
[file_path],
options.fields,
max_depth === Infinity ? 100 : max_depth,
!options.collapse,
max_depth === Infinity ? DEFAULT_MAX_DEPTH : max_depth,
!options["merge-fields"],
);

const flowchart_init = remove_nullish_keys({
Expand All @@ -55,7 +62,6 @@
.slice(2, -2);
} else {
return Paths.drop_ext(

Links.resolve_to_absolute_path(
plugin.app,
node_path,
Expand All @@ -68,13 +74,16 @@
);

try {
mermaid = plugin.graph.generate_mermaid_graph(traversal_options, mermaid_options).mermaid;
code = plugin.graph.generate_mermaid_graph(
traversal_options,
mermaid_options,
).mermaid;
error = undefined;
} catch (e) {
log.error("Error generating mermaid graph", e);

if (e instanceof NoteGraphError) {
mermaid = "";
code = "";
error = e;
}
}
Expand All @@ -83,7 +92,8 @@
onMount(() => {
update();
});


// TODO(RUST)
// const sort = get_edge_sorter(
// // @ts-expect-error: ts(2345)
// options.sort,
Expand Down Expand Up @@ -168,7 +178,6 @@
// });

// $: log.debug(mermaid);

</script>

<div class="BC-codeblock-mermaid">
Expand All @@ -180,7 +189,7 @@
</h3>
{/if}

{#if mermaid}
{#if code}
<div class="relative">
<div class="absolute left-2 top-2 flex">
<CopyToClipboardButton
Expand Down Expand Up @@ -212,18 +221,16 @@
</div>

<RenderExternalCodeblock
code={mermaid}
{code}
{plugin}
source_path={file_path}
type="mermaid"
/>
</div>
{:else if error}
<p class="search-empty-state">{error.message}</p>
{:else}
{#if error}
<p class="search-empty-state">{error.message}</p>
{:else}
<!-- TODO(HELP-MSG) -->
<p class="search-empty-state">No paths found.</p>
{/if}
<!-- TODO(HELP-MSG) -->
<p class="search-empty-state">No paths found.</p>
{/if}
</div>
72 changes: 27 additions & 45 deletions src/components/codeblocks/CodeblockTree.svelte
mProjectsCode marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,20 @@
import type { ICodeblock } from "src/codeblocks/schema";
import { ListIndex } from "src/commands/list_index";
import type { BreadcrumbsError } from "src/interfaces/graph";
import { log } from "src/logger";
import type BreadcrumbsPlugin from "src/main";
import { active_file_store } from "src/stores/active_file";
import { Timer } from "src/utils/timer";
import { onMount } from "svelte";
import {
NoteGraphError,
RecTraversalResult,
TraversalOptions,
create_edge_sorter,
} from "wasm/pkg/breadcrumbs_graph_wasm";
import NestedEdgeList from "../NestedEdgeList.svelte";
import CopyToClipboardButton from "../button/CopyToClipboardButton.svelte";
import CodeblockErrors from "./CodeblockErrors.svelte";
import { NoteGraphError, RecTraversalResult, TraversalOptions, create_edge_sorter, type RecTraversalData } from "wasm/pkg/breadcrumbs_graph_wasm";
import { log } from "src/logger";
import { Timer } from "src/utils/timer";

export let plugin: BreadcrumbsPlugin;
export let options: ICodeblock["Options"];
Expand All @@ -30,19 +36,26 @@
export const update = () => {
const max_depth = options.depth[1] ?? DEFAULT_MAX_DEPTH;

const fields =
options.fields ?? plugin.settings.edge_fields.map((f) => f.label);

const source_path = file_path
? file_path
: $active_file_store
? $active_file_store.path
: "";

const traversal_options = new TraversalOptions(
[file_path],
options.fields ?? [],
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Question here. Previously the fallback was []. Does your traversal treat an empty fields list as all fields allowed? Cause mine needed you to explicitly pass in the full list of fields, if that's what you wanted

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

undefined is all fields, [] is none

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok call, I'll update my change to use undefined when necessary

[source_path],
fields,
max_depth === Infinity ? DEFAULT_MAX_DEPTH : max_depth,
!options["merge-fields"],
);

try {
tree = plugin.graph.rec_traverse(
traversal_options
);
tree = plugin.graph.rec_traverse(traversal_options);
tree.sort(plugin.graph, sort);

error = undefined;
} catch (e) {
log.error("Error updating codeblock tree", e);
Expand All @@ -61,34 +74,7 @@
log.debug(timer.elapsedMessage("CodeblockTree initial traversal"));
});

// TODO reimplement all this logic

// // if the file_path is an empty string, so the code block is not rendered inside note, we fall back to the active file store
// $: source_path = file_path
// ? file_path
// : $active_file_store
// ? $active_file_store.path
// : "";

// // this is an exposed function that we can call from the outside to update the codeblock
// export const update = () => {
// tree = get_tree();
// };

// const base_traversal = (attr: EdgeAttrFilters) =>
// Traverse.build_tree(
// plugin.graph,
// source_path,
// { max_depth: options.depth[1] },
// (e) =>
// has_edge_attrs(e, {
// ...attr,
// $or_target_ids: options["dataview-from-paths"],
// }),
// );

// const edge_field_labels =
// options.fields ?? plugin.settings.edge_fields.map((f) => f.label);
// TODO(RUST): reimplement all this logic

// const get_tree = () => {
// if (source_path && plugin.graph.hasNode(source_path)) {
Expand All @@ -112,8 +98,6 @@
// return [];
// }
// };

// onMount(update);
</script>

<div class="BC-codeblock-tree">
Expand Down Expand Up @@ -148,12 +132,10 @@
/>
</div>
</div>
{:else if error}
<p class="search-empty-state">{error.message}</p>
{:else}
{#if error}
<p class="search-empty-state">{error.message}</p>
{:else}
<!-- TODO(HELP-MSG) -->
<p class="search-empty-state">No paths found.</p>
{/if}
<!-- TODO(HELP-MSG) -->
<p class="search-empty-state">No paths found.</p>
{/if}
</div>
54 changes: 16 additions & 38 deletions src/components/side_views/TreeView.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,10 @@
import EdgeSortIdSelector from "../selector/EdgeSortIdSelector.svelte";
import FieldGroupLabelsSelector from "../selector/FieldGroupLabelsSelector.svelte";
import ShowAttributesSelectorMenu from "../selector/ShowAttributesSelectorMenu.svelte";
import { TraversalOptions, create_edge_sorter } from "wasm/pkg/breadcrumbs_graph_wasm";
import {
TraversalOptions,
create_edge_sorter,
} from "wasm/pkg/breadcrumbs_graph_wasm";

export let plugin: BreadcrumbsPlugin;

Expand All @@ -27,45 +30,21 @@
field_group_labels,
);

$: tree = $active_file_store && plugin.graph.has_node($active_file_store.path)
? plugin.graph.rec_traverse(
new TraversalOptions(
[$active_file_store!.path],
edge_field_labels,
20,
!merge_fields,
),
)
: undefined;
$: tree =
$active_file_store && plugin.graph.has_node($active_file_store.path)
? plugin.graph.rec_traverse(
new TraversalOptions(
[$active_file_store!.path],
edge_field_labels,
20,
!merge_fields,
),
)
: undefined;

$: sort = create_edge_sorter(
edge_sort_id.field,
edge_sort_id.order === -1,
);
$: sort = create_edge_sorter(edge_sort_id.field, edge_sort_id.order === -1);

$: tree?.sort(plugin.graph, sort);

// const base_traversal = (attr: EdgeAttrFilters) =>
// Traverse.build_tree(
// plugin.graph,
// $active_file_store!.path,
// // TODO: Customisable max depth
// { max_depth: 20 },
// (edge) => has_edge_attrs(edge, attr),
// );

// $: sort = get_edge_sorter(edge_sort_id);



// $: tree =
// $active_file_store && plugin.graph.hasNode($active_file_store.path)
// ? merge_fields
// ? base_traversal({ $or_fields: edge_field_labels })
// : edge_field_labels.flatMap((field) =>
// base_traversal({ field }),
// )
// : [];
</script>

<div class="markdown-rendered BC-tree-view">
Expand Down Expand Up @@ -109,7 +88,6 @@
{#key tree || sort}
{#if tree && !tree.is_empty()}
<NestedEdgeList
{tree}
{plugin}
{show_attributes}
{show_node_options}
Expand Down
Loading