-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit ac007cf
Showing
209 changed files
with
35,872 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
root = true | ||
|
||
[*] | ||
end_of_line = lf | ||
insert_final_newline = true | ||
indent_style = space | ||
indent_size = 2 | ||
|
||
[*.txt] | ||
end_of_line = crlf |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
.vscode | ||
bin | ||
etc | ||
lib | ||
node_modules | ||
|
||
docs | ||
!docs/compile.bat | ||
!docs/LICENSE | ||
!docs/update.bat |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
.vscode/** | ||
.gitignore | ||
.travis.yml | ||
tsconfig.json | ||
contributing.md | ||
package-lock.json | ||
|
||
bin | ||
etc | ||
src | ||
test | ||
|
||
docs/** | ||
!docs/cache | ||
!docs/LICENSE | ||
|
||
node_modules/** | ||
!node_modules/fast-levenshtein | ||
!node_modules/handlebars | ||
!node_modules/long | ||
!node_modules/promise-queue | ||
!node_modules/sax | ||
!node_modules/semver | ||
!node_modules/vscode-languageclient | ||
!node_modules/vscode-languageserver | ||
!node_modules/vscode-languageserver-protocol/** | ||
!node_modules/vscode-languageserver-types/** | ||
!node_modules/vscode-jsonrpc/** | ||
!node_modules/xml2js | ||
!node_modules/xmlbuilder |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
# Version 1.0.0 | ||
|
||
Initial release |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
MIT License | ||
|
||
Copyright (c) 2018 Sebastian Lenz | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files | ||
(the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, | ||
publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do | ||
so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE | ||
FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,157 @@ | ||
# Divinity Engine Script Support for VS Code | ||
|
||
This extensions enables language features for the scripting language Osiris found in The Divinity Engine 2 based games. | ||
|
||
## Getting started | ||
|
||
### Installation | ||
|
||
- Open the extensions tab (usually the last button in the action bar. You can lso use the shortcut Ctrl+Shift+X) | ||
- Search for "divinity-vscode" | ||
- On the plugin page, click the "Install", then the "Enable" button | ||
|
||
### Open project | ||
|
||
- Before editing a project for the first time in VS Code, make sure you have a fresh built of the project. | ||
- Start the Glasses editor and switch to your project. | ||
- Open the story editor and choose "File" > "Build". | ||
- In VS Code, select "File" > "Open Folder..." and select the data folder of your project. The path usually looks something like this: `../Divinity Original Sin 2/Data/Mods/MyModeName_########-####-####-####-############` | ||
- After a moment the story outline panel should show up beneath your files and you are ready to go. | ||
|
||
## Features | ||
|
||
### Story outline | ||
|
||
The story outline brings you the familiar tree view from the native editor to VS Code. You can add, delete, move and rename goals using it. | ||
|
||
data:image/s3,"s3://crabby-images/7f419/7f419429dda2f9fc4d28b8747c436b1abe3bbd44" alt="Story outline" | ||
|
||
### Code analysis | ||
|
||
The extension analyzes your code while you type and immediately shows you errors and problems. | ||
|
||
data:image/s3,"s3://crabby-images/023fd/023fdeee0a4dbf56ce50e8a1b5ecf3ae796b605d" alt="Code analysis" | ||
|
||
### Completion | ||
|
||
Code completion shows you matching symbols for your current input, it will show up automatically when typing or by pressing Shift+Space. The suggestions are context sensitive and only show you the symbols that are currently available. | ||
|
||
data:image/s3,"s3://crabby-images/81aa5/81aa5d9c9d929c4387a0f412ddf39fef3e8bc604" alt="Code completion" | ||
|
||
### Find all references and go to definition | ||
|
||
Bring up a list of all usages of a procedure, query or database by pressing Shift+F12 or selecting the command `Find All References` from the context menu. You can also jump to the definition by pressing F12 or using the command `Go to Definition`. | ||
|
||
data:image/s3,"s3://crabby-images/5da4e/5da4ef095c168fb515fc64df4cc892e699cb8976" alt="Goto definition and find all references" | ||
|
||
### Document structure | ||
|
||
Use the outline panel to get a broad overview over your current goal or jump to individial rules using the the shortcut Ctrl+Shift+O. | ||
|
||
data:image/s3,"s3://crabby-images/a8af2/a8af29a2180b5faa294c57946bbbdad4980c7e90" alt="Document structure" | ||
|
||
### Hover and signature help | ||
|
||
Quickly gain information about the symbols on screen, move your mouse over them and the extension will show you a short info. The signature help shows up everytime you start writing a function call (when pressing `(` or with the shortcut Ctrl+Shift+Space) and shows you a preview of the parameters. | ||
|
||
data:image/s3,"s3://crabby-images/b4b42/b4b42cd63afeb7158221205fccf042fe12b32426" alt="Hover and signature help" | ||
|
||
### Rename | ||
|
||
You can rename custom procedures, databases and queries as well as variables and GUID references. Press F2 while the cursor is above the symbol you want to rename or use the rename command from the context menu. | ||
|
||
data:image/s3,"s3://crabby-images/4cc29/4cc29655fe2e4ca0cee33873c96650c1949f4751" alt="Rename" | ||
|
||
### API Explorer | ||
|
||
Built in browser for the complete API with contents fetched from the Divinity Wiki when available. Open the command palette (e.g. press Ctrl+Shift+P) and search for the command `Show API explorer` to open the API explorer. | ||
|
||
data:image/s3,"s3://crabby-images/76a24/76a249314c48cc415be1809b6d56447267432283" alt="API explorer" | ||
|
||
### Custom documentation support | ||
|
||
The code completion, hovers and the signature help will show you short snippet from the Wiki to assist you. You can add documentation to your own procedures and queries by placing a JSDoc comment above them. | ||
|
||
## Differences to the built in editor | ||
|
||
Unlike the built in editor VS Code will not display three different regions when editing story goals. Instead you'll see the complete source file of each goal. The basic file structure looks like this: | ||
|
||
```javascript | ||
Version 1 | ||
SubGoalCombiner SGC_AND | ||
INITSECTION | ||
|
||
// Init section contents go here | ||
|
||
KBSECTION | ||
|
||
// KB section contents go here | ||
|
||
EXITSECTION | ||
|
||
// Exit section contents go here | ||
|
||
ENDEXITSECTION | ||
ParentTargetEdge "NameOfParentGoal" | ||
``` | ||
|
||
You can safely ignore the header section, it will be the same for all your goals. The three main sections are self explonary and are the equvalent of the three panels you see in the built in editor. Beneath the exit section you'll notice the command `ParentTargetEdge`, this command tells the game the name of the parent goal. You may use the story outline to move goals around or you can directly edit the structure here. | ||
|
||
## Feedback | ||
|
||
All feedback is welcome. Please head over to the GitHub page of this project and start a new issue if you find any problems: | ||
https://github.com/sebastian-lenz/divinity-vscode | ||
|
||
## License | ||
|
||
This extension is released under the MIT License. | ||
|
||
### Packaged software | ||
|
||
This extension uses several external dependencies, the following modules | ||
are part of the installed extension: | ||
|
||
- **djsdoc** | ||
Copyright (c) 2016-present Zeit, Inc. | ||
GPL v3.0 License | ||
https://github.com/EYHN/djsdoc | ||
- **fast-levenshtein** | ||
Copyright (c) 2013 Ramesh Nair | ||
MIT License | ||
https://github.com/hiddentao/fast-levenshtein | ||
- **Handlebars.js** | ||
Copyright (C) 2011-2017 by Yehuda Katz | ||
MIT License | ||
https://github.com/wycats/handlebars.js | ||
- **long.js** | ||
Copyright (C) Daniel Wirtz | ||
Apache License Version 2.0 | ||
https://github.com/dcodeIO/long.js | ||
- **lslib** | ||
Copyright (c) 2015 Norbyte | ||
MIT License | ||
https://github.com/Norbyte/lslib | ||
- **promise-queue** | ||
Copyright (c) 2013 Mikhail Davydov and other contributors | ||
MIT License | ||
https://github.com/promise-queue/promise-queue | ||
- **sax** | ||
Copyright (c) Isaac Z. Schlueter and Contributors | ||
ISC License | ||
https://github.com/isaacs/sax-js/blob/master/LICENSE | ||
- **semver** | ||
Copyright (c) Isaac Z. Schlueter and Contributors | ||
ISC License | ||
https://github.com/npm/node-semver | ||
- **vscode** | ||
Copyright (c) Microsoft Corporation | ||
MIT License | ||
https://github.com/Microsoft/vscode | ||
- **node-xml2js** | ||
Copyright 2010, 2011, 2012, 2013. All rights reserved. | ||
MIT License | ||
https://github.com/Leonidas-from-XIV/node-xml2js | ||
- **xmlbuilder-js** | ||
Copyright (c) 2013 Ozgur Ozcitak | ||
MIT License | ||
https://github.com/oozcitak/xmlbuilder-js |
Oops, something went wrong.