JsonTools v5.5. is live!
- 
 Release 5.8 is live, with support for INI files, including reformatting them querying/viewing/editing them with the tree view. Thoughts? 
- 
 @Mark-Olson 
 Interesting functionality, thank you!
 Maybe it’s just me - but 4 toolbar buttons look too much to me. Let’s imagine we have 10 plugins with 4 toolbar buttons added by each of them - as the result, the toolbar will explode! :) So I’d propose to make the toolbar buttons configurable - e.g. by introducing the corresponding check-boxes in the settings - to allow user to decide which buttons should be visible and which not. (Surely, Notepad++ will need to be restarted to apply the selected number of buttons).
- 
 @Vitalii-Dovgan 
 Good idea! Starting in the next release of JsonTools, you can customize which icons are shown and the order they appear in.Because I don’t want to have a separate setting for each icon, what I’ve done is added a setting that uses a string where each char can represent an icon, and the position of the char in the string represents its left-to-right position on the toolbar. Currently the character-icon mappings (case-insensitive) are ('t' = tree view, 'c' = compress, 'p' = pretty-print, 'o' = path to current position)So afor this setting would mean no icons (b/c no char is mapped to an icon),tcpomeans(tree, compress, pretty-print, path)in that order, andctmeans(compress, tree)in that order.
- 
 So I thought to myself, “JsonTools has a perfectly good tree viewer. Why shouldn’t I be able to use it for non-JSON files?”  I haven’t released v6.0 yet, but it’s a big one. This in the documentation, but I should emphasize that JsonTools uses .NET regular expressions, not the Boost library that Notepad++ uses. 
- 
 JsonTools v6.1.1 is out, and the next version of the plugin list should list it. 
 It includes fixes for several bugs, performance improvements for the error form, improvements to regular expressions, and even Python-style F-strings! 
- 
 JsonTools v7 is out. It’s not on the plugin list, because I’m hoping for some guinea pigs to check it out first. Rather than list all the new features, see how many you can spot in the image below!  
- 
 JsonTools v7.1.0 is live! Hopefully it will be in the version of the Plugin List that ships with Notepad++ 8.5.5. You should definitely upgrade to this version, especially if you have Notepad++ 8.6.3 or newer. 
- 
 @Mark-Olson said in JsonTools v5.5. is live!: JsonTools v7.1.0 is live! Hopefully it will be in the version of the Plugin List that ships with Notepad++ 8.5.5. You should definitely upgrade to this version, especially if you have Notepad++ 8.6.3 or newer. I think you mean the Plugin List that ships with Notepad++ 8.6.5 
- 
 JsonTools v8.0 is now live, and the most notable change is that it can now be translated to other languages.  I would be particularly interested in getting feedback from other C# plugin developers, particularly @Bas-de-Reuver, on the API I devised for translating forms using JSON with comments files and a somewhat hacky algorithm for translating WinForm controls while avoiding collisions. I am currently planning to add this code (or possibly a variant that uses XML instead of JSON with comments) to my NppCSharpPluginPack plugin template. 
- 
C conky77 referenced this topic on 
- 
 JsonTools v8.2 is now downloadable via the Plugins Admin for Notepad++ 8.7.2. This version includes a variety of enhancements and bugfixes, but the main reason I wanted to post this here is that it attempts to fix a problem introduced in JsonTools v8.1, wherein decimal numbers had unnecessarily long representations (for example, 11.11was reformatted as11.109999999999999), and I’ve gotten a report that this issue is still not fixed in JsonTools v8.2, even though it is fixed on both of the two machines that I tested it on.So here’s my request: please upvote this comment if and only if you notice that JsonTools v8.2 reformats 11.11as11.109999999999999. Don’t upvote this comment for any other reason; that way, I’ll know that this is still an issue if I get upvotes.
