// This is a generated file, modify: generate/templates/class.cc.
#include <nan.h>
#include <string.h>

extern "C" {
#include <git2.h>
}

#include "../include/functions/copy.h"
#include "../include/refdb.h"

#include "../include/refdb.h"
#include "../include/repository.h"

using namespace v8;
using namespace node;

GitRefdb::GitRefdb(git_refdb *raw) {
  this->raw = raw;
}

GitRefdb::~GitRefdb() {
    git_refdb_free(this->raw);
  }

void GitRefdb::Initialize(Handle<v8::Object> target) {
  NanScope();

  Local<FunctionTemplate> tpl = NanNew<FunctionTemplate>(New);

  tpl->InstanceTemplate()->SetInternalFieldCount(1);
  tpl->SetClassName(NanNew<String>("Refdb"));

  
  
  Local<Function> _constructor_template = tpl->GetFunction();
  NanAssignPersistent(constructor_template, _constructor_template);
  target->Set(NanNew<String>("Refdb"), _constructor_template);
}

NAN_METHOD(GitRefdb::New) {
  NanScope();

  if (args.Length() == 0 || !args[0]->IsExternal()) {
    return NanThrowError("git_refdb is required.");
  }
  GitRefdb* object = new GitRefdb(static_cast<git_refdb *>(Handle<External>::Cast(args[0])->Value()));
  object->Wrap(args.This());

  NanReturnValue(args.This());
}

Handle<Value> GitRefdb::New(void *raw) {
  NanEscapableScope();
  Handle<Value> argv[1] = { NanNew<External>((void *)raw) };
  return NanEscapeScope(NanNew<Function>(GitRefdb::constructor_template)->NewInstance(1, argv));
}

git_refdb *GitRefdb::GetValue() {
  return this->raw;
}



Persistent<Function> GitRefdb::constructor_template;
