meteor-package-json
A helper for Meteor build plugin authors (for now) who need info from the apps package.json.  Watches the file and has a callback for your package to accept changes to it's relevant section, otherwise quits Meteor asking for the user to restart.
Quick Start
For the examples below, assume we are developing john:doe and have the following package.json:
1{ 2 "john:doe": { 3 "experimental": false 4 } 5}
Simple Fetch
1const config = packageJson.getPackageConfig('john:doe'); 2expect(config).to.deep.equal({ experimental: true });
If the john:doe section is modified, Meteor will exit.  If any other part of the file is modified, nothing happens.  But it's even better if you can accept the changes to avoid a restart.
Accepting Changes
1// The callback below is only ever called if prev does not deep equal next 2const config = packageJson.getPackageConfig('john:doe', (prev, next) => { 3 if (prev.experimental !== next.experiemnetal) { 4 enableExperimentalFeatures(next.experimental); 5 } 6 7 // We can accept this change; no need to restart Meteor. 8 return true; 9}); 10 11// On initial load 12if (config.experimental) 13 enableExperimentalFeatures(true);
API
- 
packageJson.getPackageConfig('sectionName', [acceptHandler]);- Returns the sectionNameproperty frompackage.json.
- If the properties in sectionNamehave changed (are not deeply equal), then, Meteor will quite if noacceptHandleris given, or ifacceptHandler(prevSection, newSection)does not returntrue.
- For both the initial return and acceptHandler, if the section is undefined, an empty object ({}) will be returned, so no need to test for this in your code.
 
- Returns the 
Development && testing
npm test or with Wallaby.js.

