-
v6.21.1 January 6, 2013
- Added support for running multiple plugin tests for the same plugin
- Closes issue #393
- Added support for running multiple plugin tests for the same plugin
-
v6.21.0 January 2, 2013
- Cleanup focused around loading, parsing, and writing of files and documents
- Added
DocPad::flowDocumentDocPad::loadDocumentexistsattribute onFilemodel
- Fixed
Document::writeSource
-
v6.20.1 December 24, 2012
- Fixed
File::writeSource- Thanks to ashnur for pull request #381
- Fixed
-
v6.20.0 December 17, 2012
- Better watch handling
- Updated dependencies
- watchr from ~2.2.1 to 2.3.x
-
v6.19.0 December 15, 2012
-
v6.18.0 December 14, 2012
- Added
regeneratePathsconfiguration option - Include now returns expected results if the content hasn't been rendered yet
- Closes issue #378
- Updated QueryEngine to v1.5.x from v1.4.x
- Backbone dependency now moved to our dependencies from QueryEngine's. Version set explicitly to v0.9.9.
- If you have any plugins or whatever that used the
myCollection.getByCidfunction, change that call tomyCollection.get
- If you have any plugins or whatever that used the
- Improved help URLs
- Added
-
v6.17.3 December 5, 2012
- Fixed an issue introduced in v6.17.0 that prevented files from reloading under certain circumstances
- Thanks Vladislav Botvin for issue #370 and pull request #371
- Fixed an issue introduced in v6.17.0 that prevented files from reloading under certain circumstances
-
v6.17.2 December 5, 2012
watchandserveractions now perform an initial generation- Thanks Khalid Jebbari, Vladislav Botvin
- Closes #369, #368, #366
-
v6.17.1 December 4, 2012
- Updated misc internals to use the new
File::getOutContentcall
- Updated misc internals to use the new
-
v6.17.0 December 4, 2012
- Cleaned up the way we handle buffers, data, and meta data - more effecient and simpler api
- Updated
File::getMetato create meta if it doesn't exist yet
- Removed
Document::initializedidn't do anythingDocument::getMetadidn't do anythingFile::readFilemerged intoFile::parseFile::parseDatarenamed toFile::parseand cleaned signficantly
- Added
Base::setDefaultsto update attributes that haven't been setFile::setMetato update the meta more easily thanFile.getMeta().setFile::setMetaDefaultsto update the meta attributes that haven't been setFile::getContentto get the content or bufferFile::getOutContentto get the rendered content, or content, or bufferFile::getStatto get the statFile::setBufferto set the bufferFile::getBufferto get the buffer
-
v6.16.0 December 4, 2012
- The amount of render passes is now customisable via the
renderPassesconfiguration option, defaults to1- Increment this value dependening on how many levels of cross-document references you have (e.g. 2 passes for C includes B, B includes A)
- The render pass functionality has been changed to render all documents that don't reference anything else first, then for each additional render pass, render documents that do reference others
- Previously it would render both types of documents in the one batch, which resulted in hit and miss results
- Doing this, we now safely have the default
renderPassesvalue set to1which has the same effect as the traditional2render pass - Refer to issue #359 for more information
- The amount of render passes is now customisable via the
-
v6.15.0 December 3, 2012
- Nodejitsu Support
-
v6.14.0 November 29, 2012
- Added
DocPad::getFileByUrl(url)and updated the middleware router to use it- Big performance gain on request response time
- Added
-
v6.13.4 November 29, 2012
reportErrorsandreportStatisticsare nowfalseiftestis included in theprocess.argv- Closes issue #354
-
v6.13.3 November 28, 2012
- Fixed the
includetemplate helper DocPad::getFileAtPathnow does fuzzy findingFilesCollection::fuzzyFindOnenow also fuzzy matches against the url and acceptssortingandpagingarguments
- Fixed the
-
v6.13.2 November 27, 2012
- Reduced the extension not rendering error to a warning
-
v6.13.1 November 26, 2012
- Fixed up growl notifications
-
v6.13.0 November 26, 2012
- Added Terms of Service and Privacy Policy confirmation
- Added statistic tracking so we can better understand usage allowing us to improve DocPad is much greater ways
- Added automatic locale detection for OSX
- Improved error reporting
- Will now error if you try to run an action that doesn't exist (instead of defaulting to the
runaction instead) - Updated dependencies
- Added dependencies
- Mixpanel 0.0.9
- Moved dependencies to dev dependencies
-
v6.12.1 November 23, 2012
- Fixed update check, been broken since v6.7.3
- Updated bal-util dependency from 1.13.13 to 1.14.x
-
v6.12.0 November 23, 2012
- When creating new documents or files, if it is inside an unknown path we will now default to creating a document intead of a file
- We now send growl notifications when errors occur
- Thanks to Luke Hagan for pull request #346 and issue #343
- We now error and provide suggestions when an extension transform doesn't do anything
- Thanks to Farid Neshat, Elias Dawson and Steve Trevathan for issue #192
- Watching stability has been improved signifcantly
- Thanks to ashnur for issue #283
- Parser headers that don't include spacing now work again (e.g.
---csoninstead of--- cson)- Thanks to bobobo1618 for issue #341
- Removed default comparator on
FilesCollectiondue to performance improvement it provides- Thanks to Bruno Héridet for issue #330
- Added
Document::parseFileDirectory(opts,next)Document::parseDocumentDirectory(opts,next)FilesCollection::fuzzyFindOne(data)
-
v6.11.1 November 16, 2012
- Changes made to help get the docpad server up and running as soon as possible:
serveraction is now run beforegenerateaction- if a request is made while a generation is occuring, the request will be put on hold until the generation completes
- We now pass the option
resetto thegenerateBeforeevent- Lets you know if the generation is a complete generation (
resetistrue) or a differential generation (resetisfalse)
- Lets you know if the generation is a complete generation (
- Changes made to help get the docpad server up and running as soon as possible:
-
v6.11.0 October 29, 2012
- Updated QueryEngine dependency from 1.3.x to 1.4.x
- Should see speed improvements
- Added
docsdirectory to.npmignore
- Updated QueryEngine dependency from 1.3.x to 1.4.x
-
v6.10.0 October 29, 2012
- Updated QueryEngine dependency from 1.2.3 to 1.3.x
- Should see better memory usage and speed improvements
- Now tells you how many files we have when doing a complete render
- Updated QueryEngine dependency from 1.2.3 to 1.3.x
-
v6.9.2 October 26, 2012
-
v6.9.1 October 25, 2012
- Added
reloadPathsconfiguration option- When a change occurs in one of the reload paths then we will reload docpad
- Added
getBlocksandsetBlocks - Added
getCollectionsandsetCollections - Will now output how long the generation took
- Added
-
v6.9.0 October 25, 2012
- Updated dependencies
- CoffeeScript 1.4.x from 1.3.x
- CSON 1.4.x from 1.2.x
- Joe 1.1.x from 1.0.x
- Underscore 1.4.x from 1.3.x
- Chai 1.3.x from 1.1.x
- Removed ability to require uncompiled plugins
- This is due to the CoffeeScript 1.4.x from 1.3.x upgrade
skeletonNonexistantnow tells us the path it checked
- Updated dependencies
-
v6.8.4 October 25, 2012
- Added
getEnvironmentandgetEnvironmentstemplate helpers
- Added
-
v6.8.3 October 22, 2012
- Fixed growl generating notification from saying
generatedinstead ofgenerating - Added
ignorePatternsoption- Closes #193 thanks to Bruno Héridet for pull request #326
- Fixed growl generating notification from saying
-
v6.8.2 October 19, 2012
- Updated the document meta data extraction regex
- It will now treat data that is wrapped in anything that repeats 3 or more times, as meta data allowing you to use whatever is appropriate for the markup you are currently in (before we only supported
---and###)
- It will now treat data that is wrapped in anything that repeats 3 or more times, as meta data allowing you to use whatever is appropriate for the markup you are currently in (before we only supported
- Updated the document meta data extraction regex
-
v6.8.1 October 19, 2012
- Fixed
--portCLI option not working (and possibly others) - Fixed
docpad skeletonblocking instead of ending- Closes #225 thanks to Bruno Héridet
- Improved localisation
- Thanks to Bruno Héridet for pull request #325
- Fixed
-
v6.8.0 October 18, 2012
- Added support for
.envfiles- If a
.envfile is present in your website path, we will add its key values toprocess.env - More information on
.envfiles here
- If a
- Improved localisation
- Thanks to Bruno Héridet for pull request #323
- Removed unused model requirement inside document model file
- Thanks to Bruno Héridet for pull request #318
- Added support for
-
v6.7.4 October 10, 2012
PORTenvironment variable now comes before infrastructure specific port variables- Can now do
docpad-server --action generate,server,watch --port 8080
-
v6.7.3 October 8, 2012
- Fixed logging when a fatal error occurs during initialisation
- We now do warnings when plugins do invalid naming conventions
- Closes #313
- Help by Eugene Mirotin
- We now display the plugin versions in the plugin listing information when debugging
- Help by ashnur
- More localization progress
-
v6.7.2 October 3, 2012
- Fixed custom middleware (via the
serverExtendevent) being loaded too late (after the express router middleware)
- Fixed custom middleware (via the
-
v6.7.1 October 2, 2012
- Can now use the
urlproperty in meta data to specify a custom URL to use - Collection creation functions in the DocPad Configuration Files now scope to the DocPad Instance
- Fixed the 400 and 500 middlewares
- Can now use the
-
v6.7.0 October 2, 2012
- Server changes:
- Updated Express.js from v2.5 to v3.0
- If you're doing custom routing, you'll want to check the Express.js Upgrade Guide
- There are now two server objects:
serverExpressandserverHttp- get them usingdocpadInstance.getServer(true), set them usingdocpad.setServer({serverExpress,serverHttp})-serverin events, anddocpadInstance.getServer()return theserverExpressobject for backwards compatibility (however things like socket.io require theserverHttpobject) - Closes #311, #308, #272, #274
- Help by dave8401 and Ben Harris
- Abstracted out the different middlewares to
serverMiddlewareHeader,serverMiddlewareRouter,serverMiddleware404, andserverMiddleware500 - Added the following options to the
serveractions:serverExpressfor a custom express.js serverserverHttpfor a custom http servermiddlewareStandardset it tofalsefor us to not use any of the standard middleware (body parse, method override, express router)middlewareBodyParserset it tofalsefor us to not add thebodyParsermiddlewaremiddlewareMethodOverrideset it tofalsefor us to not add themethodOverridemiddlewaremiddlewareExpressRouterset it tofalsefor us to not add the Express.jsroutermiddlewaremiddleware404set it tofalsefor us to not add our404middlewaremiddleware500set it tofalsefor us to not add our500middleware
- Example API usage can be found here
- Updated Express.js from v2.5 to v3.0
- Added
standaloneattribute to files (defaults tofalse)- If you set to
true, changes to the file will only cause re-rendering of that file alone
- If you set to
- Added a progress indicator during generation
- Closes #247
- Help by Bruno Héridet
- Server changes:
-
v6.6.8 September 29, 2012
- Fixed watching setup not completing under some conditions
- Bumped watchr minimum version to v2.1.5
- Fixed watching setup not completing under some conditions
-
v6.6.7 September 28, 2012
- Added built-in support for AppFog and CloudFoundry ports
-
v6.6.6 September 24, 2012
- Further improved file text/binary detection
-
v6.6.5 September 18, 2012
- Further improved file encoding detection
- Closes #266: Images are broken
- Further improved file encoding detection
-
v6.6.4 September 4, 2012
- Better file encoding detection
-
v6.6.3 September 3, 2012
- Fixed
dateandnamealways being their automatic values
- Fixed
-
v6.6.0-6.6.2 August 28, 2012
- Added
docpad-debugexecutable for easier debugging - Will now ask if you would like to subscribe to our newsletter when running on the development environment
- Beginnings of localisation
- Added
-
v6.5.7 August 26, 2012
- Fixed "cannot get length of undefined" intermittent error
- Due to an incorret variable name inside
DocPad::ensureDocumentOrFile
- Due to an incorret variable name inside
- Fixed "cannot get length of undefined" intermittent error
-
v6.5.6 August 19, 2012
- Added
regenerateEveryconfiguration option
- Added
-
v6.5.0-6.5.5 August 10, 2012
- IMPORTANT: Renamed
extensionRenderedtooutExtension,filenameRenderedtooutFilename, andcontentTypeRenderedtooutContentTypeand moved them from the Document model to the File model - The
serverExtendevent will now also emit theexpressdependency if used - No longer attempts to install plugins dependencies every time, this is outside the scope of DocPad and in the standard use cases already handled via npm
- No longer accepts
npmPath,gitPath, andnodePathas configuration options, instead these should be environment variables atNPM_PATH,GIT_PATH, andNODE_PATHrespectively (without the underscore is also acceptable) - Eliminated ambiguity with
renderSingleExtensions- if
trueit will rendermarkdown,.mdandexample.md - if
'auto'it will rendermarkdownbut not.mdandexample.md autois now used on thedocpad rendercommand
- if
- Can now specify a custom configuration file vis the command line using
-c, --config <configPath> - Can now specify a custom outPath via the command line using
-o, --out <outPath> - Can now set template data via
req.templateData - Can now customise the action that the
docpad-serverexecutable performs by setting theDOCPAD_SERVER_ACTIONenvironment variable - Fixed
Document::writeSource - Fixed
require('docpad').createInstance(was accidentally dropped in v6.2.0) - Fixed
no readmenpm warning- Removed markdown files from
.npmignoreas they are now required for the new npm website listing
- Removed markdown files from
- Fixed the regeneration not picking up changes when modifying a referenced stylesheet
- Added a new
stylesheetcollection that contains any stylesheet file (including pre-processors) and sets theirreferenceOthersproperty totrue
- Added a new
- Fixed
contextualizeBeforeandcontextualizeAfterevents not firing- Thanks to Bruno Héridet for pull request #277
- Fixed
contentTypebeing looked up twice- Thanks to Nick Crohn for pull request #273
- IMPORTANT: Renamed
-
v6.4.1 July 19, 2012
- Added new
sourceattribute to the file model, as thecontentattribute on the document model is actually thebodynot the original content like it is in the file model
- Added new
-
v6.4.0 July 19, 2012
- We now support
404 Not Foundand500 Internal Server Errorerror pages thanks to Nick Crohn for pull request #251 - Fixed #269 where the
docpad rendercommand wouldn't work - Fixed #268 where files which names start with a
.from having a.appended to their output filename
- We now support
-
v6.3.3 July 18, 2012
- Fixed binary file output
- Added binary files to the test suite so this won't happen again
- Was due to the dereference on the new clear introduced in v6.3.0
- As such, we now store the
dataattribute for files outside of the attributes, usegetDataandsetData(data)now instead ofget('data')andset({data:data})
- As such, we now store the
- Fixed binary file output
-
v6.3.2 July 18, 2012
- Fixed install action
-
v6.3.1 July 18, 2012
- Fixed
extendCollectionsbeing called before the plugins have loaded when using the CLI
- Fixed
-
v6.3.0 July 18, 2012
- Added support for multiple environments
- Top-level configuration assumed to reflect the production environment, other environments will extend from it
- This is because getting a production environment configuration inside your development environment is fine, however getting a development environment configuration inside your production environment is catastrophic - as such, having the top-level configuration reflect the production environment handles this assumption correctly
- Added environment configuration support to plugins and their configuration
- Removed
package.json > docpad > pluginconfiguration mode for a plugin'spackage.json, they should use theconfigproperty in their class instead - Added
isEnabled()to the plugin class, this reflects theenabledproperty in the plugin configuration, if it is false, then no events are executed for that plugin - Killed the
docpad cliaction, no one used it and introduced a lot of complexity to the codebase - Added
populateCollectionsevent, use this to insert things into our collections and blocks - Added
docpadLoadedevent which fires whenever our configuration is re-loaded - Added support for overriding the
extensionattribute via your document's meta data - Added support for the
renderSingleExtensionsattribute in documents - Fixed
cleanaction from not behaving as expected- Had the wrong indexOf indice value in the check
- Fixed default attributes not being kept inside document and file attributes when cleared
- Turns out Backbone's
Mode::clear()wipes everything, rather than reset to the default attributes and values
- Turns out Backbone's
-
v6.2.0 July 10, 2012
- Dropped node v0.4 support
- Minimum required version is now 0.6
- Dropped
npmdependency - Configuration merging now deep extends plain javascript objects
- Added environment specific configuration support
- By default we use
process.env.NODE_ENVfor the environment, falling back todevelopment - Specify your environment specific configuration in
environments[env] - By default, our production environment sets
maxAgeto one day, andcheckVersionto false - Use
getEnvironmentto get the current environment
- By default we use
- Added new
extendCollectionsevent - Added check during clean action to ensure we don't remove outPath if it is higher than our rootPath
- Added
docpad-serverbinary to shortcut heroku deployment - Scripts collection now supports adding plaintext javascript
consoleSetupoptions are nowconsoleInterfaceandcommanderinstead ofinterfaceandprogram- DocPad's main file is now
out/main.coffeeand the exportedrequireis now limited to files in theoutdirectory (not higher)
- Dropped node v0.4 support
-
v6.1.3 July 8, 2012
- Fixed
extendTemplateDataevent firing before our plugins have finished loading
- Fixed
-
v6.1.2 July 8, 2012
- Fixed
DocPad::getBlock
- Fixed
-
v6.1.1 July 8, 2012
- Added
htmlcollection - Dependency updates
- chai from v1.0 to v1.1
- Added
-
v6.1.0 July 8, 2012
- End user changes
- Added suport for using no skeleton on empty directory
- Action completion callback will now correctly return all arugments instead of just the error argument
- Filename argument on command line is now optional, if specified it now supports single extension values, e.g.
markdowninstead offile.html.md - When using CoffeeScript intead of YAML for meta data headers, the CoffeeScript will now be sandboxed
- If you are wanting to get stuff outside the sandbox write a
docpad.coffeeconfiguration file
- If you are wanting to get stuff outside the sandbox write a
- Document and File model changes
- Now work fine without any path specified
rendersplit intorenderExtensions,renderDocumentandrenderLayoutrenderExtensionsnow supports the optionrenderSingleExtensionswhen specified, will prepend the extensionnull, allowing supported plugins to render single extensionsrendernow supports the optionactionswhich is an array of actions to perform- we now do not clear the
contentRendered,contentRenderedWithoutLayouts, andrenderedproperties between render passes
- DocPad prototype changes
- New Events
extendTemplateData, opts:templateData,extend(objs...)
- Attached Classes
Base,Model,Collection,View,QueryCollectionFileModel,DocumentModelFilesCollection,ElementsCollection,MetaCollection,ScriptsCollection,StylesCollectionPluginLoader,BasePlugin
- New Collection Helpers
getFiles(query,storting,paging)getFile(query,sorting,paging)getFilesAtPath(path,sorting,paging)getFileAtPath(path,sorting,paging)
- New Render Helpers
loadAndRenderDocument(document,opts,next)renderDocument(document,opts,next)renderPath(path,opts,next)renderData(data,opts,next)renderText(text,opts,next)
- New Template Data Helpers
referencesOthers(flag)getDocument()getPath(path,parentPath)getFiles(query,sorting,paging)getFile(query,sorting,paging)getFilesAtPath(path,sorting,paging)getFileAtPath(path,sorting,paging)
- New Events
- Added the following to the export
Backbone,queryEngine
- Dependency updates
- End user changes
-
v6.0.14 June 27, 2012
- Configuration variables
documentPaths,filesPaths, andlayoutsPathsare now relative to thesrcPathinstead of therootPathpluginsPathsis still relative to therootPath
- Configuration variables
-
v6.0.13 June 27, 2012
- Added
getFileModel,getFileUrl,getFiletemplate helpers
- Added
-
v6.0.12 June 26, 2012
- More robust node and git path handling
- Dependency updates
- bal-util from v1.9 to v1.10
-
v6.0.11 June 24, 2012
- We now output that we are actually installing the skeleton, rather than just doing nothing
- We now also always output the skeleton clone and instlalation progress to the user
- Skeletons are now a backbone collection
-
v6.0.10 June 22, 2012
- Fixed CLI on certain setups
-
v6.0.9 June 22, 2012
- Many minor fixes and improvements
- Available DocPad events are now exposed through
docpadInstance.getEvents() - DocPad configuration is now exposed through
docpadInstance.getConfig() - Removed
DocPad::getActionArgsin favor ofbalUtil.extractOptsAndCallback - Configuration events now have a context that persists and do not pile up if configuration is reloaded
- DocPad constructor now returns
erranddocpadInstanceto the completion callback if it exists - Fixed a problem with grouped actions not completing under some circumstances
- Will now watch configuration files for changes, if a change is detected, regenerate everything
- Cleaned up the server action a bit
- Added a new
serverExtendevent so listeners can now extend the server before the docpad routes are applied - Dependency updates
- watchr from v2.0 to v2.1
-
v6.0.8 June 21, 2012
- Configuration changes
- DocPad now checks the following paths for a configuration file
docpad.js,docpad.coffee,docpad.json,docpad.cson, and will go with whichever one it finds first- If you use
coffeeorjsextensions, remember to prefix your file withmodule.exports =
- If you use
- Fixed instance configuration not always coming first
- Removed
configPathconfiguration option. Use the array basedconfigPathsinstead. rootPathandconfigPathswill now be properly respected if specified in yourpackage.jsonfile under thedocpadproperty- Configuration files can now bind event handlers using the
eventshash
- DocPad now checks the following paths for a configuration file
- Event changes
- Completion callbacks are now optional for event listeners, if omitted event listener will be treated as synchronous
- Added new
docpadReadyevent that fires once docpad has finished initializing and loading its configuration, will provide the opts{docpad}wheredocpadis the docpad instance
- Server changes
- If a document has multiple urls, and it is accessed on the non primary url, we will 301 (permanent) redirect to the primary url
- Dependency updates
- Configuration changes
-
v6.0.7 June 20, 2012
- When watching files, and you modify a layout, docpad will now re-render anything using that layout - closes #242
-
v6.0.6 June 19, 2012
- Greatly simplified the event architecture
- We now inherit from the simpler
balUtil.EventEmitterEnhancedinstead ofbalUtil.EventSystem, and have moved queue code intobalUtil.GroupasdocpadInstance.getRunner() - Actions when called directly do not queue, they only queue when called through
docpadInstance.action
- We now inherit from the simpler
docpadinstance.loadConfigurationis now an action calledload- Fixed the run action not completing due to a missing callback
- Greatly simplified the event architecture
-
v6.0.5 June 19, 2012
- Updated QueryEngine from version 1.1 to 1.2
- Fixed watch error when deleting files, or changing a directory
-
v6.0.4 June 19, 2012
- Fixed skeleton action
-
v6.0.3 June 19, 2012
- Fixed
serveraction when used in combination with a custom server
- Fixed
-
v6.0.2 June 11, 2012
- Now fetches the DocPad v6 exchange file
-
v6.0.1 June 11, 2012
- Fixed plugin generation tests
-
v6.0.0 June 11, 2012
- Breaking changes that may affect you
- Removed
documentsPath,filesPath,layoutsPathconfiguration options for their array based alternativesdocumentsPaths,filesPaths,layoutsPaths - Removed
requirefromtemplateDataas it needs to be specified in your project otherwise it has the wrong paths - Removed
database,collections,blocksfromtemplateDatafor their helper based alternativesgetDatabase(),getCollection('collectionName'),getBlock('blockName') - Removed
String::startsWith,String::finsihesWith,Array::hasCount,Array::hasas we never used them - Removed
DocPad::documentsandtemplateData.documents, now usegetCollection('documents')
- Removed
- New features
- Differential rendering
- Extendable CLI
- Template helpers
- Other changes
- Better error handling
- Moved to Joe for unit testing
- Breaking changes that may affect you
-
v5.2.5 May 18, 2012
- Fixed layout selection when two layout's share similar names - Closes #227
-
v5.2.4 May 18, 2012
- Upgraded chai dev dependency from 0.5.x to 1.0.x
- Fixed a dereferencing issue
- Plugin testers will now run the
installandcleanactions when creating the DocPad instance
-
v5.2.3 May 18, 2012
- DocPad will no longer try and use a skeleton inside a non-empty directory
- DocPad will now only include the CoffeeScript runtime if needed (for loading CoffeeScript plugins)
-
v5.2.2 May 17, 2012
-
v5.2.1 May 8, 2012
- Fixed a complication that prevents
src/publicfrom being written toout- Added automated regression tests to ensure this will never happen again
- Added
documentsPaths,filesPaths, andlayoutsPathsconfiguration variables - Simplified model code
- Cleaned up some async code
- Fixed a complication that prevents
-
v5.2.0 May 4, 2012
- We now pre-compile our CoffeeScript
- Added the ability to specify a
docpad.csonconfiguration file inside your website- This file will also be watched for changes, and if a change is made, we'll reload it and regenerate :)
- Database/Collections have been cleaned up
- files, layouts and documents are all added to the database
- documents and layouts are represented by the
Documentmodel which extends theFilemodel - files are represented by the
Filemodel - documents are accessible via the
collections.documentswhich is a live child collection of database - files are accessible via the
collections.fileswhich is a live child collection of database - layouts are accessible via the
collections.layoutswhich is a live child collection of database
- You can create your own live child collections by specifying them in your configuration file, e.g. add this to your
docpad.csonfile:# Collections collections: pages: (database) -> database.findAll(pageOrder: $exists: true) posts: (database) -> database.findAll(tags: $has: 'post')
- Templates now have access to a new function called
include. It will include the renderedContent (or if unavilable to content) of the file. In eco, you would use it like this:<%- @include('filename.ext1.ext2.ext3') %> - Blocks are now Collections too! You can call
.addon them, and use.toHTML()to grab them as HTML (.joinwill do the same thing for b/c) - This should be a completely backwards compatible release, let us know if you any issues on the
-
v5.1.2 April 26, 2012
- Fixed some UTF8 encoded files from being detected as binary
- Fixed documents with no extension being outputted with an undefined extension
-
v5.1.0-5.1.1 April 25, 2012
- Fixed EventEmitter warning
- Binary files can now be placed within the
src/documentsdirectory - Removed eyes devDependency
- Models now use CoffeeScript's class extend, instead of Backbone's extend
-
v5.0.5 April 14, 2012
- Added
.npmignorefile - Added
document.contentTypeanddocument.contentTypeRendered - Fixed
document.contentRenderedon files that do not have layouts - Added tests for:
- Checking that
ignored: truedocuments are properly ignored - That ignored common pattern files/dirs are properly ignored
- That attributes are being applied properly
- Checking that
- Added
-
v5.0.1-v5.0.4 April 14, 2012
- Updated balUtil from 1.4 to 1.5
- Fixes some scandir bugs
- Updated watchr from 1.0 to 2.0
- This should make watching re-generation a lot faster
- Added a warning if you have no plugins loaded and are trying to do a generate
- Fixed ignored check on documents
- Updated balUtil from 1.4 to 1.5
-
v5.0.0 April 14, 2012
- Models are now Backbone Models
- Upgraded Query-Engine version from 0.6 to 1.1
- Plugins are now managed by npm and are no longer bundled with DocPad
- You will need to add them to your website's
package.jsonand install them vianpm install docpad-plugin-#{pluginName} - We now scan the
node_modulesandpluginsdirectories of your website for docpad plugins- These paths can be customised via the
pluginsPathsvariable in the docpad configuration
- These paths can be customised via the
- DocPad detects if something is a plugin by checking for the
docpad-pluginkeyword in thepackage.jsonfile, or if the file follows the#{pluginName}.plugin.coffeenaming convention
- You will need to add them to your website's
- CoffeeScript dependency is now bundled inside, instead of being an external dependency
- A website's npm dependencies are now installed as part of the initialisation process
- This is a big backwards compatibility break, previous skeletons and plugins need to upgraded
- Refer to the Upgrade Guide for instructions
-
v4.1.1 April 9, 2012
- Fixed DocPad from outputting
undefinedinstead the layout's name which it could not find- Thanks to Changwoo Park for the fix, and [https://github.com/msutherl](Mogran Sutherland) for the report
- Fixed DocPad from outputting
-
v4.1.0 April 6, 2012
- Feedr Plugin now exposes
@feedr.feedsto thetemplateDatainstead of@feeds - Exchange data now moved to the docpad-extras repository
- Fixed broken
balupton.docpadskeleton repo url
- Feedr Plugin now exposes
-
v4.0.0-4.0.3 April 6, 2012
- Added support for partials, with the new Partials Plugin
- Added support for caching remote assets, with the new Cachr Plugin
- Added support for caching and parsing remote feeds, with the new Feedr Plugin
- Added support for independent plugin unit tests
- Added support for specifying
templateDatafor the docpad configuration - Skeletons are no longer cached
- Caching skeletons was causing far too many problems
- Will now always use the local npm installation
- Added
gitPathandnodePathto docpad configuration - Split a document's
titleintotitleandname- Use
titlefor page titles (e.g.<title>page title</title>) - Use
namefor navigation listings - This was introduced as sometimes you want a different title for your page title, than for your navigation page names
- Use
- Cleaned up the plugin event system
- When an error occurs we will send an error report back to DocPad using AirBrake
- To turn this off, set
reportErrorsin your docpad configuration tofalse
- To turn this off, set
- Files, Documents, Layouts and Partials are now proper "models" and are now found in the
lib/modelsdirectory - Moved out some unstable or not as popular plugins to the docpad-extras repository, plugins moved are:
- Admin
- Authenticate
- AutoUpdate
- Buildr
- HTML2Jade
- Move
- PHP
- REST
- Roy
- Ruby
-
v3.3.2 March 18, 2012
- Fixed missing interpolation on new version notification
- Fixed the scandir error with the skeletons path when doing the first run on windows
- Updated paths to use
path.joininstead of always using forward slashes
-
v3.3.1 March 18, 2012
- Fixed Pygments plugin highlighting the code multiple times for documents with layouts
- Added
isLayoutandisDocumentflags toDocumentandLayoutprototypes
-
v3.3.0 February 29, 2012
- Fixed ruby rendering with ruby v1.8
- Thanks to Sorin Ionescu - patch here
- The
enabledPluginsconfig option will now correctly only overwrite the default values if you have set it to be a string- Before it would always incorrectly overwrite the default value if set, which would cause some experimental disabled-by-default plugins to enable
- Added a Pygments Syntax Highlighting plugin
- It is disabled by default as not everyone would want syntax highlighting, to enable it, add the following to your website's
package.jsonfile:"docpad": { "enabledPlugins": { "pygments": true } }
- Thanks to Doug Neiner for urging it along
- It is disabled by default as not everyone would want syntax highlighting, to enable it, add the following to your website's
- Added a new
renderDocumentplugin event- It is fired after the extensions are rendered, but before the document is rendered inside its layout
- Useful for things that modify the rendered result of a document, e.g. syntax highlighting, paging, etc
- Closes
- Fixed ruby rendering with ruby v1.8
-
v3.2.8 February 26, 2012
- Stopped
docpad renderfrom outputting the welcome message - Removed
try..catchs from plugins, you should do this too- The checking is now higher up in the callstack, which provides better error reporting and capturing
- Fixed a problem with the error bubbling that was preventing template errors from being outputted
- Fixed the "too many files open" issue thanks to bal-util's
openFileandcloseFileutility functions - Closes
- #143 - No errors on wrong layout
- Stopped
-
v3.2.0-3.2.7 February 15, 2012
- Cleaned architecture
- Added unit tests (uses mocha)
- Better source code documentation
- Moved changelog from
README.mdtoHistory.mdas it was starting to get a bit long - Added
File.writeRendered - Added
File.contentRenderedWithoutLayout - Watching will no longer watch hidden files
- Added support for
- Added the ability to render files programatically via the command line
- See the readme for usage instructions and more information
- Backwards compatibility breaks
- File property names have been changed
- New plugin structure
- Added offline installation support
- Added skeleton selection
- Added npm scripts for testing, installing and updating
- Closes
- #130 - As a Maintainer, I want unit tests, so that I can automatically ensure everything works
- #127 - As a User, I want support for Move, so I can write my javascript in my preferred language
- #122 - As a User, I want to be able to get the rendered content without the layout, so that I can include it inside other documents
- #98 - As a User, I want offline creation, so I can create new docpad projects offline
- #97 - Watching is unusable when combined with hidden files from IDEs and SVN
- #57 - Offline Setup: Skeletons needs to be cached for future offline installs
- #55 - As a User, I want support for Moustache, so that I can use my preferred markup
-
v3.1 Unreleased
- Added an interactive cli
- Closes
- #125 - As a User, I want an Interactive CLI, so that I can do more with DocPad's CLI
-
v3.0 Unreleased
- Added a new event system
- Closes
- #60 - DocPad needs a better event system
-
v2.6 January 2, 2012
- Transferred DocPad's ownership from Benjamin Lupton to Bevry (Benjamin's company)
- Things that have changed
- It is now easier for us to manage DocPad, its extensions, collaborators and future repositories
- Thanks to Github's excellent organisation functionality - https://github.com/blog/674-introducing-organizations
- DocPad is now supported and backed by a commercial entity, meaning that it won't go away
- It is now easier for us to manage DocPad, its extensions, collaborators and future repositories
- Things that won't change
- DocPad will remain free as in beer, and free as in freedom
- DocPad will remain awesome
- If you are working on a cloned version of docpad, be sure to update your docpad's git repo address
- Things that have changed
- Fixed plugin priorities #115
- Thanks to Changwoo Park
- Updated depdencies
- Growl 1.2.x -> 1.4.x - changelog
- CoffeeScript 1.1.3 -> 1.2.x - changelog
- Transferred DocPad's ownership from Benjamin Lupton to Bevry (Benjamin's company)
-
v2.5 December 15, 2011
- Swapped out Dominic Baggott's Markdown.js for Isaac Z. Schlueter's Github-Flavored-Markdown
- Now adds support for inline html in markdown files
- Closes #107
- Now adds support for inline html in markdown files
- Fixed plugin installation on windows
- Fixed the error:
Object #<Object> has no method 'error'- Fixes #106
- Can now pass over options to the coffeekup renderer inside the coffee plugin
- E.g. set
docpad: plugins: coffee: coffeekup: format: trueto have it tidy the html output - Thanks to Changwoo Park
- E.g. set
- Disabled the following plugins by default
- Admin
- Authenticate
- Rest
- AutoUpdate
- Buildr
- Html2Jade
- Updated depdencies
- Commander 0.3.x -> 0.5.x - changelog
- Growl 1.1.x -> 1.2.x - changelog
- NPM 1.0.x -> 1.1.x
- Jade 0.17.x -> 0.19.x - changelog
- Stylus 0.19.x -> 0.20.x - changelog
- Nib 0.2.x -> 0.3.x - changelog
- Swapped out Dominic Baggott's Markdown.js for Isaac Z. Schlueter's Github-Flavored-Markdown
-
v2.4 November 26, 2011
- AutoUpdate plugin
- Automatically refreshes the user's current page when the website is regenerated
- Very useful for development, though you probably want to disable it for production
- Enabled by default
- AutoUpdate plugin
-
v2.3 November 18, 2011
- Heroku server support
- Added
extendServerconfiguration option- Now, by default, even if the server is provided, we will extend it. If you do not want this, set this configuration option to
false.
- Now, by default, even if the server is provided, we will extend it. If you do not want this, set this configuration option to
- Made it easier to load docpad as a module
- Instead of crashing when an uncaught error happens, it'll output it and keep running
- The log messages and next handling in
docpad.actionhas been cleaned up- Now those log messages are contained within the default next handler, so if you provide a custom default next handler you'll have to do your own success log messages
- NPM is now installed locally
- This is to ensure it's availability on cloud servers
- DocPad will now try and figure out the node executable location to provide greater compatibility on cloud servers
- If the plugin installations are taking a while, you'll get informed of this, rather than just staring at a blank blinking cursor
- Roy plugin
- Adds Roy to JavaScript support
.js.roy
- Adds Roy to JavaScript support
-
v2.2 November 14, 2011
- Windows support!
- Now uses Benjamin Lupton's Watchr as the watcher library
- Provides windows support
- Now uses Tim Caswell's Haml.js as the haml library
- Provides windows support
- Bug fixes
- Works with zero documents
- Works with empty
package.json - Fixed mime-type problems with documents
-
v2.1 November 10, 2011
- Support for dynamic documents
- These are re-rendered on each request, must use the docpad server
- See the search example in the kitchensink skeleton
- Removed deprecated
@Document,@Documents, and@Sitefrom thetemplateData(the variables available to the templates). Use their lowercase equivalants instead. This can cause backwards compatibility problems with your templates, the console will notify you if there is a problem. - Fixed
docpad --versionreturningnullinstead of the docpad version
- Support for dynamic documents
-
v2.0 November 8, 2011
- Upgrade guide for 1.x users
- Tested and working on Node 0.4, 0.5, and 0.6
- Windows support is still to come - track it's progress here
- Configurable via
package.json- DocPad is now configurable via its and your website's
package.jsonfile
- DocPad is now configurable via its and your website's
- New plugin architecture
- Plugins must now be isolated in their own directory
- Plugins can now have their own
package.jsonfile- Use this for specifying plugin configuration, dependencies, etc
- Plugin events have been renamed to before/after
- New before/after events have been added
docpadandloggerare now local variables, rather than passed arguments- Arguments are still kept for backwards compatibility - this may change
- Generation changes
- Rendering is now a 2-pass process
- Contextualize is now a sub-step of parse, instead of it's own main step
- Better simplicity, less complexity
- Documents can now have multiple urls
- These are customisable via the document's
urlsarray property
- These are customisable via the document's
- Plugin Changes
- REST plugin supports saving document data via POST (disabled by default)
- Administration plugin adds front-end admin functionality (disabled by default)
- See the client side editing example in the kitchensink skeleton
- SASS plugin
- Adds SASS to CSS support
- Uses TJ Holowaychuk's Sass.js - https://github.com/visionmedia/sass.js
- Adds SASS to CSS support
- Coffee Plugin
- Removed CoffeeCSS support as it had problems
-
v1.4 October 22, 2011
- Template engines now have access to node.js's
require - Less Plugin
- Added LessCSS to CSS support
- Uses Alexis Sellier's Less.js
- Added LessCSS to CSS support
- Fixed NPM warning about incorrect property name
- Logged errors will now also output their stacktraces for easier debugging
- If an error occurs during rendering of a document, docpad will let us know which document it happened on
- Template engines now have access to node.js's
-
v1.3 October 3, 2011
- Parsing is now split into two parts
parsingandcontextualizing- Contextualizing is used to determine the result filename, and title if title was not set
- The code is now more concise
- File class moved to
lib/file.coffee - Prototypes moved to
lib/prototypes.coffee - Version checking moved to the
bal-utilmodule
- File class moved to
- File properties have changed
basenameis extensionlessfilenamenow contains the file's extnesionsidis now therelativeBaseinstead of theslugextensionRenderedis the result extensionfilenameRenderedis the result filename: `"#{basename}.#{extensionRendered}"titleif now set tofilenameRenderedif not set
- Added support for different meta parsers, starting with CoffeeScript and YAML support. YAML is still the default meta parser
- The YAML dependency is specifically set now to v0.2.1 as the newer version has a bug in it
- Fixed multiple renderers for a single document. E.g.
file.html.md.eco - Now also supports using
###along with---for wrapping the meta data - Supports the
publicalias for thefilesdirectory
- Parsing is now split into two parts
-
v1.2 September 29, 2011
- Plugins now conform to a
.plugin.coffeenaming standard - Dependencies now allow for minor patches
- Stylus Plugin
- Added Stylus to CSS support
- Uses TJ Holowaychuk's Stylus
- Added Stylus to CSS support
- Jade Plugin
- Added HTML to Jade support
- Uses Don Park's Html2Jade
- Added HTML to Jade support
- Coffee Plugin
- Added CoffeeCSS to CSS support
- Uses James Campos's CCSS
- Added CoffeeCSS to CSS support
- Fixed incorrect date sorting for documents
- Thanks to Olivier Bazoud
- Plugins now conform to a
-
v1.1 September 28, 2011
- Added Buildr Plugin so you can now bundle your scripts and styles together :-)
- The
actionmethod now supports an optional callback- Thanks to #41 by Aaron Powell
- Added a try..catch around the version detection to ensure it never kills docpad if something goes wrong
- Skeletons have been removed from the repository due to circular references. The chosen skeleton is now pulled during the skeleton action. We also now perform a recursive git submodule init and update, as well as a npm install if necessary.
-
v1.0 September 20, 2011
- Upgrade guide for v0.x users
- The concept of template engines and markup languages have been merged into the concept of renderers
- Coffee Plugin
- Added CoffeeKup to anything and HTML to CoffeeKup support
- Added CoffeeScript to JavaScript and JavaScript to CoffeeScript support
- Added a Commander.js based CLI
- Thanks to ~eldios
- Added support for Growl notificaitons
- Added asynchronous version comparison
-
v0.10 September 14, 2011
- Plugin infrastructure
- Better logging through Caterpillar
- HAML Plugin
- Added HAML to anything support
- Uses TJ Holowaychuk's HAML
- Added HAML to anything support
- Jade Plugin
- Added Jade to anything support
- Uses TJ Holowaychuk's Jade
- Added Jade to anything support
-
v0.9 July 6, 2011
- No longer uses MongoDB/Mongoose! We now use Query-Engine which doesn't need any database server :)
- Watching files now working even better
- Now supports clean urls :)
-
v0.8 May 23, 2011
- Now supports mutliple skeletons
- Structure changes
-
v0.7 May 20, 2011
- Now supports multiple docpad instances
-
v0.6 May 12, 2011
- Moved to CoffeeScript
- Removed highlight.js (should be a plugin or client-side feature)
-
v0.5 May 9, 2011
- Pretty big clean
-
v0.4 May 9, 2011
- The CLI is now working as documented
-
v0.3 May 7, 2011
- Got the generation and server going
-
v0.2 March 24, 2011
- Prototyping with disenchant
-
v0.1 March 16, 2011
- Initial commit with bergie