hokein added a comment.

Haven't looked at the patch in details.

Looks like the patch is doing different things, and the test just covers a 
small set of the code.

1. find and parse the theme definition files `json` ;
2. define related data structures to save the TM scopes and do the 
transformation;
3. handle changes of the theme;

could we narrow it further? I think we could just implement 1) for this patch.



================
Comment at: clang-tools-extra/clangd/clients/clangd-vscode/src/TextMate.ts:11
+  // Mapping from a clangd scope index to a color hex string.
+  private colors: string[];
+  // The current best matching scope for every index.
----------------
The `color` word here is ambiguous -- we have different colors in 
DecorationRenderOptions, e.g. `color`, `backgroundColor`, `borderColor`, I 
believe you meant `color`, maybe we could just a more descriptive name, like 
`highlightColor`, or `TextColor`? 

I think we may want to use a structure here (`color` is one of the field), so 
that the code is extensible to support more options in  
`DecorationRenderOptions`.


================
Comment at: clang-tools-extra/clangd/clients/clangd-vscode/src/TextMate.ts:12
+  private colors: string[];
+  // The current best matching scope for every index.
+  private colorScopes: string[];
----------------
what does the `index` mean here?


================
Comment at: clang-tools-extra/clangd/clients/clangd-vscode/src/TextMate.ts:119
+// Gets a TextMate theme by its name and all its included themes.
+async function getFullNamedTheme(themeName: string): Promise<any[]> {
+  const extension =
----------------
I think we may define a type/interface (like `TokenColorRule`) for the entries 
(tokenColors) in the theme file, and have a function that parsing the content 
and returning an array of `TokenColorRule`?




================
Comment at: clang-tools-extra/clangd/clients/clangd-vscode/src/TextMate.ts:148
+    const contents = await readFileText(fullPath);
+    const parsed = jsonc.parse(contents);
+    if (parsed.include)
----------------
note that `json` is one of the theme format files, vscode also supports 
`.tmTheme`. We probably don't support `tmTheme` for now (just add a fixme).


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D65738/new/

https://reviews.llvm.org/D65738



_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to