- 
 I’ve just commited the unreleased JsonTools v8.2.0.3that hopefully fixes the issue described in my previous comment. Did my commit fix it? I have no idea, 🤷!Same deal as in my previous comment: please upvote this comment if and only if you notice that JsonTools v8.2.0.3reformats11.11as11.109999999999999. Don’t upvote this comment for any other reason; that way, I’ll know that this is still an issue if I get upvotes.
- 
 JsonTools v8.4, which adds translation to several more languages and a few minor bugfixes, is live. It has been tested and appears to work well for versions of Notepad++ ranging from 7.3.3 to 8.8.1, both 32-bit and 64-bit. 
- 
 How to enable auto JSON format in JsonToolsNppPlugin? 
- 
 You’ll have to clarify what you mean by “auto JSON format”. If you mean “automatically format JSON when you open a file”, I’m sorry but I have chosen not to implement this feature. If you’re curious, I haven’t implemented automatic reformatting for the following reasons: - keyboard shortcuts and icons exist for both pretty-printing and compressing JSON, and it only takes a fraction of a second to execute the keyboard shortcut
- reformatting JSON can take a long time on large JSON files, so automatically reformatting them would delay them from actually getting to work on the file.
- The whole point of having a tree viewer is to allow for easy navigation of the document without reformatting it
- By default, reformatting JSON removes comments
- If something is rendered in JSON5, it will be converted into the corresponding JSON representation when reformatting, and there is no way to turn this behavior off. For example, {foo: 'bar', baz: 0xf}will be reformatted to{"foo": "bar", "baz": 15}.
- JsonTools already has too many user-configurable settings that few people ever use. Why add another?
 
- 
 JsonTools v8.4.0.4 is live, with support for arbitrarily large integers. This is not a strict upgrade to JsonTools v8.4, the latest version on the plugins manager, because using BigIntegerto store integers comes with a hefty performance cost relative to the 64-bitlongthat I had been using previously. You should only use this version if you need it.As such, JsonTools is being bifurcated for the foreseeable future, with every future release available on the plugin manager using 64-bit integers, and the BigInteger branch only being updated as needed to remedy serious bugs. 
- 
 @Mark-Olson said in JsonTools v5.5. is live!: You’ll have to clarify what you mean by “auto JSON format”. If you mean “automatically format JSON when you open a file”, I’m sorry but I have chosen not to implement this feature. If you’re curious, I haven’t implemented automatic reformatting for the following reasons: - keyboard shortcuts and icons exist for both pretty-printing and compressing JSON, and it only takes a fraction of a second to execute the keyboard shortcut
- reformatting JSON can take a long time on large JSON files, so automatically reformatting them would delay them from actually getting to work on the file.
- The whole point of having a tree viewer is to allow for easy navigation of the document without reformatting it
- By default, reformatting JSON removes comments
- If something is rendered in JSON5, it will be converted into the corresponding JSON representation when reformatting, and there is no way to turn this behavior off. For example, {foo: 'bar', baz: 0xf}will be reformatted to{"foo": "bar", "baz": 15}.
- JsonTools already has too many user-configurable settings that few people ever use. Why add another?
 Yes, you’re absolutely right—I did mean automatically formatting the document into a readable form when opening a file. Nobody will force you to use this feature, but perhaps someone else might want to. You don’t need to make decisions for all users. (Sorry for my poor English.) 
