Code Snippets plugin
Code snippets plugin is a simple snippets management plugin for Code::Blocks. It integrates with the interface by creating a floating docking window which shows all the snippets. Snippets can be assigned to categories or they can be in the global category called All snippets.
Creating a new snippet
To create a snippet you may
- 1) write the text in the default snippet editor;
- 2) mark some text and drag it over the top of a snippet tree item; or
- 3) cut, paste or drag text into the snippet editor.
For example, create some external text. Select your text and and drag it over the top of a Category, either to the All Snippets root item or to some other Category you may have created via the Snippets context menu.
You might noticed that the text you dragged disappeared. This is the default behavior of drag and drop; it moves by default. If you want to copy instead, simply hold down the Ctrl key while dragging the text.
To assign text to a existing snippet, you drag and drop the text to that snippet. If you pefer to append the text, use the context menu Edit command.
The default editor is based on Scintilla and contains a context menu of its own for copy/cut/paste/undo etc.
Applying a snippet
To apply a snippet, double click it. It will be applied to the currently active editor at the current cursor location.
You can, alternatively, right click on the snippet and select Apply.
You may also open the snippet with the editor, mark the text and drag it to its destination.
Creating a new category
Snippets can be added to Categories. And Categories can be added to Categories. To add a Category, right click the root or other Category and select Add SubCategory.
You may change any Snippet or Category label by slowly left clicking the label, typing a new label, then finishing with the Enter key.
Snippet labels may also be changed from within the editor. Right click the Snippet, choose Edit and change the Label field, Click Ok
Each Snippet is owned by its containing Category. But you may drag Snippets and Categories to other locations on the tree.
The number of Categories and sub-Categories is not limited.
Each Category has a parent Category, whose ultimate base is the All Snippets parent Category. If you want to create a Category to the root, right click All Snippets and select Add SubCategory.
Search for Snippets by typing their labels into the search pane at the top of the window. Searching is performed by find-as-you-type method. Category labels are included in the default search method.
Select the ">" icon to change the search method and case sensitivity.
File Link Snippets
File Link Snippets contain a file name.
When the editor is invoked on a File Link Snippet, the file data is opened in the editor rather than the Snippet data. The Snippet data containing the file name can be accessed with the context menu Properties command.
To create a File Linked Snippet item either:
- Right click a text Snippet and invoke the context menu Convert To File Link.
- Invoke the Properties context menu and choose a file as a target link to be placed in the Snippet item (use the Link Target button).
Modified data for a File Link is saved with the Ok button and disgarded by Cancel.
The user may specify their own editor by using the Settings entry in the root items context menu.
Code snippets plugin uses XML (UTF-8 encoded) file to save all code snippets.
The XML file starts with root item, snippets, which holds all the categories and code snippets. Code snippets and categories use the same element called item. The item's attributes tell what type of item it is, category or code snippet.
- Attributes: None
- Sub-elements: All snippets and categories
- name -- Name of the element
- type -- Type of the element, either snippet or category
- snippet -- The actual code snippet (only if the item's type is snippet)
- Sub-items and categories (only if the item's type is category)
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?> <snippets> <item name="Test category" type="category" /> <item name="Test item 1" type="snippet" /> <snippet>// Test 1</snippets> </item> </item> <item name="Test item 2" type="snippet" /> <snippet>// Test 2</snippets> <item> </snippets>
The file would create the following structure:
All snippets | |- Test category | | | |- Test item 1 | |- Test item 2
Snippet Drag n Drop out of Window
- Dragging Snippet tree items "out" of the window is disabled on wxGTK unless CodeSnippers is compiled with the X11 development headers and HAVEX11DEV is specified in the project compiler options.
- Clicking a main menu item after floating the CodeSnippets window causes wxAUI to redock the window. Very annoying.
"Name:" and "Snippet:" text labels in Edit snippet dialog don't have underscores; makes keyboard navigation hard
- A bug in wxWidgets, fixed in wxWidgets 2.8. The fix might be backported to 2.6.