Browse Source

store config in package.json or .local-web-server.json

master
Lloyd Brookes 11 years ago
parent
commit
f558855d3b
  1. 32
      ws.js

32
ws.js

@ -4,8 +4,10 @@ require("console-dope");
var connect = require("connect"),
http = require("http"),
util = require("util"),
fs = require("fs"),
Thing = require("nature").Thing,
w = require("wodge");
w = require("wodge"),
path = require("path");
var usage = "usage: ws [--directory|-d <directory>] [--port|-p <port>] [--log-format|-f dev|default|short|tiny]";
@ -15,6 +17,14 @@ function halt(message){
process.exit(1);
}
function handleServerError(err){
if (err.code === "EADDRINUSE"){
halt("port " + argv.port + " is already is use");
} else {
halt(err.message);
}
}
/**
parse command-line args
*/
@ -29,12 +39,20 @@ var argv = new Thing()
})
.set(process.argv);
function handleServerError(err){
if (err.code === "EADDRINUSE"){
halt("port " + argv.port + " is already is use");
} else {
halt(err.message);
}
/*
Include any options from "package.json", ".local-web-server.json" or "~/.local-web-server.json", in that order
*/
var pkgPath = path.join(process.cwd(), "package.json"),
lwsPath = path.join(process.cwd(), ".local-web-server.json"),
homePath = path.join(w.getHomeDir(), ".local-web-server.json");
if (fs.existsSync(pkgPath)){
argv.set(require(pkgPath)["local-web-server"]);
}
if (fs.existsSync(lwsPath)){
argv.set(require(lwsPath));
}
if (fs.existsSync(homePath)){
argv.set(require(homePath));
}
/**

Loading…
Cancel
Save