From 63c0d71213da10944f8ed35759db744b313be931 Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Tue, 17 May 2011 13:22:34 -0700 Subject: [PATCH 1/2] Changes for job bullets --- doc/index.html | 3 ++- doc/pipe.css | 8 +++++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/doc/index.html b/doc/index.html index ae2c76e4cc1..758f02f8e51 100644 --- a/doc/index.html +++ b/doc/index.html @@ -30,9 +30,10 @@
  • Wiki
  • Blog
  • -
  • Jobs
  • Community
  • Demo
  • +
  • Jobs
  • +
    diff --git a/doc/pipe.css b/doc/pipe.css index c86bf2ae36a..5d9edfea4ba 100644 --- a/doc/pipe.css +++ b/doc/pipe.css @@ -15,7 +15,7 @@ img { position: absolute; top: 2em; left: 0; - width: 8em; + width: 10em; font-size: 12pt; line-height: 150%; } @@ -42,6 +42,12 @@ h1, h2, h3, h4 { margin: 2em 0; } +#toc ol ol { + font-size: 8pt; + line-height: 110%; + list-style: circle; +} + h1 code, h2 code, h3 code, h4 code, h1 a, h2 a, h3 a, h4 a { From f4e69e44ff3b73921e1a009df104f3db962f10ee Mon Sep 17 00:00:00 2001 From: David Trejo Date: Wed, 18 May 2011 18:39:06 -0700 Subject: [PATCH 2/2] readline docs --- doc/api/readline.md | 133 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 133 insertions(+) create mode 100644 doc/api/readline.md diff --git a/doc/api/readline.md b/doc/api/readline.md new file mode 100644 index 00000000000..ea2a7f2e4a3 --- /dev/null +++ b/doc/api/readline.md @@ -0,0 +1,133 @@ +## Readline + +To use this module, do `require('readline')`. Readline allows reading of a +stream (such as STDIN) on a line-by-line basis. + +Note that once you've invoked this module, your node program will not +terminate until you've closed the interface, and the STDIN stream. Here's how +to allow your program to gracefully terminate: + + var rl = require('readline'); + + var i = rl.createInterface(process.sdtin, process.stdout, null); + i.question("What do you think of node.js?", function(answer) { + // TODO: Log the answer in a database + console.log("Thank you for your valuable feedback."); + + // These two lines together allow the program to terminate. Without + // them, it would run forever. + i.close(); + process.stdin.destroy(); + }); + +### rl.createInterface(input, output, completer) + +Takes two streams and creates a readline interface. The `completer` function +is used for autocompletion. When given a substring, it returns `[[substr1, +substr2, ...], originalsubstring]`. + +`createInterface` is commonly used with `process.stdin` and +`process.stdout` in order to accept user input: + + var readline = require('readline'), + rl = readline.createInterface(process.stdin, process.stdout); + +### rl.setPrompt(prompt, length) + +Sets the prompt, for example when you run `node` on the command line, you see +`> `, which is node's prompt. + +### rl.prompt() + +Readies readline for input from the user, putting the current `setPrompt` +options on a new line, giving the user a new spot to write. + + + +### rl.question(query, callback) + +Prepends the prompt with `query` and invokes `callback` with the user's +response. Displays the query to the user, and then invokes `callback` with the +user's response after it has been typed. + +Example usage: + + interface.question('What is your favorite food?', function(answer) { + console.log('Oh, so your favorite food is ' + answer); + }); + +### rl.close() + + Closes tty. + +### rl.pause() + + Pauses tty. + +### rl.resume() + + Resumes tty. + +### rl.write() + + Writes to tty. + +### Event: 'line' + +`function (line) {}` + +Emitted whenever the `in` stream receives a `\n`, usually received when the +user hits enter, or return. This is a good hook to listen for user input. + +Example of listening for `line`: + + rl.on('line', function (cmd) { + console.log('You just typed: '+cmd); + }); + +### Event: 'close' + +`function () {}` + +Emitted whenever the `in` stream receives a `^C` or `^D`, respectively known +as `SIGINT` and `EOT`. This is a good way to know the user is finished using +your program. + +Example of listening for `close`, and exiting the program afterward: + + rl.on('close', function() { + console.log('goodbye!'); + process.exit(0); + }); + +Here's an example of how to use all these together to craft a tiny command +line interface: + + var readline = require('readline'), + rl = readline.createInterface(process.stdin, process.stdout), + prefix = 'OHAI> '; + + rl.on('line', function(line) { + switch(line.trim()) { + case 'hello': + console.log('world!'); + break; + default: + console.log('Say what? I might have heard `' + line.trim() + '`'); + break; + } + rl.setPrompt(prefix, prefix.length); + rl.prompt(); + }).on('close', function() { + console.log('Have a great day!'); + process.exit(0); + }); + console.log(prefix + 'Good to see you. Try typing stuff.'); + rl.setPrompt(prefix, prefix.length); + rl.prompt(); + + +Take a look at this slightly more complicated +[example](https://gist.github.com/901104), and +[http-console](http://github.com/cloudhead/http-console) for a real-life use +case. \ No newline at end of file