// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
// USE OR OTHER DEALINGS IN THE SOFTWARE.
-#include <node.h>
-#include <node_buffer.h>
-#include <req_wrap.h>
-#include <handle_wrap.h>
-#include <stream_wrap.h>
+#include "node.h"
+#include "node_buffer.h"
+#include "req_wrap.h"
+#include "handle_wrap.h"
+#include "stream_wrap.h"
+#include "tty_wrap.h"
namespace node {
-using v8::Object;
+using v8::Arguments;
+using v8::Context;
+using v8::Function;
+using v8::FunctionTemplate;
using v8::Handle;
+using v8::HandleScope;
+using v8::Integer;
using v8::Local;
+using v8::Object;
using v8::Persistent;
-using v8::Value;
-using v8::HandleScope;
-using v8::FunctionTemplate;
+using v8::PropertyAttribute;
using v8::String;
-using v8::Function;
using v8::TryCatch;
-using v8::Context;
-using v8::Arguments;
-using v8::Integer;
using v8::Undefined;
+using v8::Value;
-#define UNWRAP \
- assert(!args.Holder().IsEmpty()); \
- assert(args.Holder()->InternalFieldCount() > 0); \
- TTYWrap* wrap = \
- static_cast<TTYWrap*>(args.Holder()->GetPointerFromInternalField(0)); \
- if (!wrap) { \
- uv_err_t err; \
- err.code = UV_EBADF; \
- SetErrno(err); \
- return scope.Close(Integer::New(-1)); \
- }
+void TTYWrap::Initialize(Handle<Object> target) {
+ StreamWrap::Initialize(target);
-class TTYWrap : StreamWrap {
- public:
- static void Initialize(Handle<Object> target) {
- StreamWrap::Initialize(target);
+ HandleScope scope(node_isolate);
- HandleScope scope;
+ Local<FunctionTemplate> t = FunctionTemplate::New(New);
+ t->SetClassName(String::NewSymbol("TTY"));
- Local<FunctionTemplate> t = FunctionTemplate::New(New);
- t->SetClassName(String::NewSymbol("TTY"));
+ t->InstanceTemplate()->SetInternalFieldCount(1);
- t->InstanceTemplate()->SetInternalFieldCount(1);
+ enum PropertyAttribute attributes =
+ static_cast<PropertyAttribute>(v8::ReadOnly | v8::DontDelete);
+ t->InstanceTemplate()->SetAccessor(String::New("fd"),
+ StreamWrap::GetFD,
+ NULL,
+ Handle<Value>(),
+ v8::DEFAULT,
+ attributes);
- NODE_SET_PROTOTYPE_METHOD(t, "close", HandleWrap::Close);
- NODE_SET_PROTOTYPE_METHOD(t, "unref", HandleWrap::Unref);
+ NODE_SET_PROTOTYPE_METHOD(t, "close", HandleWrap::Close);
+ NODE_SET_PROTOTYPE_METHOD(t, "unref", HandleWrap::Unref);
- NODE_SET_PROTOTYPE_METHOD(t, "readStart", StreamWrap::ReadStart);
- NODE_SET_PROTOTYPE_METHOD(t, "readStop", StreamWrap::ReadStop);
- NODE_SET_PROTOTYPE_METHOD(t, "write", StreamWrap::Write);
+ NODE_SET_PROTOTYPE_METHOD(t, "readStart", StreamWrap::ReadStart);
+ NODE_SET_PROTOTYPE_METHOD(t, "readStop", StreamWrap::ReadStop);
- NODE_SET_PROTOTYPE_METHOD(t, "getWindowSize", TTYWrap::GetWindowSize);
- NODE_SET_PROTOTYPE_METHOD(t, "setRawMode", SetRawMode);
+ NODE_SET_PROTOTYPE_METHOD(t, "writeBuffer", StreamWrap::WriteBuffer);
+ NODE_SET_PROTOTYPE_METHOD(t, "writeAsciiString", StreamWrap::WriteAsciiString);
+ NODE_SET_PROTOTYPE_METHOD(t, "writeUtf8String", StreamWrap::WriteUtf8String);
+ NODE_SET_PROTOTYPE_METHOD(t, "writeUcs2String", StreamWrap::WriteUcs2String);
- NODE_SET_METHOD(target, "isTTY", IsTTY);
- NODE_SET_METHOD(target, "guessHandleType", GuessHandleType);
+ NODE_SET_PROTOTYPE_METHOD(t, "getWindowSize", TTYWrap::GetWindowSize);
+ NODE_SET_PROTOTYPE_METHOD(t, "setRawMode", SetRawMode);
+
+ NODE_SET_METHOD(target, "isTTY", IsTTY);
+ NODE_SET_METHOD(target, "guessHandleType", GuessHandleType);
+
+ target->Set(String::NewSymbol("TTY"), t->GetFunction());
+}
+
+
+TTYWrap* TTYWrap::Unwrap(Local<Object> obj) {
+ assert(!obj.IsEmpty());
+ assert(obj->InternalFieldCount() > 0);
+ return static_cast<TTYWrap*>(obj->GetAlignedPointerFromInternalField(0));
+}
- target->Set(String::NewSymbol("TTY"), t->GetFunction());
- }
- private:
- static Handle<Value> GuessHandleType(const Arguments& args) {
- HandleScope scope;
- int fd = args[0]->Int32Value();
- assert(fd >= 0);
+uv_tty_t* TTYWrap::UVHandle() {
+ return &handle_;
+}
- uv_handle_type t = uv_guess_handle(fd);
- switch (t) {
- case UV_TTY:
- return scope.Close(String::New("TTY"));
+Handle<Value> TTYWrap::GuessHandleType(const Arguments& args) {
+ HandleScope scope(node_isolate);
+ int fd = args[0]->Int32Value();
+ assert(fd >= 0);
- case UV_NAMED_PIPE:
- return scope.Close(String::New("PIPE"));
+ uv_handle_type t = uv_guess_handle(fd);
- case UV_FILE:
- return scope.Close(String::New("FILE"));
+ switch (t) {
+ case UV_TTY:
+ return scope.Close(String::New("TTY"));
- default:
- assert(0);
- return v8::Undefined();
- }
+ case UV_NAMED_PIPE:
+ return scope.Close(String::New("PIPE"));
+
+ case UV_FILE:
+ return scope.Close(String::New("FILE"));
+
+ case UV_UNKNOWN_HANDLE:
+ return scope.Close(String::New("UNKNOWN"));
+
+ default:
+ assert(0);
+ return v8::Undefined(node_isolate);
}
+}
+
- static Handle<Value> IsTTY(const Arguments& args) {
- HandleScope scope;
- int fd = args[0]->Int32Value();
- assert(fd >= 0);
- return uv_guess_handle(fd) == UV_TTY ? v8::True() : v8::False();
+Handle<Value> TTYWrap::IsTTY(const Arguments& args) {
+ HandleScope scope(node_isolate);
+ int fd = args[0]->Int32Value();
+ assert(fd >= 0);
+
+ if (uv_guess_handle(fd) == UV_TTY) {
+ return v8::True(node_isolate);
}
- static Handle<Value> GetWindowSize(const Arguments& args) {
- HandleScope scope;
-
- UNWRAP
+ return v8::False(node_isolate);
+}
+
- int width, height;
- int r = uv_tty_get_winsize(&wrap->handle_, &width, &height);
+Handle<Value> TTYWrap::GetWindowSize(const Arguments& args) {
+ HandleScope scope(node_isolate);
- if (r) {
- SetErrno(uv_last_error(uv_default_loop()));
- return v8::Undefined();
- }
+ UNWRAP(TTYWrap)
- Local<v8::Array> a = v8::Array::New(2);
- a->Set(0, Integer::New(width));
- a->Set(1, Integer::New(height));
+ int width, height;
+ int r = uv_tty_get_winsize(&wrap->handle_, &width, &height);
- return scope.Close(a);
+ if (r) {
+ SetErrno(uv_last_error(uv_default_loop()));
+ return v8::Undefined(node_isolate);
}
- static Handle<Value> SetRawMode(const Arguments& args) {
- HandleScope scope;
+ Local<v8::Array> a = v8::Array::New(2);
+ a->Set(0, Integer::New(width, node_isolate));
+ a->Set(1, Integer::New(height, node_isolate));
+
+ return scope.Close(a);
+}
+
- UNWRAP
+Handle<Value> TTYWrap::SetRawMode(const Arguments& args) {
+ HandleScope scope(node_isolate);
- int r = uv_tty_set_mode(&wrap->handle_, args[0]->IsTrue());
+ UNWRAP(TTYWrap)
- if (r) {
- SetErrno(uv_last_error(uv_default_loop()));
- }
+ int r = uv_tty_set_mode(&wrap->handle_, args[0]->IsTrue());
- return scope.Close(Integer::New(r));
+ if (r) {
+ SetErrno(uv_last_error(uv_default_loop()));
}
- static Handle<Value> New(const Arguments& args) {
- HandleScope scope;
+ return scope.Close(Integer::New(r, node_isolate));
+}
- // This constructor should not be exposed to public javascript.
- // Therefore we assert that we are not trying to call this as a
- // normal function.
- assert(args.IsConstructCall());
- int fd = args[0]->Int32Value();
- assert(fd >= 0);
+Handle<Value> TTYWrap::New(const Arguments& args) {
+ HandleScope scope(node_isolate);
- TTYWrap* wrap = new TTYWrap(args.This(), fd, args[1]->IsTrue());
- assert(wrap);
- wrap->UpdateWriteQueueSize();
+ // This constructor should not be exposed to public javascript.
+ // Therefore we assert that we are not trying to call this as a
+ // normal function.
+ assert(args.IsConstructCall());
- return scope.Close(args.This());
- }
+ int fd = args[0]->Int32Value();
+ assert(fd >= 0);
+
+ TTYWrap* wrap = new TTYWrap(args.This(), fd, args[1]->IsTrue());
+ assert(wrap);
+ wrap->UpdateWriteQueueSize();
+
+ return scope.Close(args.This());
+}
- TTYWrap(Handle<Object> object, int fd, bool readable)
- : StreamWrap(object, (uv_stream_t*)&handle_) {
- uv_tty_init(uv_default_loop(), &handle_, fd, readable);
- }
- uv_tty_t handle_;
-};
+TTYWrap::TTYWrap(Handle<Object> object, int fd, bool readable)
+ : StreamWrap(object, (uv_stream_t*)&handle_) {
+ uv_tty_init(uv_default_loop(), &handle_, fd, readable);
+}
} // namespace node
-NODE_MODULE(node_tty_wrap, node::TTYWrap::Initialize);
+NODE_MODULE(node_tty_wrap, node::TTYWrap::Initialize)