JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 2524
  • Score
    100M100P100Q124778F
  • License BSD

code-stringify is node.js module that converts JavaScript variables into source codes. Unlike JSON.stringify, code-stringify converts things into strings of code, not JSON.

Package Exports

  • code-stringify

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (code-stringify) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Build Status

code-stringify

code-stringify is the node.js module that converts JavaScript variables into source codes.

Unlike JSON.stringify, code-stringify also deals with reference(object) types of variables, and it converts JavaScript variables into strings of codes, not JSON.

Installation

npm install code-stringify --save

Usage

const code = require('code-stringify')
const obj = {
  0: 1,
  a: function(n){return n;},
  b: 1,
  'c-d': 3
}

const fs = require('fs')

// So you can use code-stringify to save your javascript variables into a file:
fs.writeFileSync(
  'output.js',
  'module.exports = ' + code(a, null, 2)
)

Then 'output.js' will look like:

module.exports = {
  0: 1,
  a: function (n){return n;},
  b: 1,
  "c-d": 3
}

code(subject, replacer, space)

subject mixed

The subject to be converted

replacer function(key, value)

The replacer argument acts just like the second parameter of JSON.stringify.

space number

The space argument acts just like the third parameter of JSON.stringify.

code.Code(string)

If an object obj has a prototype property toCode and obj.toCode is an function, then code(obj) will be equal to obj.toCode().

We could use new code.Code(code_string) to define an already-stringified property.

So, see the example below:

let output = 'module.exports = ' + code({
  a: 1,
  'foo-bar': 2,
  foo: new code.Code('(function(a){return a})(3)')
})

saveFile(output, 'output.js')

And the output.js will be:

module.exports = {
  a: 1,
  'foo-bar': 2,
  foo: (function(a){return a})(3)
}

Known Issues

  • Can't deal with recursive objects or arrays SO FAR.
  • space parameter could not affect the code indent inside functions.
  • Could not deal with variable scope so far.

Those issues or tasks which should be done to enhance the module might be fixed in the future. Or there will be a million thanks if you fork and contribute ~~