Home

tailwind-ctp-intellisense @master - refs - log -
-
https://git.jolheiser.com/tailwind-ctp-intellisense.git
Tailwind intellisense + Catppuccin
tree log patch
fix language boundary ranges
Brad Cornes <bradlc41@gmail.com>
4 years ago
1 changed files, 20 additions(+), 6 deletions(-)
M src/lsp/util/getLanguageBoundaries.tssrc/lsp/util/getLanguageBoundaries.ts
diff --git a/src/lsp/util/getLanguageBoundaries.ts b/src/lsp/util/getLanguageBoundaries.ts
index dfef2300d3a9052cb3f60970538858b81d8af39b..c309aaeca3846b7f2f0fc98af7cf80a95e6cd817 100644
--- a/src/lsp/util/getLanguageBoundaries.ts
+++ b/src/lsp/util/getLanguageBoundaries.ts
@@ -16,15 +16,21 @@ ): LanguageBoundaries | null {
   if (isVueDoc(doc)) {
     let text = doc.getText()
     let blocks = findAll(
-      /<(?<type>template|style|script)\b[^>]*>.*?(<\/\k<type>>|$)/gis,
+      /(?<open><(?<type>template|style|script)\b[^>]*>).*?(?<close><\/\k<type>>|$)/gis,
       text
     )
     let htmlRanges: Range[] = []
     let cssRanges: Range[] = []
     for (let i = 0; i < blocks.length; i++) {
       let range = {
-        start: indexToPosition(text, blocks[i].index),
-        end: indexToPosition(text, blocks[i].index + blocks[i][0].length),
+        start: indexToPosition(
+          text,
+          blocks[i].index + blocks[i].groups.open.length
+        ),
+        end: indexToPosition(
+          text,
+          blocks[i].index + blocks[i][0].length - blocks[i].groups.close.length
+        ),
       }
       if (blocks[i].groups.type === 'style') {
         cssRanges.push(range)
@@ -41,7 +47,10 @@   }
 
   if (isHtmlDoc(state, doc) || isJsDoc(state, doc) || isSvelteDoc(doc)) {
     let text = doc.getText()
-    let styleBlocks = findAll(/<style(?:\s[^>]*>|>).*?(<\/style>|$)/gis, text)
+    let styleBlocks = findAll(
+      /(?<open><style(?:\s[^>]*>|>)).*?(?<close><\/style>|$)/gis,
+      text
+    )
     let htmlRanges: Range[] = []
     let cssRanges: Range[] = []
     let currentIndex = 0
@@ -52,10 +61,15 @@         start: indexToPosition(text, currentIndex),
         end: indexToPosition(text, styleBlocks[i].index),
       })
       cssRanges.push({
-        start: indexToPosition(text, styleBlocks[i].index),
+        start: indexToPosition(
+          text,
+          styleBlocks[i].index + styleBlocks[i].groups.open.length
+        ),
         end: indexToPosition(
           text,
-          styleBlocks[i].index + styleBlocks[i][0].length
+          styleBlocks[i].index +
+            styleBlocks[i][0].length -
+            styleBlocks[i].groups.close.length
         ),
       })
       currentIndex = styleBlocks[i].index + styleBlocks[i][0].length