title: PluginMechanism tags: internals !Introduction TiddlyWiki5 is based on a 500 line boot kernel that runs on node.js or in the browser, and everything else is plugins. The kernel boots just enough of the TiddlyWiki environment to allow it to load tiddlers as plugins and execute them (a barebones tiddler class, a barebones wiki store class, some utilities etc.). Plugin modules are written like `node.js` modules; you can use `require()` to invoke sub components and to control load order. There are several different types of plugins: parsers, serializers, deserializers, macros etc. It goes much further than you might expect. For example, individual tiddler fields are plugins, too: there's a plugin that knows how to handle the `tags` field, and another that knows how to handle the special behaviour of the `modified` and `created` fields. Some plugins have further sub-plugins: the wikitext parser, for instance, accepts rules as individual plugins. !Plugins and Modules In TiddlyWiki5, a plugin is a bundle of related tiddlers that are distributed together as a single unit. Plugins can include tiddlers which are JavaScript modules. The file `core/boot.js` is a barebones TiddlyWiki kernel that is just sufficient to load the core plugin modules and trigger a startup plugin module to load up the rest of the application. The kernel includes: * Eight short shared utility functions * Three methods implementing the plugin module mechanism * The `$tw.Tiddler` class (and three field definition plugins) * The `$tw.Wiki` class (and three tiddler deserialization methods) * Code for the browser to load tiddlers from the HTML DOM * Code for the server to load tiddlers from the file system Each module is an ordinary `node.js`-style module, using the `require()` function to access other modules and the `exports` global to return JavaScript values. The boot kernel smooths over the differences between `node.js` and the browser, allowing the same plugin modules to execute in both environments. In the browser, `core/boot.js` is packed into a template HTML file that contains the following elements in order: * Ordinary and shadow tiddlers, packed as HTML `
` elements * `core/bootprefix.js`, containing a few lines to set up the plugin environment * Plugin JavaScript modules, packed as HTML `