mirror of
				https://github.com/We-Dont-Byte/Mind_Reader.git
				synced 2025-02-04 10:38:42 +00:00 
			
		
		
		
	Merge remote-tracking branch 'origin/thomasLane' into merge-johnbreaux-thomaslane
This commit is contained in:
		
							
								
								
									
										295
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										295
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,8 +1,54 @@ | |||||||
| { | { | ||||||
| 	"name": "mind-reader", | 	"name": "mind-reader", | ||||||
| 	"displayName": "Mind_Reader", | 	"displayName": "Mind Reader", | ||||||
| 	"repository": "https://github.com/We-Dont-Byte/Mind_Reader", | 	"homepage": "https://github.com/We-Dont-Byte/Mind_Reader/wiki", | ||||||
| 	"version": "1.0.0", | 	"repository": { | ||||||
|  | 		"type": "git", | ||||||
|  | 		"url": "https://github.com/We-Dont-Byte/Mind_Reader" | ||||||
|  | 	}, | ||||||
|  | 	"bugs": { | ||||||
|  | 		"type": "git", | ||||||
|  | 		"url": "https://github.com/We-Dont-Byte/Mind_Reader/issues" | ||||||
|  | 	}, | ||||||
|  | 	"contributors": [ | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Jake Grossman", | ||||||
|  | 			"email" : "JacobGrossman2@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Cal Wooten", | ||||||
|  | 			"email" : "calwooten@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Josiah Mosesn", | ||||||
|  | 			"email" : "josiahmoses@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Sophia Drewfs", | ||||||
|  | 			"email" : "sophiadrewfs@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "John Breaux", | ||||||
|  | 			"email" : "JohnBreaux@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Thomas Lane", | ||||||
|  | 			"email" : "ThomasLane2@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Ryan Tolbert", | ||||||
|  | 			"email" : "RyanTolbert@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Kendrick Johnson", | ||||||
|  | 			"email" : "KendrickJohnson@my.unt.edu" | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"name" : "Pedro Alvarez", | ||||||
|  | 			"email" : "PedroAlvarez3@my.unt.edu" | ||||||
|  | 		} | ||||||
|  | 	], | ||||||
|  | 	"version": "2.0.0", | ||||||
| 	"engines": { | 	"engines": { | ||||||
| 		"vscode": "^1.66.0" | 		"vscode": "^1.66.0" | ||||||
| 	}, | 	}, | ||||||
| @@ -69,10 +115,25 @@ | |||||||
| 				"title": "Get Words Under the Cursor", | 				"title": "Get Words Under the Cursor", | ||||||
| 				"category": "Mind Reader" | 				"category": "Mind Reader" | ||||||
| 			}, | 			}, | ||||||
|  | 			{ | ||||||
|  | 				"command": "mind-reader.getLineNumber", | ||||||
|  | 				"title": "Get The Current Line Number" | ||||||
|  | 			}, | ||||||
| 			{ | 			{ | ||||||
| 				"command": "mind-reader.getIndent", | 				"command": "mind-reader.getIndent", | ||||||
| 				"title": "Get Line Indentation", | 				"title": "Get The Number Of Line Indentations" | ||||||
| 				"category": "Mind_Reader" | 			}, | ||||||
|  | 			{ | ||||||
|  | 				"command": "mind-reader.getLeadingSpaces", | ||||||
|  | 				"title": "Get The Number Of Leading Spaces" | ||||||
|  | 			}, | ||||||
|  | 			{ | ||||||
|  | 				"command": "mind-reader.selectLeadingWhitespace", | ||||||
|  | 				"title": "Select The Leading Whitespace" | ||||||
|  | 			}, | ||||||
|  | 			{ | ||||||
|  | 				"command": "mind-reader.getNumberOfSelectedLines", | ||||||
|  | 				"title": "Get The Number Of Selected Lines" | ||||||
| 			}, | 			}, | ||||||
| 			{ | 			{ | ||||||
| 				"command": "mind-reader.connectHub", | 				"command": "mind-reader.connectHub", | ||||||
| @@ -231,15 +292,18 @@ | |||||||
| 			} | 			} | ||||||
| 		], | 		], | ||||||
| 		"menus": { | 		"menus": { | ||||||
| 			"editor/context": [ | 			"editor/context": [{ | ||||||
| 				{ | 				"submenu": "mind-reader.editor.context", | ||||||
| 					"submenu": "mind-reader.editor.context", | 				"group": "mind-reader" | ||||||
| 					"group": "mind-reader" | 			}], | ||||||
| 				} |  | ||||||
| 			], |  | ||||||
| 			"mind-reader.editor.context": [ | 			"mind-reader.editor.context": [ | ||||||
| 				{ | 				{ | ||||||
| 					"command": "mind-reader.increaseEditorScale", | 					"command": "mind-reader.selectTheme", | ||||||
|  | 					"group": "mind-reader", | ||||||
|  | 					"when": "activeEditor" | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					"command": "mind-reader.increaseFontScale", | ||||||
| 					"group": "mind-reader", | 					"group": "mind-reader", | ||||||
| 					"when": "activeEditor" | 					"when": "activeEditor" | ||||||
| 				}, | 				}, | ||||||
| @@ -269,7 +333,27 @@ | |||||||
| 					"when": "activeEditor" | 					"when": "activeEditor" | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					"command": "mind-reader.selectTheme", | 					"command": "mind-reader.getLineNumber", | ||||||
|  | 					"group": "mind-reader", | ||||||
|  | 					"when": "activeEditor" | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					"command": "mind-reader.getIndent", | ||||||
|  | 					"group": "mind-reader", | ||||||
|  | 					"when": "activeEditor" | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					"command": "mind-reader.getLeadingSpaces", | ||||||
|  | 					"group": "mind-reader", | ||||||
|  | 					"when": "activeEditor" | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					"command": "mind-reader.selectLeadingWhitespace", | ||||||
|  | 					"group": "mind-reader", | ||||||
|  | 					"when": "activeEditor" | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					"command": "mind-reader.getNumberOfSelectedLines", | ||||||
| 					"group": "mind-reader", | 					"group": "mind-reader", | ||||||
| 					"when": "activeEditor" | 					"when": "activeEditor" | ||||||
| 				}, | 				}, | ||||||
| @@ -285,16 +369,16 @@ | |||||||
| 				} | 				} | ||||||
| 			] | 			] | ||||||
| 		}, | 		}, | ||||||
| 		"submenus": [ | 		"submenus": [{ | ||||||
| 			{ | 			"id": "mind-reader.editor.context", | ||||||
| 				"id": "mind-reader.editor.context", | 			"label": "Mind Reader" | ||||||
| 				"label": "Mind_Reader" | 		}], | ||||||
| 			} | 		"configuration": [{ | ||||||
| 		], | 			"title": "Mind Reader", | ||||||
| 		"configuration": { | 			"order": 0, | ||||||
| 			"title": "Mind_Reader", |  | ||||||
| 			"properties": { | 			"properties": { | ||||||
| 				"mindReader.productType": { | 				"mind-reader.productType": { | ||||||
|  | 					"order": 1, | ||||||
| 					"type": "string", | 					"type": "string", | ||||||
| 					"description": "Specifies the LEGO® product.", | 					"description": "Specifies the LEGO® product.", | ||||||
| 					"default": "SPIKE Prime", | 					"default": "SPIKE Prime", | ||||||
| @@ -307,7 +391,8 @@ | |||||||
| 						"LEGO® Education SPIKE™ Prime Set (45678)" | 						"LEGO® Education SPIKE™ Prime Set (45678)" | ||||||
| 					] | 					] | ||||||
| 				}, | 				}, | ||||||
| 				"mindReader.reader.screenReader": { | 				"mind-reader.reader.screenReader": { | ||||||
|  | 					"order": 0, | ||||||
| 					"type": "string", | 					"type": "string", | ||||||
| 					"description": "Specifies which screen reader to optimize for.", | 					"description": "Specifies which screen reader to optimize for.", | ||||||
| 					"default": "NVDA", | 					"default": "NVDA", | ||||||
| @@ -324,25 +409,159 @@ | |||||||
| 						"Apple VoiceOver (macOS)" | 						"Apple VoiceOver (macOS)" | ||||||
| 					] | 					] | ||||||
| 				}, | 				}, | ||||||
| 				"mindReader.reader.contextWindow": { | 				"mind-reader.reader.contextWindow": { | ||||||
|  | 					"order": 3, | ||||||
| 					"type": "number", | 					"type": "number", | ||||||
| 					"description": "The number of words around the cursor to use when reading the cursor context", | 					"description": "The number of words around the cursor to use when reading the cursor context", | ||||||
| 					"default": 1 | 					"default": 1 | ||||||
| 				}, | 				}, | ||||||
| 				"mindReader.connection.portPath": { | 				"mind-reader.connection.portPath": { | ||||||
|  | 					"order": 2, | ||||||
| 					"type": "string", | 					"type": "string", | ||||||
| 					"markdownDescription": "The default port to try and establish a connection on." | 					"markdownDescription": "The default port to try and establish a connection on." | ||||||
| 				}, |  | ||||||
| 				"mindReader.connection.clearOutputOnRun": { |  | ||||||
| 					"type": "boolean", |  | ||||||
| 					"description": "Whether to clear the output each time the program is run", |  | ||||||
| 					"default": "true" |  | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		}, | 		}, | ||||||
|  | 		{ | ||||||
|  | 			"title": "Line Highlighter [Must Close Settings And RESTART VSCode For The Line Highlighter To Function]", | ||||||
|  | 			"order": 1, | ||||||
|  | 			"properties": { | ||||||
|  | 				"mind-reader.lineHighlighter.isEnabled": { | ||||||
|  | 					"order": 4, | ||||||
|  | 					"type": "boolean", | ||||||
|  | 					"markdownDescription": "Enable/Disable the line highlighter.\n\n\n* `Enabled (our default)`: Checked: Line Highlighter is turned `ON`\n* `Disabled`: Unchecked: Line Highlighter is turned `OFF`\n\n### `NOTE`: You Must Close Settings And RESTART Visual Studio Code For The Line Highlighter To Function\n#### Even If No Changes Were Made", | ||||||
|  | 					"default": "true" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.multiLineIsEnabled": { | ||||||
|  | 					"order": 5, | ||||||
|  | 					"type": "boolean", | ||||||
|  | 					"markdownDescription": "Temporarily Disable highlighting when highlighting multiple lines.\n\n\n* `Enabled`: Checked: Multiline Highlighting is turned `ON`:\n* * When you click and drag line highlights will be applied to all lines\n* `Disabled (our default)`: Unchecked: Multiline Highlighting is turned `OFF`:\n* * When you click and drag the line highlighter will disable itself then re-enable itself when you click onto a single line.", | ||||||
|  | 					"default": "false" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.backgroundColor": { | ||||||
|  | 					"order": 6, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the background color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#232C5C` is our default", | ||||||
|  | 					"default": "#232C5C" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.outlineColor": { | ||||||
|  | 					"order": 7, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the outline color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#4866FE` is our default", | ||||||
|  | 					"default": "#4866FE" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.outlineWidth": { | ||||||
|  | 					"order": 8, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the outline width to be used by the line highlighter.\n\nSyntax: `medium` or `thin` or `thick` or `length` or `none`\n* `medium`: Specifies a medium outline. (usual default)\n* `thin`: Specifies a thin outline\n* `thick`: Specifies a thick outline\n* `length`: you to define the thickness of the outline in [length](https://www.w3schools.com/cssref/css_units.asp) units.\n* `none`: No outline width will be applied\n* `1px` is our default", | ||||||
|  | 					"default": "1px" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.outlineStyle": { | ||||||
|  | 					"order": 9, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the outline style to be used by the line highlighter.\n\nSyntax: `none` or `hidden` or `dotted` or `dashed` or `solid` or `double` or `groove` or `ridge` or `inset` or `outset`\n* `none`: No border will be applied (usual default)\n* `hidden`: The same as `none`\n* `dotted`: Dotted border\n* `dashed`: Dashed border\n* `solid (our default)`: Solid border\n* `double`: Double border\n* `groove`: 3D grooved border, depends on the outline-color value.\n* `ridge`: 3D ridged border, depends on the outline-color value.\n* `inset`: 3D inset border, depends on the outline-color value.\n* `outset`: 3D outset border, depends on the outline-color value.", | ||||||
|  | 					"default": "solid" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderColorTop": { | ||||||
|  | 					"order": 10, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the top border color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#FFFFFF` is our default", | ||||||
|  | 					"default": "#FFFFFF" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderColorRight": { | ||||||
|  | 					"order": 11, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the right border color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#FFFFFF` is our default", | ||||||
|  | 					"default": "#FFFFFF" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderColorBottom": { | ||||||
|  | 					"order": 12, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the bottom border color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#FFFFFF` is our default", | ||||||
|  | 					"default": "#FFFFFF" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderColorLeft": { | ||||||
|  | 					"order": 13, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the left border color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#FFFFFF` is our default", | ||||||
|  | 					"default": "#FFFFFF" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderWidthTop": { | ||||||
|  | 					"order": 14, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the top border width to be used by the line highlighter.\n\nSyntax: `medium` or `thin` or `thick` or `length` or `none`\n* `medium`: Specifies a medium border. (usual default)\n* `thin`: Specifies a thin border\n* `thick`: Specifies a thick border\n* `length`: you to define the thickness of the border in [length](https://www.w3schools.com/cssref/css_units.asp) units.\n* `none`: No border width will be applied\n* `1px` is our default", | ||||||
|  | 					"default": "1px" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderWidthRight": { | ||||||
|  | 					"order": 15, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the right border width to be used by the line highlighter.\n\nSyntax: `medium` or `thin` or `thick` or `length` or `none`\n* `medium`: Specifies a medium border. (usual default)\n* `thin`: Specifies a thin border\n* `thick`: Specifies a thick border\n* `length`: you to define the thickness of the border in [length](https://www.w3schools.com/cssref/css_units.asp) units.\n* `none`: No border width will be applied\n* `16px` is our default\n\n#### \nborderWidthRight exhibits odd behavior, play around with different sizes to find what works best for your environment.", | ||||||
|  | 					"default": "16px" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderWidthBottom": { | ||||||
|  | 					"order": 16, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the bottom border width to be used by the line highlighter.\n\nSyntax: `medium` or `thin` or `thick` or `length` or `none`\n* `medium`: Specifies a medium border. (usual default)\n* `thin`: Specifies a thin border\n* `thick`: Specifies a thick border\n* `length`: you to define the thickness of the border in [length](https://www.w3schools.com/cssref/css_units.asp) units.\n* `none`: No border width will be applied\n* `1px` is our default", | ||||||
|  | 					"default": "1px" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderWidthLeft": { | ||||||
|  | 					"order": 17, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the left border width to be used by the line highlighter.\n\nSyntax: `medium` or `thin` or `thick` or `length` or `none`\n* `medium`: Specifies a medium border. (usual default)\n* `thin`: Specifies a thin border\n* `thick`: Specifies a thick border\n* `length`: you to define the thickness of the border in [length](https://www.w3schools.com/cssref/css_units.asp) units.\n* `none`: No border width will be applied\n* `1px` is our default", | ||||||
|  | 					"default": "1px" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderStyleTop": { | ||||||
|  | 					"order": 18, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the top border style to be used by the line highlighter.\n\nSyntax: `none` or `hidden` or `dotted` or `dashed` or `solid` or `double` or `groove` or `ridge` or `inset` or `outset`\n* `none`: No border will be applied (usual default)\n* `hidden`: The same as `none`\n* `dotted`: Dotted border\n* `dashed`: Dashed border\n* `solid (our default)`: Solid border\n* `double`: Double border\n* `groove`: 3D grooved border, depends on the border-color value.\n* `ridge`: 3D ridged border, depends on the border-color value.\n* `inset`: 3D inset border, depends on the border-color value.\n* `outset`: 3D outset border, depends on the border-color value.", | ||||||
|  | 					"default": "solid" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderStyleRight": { | ||||||
|  | 					"order": 19, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the right border style to be used by the line highlighter.\n\nSyntax: `none` or `hidden` or `dotted` or `dashed` or `solid` or `double` or `groove` or `ridge` or `inset` or `outset`\n* `none`: No border will be applied (usual default)\n* `hidden`: The same as `none`\n* `dotted`: Dotted border\n* `dashed`: Dashed border\n* `solid (our default)`: Solid border\n* `double`: Double border\n* `groove`: 3D grooved border, depends on the border-color value.\n* `ridge`: 3D ridged border, depends on the border-color value.\n* `inset`: 3D inset border, depends on the border-color value.\n* `outset`: 3D outset border, depends on the border-color value.", | ||||||
|  | 					"default": "solid" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderStyleBottom": { | ||||||
|  | 					"order": 20, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the bottom border style to be used by the line highlighter.\n\nSyntax: `none` or `hidden` or `dotted` or `dashed` or `solid` or `double` or `groove` or `ridge` or `inset` or `outset`\n* `none`: No border will be applied (usual default)\n* `hidden`: The same as `none`\n* `dotted`: Dotted border\n* `dashed`: Dashed border\n* `solid (our default)`: Solid border\n* `double`: Double border\n* `groove`: 3D grooved border, depends on the border-color value.\n* `ridge`: 3D ridged border, depends on the border-color value.\n* `inset`: 3D inset border, depends on the border-color value.\n* `outset`: 3D outset border, depends on the border-color value.", | ||||||
|  | 					"default": "solid" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.borderStyleLeft": { | ||||||
|  | 					"order": 21, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the left border style to be used by the line highlighter.\n\nSyntax: `none` or `hidden` or `dotted` or `dashed` or `solid` or `double` or `groove` or `ridge` or `inset` or `outset`\n* `none`: No border will be applied (usual default)\n* `hidden`: The same as `none`\n* `dotted`: Dotted border\n* `dashed`: Dashed border\n* `solid (our default)`: Solid border\n* `double`: Double border\n* `groove`: 3D grooved border, depends on the border-color value.\n* `ridge`: 3D ridged border, depends on the border-color value.\n* `inset`: 3D inset border, depends on the border-color value.\n* `outset`: 3D outset border, depends on the border-color value.", | ||||||
|  | 					"default": "solid" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.fontStyle": { | ||||||
|  | 					"order": 22, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the font style to be used by the line highlighter.\n\nSyntax: `normal` or `italic` or `oblique` or `none`\n* `normal (our default)`: Displays a normal font style. This is default\n* `italic`: Displays an italic font style\n* `oblique`: Displays an oblique font style\n* `none`: No font style will be applied", | ||||||
|  | 					"default": "normal" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.fontWeight": { | ||||||
|  | 					"order": 23, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the font weight to be used by the line highlighter.\n\nSyntax: `normal` or `bold` or `bolder` or `lighter` or _number_ or `none`\n* `normal`: Normal Characters. (usual default)\n* `bold`: Thick Characters\n* `bolder (our default)`: Thicker Characters\n* `lighter`: Lighter Characters\n * _number_: From `thin` to `thick` characters: `100`, `200`, `300`, `400`, `500`, `600`, `700`, `800`, or `900`: `400` is the same as normal, and `700` is the same as bold.\n* `none`: No font weight will be applied", | ||||||
|  | 					"default": "bolder" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.textDecoration": { | ||||||
|  | 					"order": 24, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the text decoration to be used by the line highlighter.\n\nSyntax: `(text-decoration-line)` `(text-decoration-color)` `(text-decoration-style)` `(text-decoration-thickness)`\n* `text-decoration-line (required)`: Sets the kind of text decoration to use: `underline`, `overline`, `line-through`\n* `text-decoration-color`: Sets the color of the text decoration\n* `text-decoration-style`: Sets the style of the text decoration: `solid`, `wavy`, `dotted`, `dashed`, `double`\n* `text-decoration-thickness`: Sets the thickness of the decoration line\n* `none (our default)`: No text decorations will be applied\n\n`Examples`:\n1. underline blue wavy 5px\n2. line-through\n3. underline overline dotted red", | ||||||
|  | 					"default": "none" | ||||||
|  | 				}, | ||||||
|  | 				"mind-reader.lineHighlighter.textColor": { | ||||||
|  | 					"order": 25, | ||||||
|  | 					"type": "string", | ||||||
|  | 					"markdownDescription": "Set the text color to be used by the line highlighter.\n\nSyntax: _color_ or `transparent`\n\nAvailable color formats include:\n* `HEX(A)`: for Hexadecimal Colors: `#RRGGBB` or `#RRGGBBAA` to add transparency\n* `RGB(A)`: for RGB Colors: `rgb(red, green, blue)` or `rgba(red, green, blue, alpha)`\n* `HSL(A)`: for HSL Colors: `hsl(hue, saturation, lightness)` or `hsla(hue, saturation, lightness, alpha)`\n* `Predefined Color Names`: 140 color names are predefined in the HTML and CSS color specification: `blue`, `red`, `coral`, `brown`, [etc...](https://www.w3schools.com/colors/colors_names.asp)\n* `None`: For no color to be applied: Sometimes VSCode will pull a color from your theme, other times it uses black\n* `#FFFFFF` is our default", | ||||||
|  | 					"default": "#FFFFFF" | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}], | ||||||
| 		"views": { | 		"views": { | ||||||
| 			"MindReader": [ | 			"MindReader": [{ | ||||||
| 				{ |  | ||||||
| 					"id": "accessActions", | 					"id": "accessActions", | ||||||
| 					"name": "Access Actions", | 					"name": "Access Actions", | ||||||
| 					"icon": "media/dep.svg", | 					"icon": "media/dep.svg", | ||||||
| @@ -357,13 +576,11 @@ | |||||||
| 			] | 			] | ||||||
| 		}, | 		}, | ||||||
| 		"viewsContainers": { | 		"viewsContainers": { | ||||||
| 			"activitybar": [ | 			"activitybar": [{ | ||||||
| 				{ | 				"id": "MindReader", | ||||||
| 					"id": "MindReader", | 				"title": "MindReader Actions", | ||||||
| 					"title": "MindReader Actions", | 				"icon": "media/dep.svg" | ||||||
| 					"icon": "media/dep.svg" | 			}] | ||||||
| 				} |  | ||||||
| 			] |  | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	"scripts": { | 	"scripts": { | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| import * as vscode from 'vscode'; | import * as vscode      from "vscode"; | ||||||
| import * as fs from 'fs'; |  | ||||||
|  |  | ||||||
| import { CommandEntry } from './commandEntry'; | import { CommandEntry } from "./commandEntry"; | ||||||
|  |  | ||||||
| export const navCommands: CommandEntry[] = [ | export const navCommands: CommandEntry[] = [ | ||||||
|   { |   { | ||||||
| @@ -78,19 +77,58 @@ export const navCommands: CommandEntry[] = [ | |||||||
|  |  | ||||||
| // COMMAND CALLBACK IMPLEMENTATIONS | // COMMAND CALLBACK IMPLEMENTATIONS | ||||||
| function openWebview(): void { | function openWebview(): void { | ||||||
|   //vscode.commands.executeCommand('workbench.action.zoomOut'); |  | ||||||
|   const panel = vscode.window.createWebviewPanel( |   const panel = vscode.window.createWebviewPanel( | ||||||
|     'mindReader', // Identifies the type of the webview. Used internally |     "mind-reader",          // Identifies the type of the webview. Used internally | ||||||
|     'Mind Reader', // Title of the panel displayed to the user |     "Mind Reader",         // Title of the panel displayed to the user | ||||||
|     vscode.ViewColumn.One, // Editor column to show the new webview panel in. |     vscode.ViewColumn.One, // Editor column to show the new webview panel in. | ||||||
|     {} |     {} | ||||||
|   ); // Webview options. More on these later. |   ); // Webview options. More on these later. | ||||||
|  |  | ||||||
|   panel.webview.html = getWebviewContent('media/html/main.html'); |   panel.webview.html = getWebviewContent(); | ||||||
| } | } | ||||||
|  |  | ||||||
| function getWebviewContent(filepath: string) { | function getWebviewContent() { | ||||||
|   return fs.readFileSync(filepath, {encoding: 'utf-8'}); |       return `<!DOCTYPE html> | ||||||
|  |       <html lang="en"> | ||||||
|  |       <head> | ||||||
|  |           <meta charset="UTF-8"> | ||||||
|  |           <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||||
|  |           <title>Mind Reader</title> | ||||||
|  |       </head> | ||||||
|  |       <body> | ||||||
|  |           <img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcT6a4XaqHkKcxJ6ZFms1RNrRurcOfl-diW90DAdpAx0Kv-rtrLJXovIhcUpayqFHATkrQ&usqp=CAU" width="600" /> | ||||||
|  |           <p></p> | ||||||
|  |           <h1>Welcome to Mind_Reader!</h1> | ||||||
|  |           <p>We are the Single Semester Snobs and this is our tool to Help Blind Students Program Lego Mindstorms Robots in Python.</p> | ||||||
|  |           <ul> | ||||||
|  |             <li> | ||||||
|  |               This tool includes features such as a hotkey that says how many spaces in the text starts, an Accessibility Pane, | ||||||
|  |               Audio Alerts, and an advanced settings window. | ||||||
|  |               <br> | ||||||
|  |               The tool has hotkeys for both PC and Mac commands. | ||||||
|  |             </li> | ||||||
|  |             <li>This system is intended for everyone, but primarily for students K-12 who are visually impaired. </li> | ||||||
|  |             <li> | ||||||
|  |               Our goal is to provide an enhanced experience for students who are visually impaired that is transparent to | ||||||
|  |               sighted students. | ||||||
|  |               <br> | ||||||
|  |               This allows for everyone to use the same software solution, whether or not they are | ||||||
|  |               vision impaired. | ||||||
|  |             </li> | ||||||
|  |           </ul> | ||||||
|  |           <p>Use the following key binding to bring up a page for all key bindings for windows | ||||||
|  |           <br> | ||||||
|  |           Control and Shift and 8 | ||||||
|  |           </p> | ||||||
|  |           <p>Use this key binding to do the same for mac computers: | ||||||
|  |           <br> | ||||||
|  |           Command and Shift and 9 | ||||||
|  |           </p> | ||||||
|  |           <h2>This is the Lego Spike Prime!</h2z> | ||||||
|  |           <p></p> | ||||||
|  |           <img src="https://cdn.vox-cdn.com/thumbor/qoaa6N2ppl7oj97MR-aj43qPy0w=/0x0:1024x576/920x613/filters:focal(431x207:593x369):format(webp)/cdn.vox-cdn.com/uploads/chorus_image/image/63339099/lego_spike.0.png" width="300" /> | ||||||
|  |           <p></p> | ||||||
|  |           <a href="https://www.lego.com/en-us/product/lego-education-spike-prime-set-45678">Get the robot!</a> | ||||||
|  |       </body> | ||||||
|  |       </html>`; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| "use strict"; | "use strict"; | ||||||
| import { CommandEntry } from './commandEntry'; | import pl     = require("../pylex"); | ||||||
| import vscode = require("vscode"); | import { CommandEntry }                                                 from './commandEntry'; | ||||||
| import pl = require("../pylex"); | import { Position, Selection, TextEditor, TextLine, window, workspace } from "vscode"; | ||||||
|  |  | ||||||
| type TextEditor = vscode.TextEditor | undefined; |  | ||||||
|  |  | ||||||
| export const textCommands: CommandEntry[] = [ | export const textCommands: CommandEntry[] = [ | ||||||
|     { |     { | ||||||
| @@ -18,6 +16,14 @@ export const textCommands: CommandEntry[] = [ | |||||||
|         name: 'mind-reader.getLeadingSpaces', |         name: 'mind-reader.getLeadingSpaces', | ||||||
|         callback: getLeadingSpaces, |         callback: getLeadingSpaces, | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |         name: 'mind-reader.selectLeadingWhitespace', | ||||||
|  |         callback: selectLeadingWhitespace | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |         name: 'mind-reader.getNumberOfSelectedLines', | ||||||
|  |         callback: getNumberOfSelectedLines, | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|         name: 'mind-reader.getLineScope', |         name: 'mind-reader.getLineScope', | ||||||
|         callback: runLineContext, |         callback: runLineContext, | ||||||
| @@ -28,43 +34,131 @@ export const textCommands: CommandEntry[] = [ | |||||||
|     } |     } | ||||||
| ]; | ]; | ||||||
|  |  | ||||||
| /* Helper Function | /** Helper Function | ||||||
|  * This function returns the line number of the active text editor window |  * | ||||||
|  |  * @param editor | ||||||
|  |  * @returns numSpaces | ||||||
|  |  ** There are two methods that can be used to find the leading spaces: | ||||||
|  |  ** method 1: | ||||||
|  |  **    calculates the number of leading spaces by finding the length of the current line | ||||||
|  |  **    then subtracting from that the length of the text after trimming the whitespace at the start | ||||||
|  |  **    which will equal the number of whitespace characters | ||||||
|  |  ** | ||||||
|  |  **    TO-USE: set calculateLeadingSpaces to true | ||||||
|  |  ** | ||||||
|  |  ** method 2 (default): | ||||||
|  |  **    finds the index position of the first non-whitespace character in a 0-index | ||||||
|  |  **    this number will equal the number of spaces preceding the non-whitespace character | ||||||
|  |  **   due to the nature of 0-indexes. | ||||||
|  |  ** | ||||||
|  |  **    TO-USE: set calculateLeadingSpaces to false | ||||||
|  */ |  */ | ||||||
| function fetchLineNumber(editor: TextEditor): number { | function fetchNumberOfLeadingSpaces(editor: TextEditor | undefined): number { | ||||||
|     return editor? editor.selection.active.line + 1: -1; |     let numSpaces: number = 0; | ||||||
| } |  | ||||||
|  |  | ||||||
| /* Helper Function |  | ||||||
|  * This function returns the text from the current line of the active text editor window |  | ||||||
|  */ |  | ||||||
| function fetchTextLine(editor: TextEditor): vscode.TextLine|undefined { |  | ||||||
|     return editor? editor.document.lineAt(fetchLineNumber(editor) - 1): undefined; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Function that outputs the current line number the cursor is on |  | ||||||
| function getLineNumber(): void { |  | ||||||
|     const editor: TextEditor = vscode.window.activeTextEditor; |  | ||||||
|  |  | ||||||
|     if (editor) { |     if (editor) { | ||||||
|         const lineNum: number = fetchLineNumber(editor); |         /* | ||||||
|  |          * set  true to use method 1: find the number of leading spaces through arithmetic | ||||||
|  |          * set false to use method 2: find the index position of the first non-whitespace character in a 0-index | ||||||
|  |          * default: false | ||||||
|  |          */ | ||||||
|  |         const calculateLeadingSpaces: boolean = false;          // change boolean value to change method | ||||||
|  |         const line   : TextLine = fetchLine(editor); | ||||||
|  |  | ||||||
|         vscode.window.showInformationMessage(`Line ${lineNum.toString()}`); |         /* If true, calculate by arithmetic otherwise get index */ | ||||||
|  |         numSpaces = (calculateLeadingSpaces) | ||||||
|  |             ? pl.Lexer.getLeadingSpacesByArithmetic(line) | ||||||
|  |             : pl.Lexer.getLeadingSpacesByIndex(line); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return numSpaces; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** Helper Function | ||||||
|  | * * This function returns the number of selected lines in the active text editor window | ||||||
|  |     @param editor | ||||||
|  |     @returns numberOfSelectedLines | ||||||
|  | */ | ||||||
|  | function fetchNumberOfSelectedLines(editor: TextEditor | undefined): number { | ||||||
|  |     let numberOfSelectedLines: number = 0; | ||||||
|  |  | ||||||
|  |     if (editor) { | ||||||
|  |         numberOfSelectedLines = editor.selections.reduce((prev, curr) => prev + (curr.end.line - curr.start.line), 1); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return numberOfSelectedLines; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** Helper Function | ||||||
|  |  ** This function returns the line number of the active text editor window | ||||||
|  |  *  @param editor | ||||||
|  |  *  @returns editor!.selection.active.line + 1 | ||||||
|  |  */ | ||||||
|  | function fetchLineNumber(editor: TextEditor | undefined): number { | ||||||
|  |     return editor!.selection.active.line + 1; // line numbers start at 1, not 0, so we add 1 to the result | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** Helper Function | ||||||
|  |  ** This function returns the text from the current line of the active text editor window | ||||||
|  |  *  @param editor | ||||||
|  |  *  @returns editor.document.lineAt(fetchLineNumber(editor) - 1) | ||||||
|  |  */ | ||||||
|  | function fetchLine(editor: TextEditor | undefined): TextLine { | ||||||
|  |     return editor!.document.lineAt(fetchLineNumber(editor) - 1); // We want the line index, so we remove the 1 we added to the result in fetchLineNumber | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* Function | ||||||
|  |  * Function to return the number of selected (highlighted) lines | ||||||
|  |  * Changes output to 'Line' for 1 line and 'Lines' for all other instances | ||||||
|  |  */ | ||||||
|  | function getNumberOfSelectedLines(): void { | ||||||
|  |     const editor: TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|  |     if (editor) { | ||||||
|  |         const numberOfSelectedLines: number = fetchNumberOfSelectedLines(editor); | ||||||
|  |  | ||||||
|  |         (numberOfSelectedLines !== 1) | ||||||
|  |             ? window.showInformationMessage(`${numberOfSelectedLines.toString()} Lines Selected`) | ||||||
|  |             : window.showInformationMessage(`${numberOfSelectedLines.toString()} Line Selected`); | ||||||
|  |         window.showTextDocument(editor.document); // After the selection is made, the editor loses focus. We need to re-focus the editor so typing isn't interrupted | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         vscode.window.showErrorMessage('No document currently active'); |         window.showErrorMessage('No document currently active'); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| function getIndent(): void { | /*  Function | ||||||
|     const editor: TextEditor = vscode.window.activeTextEditor; |  *  Outputs the current line number the cursor is on | ||||||
|  |  */ | ||||||
|  | function getLineNumber(): void { | ||||||
|  |     const editor: TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|     if (editor) { |     if (editor) { | ||||||
|         const lineNum: number = fetchLineNumber(editor); |         const lineNum: number = fetchLineNumber(editor); | ||||||
|         const textLine: vscode.TextLine = editor.document.lineAt(lineNum - 1); |  | ||||||
|  |  | ||||||
|         if (textLine.isEmptyOrWhitespace) { |         window.showInformationMessage(`Line ${lineNum.toString()}`); | ||||||
|             vscode.window.showInformationMessage(`Line ${lineNum.toString()} is Empty`); |         window.showTextDocument(editor.document); // After the selection is made, the editor loses focus. We need to re-focus the editor so typing isn't interrupted | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |         window.showErrorMessage('No document currently active'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* Function | ||||||
|  |  * Used to get the number of indents on a line | ||||||
|  |  */ | ||||||
|  | function getIndent(): void { | ||||||
|  |     const editor: TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|  |     if (editor) { | ||||||
|  |         const lineNum: number = (fetchLineNumber(editor)); | ||||||
|  |         const line   : TextLine = fetchLine(editor); | ||||||
|  |  | ||||||
|  |         if (line.isEmptyOrWhitespace) { | ||||||
|  |             window.showInformationMessage(`Line ${lineNum.toString()} is Empty`); | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|             // Grab tab format from open document |             // Grab tab format from open document | ||||||
| @@ -72,77 +166,99 @@ function getIndent(): void { | |||||||
|                 size: typeof editor.options.tabSize === 'number'? editor.options.tabSize: 4, |                 size: typeof editor.options.tabSize === 'number'? editor.options.tabSize: 4, | ||||||
|                 hard: !editor.options.insertSpaces |                 hard: !editor.options.insertSpaces | ||||||
|             }; |             }; | ||||||
|             const i: number = pl.Lexer.getIndent(textLine.text, tabFmt); |             const i: number = pl.Lexer.getIndent(line.text, tabFmt); | ||||||
|  |  | ||||||
|             vscode.window.showInformationMessage(`Line ${lineNum.toString()}: ${i.toString()} indents`); |             (i !== 1) | ||||||
|  |                 ? window.showInformationMessage(`Line ${lineNum.toString()}: ${i.toString()} indents`) | ||||||
|  |                 : window.showInformationMessage(`Line ${lineNum.toString()}: ${i.toString()} indent`); | ||||||
|         } |         } | ||||||
|  |         window.showTextDocument(editor.document); // After the selection is made, the editor loses focus. We need to re-focus the editor so typing isn't interrupted | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         vscode.window.showErrorMessage('No document currently active'); |         window.showErrorMessage('No document currently active'); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Function -> Returns the number of leading spaces on the line the cursor is on | /* Function | ||||||
|  * There are two methods that can be used to find the leading spaces: |  * Returns the number of leading spaces on the line the cursor is on | ||||||
|  *  method 1: |  | ||||||
|  *      calculates the number of leading spaces by finding the length of the current line |  | ||||||
|  *      then subtracting from that the length of the text after trimming the whitespace at the start |  | ||||||
|  *      which will equal the number of whitespace characters |  | ||||||
|  * |  | ||||||
|  *      TO-USE: set calculateLeadingSpaces to true |  | ||||||
|  * |  | ||||||
|  * method 2 (default): |  | ||||||
|  *      finds the index position of the first non-whitespace character in a 0-index |  | ||||||
|  *      this number will equal the number of spaces preceding the non-whitespace character |  | ||||||
|  *      due to the nature of 0-indexes. |  | ||||||
|  * |  | ||||||
|  *      TO-USE: set calculateLeadingSpaces to false |  | ||||||
|  */ |  */ | ||||||
| function getLeadingSpaces(): void { | function getLeadingSpaces(): void { | ||||||
|     const editor: any = vscode.window.activeTextEditor; |     const editor: TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|     if (editor) { |     if (editor) { | ||||||
|         const lineNum: number = fetchLineNumber(editor); |         const lineNum : number = fetchLineNumber(editor); | ||||||
|         const textLine: vscode.TextLine|undefined = fetchTextLine(editor); |         const line    : TextLine | undefined = fetchLine(editor); | ||||||
|         // If there's no line, or the line is empty, say the line is empty |  | ||||||
|         if (!textLine || textLine.isEmptyOrWhitespace) { |         if (line.isEmptyOrWhitespace) { | ||||||
|             vscode.window.showInformationMessage(`Line ${lineNum.toString()} is empty`); |             window.showInformationMessage(`Line ${lineNum.toString()} is empty`); | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|             /* |             const numSpaces = fetchNumberOfLeadingSpaces(editor); | ||||||
|              * set  true to use method 1: find the number of leading spaces through arithmetic |  | ||||||
|              * set false to use method 2: find the index position of the first non-whitespace character in a 0-index |  | ||||||
|              * |  | ||||||
|              * default: false |  | ||||||
|              */ |  | ||||||
|             const calculateLeadingSpaces: boolean = false; // change boolean value to change method |  | ||||||
|             const numSpaces: number = (calculateLeadingSpaces) ? |  | ||||||
|                 pl.Lexer.getLeadingSpacesByArithmetic(textLine) : |  | ||||||
|                 pl.Lexer.getLeadingSpacesByIndex(textLine); |  | ||||||
|  |  | ||||||
|             /* Ternary operator to change the tense of 'space' to 'spaces' for the output if numSpaces is 0 or greater than 1 */ |             /* Ternary operator to change the tense of 'space' to 'spaces' for the output if numSpaces is 0 or greater than 1 */ | ||||||
|             (numSpaces !== 1) ? |             (numSpaces !== 1) | ||||||
|             vscode.window.showInformationMessage(`Line ${lineNum.toString()}: ${numSpaces.toString()} spaces`): |                 ? window.showInformationMessage(`Line ${lineNum.toString()}: ${numSpaces.toString()} spaces`) | ||||||
|                 vscode.window.showInformationMessage(`Line ${lineNum.toString()}: ${numSpaces.toString()} space`); |                 : window.showInformationMessage(`Line ${lineNum.toString()}: ${numSpaces.toString()} space`); | ||||||
|         } |         } | ||||||
|  |         window.showTextDocument(editor.document); // After the selection is made, the editor loses focus. We need to re-focus the editor so typing isn't interrupted | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         vscode.window.showErrorMessage('No document currently active'); |         window.showErrorMessage('No document currently active'); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* Function | ||||||
|  |  * Selects the leading whitespace at the beginning of a line | ||||||
|  |  * This feature was a request from Senior Design Day Spring 2022 | ||||||
|  |  */ | ||||||
|  | function selectLeadingWhitespace(): void { | ||||||
|  |     const editor : TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|  |     if (editor) { | ||||||
|  |         const numSpaces = fetchNumberOfLeadingSpaces(editor); // This will be used for the output message | ||||||
|  |         const lineNum : number = (fetchLineNumber(editor));   // Get the displayed line number | ||||||
|  |  | ||||||
|  |         /* If numSpaces isn't greater than 1, then there is no leading whitespace to select */ | ||||||
|  |         if (numSpaces >= 1) { | ||||||
|  |             const line    : TextLine = fetchLine(editor); | ||||||
|  |             const startPos: number = line.range.start.character;            // Start at the starting character position | ||||||
|  |             const endPos  : number = line.firstNonWhitespaceCharacterIndex; // End at the first non whitespace character index | ||||||
|  |  | ||||||
|  |             /* Apply our selection */ | ||||||
|  |             /* We need to subtract 1 from lineNum because we added 1 during the fetchLineNumber above and we want the 0-index for position, so remove it */ | ||||||
|  |             editor.selection       = new Selection(new Position((lineNum - 1), startPos), new Position((lineNum - 1), endPos)); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             /* Ternary operator to change the tense of 'space' to 'spaces' for the output if numSpaces is 0 or greater than 1 */ | ||||||
|  |             (numSpaces !== 1) | ||||||
|  |                 ? window.showInformationMessage(`Line ${lineNum.toString()}: ${numSpaces.toString()} spaces selected`) | ||||||
|  |                 : window.showInformationMessage(`Line ${lineNum.toString()}: ${numSpaces.toString()} space selected`); | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             window.showErrorMessage(`Line ${lineNum.toString()}: No leading spaces to select!`); // No whitespace to select | ||||||
|  |         } | ||||||
|  |         window.showTextDocument(editor.document); // After the selection is made, the editor loses focus. We need to re-focus the editor so typing isn't interrupted | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |         window.showErrorMessage('No document currently active'); // No active document | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| function runLineContext(): void { | function runLineContext(): void { | ||||||
|     const editor: TextEditor = vscode.window.activeTextEditor; |     const editor: TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|     if (editor) { |     if (editor) { | ||||||
|         // current text and line number |         // current text and line number | ||||||
|         const editorText: string = editor.document.getText(); |         const editorText: string    = editor.document.getText(); | ||||||
|         const line: number = editor.selection.active.line; |         const line      : number    = editor.selection.active.line; | ||||||
|         // get tab info settings |         // get tab info settings | ||||||
|         const size: number = typeof editor.options.tabSize === 'number'? editor.options.tabSize: 4; |         const size      : number    = typeof editor.options.tabSize === 'number'? editor.options.tabSize: 4; | ||||||
|         const hard: boolean = !editor.options.insertSpaces; |         const hard      : boolean   = !editor.options.insertSpaces; | ||||||
|         // initialize parser |         // initialize parser | ||||||
|         const parser: pl.Parser = new pl.Parser(editorText, { |         const parser    : pl.Parser = new pl.Parser(editorText, { | ||||||
|             size, |             size, | ||||||
|             hard |             hard | ||||||
|         }); |         }); | ||||||
| @@ -152,10 +268,10 @@ function runLineContext(): void { | |||||||
|         // build text |         // build text | ||||||
|         const contentString: string = createContextString(context, line); |         const contentString: string = createContextString(context, line); | ||||||
|  |  | ||||||
|         vscode.window.showInformationMessage(contentString); |         window.showInformationMessage(contentString); | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         vscode.window.showErrorMessage('No document currently active'); |         window.showErrorMessage('No document currently active'); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -186,8 +302,8 @@ function createContextString(context: pl.LexNode[], line: number): string { | |||||||
|         // Node is the document root |         // Node is the document root | ||||||
|         if (node.label === 'root') { |         if (node.label === 'root') { | ||||||
|             // Append the name (relative path) of the document in the workspace |             // Append the name (relative path) of the document in the workspace | ||||||
|             if (vscode.window.activeTextEditor?.document.uri) { |             if (window.activeTextEditor?.document.uri) { | ||||||
|                 contextString += ` ${inside} ${vscode.workspace.asRelativePath(vscode.window.activeTextEditor?.document.uri)}`; |                 contextString += ` ${inside} ${workspace.asRelativePath(window.activeTextEditor?.document.uri)}`; | ||||||
|             } else { |             } else { | ||||||
|                 contextString += ` ${inside} the Document`; |                 contextString += ` ${inside} the Document`; | ||||||
|             } |             } | ||||||
| @@ -198,25 +314,27 @@ function createContextString(context: pl.LexNode[], line: number): string { | |||||||
|     return contextString; |     return contextString; | ||||||
| } | } | ||||||
|  |  | ||||||
| // find up to `n` words around the cursor, where `n` is | /* | ||||||
| // the value of `#mindReader.reader.contextWindow` |  * find up to `n` words around the cursor, where `n` is | ||||||
|  |  * the value of `#mindReader.reader.contextWindow` | ||||||
|  |  */ | ||||||
| function runCursorContext(): void { | function runCursorContext(): void { | ||||||
|     const editor: vscode.TextEditor | undefined = vscode.window.activeTextEditor; |     const editor: TextEditor | undefined = window.activeTextEditor; | ||||||
|  |  | ||||||
|     if (!editor) { |     if (!editor) { | ||||||
|         vscode.window.showErrorMessage('RunCursorContext: No Active Editor'); |         window.showErrorMessage('RunCursorContext: No Active Editor'); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const cursorPos: vscode.Position = editor.selection.active; |     const cursorPos  : Position = editor.selection.active; | ||||||
|     const text: string = editor.document.lineAt(cursorPos).text; |     const text       : string   = editor.document.lineAt(cursorPos).text; | ||||||
|     const windowSize: any = vscode.workspace.getConfiguration('mindReader').get('reader.contextWindow'); |     const windowSize : any      = workspace.getConfiguration('mindReader').get('reader.contextWindow'); | ||||||
|     let trimmedText: string = text.trimStart(); // trim leading whitespace |     let   trimmedText: string   = text.trimStart(); // trim leading whitespace | ||||||
|     const leadingWS: number = text.length - trimmedText.length; // # of characters of leading whitespace |     const leadingWS  : number   = text.length - trimmedText.length; // # of characters of leading whitespace | ||||||
|     let pos: number = leadingWS; |     let   pos        : number   = leadingWS; | ||||||
|     const maxPos: number = text.length; |     const maxPos     : number   = text.length; | ||||||
|     // clamp cursor start/end to new range |     // clamp cursor start/end to new range | ||||||
|     let col: number = cursorPos.character; // effective column of the cursor position |     let   col        : number = cursorPos.character; // effective column of the cursor position | ||||||
|  |  | ||||||
|     trimmedText = trimmedText.trimEnd(); // trim trailing whitespace |     trimmedText = trimmedText.trimEnd(); // trim trailing whitespace | ||||||
|  |  | ||||||
| @@ -251,7 +369,7 @@ function runCursorContext(): void { | |||||||
|  |  | ||||||
|     // find word the user is in |     // find word the user is in | ||||||
|     let contextStart: number = -1; |     let contextStart: number = -1; | ||||||
|     let contextEnd: number = -1; |     let contextEnd  : number = -1; | ||||||
|  |  | ||||||
|     for (let i: number = 0; i < spaceWords.length; i++) { |     for (let i: number = 0; i < spaceWords.length; i++) { | ||||||
|         if (col >= spaceWords[i].start && col <= spaceWords[i].end) { |         if (col >= spaceWords[i].start && col <= spaceWords[i].end) { | ||||||
| @@ -265,7 +383,7 @@ function runCursorContext(): void { | |||||||
|                 contextString += spaceWords[i].word + ' '; |                 contextString += spaceWords[i].word + ' '; | ||||||
|             } |             } | ||||||
|             // output cursor context string |             // output cursor context string | ||||||
|             vscode.window.showInformationMessage(contextString); |             window.showInformationMessage(contextString); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,49 +1,47 @@ | |||||||
| import * as vscode from 'vscode'; | import * as vscode                                                from "vscode"; | ||||||
| import * as pl from './pylex'; | import * as pl                                                    from "./pylex"; | ||||||
|  | import CommandNodeProvider                                        from "./commandNodeProvider"; | ||||||
|  | import Logger                                                     from "./log"; | ||||||
|  | import { lineHighlighter }                                        from "./lineHighlighter"; | ||||||
|  |  | ||||||
| import { | import { accessCommands, hubCommands, navCommands, textCommands } from "./commands"; | ||||||
|   accessCommands, |  | ||||||
|   hubCommands, |  | ||||||
|   navCommands, |  | ||||||
|   textCommands |  | ||||||
| } from './commands'; |  | ||||||
|  |  | ||||||
| import CommandNodeProvider from './commandNodeProvider'; |  | ||||||
| import Logger from './log'; |  | ||||||
|  |  | ||||||
| // Output Logger | // Output Logger | ||||||
| const product: string = vscode.workspace.getConfiguration('mindReader').get('productType')!; | const product: string = vscode.workspace.getConfiguration("mindReader").get("productType")!; | ||||||
| const outputChannel = vscode.window.createOutputChannel(product + " Output"); | const outputChannel   = vscode.window.createOutputChannel(product + " Output"); | ||||||
| export const logger = new Logger(outputChannel); | export const logger   = new Logger(outputChannel); | ||||||
|  |  | ||||||
| let parser: pl.Parser = new pl.Parser(); | let parser: pl.Parser = new pl.Parser(); | ||||||
|  |  | ||||||
| export function activate(context: vscode.ExtensionContext) { | export function activate(context: vscode.ExtensionContext) { | ||||||
|   vscode.window.showInformationMessage('Mind_Reader is loaded!'); |   // Engage LineHighlighter | ||||||
|  |   lineHighlighter(); | ||||||
|  |  | ||||||
|   parser.parse('Beep Boop'); |   parser.parse("Beep Boop"); | ||||||
|  |  | ||||||
|   const allCommands = [ |   const allCommands = [ | ||||||
|     accessCommands, |     accessCommands, | ||||||
|     hubCommands, |     hubCommands, | ||||||
|     navCommands, |     navCommands, | ||||||
|     textCommands |     textCommands, | ||||||
|   ].flat(1); |   ].flat(1); | ||||||
|  |  | ||||||
|   // Register Commands |   // Register Commands | ||||||
|   allCommands.forEach(command => { |   allCommands.forEach((command) => { | ||||||
|     let disposable = vscode.commands.registerCommand( |     context.subscriptions.push( | ||||||
|       command.name, |       vscode.commands.registerCommand(command.name, command.callback) | ||||||
|       command.callback |  | ||||||
|     ); |     ); | ||||||
|     context.subscriptions.push(disposable); |  | ||||||
|   }); |   }); | ||||||
|  |  | ||||||
|   let accessProvider = new CommandNodeProvider([accessCommands, textCommands].flat(1)); |   let accessProvider = new CommandNodeProvider( | ||||||
|   vscode.window.registerTreeDataProvider('accessActions', accessProvider); |     [accessCommands, textCommands].flat(1) | ||||||
|  |   ); | ||||||
|  |   vscode.window.registerTreeDataProvider("accessActions", accessProvider); | ||||||
|  |  | ||||||
|   let hubProvider = new CommandNodeProvider(hubCommands); |   let hubProvider = new CommandNodeProvider(hubCommands); | ||||||
|   vscode.window.registerTreeDataProvider('hubActions', hubProvider); |   vscode.window.registerTreeDataProvider("hubActions", hubProvider); | ||||||
|  |  | ||||||
|  |   vscode.window.showInformationMessage("Mind Reader finished loading!"); | ||||||
| } | } | ||||||
|  |  | ||||||
| export function deactivate() {} | export function deactivate() {} | ||||||
|   | |||||||
							
								
								
									
										274
									
								
								src/lineHighlighter.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										274
									
								
								src/lineHighlighter.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,274 @@ | |||||||
|  | /** | ||||||
|  | * ? ██╗  ██╗██╗ ██████╗ ██╗  ██╗██╗     ██╗ ██████╗ ██╗  ██╗████████╗      ██╗████████╗ | ||||||
|  | * ? ██║  ██║██║██╔════╝ ██║  ██║██║     ██║██╔════╝ ██║  ██║╚══██╔══╝      ██║╚══██╔══╝ | ||||||
|  | * ? ███████║██║██║  ███╗███████║██║     ██║██║  ███╗███████║   ██║   █████╗██║   ██║ | ||||||
|  | * ? ██╔══██║██║██║   ██║██╔══██║██║     ██║██║   ██║██╔══██║   ██║   ╚════╝██║   ██║ | ||||||
|  | * ? ██║  ██║██║╚██████╔╝██║  ██║███████╗██║╚██████╔╝██║  ██║   ██║         ██║   ██║ | ||||||
|  | * ? ╚═╝  ╚═╝╚═╝ ╚═════╝ ╚═╝  ╚═╝╚══════╝╚═╝ ╚═════╝ ╚═╝  ╚═╝   ╚═╝         ╚═╝   ╚═╝ | ||||||
|  | * TODO: Add ability for user to change options through a command pallette configurator | ||||||
|  | **/ | ||||||
|  | 'use strict'; | ||||||
|  | import { Position, window, workspace, TextEditorDecorationType, TextEditor, WorkspaceConfiguration, Range } from 'vscode'; | ||||||
|  |  | ||||||
|  | export { lineHighlighter }; | ||||||
|  |  | ||||||
|  | let highlightStyle: TextEditorDecorationType; | ||||||
|  |  | ||||||
|  | function lineHighlighter(): void { | ||||||
|  |     let highlightStyle    : TextEditorDecorationType = getHighlighterStyle(); | ||||||
|  |     let activeTextEditor  : TextEditor | undefined   = window.activeTextEditor; | ||||||
|  |     let isEnabled         : boolean    | undefined   = getHighlighterStatus(); | ||||||
|  |     let multiLineIsEnabled: boolean    | undefined   = getMultiLineHighlighterStatus(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      *  Trigger the line highlight when the extension loads so current line gets highlighted | ||||||
|  |      */ | ||||||
|  |     triggerHighlight(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Trigger for when the active text editor changes | ||||||
|  |      */ | ||||||
|  |     window.onDidChangeActiveTextEditor((editor) => { | ||||||
|  |         if (!editor) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         triggerHighlight(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      *  Trigger for when text selection changes | ||||||
|  |      */ | ||||||
|  |     window.onDidChangeTextEditorSelection((editor) => { | ||||||
|  |         if (!editor.textEditor) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         triggerHighlight(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Trigger for when the text document changes | ||||||
|  |      */ | ||||||
|  |     workspace.onDidChangeTextDocument(() => { | ||||||
|  |         if (!activeTextEditor) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         triggerHighlight(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Trigger for when the window state changes | ||||||
|  |      */ | ||||||
|  |     window.onDidChangeWindowState((editor) => { | ||||||
|  |         if (!editor) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         triggerHighlight(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Trigger for when configuration changes | ||||||
|  |      */ | ||||||
|  |     workspace.onDidChangeConfiguration((editor) => { | ||||||
|  |         if (!editor) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         highlightStyle.dispose();                              // Dump existing styling | ||||||
|  |         isEnabled          = getHighlighterStatus();           // check if line highlighter is enable/disabled | ||||||
|  |         multiLineIsEnabled = getMultiLineHighlighterStatus();  // Check if multiline highlighting is enabled/disabled | ||||||
|  |         highlightStyle     = getHighlighterStyle();            // get new line highlighter styling | ||||||
|  |         triggerHighlight();                                    // trigger highlight with new styling | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * main function that triggers the highlights | ||||||
|  |      */ | ||||||
|  |     function triggerHighlight(): void { | ||||||
|  |         if (!activeTextEditor) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         /** | ||||||
|  |          * Sets the activeTextEditor to the current active window | ||||||
|  |          */ | ||||||
|  |         activeTextEditor  = window.activeTextEditor; | ||||||
|  |         if (activeTextEditor !== undefined) { | ||||||
|  |             /** | ||||||
|  |              * If the line highlighter function is enabled | ||||||
|  |              *      set the decorations with our chosen highlighting style on the selection | ||||||
|  |              *      otherwise (highlighter is disabled) dump our highlighting style | ||||||
|  |              */ | ||||||
|  |             switch (isEnabled) { | ||||||
|  |                 case true: /* isEnabled is true */ | ||||||
|  |                     switch (multiLineIsEnabled) { | ||||||
|  |                         case true: /* isEnabled is true and multiLineIsEnabled is true */ | ||||||
|  |                             activeTextEditor.setDecorations(highlightStyle, activeTextEditor.selections); | ||||||
|  |                             break; | ||||||
|  |                         case false: /* isEnabled is true and multiLineIsEnabled is false */ | ||||||
|  |                             switch (activeTextEditor.selection.isSingleLine) { | ||||||
|  |                                 case true: /* isEnabled is true and multiLineIsEnabled is false and VSCode is reporting a single line */ | ||||||
|  |                                     let currentPosition = []; | ||||||
|  |                                     for (let i = 0; i < activeTextEditor.selections.length; i++) { | ||||||
|  |                                         currentPosition[i] = { range: new Range(activeTextEditor.selections[i].anchor, activeTextEditor.selections[i].anchor) }; | ||||||
|  |                                     } | ||||||
|  |  | ||||||
|  |                                     activeTextEditor.setDecorations(highlightStyle, currentPosition); | ||||||
|  |                                     break; | ||||||
|  |                                 case false: /* isEnabled is true and multiLineIsEnabled is false and VSCode is reporting multiple lines */ | ||||||
|  |                                     // Dispose of our highlighting style so multiple lines aren't all highlighted when clicking and dragging to highlight | ||||||
|  |                                     activeTextEditor.setDecorations(highlightStyle, []); // This will dispose of a single editor instead of all editors | ||||||
|  |                                     break; | ||||||
|  |                                 default: /* isEnabled is true and multiLineIsEnabled is false and VSCode is reporting something else - break out of 3rd switch */ | ||||||
|  |                                     break; | ||||||
|  |                             } | ||||||
|  |                             break; | ||||||
|  |                         default: /* isEnabled is true and multiLineIsEnabled is undetected - break out of 2nd switch statement */ | ||||||
|  |                             break; | ||||||
|  |                     } | ||||||
|  |                     break; | ||||||
|  |                 case false: /* isEnabled is false */ | ||||||
|  |                     highlightStyle.dispose(); | ||||||
|  |                     break; | ||||||
|  |                 default: /* break out of initial switch if 'true or false' is not found */ | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             // Keep track of position | ||||||
|  |             new Position(activeTextEditor.selection.start.line, activeTextEditor.selection.start.character); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * * Function to get the user configured highlighting styles, or use defaults | ||||||
|  |      * | ||||||
|  |      * * Designed with user configuration in mind, able to control different sides | ||||||
|  |      * * independently from each other (in most cases). This allows for many different | ||||||
|  |      * * configurations. | ||||||
|  |      * | ||||||
|  |      * ? Colors Can be input with the following values: | ||||||
|  |      * * https://www.w3schools.com/cssref/css_colors.asp for string based color values | ||||||
|  |      * * Hex -> #<value> | rgb(###, ###, ###) | rgba(###, ###, ###, ###) | hsla(##, ##%, ##%, .#) | ||||||
|  |      * | ||||||
|  |      * ? Width Input Values | ||||||
|  |      * ! Some work better than others, if one isn't working try a different method: | ||||||
|  |      * * thin | medium | thick | px | rem | em | cm | ||||||
|  |      * | ||||||
|  |      * ? Other values | ||||||
|  |      * * font-style    : none|normal|italic|oblique; | ||||||
|  |      * * font-weight   : none|normal|bold|bolder|lighter|number; | ||||||
|  |      * * border-style  : none|hidden|dotted|dashed|solid|double|groove|ridge|inset|outset; | ||||||
|  |      * * outline-style : none|hidden|dotted|dashed|solid|double|groove|ridge|inset|outset; | ||||||
|  |      * * outline-width : none|medium|thin|thick|length; | ||||||
|  |      * * border-width  : none|medium|thin|thick|length; | ||||||
|  |      * ? https://www.w3schools.com/cssref/pr_text_text-decoration.asp for text-decoration | ||||||
|  |      * | ||||||
|  |      * ! borderWidthRight acts weirdly, on my system 16px works best with the other directions set to 1px | ||||||
|  |      * | ||||||
|  |      * @returns highlighterStyle | ||||||
|  |      */ | ||||||
|  |     function getHighlighterStyle(): TextEditorDecorationType { | ||||||
|  |         // Used so we don't have to type out workspace.getConfiguration('mind-reader.lineHighlighter') on every line, ie: shorthand | ||||||
|  |         const userConfig: WorkspaceConfiguration = workspace.getConfiguration('mind-reader.lineHighlighter'); | ||||||
|  |  | ||||||
|  |         const borderWidthTop    : string = userConfig.get('borderWidthTop')    || "1px"; | ||||||
|  |         const borderWidthRight  : string = userConfig.get('borderWidthRight')  || "16px"; | ||||||
|  |         const borderWidthBottom : string = userConfig.get('borderWidthBottom') || "1px"; | ||||||
|  |         const borderWidthLeft   : string = userConfig.get('borderWidthLeft')   || "1px"; | ||||||
|  |  | ||||||
|  |         const borderStyleTop    : string = userConfig.get('borderStyleTop')    || "solid"; | ||||||
|  |         const borderStyleRight  : string = userConfig.get('borderStyleRight')  || "solid"; | ||||||
|  |         const borderStyleBottom : string = userConfig.get('borderStyleBottom') || "solid"; | ||||||
|  |         const borderStyleLeft   : string = userConfig.get('borderStyleLeft')   || "solid"; | ||||||
|  |  | ||||||
|  |         const borderColorTop    : string = userConfig.get('borderColorTop')    || "#FFFFFF"; | ||||||
|  |         const borderColorRight  : string = userConfig.get('borderColorRight')  || "#FFFFFF"; | ||||||
|  |         const borderColorBottom : string = userConfig.get('borderColorBottom') || "#FFFFFF"; | ||||||
|  |         const borderColorLeft   : string = userConfig.get('borderColorLeft')   || "#FFFFFF"; | ||||||
|  |  | ||||||
|  |         const backgroundColor   : string = userConfig.get('backgroundColor')   || "#232C5C"; | ||||||
|  |  | ||||||
|  |         const fontStyle         : string = userConfig.get('fontStyle')         || "normal"; | ||||||
|  |         const fontWeight        : string = userConfig.get('fontWeight')        || "bolder"; | ||||||
|  |         const outlineColor      : string = userConfig.get('outlineColor')      || "#4866FE"; | ||||||
|  |         const outlineStyle      : string = userConfig.get('outlineStyle')      || "solid"; | ||||||
|  |         const outlineWidth      : string = userConfig.get('outlineWidth')      || "1px"; | ||||||
|  |         const textDecoration    : string = userConfig.get('textDecoration')    || "none"; | ||||||
|  |         const textColor         : string = userConfig.get('textColor')         || "#FFFFFF"; | ||||||
|  |  | ||||||
|  |         // Combine all our styling into a single variable to return | ||||||
|  |         const highlighterStyle  : TextEditorDecorationType  = window.createTextEditorDecorationType({ | ||||||
|  |             isWholeLine         : true, | ||||||
|  |             backgroundColor     : `${backgroundColor}`, | ||||||
|  |             fontStyle           : `${fontStyle}`, | ||||||
|  |             fontWeight          : `${fontWeight}`, | ||||||
|  |             textDecoration      : `${textDecoration}`, | ||||||
|  |             color               : `${textColor}`, | ||||||
|  |             borderColor         : `${borderColorTop} ${borderColorRight} ${borderColorBottom} ${borderColorLeft}`, | ||||||
|  |             borderWidth         : `${borderWidthTop} ${borderWidthRight} ${borderWidthBottom} ${borderWidthLeft}`, | ||||||
|  |             borderStyle         : `${borderStyleTop} ${borderStyleRight} ${borderStyleBottom} ${borderStyleLeft}`, | ||||||
|  |             outlineColor        : `${outlineColor}`, | ||||||
|  |             outlineWidth        : `${outlineWidth}`, | ||||||
|  |             outlineStyle        : `${outlineStyle}`, | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         // Return our variable | ||||||
|  |         return highlighterStyle; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Function to retrieve the 'isEnabled' status | ||||||
|  |      * | ||||||
|  |      * This will determine if the line highlighter will display or not | ||||||
|  |      *      - enabled  -> will show | ||||||
|  |      *      - disabled -> will not show | ||||||
|  |      * | ||||||
|  |      * @returns enabledStatus | ||||||
|  |      */ | ||||||
|  |     function getHighlighterStatus(): boolean | undefined { | ||||||
|  |         // set a boolean variable | ||||||
|  |         let enabledStatus: boolean | undefined; | ||||||
|  |  | ||||||
|  |         /*** | ||||||
|  |          * if "isEnabled" is missing from the settings (aka undefined) | ||||||
|  |          *      - set our variable to true (default) | ||||||
|  |          * otherwise, "isEnabled" is listed in the settings | ||||||
|  |          *      - so we just pull its value | ||||||
|  |          */ | ||||||
|  |         (workspace.getConfiguration("mind-reader.lineHighlighter").get("isEnabled") === undefined) | ||||||
|  |             ? (enabledStatus = true) | ||||||
|  |             : (enabledStatus = workspace.getConfiguration("mind-reader.lineHighlighter").get("isEnabled")); | ||||||
|  |  | ||||||
|  |         // return the enabledStatus | ||||||
|  |         return enabledStatus; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     function getMultiLineHighlighterStatus(): boolean | undefined { | ||||||
|  |         // set a boolean variable | ||||||
|  |         let multiLineIsEnabled: boolean | undefined; | ||||||
|  |  | ||||||
|  |         /*** | ||||||
|  |          * if "isEnabled" is missing from the settings (aka undefined) | ||||||
|  |          *      - set our variable to true (default) | ||||||
|  |          * otherwise, "isEnabled" is listed in the settings | ||||||
|  |          *      - so we just pull its value | ||||||
|  |          */ | ||||||
|  |         (workspace.getConfiguration("mind-reader.lineHighlighter").get("multiLineIsEnabled") === undefined) | ||||||
|  |             ? (multiLineIsEnabled = true) | ||||||
|  |             : (multiLineIsEnabled = workspace.getConfiguration("mind-reader.lineHighlighter").get("multiLineIsEnabled")); | ||||||
|  |  | ||||||
|  |         // return the enabledStatus | ||||||
|  |         return multiLineIsEnabled; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Clean-up after ourself | ||||||
|  | export function deactivate() { | ||||||
|  | 	// when the plugin is terminated remove all highlighting | ||||||
|  | 	if (highlightStyle !== undefined) { | ||||||
|  | 		highlightStyle.dispose(); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -1,9 +1,9 @@ | |||||||
| import { LineToken } from '.'; | import { LineToken }                 from '.'; | ||||||
| import { Symbol, EOFTOKEN, TabInfo } from './token'; | import { Symbol, EOFTOKEN, TabInfo } from './token'; | ||||||
|  |  | ||||||
| type Rule = { | type Rule = { | ||||||
|     pattern: RegExp, |     pattern: RegExp, | ||||||
|     type: Symbol, |     type   : Symbol, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -11,8 +11,7 @@ type Rule = { | |||||||
|  * The first item is a recognition pattern, used to recognize the token |  * The first item is a recognition pattern, used to recognize the token | ||||||
|  * the second item is the token type |  * the second item is the token type | ||||||
|  */ |  */ | ||||||
| const rules: Rule[] = [ | const rules: Rule[] = [{ | ||||||
|     { |  | ||||||
|         pattern: /^\s*def\s+(?<attr>[a-zA-Z_][a-zA-Z0-9_]*)\(/, |         pattern: /^\s*def\s+(?<attr>[a-zA-Z_][a-zA-Z0-9_]*)\(/, | ||||||
|         type: Symbol.FUNCTION |         type: Symbol.FUNCTION | ||||||
|     }, |     }, | ||||||
| @@ -74,8 +73,8 @@ const rules: Rule[] = [ | |||||||
|  * Line-By-Line Lexer |  * Line-By-Line Lexer | ||||||
|  */ |  */ | ||||||
| export default class Lexer { | export default class Lexer { | ||||||
|     private textLines: string[] = []; // array of text lines |     private textLines : string[] = []; // array of text lines | ||||||
|     private pos: number = 0; |     private pos       : number = 0; | ||||||
|     private _currToken: LineToken = EOFTOKEN; |     private _currToken: LineToken = EOFTOKEN; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -105,8 +104,8 @@ export default class Lexer { | |||||||
|      * @param `text` The new text to lex. |      * @param `text` The new text to lex. | ||||||
|      */ |      */ | ||||||
|     restart(text ? : string): void { |     restart(text ? : string): void { | ||||||
|         this.pos = 0; |         this.pos           = 0; | ||||||
|         this._currToken = EOFTOKEN; // if no input, already on EOFTOKEN |         this._currToken    = EOFTOKEN; // if no input, already on EOFTOKEN | ||||||
|         if (text) { |         if (text) { | ||||||
|             this.textLines = text.split('\n'); |             this.textLines = text.split('\n'); | ||||||
|             this.next(); // advance to the first token |             this.next(); // advance to the first token | ||||||
| @@ -132,9 +131,9 @@ export default class Lexer { | |||||||
|  |  | ||||||
|         // Until a LineToken is found, or EOF |         // Until a LineToken is found, or EOF | ||||||
|         while (this.pos < this.textLines.length) { |         while (this.pos < this.textLines.length) { | ||||||
|             const line: string = this.textLines[this.pos]; |             const line  : string = this.textLines[this.pos]; | ||||||
|             const indent: number = Lexer.getIndent(line, this.tabFmt!); |             const indent: number = Lexer.getIndent(line, this.tabFmt!); | ||||||
|             let token: LineToken; |             let token   : LineToken; | ||||||
|  |  | ||||||
|             for (var r of rules) { |             for (var r of rules) { | ||||||
|                 // Does line match pattern? |                 // Does line match pattern? | ||||||
| @@ -143,8 +142,7 @@ export default class Lexer { | |||||||
|                     // Yes... |                     // Yes... | ||||||
|                     if (match.groups) { |                     if (match.groups) { | ||||||
|                         token = new LineToken(r.type, this.pos, indent, match.groups["attr"]); |                         token = new LineToken(r.type, this.pos, indent, match.groups["attr"]); | ||||||
|                     } |                     } else { | ||||||
|                     else { |  | ||||||
|                         token = new LineToken(r.type, this.pos, indent); |                         token = new LineToken(r.type, this.pos, indent); | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user