- 
 @User-Name 
 I’ve decided that, while I still don’t want to implement this feature in JsonTools, I would create a PythonScript script that allows you to run any JsonTools command as soon as a file is opened. The script (shown below) is self-documenting.''' ====== SOURCE ====== Requires PythonScript (https://community.notepad-plus-plus.org/topic/23039/faq-how-to-install-and-run-a-script-in-pythonscript) Also requires JsonTools (https://github.com/molsonkiko/JsonToolsNppPlugin) Based on this question: https://community.notepad-plus-plus.org/post/102686 ====== DESCRIPTION ====== When opening a file with the "json" file extension (this is customizable), pretty-print or compress (user's choice) the entire document. This behavior is disabled for files larger than 4 megabytes (this is also customizable). Every time this script is run, the behavior is reset to match the user's current preferences. So you can just edit the configuration values (ALL_CAPS variable names below), resave the file, and re-run this script to tweak its behavior. ====== EXAMPLE ====== 1. If this script is run with the default settings, as soon as a file is opened with the text {"foo":["bar","baz",true],"qutn":[-1.5,1000,null]} and the name "blah.json", it will be reformatted to { "foo": ["bar", "baz", true], "qutn": [-1.5, 1000, null] } (the result depends on JsonTools settings) 2. However if a file with the same text and the name "blah.json5" is opened, it will NOT be reformatted because "json5" is not in FILE_EXTENSIONS_TO_REFORMAT. 3. If a file with name "blah2.json" and length 40000000 (40 megabytes) is opened, it will NOT be reformatted either, because its length is greater than MAX_LENGTH_TO_REFORMAT. ====== RUNNING THIS SCRIPT AT STARTUP ====== Creating this script is not sufficient to make it run when Notepad++ starts up. To do that, you must: 1. open the "startup.py" script (in the same directory as this script) and add the following line (with no leading indentation) at the END: import jsontools_pretty_print_on_file_open 2. Go to "Configuration..." on the PythonScript plugin menu and choose ATSTARTUP for the "Initialisation" option. 3. Close and restart Notepad++ to confirm that this script ran at startup. ''' from __future__ import print_function from Npp import notepad, editor, NOTIFICATION PRETTY_PRINT_COMMAND_NAME = 'Pretty-print current JSON file' COMPRESS_COMMAND_NAME = 'Compress current JSON file' OPEN_TREE_COMMAND_NAME = 'Open JSON tree viewer' COMMAND_NAME_USED = PRETTY_PRINT_COMMAND_NAME PLUGIN_NAME = 'JsonTools' MAX_LENGTH_TO_REFORMAT = 4e6 FILE_EXTENSIONS_TO_REFORMAT = ['json'] # could also add 'json5' or maybe 'jsonc' def run_jsontools_command_on_file_open(args): fname = notepad.getCurrentFilename() length = editor.getLength() fname_ok = any(fname.endswith('.' + ext) for ext in FILE_EXTENSIONS_TO_REFORMAT) if length <= MAX_LENGTH_TO_REFORMAT and fname_ok: notepad.runPluginCommand(PLUGIN_NAME, COMMAND_NAME_USED) print('ran command "%s" on file "%s" with length %d' % (COMMAND_NAME_USED, fname, length)) # this runs when this script is run, and sets run_jsontools_command_on_file_open to run when a file is opened notepad.clearCallbacks(run_jsontools_command_on_file_open, [NOTIFICATION.BUFFERACTIVATED]) notepad.callback(run_jsontools_command_on_file_open, [NOTIFICATION.BUFFERACTIVATED]) print('From now on, the %s command "%s" will run when files with length <= %d with an extension in %s are opened' % ( PLUGIN_NAME, COMMAND_NAME_USED, MAX_LENGTH_TO_REFORMAT, FILE_EXTENSIONS_TO_REFORMAT, ))
- 
 @Mark-Olson , thanks! But it works from the second file. In the Python console I see From now on, the JsonTools command "Pretty-print current JSON file" will run when files with length <= 4000000 with an extension in ['json'] are opened Python 2.7.18 (v2.7.18:8d21aa21f2, Apr 20 2020, 13:25:05) [MSC v.1500 64 bit (AMD64)] Initialisation took 31ms Ready.And then if I open any file, it opens formatted. But the first opened file is not formatted :)" 
- 
 @User-Name said in JsonTools v5.5. is live!: And then if I open any file, it opens formatted. Glad to hear it! But the first opened file is not formatted :) That’s probably just a limitation of how PythonScript is implemented, and I don’t think there’s anything I can do about that. 


