| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 | #!/usr/bin/env nodevar fs = require("fs"),    path = require("path"),    commander = require("commander"),    topojson = require("../");commander    .version(require("../package.json").version)    .usage("[options] <name=file>…")    .description("Converts TopoJSON objects to GeoJSON features.")    .option("-i, --in <file>", "input topology file name; defaults to “-” for stdin", "-")    .option("-l, --list", "list the object names on the input topology")    .option("-n, --newline-delimited", "output newline-delimited JSON")    .parse(process.argv);if (!commander.list === commander.args.length < 1) {  console.error();  console.error("  error: " + (commander.list ? "--list does not take arguments" : "no arguments specified"));  console.error();  process.exit(1);}read(commander.in).then(write).catch(abort);function read(file) {  return new Promise(function(resolve, reject) {    var data = [];    readStream(file)        .on("data", function(d) { data.push(d); })        .on("end", function() { resolve(JSON.parse(Buffer.concat(data))); })        .on("error", reject);  });}function readStream(file) {  return file === "-" ? process.stdin : fs.createReadStream(file);}function write(topology) {  var write, writer = commander.newlineDelimited ? writeNewlineDelimitedFeature : writeFeature, name;  if (commander.list) {    for (name in topology.objects) {      console.log(name);    }    return;  }  write = Promise.resolve();  commander.args.forEach(function(specifier) {    var i = specifier.indexOf("="),        file = i >= 0 ? specifier.slice(i + 1) : specifier,        name = i >= 0 ? specifier.slice(0, i) : path.basename(specifier, path.extname(specifier));    if (!(name in topology.objects)) {      console.error();      console.error("  error: object “" + name + "” not found");      console.error();      process.exit(1);    }    write = write.then(writer(file, topojson.feature(topology, topology.objects[name])));  });  return write;}function writeStream(file) {  return (file === "-" ? process.stdout : fs.createWriteStream(file)).on("error", handleEpipe);}function writeFeature(file, feature) {  return new Promise(function(resolve, reject) {    writeStream(file).on("error", reject)[file === "-" ? "write" : "end"](JSON.stringify(feature) + "\n", function(error) {      if (error) reject(error);      else resolve();    });  });}function writeNewlineDelimitedFeature(file, feature) {  return feature == null || feature.type != "FeatureCollection" ? writeFeature(file, feature) : new Promise(function(resolve, reject) {    var stream = writeStream(file).on("error", reject), i = -1, n = feature.features.length;    (function writeNext(error) {      if (error) return void reject(error);      if (++i >= n) {        if (file !== "-") stream.end(writeEnd);        else writeEnd();      } else {        stream.write(JSON.stringify(feature.features[i]) + "\n", writeNext);      }    })(null);    function writeEnd(error) {      if (error) return void reject(error);      resolve();    }  });}function handleEpipe(error) {  if (error.code === "EPIPE" || error.errno === "EPIPE") {    process.exit(0);  }}function abort(error) {  console.error(error.stack);}
 |