-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Renpy Code Formatter #114
Comments
What kind of formatting are you looking for? Code formatting can probably be solved by installing a second extension. |
code formatter like Black for python |
Extensions such as Prettier allow you to create plugins to support other languages using the Prettier API. I think implementing a formatter in vscode-language-renpy would require implementing things that are already perfectly covered by Prettier. In this way, it could be used independently of this extension or even vscode. |
anyone has tried using prettier for renpy? |
What kind of formatting would you like to achieve specifically? If it's something small and not too difficult to implement (and benefits everyone), I might try to implement it. Even though I agree with @LuqueDaniel and I also think this should probably be independent. |
@JelleInfinity Good point 👍 , the scope of the feature. |
I never used prettier with python before.. but I have tried using prettier with JavaScript projects.. so if possible we can fix indentation and spacing between variables and functions in general. not sure how small it is though.. |
I do have it setup in our current development workspace for typescript, json and python files. Though to be completely honest I am not sure if it actually works on python files. We only have one of those and it never changes. |
I suppose you mainly want this to function within the python scopes? Maybe it's possible to apply a formatter to a scope? Auto indentation should work, if it doesn't then I will push a fix on the main branch. (Note that this is not fixing already messed up indentation, but indenting when pressing enter after the ' : ' symbol). Spacing and indentation is not super difficult to do, I might look into that. But it would be way on the backlog as I think other extension could be used for this. I'm currently working on improving the syntax highlighting in the new branch. |
nice.. working on python3 syntax highlighting right.. yea i want the feature for renpy globally on screen language for example.. ah okay .. if it is in the backlog.. good luck finishing the other features man 👍 any other extension as workaround you recommend and how to use them with renpy? I can try to help and make PR with this too if u are willing to onboard a bit on the project.. though I havent made any vscode extension previously |
I still recommend prettier if it works. You can look through this list for all available formatters. (Please let us know if you found a nice/working one. Then we can add it to the recommended extensions list) Or you can use this to setup a custom script. And yes, that is for python3 syntax, but also a general rewrite of the syntax highlighting feature. |
@linkb15 I'll be happy to help you with any PR :) |
Ah I didn't read your edit. Any help is appreciated :). You can find a bit of documentation here. As for how to implement it, try to keep it as simple as possible. When the new tokenizer is finished you can use that to make more complex logic. You probably need to search through the document for patterns that match something that you think should be formatted. Like for example double spaces. You can use https://regexr.com/ to create the patterns, that's what I always use. Feel free to ask me if you get stuck |
Hi @JelleInfinity I do get stuck trying out simple vs code extension development following this guide. https://code.visualstudio.com/api/get-started/your-first-extension where I could not even do the F5 which my vscode does not recognize the extensionHost as the debugger.. not sure what happened.. after searching around, it says that the extensionHost is built-in vs code but seems not the case for my local :( |
Not sure what happens there, but it took me a bit to figure out how to get it to work too. I should add a 'how to' to the readme. Anyway, just forget about the whole yo generator thing. You only need that if you want to create a completely new extension (from scratch). Just make sure you installed the latest vscode version and have Node.js installed. Also test to see if you can run npm from cmd. Then you just open vscode and select open folder. Pick the cloned repo folder, making sure package.json is now in the root of your workspace. After that you should be able to press f5 to launch a second window with the extension enabled |
I wish there was a simple way to do this, I've been wanting a formatter for a while now after having been drawn into assisting in VN code cleanup/maintenance, but adding a formatter using the above mentioned options looks even more daunting than trying to write an extension. Honestly, I for one, given the choice, would rather have this formatting embedded in this extension, but it looks like that is not going to happen anytime soon. So, effectively I'll be "forced" to look into Prettier, but I would very much appreciate it if anyone has already done this, to share what is needed and explain what I need to do to get this working on rpy files, preferably without the need to install god knows what in extra software (like please no node.js) and maybe even have a parser? |
Thanks for the heads-up on the difficulties you faced with trying to setup prettier for renpy files. That gives us a bigger reason to try and add some form of formatting. (Be it an example on how to add it to an already existing extension, or adding it to this one) Could you provide some examples of what formatting issues you're currently facing in your project? That would help us understand the kinds of problems we should aim to fix. All that said, it's still in the backlog. When we have time to continue development, the first thing we'll be working on would be semantic highlighting |
The thing is that Prettier needs a parser to do the actual work, or so it seems. And I've no idea how to go about to create one seeing as I couldn't find an existing one. Basically the biggest issue I have with formatting is proper indentation. For newly created files that isn't such a big deal, but when you get presented existing code files it's a whole different kettle of fish. The thing I'd most like to be able to have automated for now is to have a blank line inserted whenever the indent is reduced, e.g. when a menu choice block ends and the next choice is encountered having a blank line before the next menu choice item, and after the last choice block, same for "if/elif/else" branches/blocks. Preferably with a command, or automatically on load/save |
We have a parser, it's on the dev branch :) |
Blank lines and spaces are rather easy to add and I think that would be a good addition to this extension. So can definitely look into adding this. About the node.js part; Node.js is a JavaScript runtime that allows desktop apps to run JavaScript. Think of it like 'installing JavaScript' like you would 'install python'. The things you'd need to learn is how to use Typescript, not much else. (Besides the vscode API ofc) |
As in: to be used with Prettier? Seeing a lot of .ts files in that branch I take it that in order for me to try it out I'll have to somehow create a build? Because I've no idea how to do that... |
From the parser in the development branch, it's possible to develop the necessary functionality to create a formatter. But not that it's ready to be used by Prettier. |
https://pypi.org/project/renpyfmt/1.0.0/ found this, preliminary test works for inline python code. input in ./game/script.rpy: run in terminal: output in ./game/script.rpy : Screen.Recording.2023-07-01.at.02.58.07.mov |
Oh, that's really nice. We could build that in if the author is okay with that |
Heyho, creator of I was made aware of this issue today and would certainly like to participate in driving this particular part of the ecosystem forward. By the way: This doesn't just work for inline Python, it also works for For now, I'm not the fastest with working on OSS due to my day-job already taking up a lot of my time, but I do intend to keep working on this as well as providing support for the cases There are a couple things that might make integration iffy until they're fully resolved:
There are also two issues with Ren'Py script itself that may end up being very difficult to handle:
label A:
"dialogue 1"
"dialogue 2"
label B:
"dialogue 3"
"dialogue 4" The AST will properly detect dialogue 1/2 as children of label Unfortunately I haven't yet found a way to detect whether successive nodes are actually supposed to be children of the preceding node (if that node can have children) or not. As such, formatting in such a case can go wildly awry. Figuring that part out will largely unlock our full ability to format Ren'Py script, as far as I can tell right now. |
The new official version of the Ren'Py extension is severely lacking in keywords for onEnterRules' indentations. I was able to create a very messy fix on my end by adding commonly indented ATL and displayable keywords to the beforeText regex string (i.e., "parallel" and "show" ), but this is obviously not a sufficient solution. While lacking richer support of later releases, the 2.0.16 version of LuqueDaniel's unofficial Ren'Py extension was the most recent release which kept (to my memory) flawless indentation and formatting. I personally subscribe to the idea that syntax rules during coding are more helpful than a full file formatter, so as a relevant aside, I've used the Python Paste and Indent extension with good results as it understands Python indentation better than most formatters and works around VSC's very poor indentation of Python files, but something about this version of the Ren'Py extension creates a very heavy CPU load that creates up to 10 seconds of delay between keypress and paste; furthermore, when profiled with the Developer: Show Running Extensions command, Ren'Py profiles so slowly that it is flagged as an unresponsive performance issue. I can supply the saved extension profiling and put this in a new issue request, but this was not an issue on any of the previous releases and I have far from a poor computer. |
Hi thanks for the bug report. I don't think the previous version did those keywords correctly. I just added syntax highlighting to those keywords, the previous version didn't support those properly. That said, I totally forgot about updating the indentation rule to support those missing block keywords. I'll add them when I find some time! Also, the profiling file would be great to have. Please add it to a new issue :) |
Been following this issue for a while now. I've no idea how far along the development of an actual Ren'Py formatter has progressed. I've switched to using N++ with some regexp's to at least make it a bit easier for myself cleaning up existing code. |
I plan on eventually returning to this project, but there's still a lot of work ahead, so it will take a while until things reach even a tentative alpha release stage. The two problems I mentioned above are still an issue and will prevent the creation of fully-working formatters until they are fixed, if they even can be. The comment thing is only an issue for AST-based formatters like With Astral's work on |
I do believe we need a code formatter in Renpy somehow
The text was updated successfully, but these errors were encountered: