Add converters between gfx:: and v8
This commit is contained in:
parent
dacbf7a042
commit
2d8fe489a7
4 changed files with 99 additions and 73 deletions
1
atom.gyp
1
atom.gyp
|
@ -227,6 +227,7 @@
|
||||||
'atom/common/native_mate_converters/accelerator_converter.cc',
|
'atom/common/native_mate_converters/accelerator_converter.cc',
|
||||||
'atom/common/native_mate_converters/accelerator_converter.h',
|
'atom/common/native_mate_converters/accelerator_converter.h',
|
||||||
'atom/common/native_mate_converters/file_path_converter.h',
|
'atom/common/native_mate_converters/file_path_converter.h',
|
||||||
|
'atom/common/native_mate_converters/gfx_converter.h',
|
||||||
'atom/common/native_mate_converters/gurl_converter.h',
|
'atom/common/native_mate_converters/gurl_converter.h',
|
||||||
'atom/common/native_mate_converters/image_converter.cc',
|
'atom/common/native_mate_converters/image_converter.cc',
|
||||||
'atom/common/native_mate_converters/image_converter.h',
|
'atom/common/native_mate_converters/image_converter.h',
|
||||||
|
|
|
@ -6,13 +6,11 @@
|
||||||
|
|
||||||
#include "atom/browser/api/atom_api_web_contents.h"
|
#include "atom/browser/api/atom_api_web_contents.h"
|
||||||
#include "atom/browser/native_window.h"
|
#include "atom/browser/native_window.h"
|
||||||
|
#include "atom/common/native_mate_converters/gfx_converter.h"
|
||||||
#include "content/public/browser/render_process_host.h"
|
#include "content/public/browser/render_process_host.h"
|
||||||
#include "native_mate/callback.h"
|
#include "native_mate/callback.h"
|
||||||
#include "native_mate/constructor.h"
|
#include "native_mate/constructor.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "ui/gfx/point.h"
|
|
||||||
#include "ui/gfx/rect.h"
|
|
||||||
#include "ui/gfx/size.h"
|
|
||||||
|
|
||||||
#include "atom/common/node_includes.h"
|
#include "atom/common/node_includes.h"
|
||||||
|
|
||||||
|
@ -40,23 +38,6 @@ struct Converter<PrintSettings> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template<>
|
|
||||||
struct Converter<gfx::Rect> {
|
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
|
||||||
v8::Handle<v8::Value> val,
|
|
||||||
gfx::Rect* out) {
|
|
||||||
if (!val->IsObject())
|
|
||||||
return false;
|
|
||||||
mate::Dictionary dict(isolate, val->ToObject());
|
|
||||||
int x, y, width, height;
|
|
||||||
if (!dict.Get("x", &x) || !dict.Get("y", &y) ||
|
|
||||||
!dict.Get("width", &width) || !dict.Get("height", &height))
|
|
||||||
return false;
|
|
||||||
*out = gfx::Rect(x, y, width, height);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace mate
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
|
@ -2,61 +2,9 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#include "native_mate/dictionary.h"
|
#include "atom/common/native_mate_converters/gfx_converter.h"
|
||||||
#include "ui/gfx/screen.h"
|
|
||||||
|
|
||||||
#include "atom/common/node_includes.h"
|
#include "atom/common/node_includes.h"
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
template<>
|
|
||||||
struct Converter<gfx::Point> {
|
|
||||||
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
|
||||||
const gfx::Point& val) {
|
|
||||||
return mate::ObjectTemplateBuilder(isolate).SetValue("x", val.x())
|
|
||||||
.SetValue("y", val.y())
|
|
||||||
.Build()->NewInstance();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template<>
|
|
||||||
struct Converter<gfx::Size> {
|
|
||||||
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
|
||||||
const gfx::Size& val) {
|
|
||||||
return mate::ObjectTemplateBuilder(isolate).SetValue("width", val.width())
|
|
||||||
.SetValue("height", val.height())
|
|
||||||
.Build()->NewInstance();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template<>
|
|
||||||
struct Converter<gfx::Rect> {
|
|
||||||
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
|
||||||
const gfx::Rect& val) {
|
|
||||||
return mate::ObjectTemplateBuilder(isolate).SetValue("x", val.x())
|
|
||||||
.SetValue("y", val.y())
|
|
||||||
.SetValue("width", val.width())
|
|
||||||
.SetValue("height", val.height())
|
|
||||||
.Build()->NewInstance();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template<>
|
|
||||||
struct Converter<gfx::Display> {
|
|
||||||
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
|
||||||
const gfx::Display& display) {
|
|
||||||
return mate::ObjectTemplateBuilder(isolate)
|
|
||||||
.SetValue("bounds", display.bounds())
|
|
||||||
.SetValue("workArea", display.work_area())
|
|
||||||
.SetValue("size", display.size())
|
|
||||||
.SetValue("workAreaSize", display.work_area_size())
|
|
||||||
.SetValue("scaleFactor", display.device_scale_factor())
|
|
||||||
.Build()->NewInstance();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace mate
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
void Initialize(v8::Handle<v8::Object> exports, v8::Handle<v8::Value> unused,
|
void Initialize(v8::Handle<v8::Object> exports, v8::Handle<v8::Value> unused,
|
||||||
|
|
96
atom/common/native_mate_converters/gfx_converter.h
Normal file
96
atom/common/native_mate_converters/gfx_converter.h
Normal file
|
@ -0,0 +1,96 @@
|
||||||
|
// Copyright (c) 2014 GitHub, Inc. All rights reserved.
|
||||||
|
// Use of this source code is governed by the MIT license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "native_mate/dictionary.h"
|
||||||
|
#include "ui/gfx/point.h"
|
||||||
|
#include "ui/gfx/rect.h"
|
||||||
|
#include "ui/gfx/screen.h"
|
||||||
|
#include "ui/gfx/size.h"
|
||||||
|
|
||||||
|
namespace mate {
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct Converter<gfx::Point> {
|
||||||
|
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const gfx::Point& val) {
|
||||||
|
mate::Dictionary dict(isolate, v8::Object::New(isolate));
|
||||||
|
dict.Set("x", val.x());
|
||||||
|
dict.Set("y", val.y());
|
||||||
|
return dict.GetHandle();
|
||||||
|
}
|
||||||
|
static bool FromV8(v8::Isolate* isolate, v8::Handle<v8::Value> val,
|
||||||
|
gfx::Point* out) {
|
||||||
|
mate::Dictionary dict;
|
||||||
|
if (!ConvertFromV8(isolate, val, &dict))
|
||||||
|
return false;
|
||||||
|
int x, y;
|
||||||
|
if (!dict.Get("x", &x) || !dict.Get("y", &y))
|
||||||
|
return false;
|
||||||
|
*out = gfx::Point(x, y);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct Converter<gfx::Size> {
|
||||||
|
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const gfx::Size& val) {
|
||||||
|
mate::Dictionary dict(isolate, v8::Object::New(isolate));
|
||||||
|
dict.Set("width", val.width());
|
||||||
|
dict.Set("height", val.height());
|
||||||
|
return dict.GetHandle();
|
||||||
|
}
|
||||||
|
static bool FromV8(v8::Isolate* isolate, v8::Handle<v8::Value> val,
|
||||||
|
gfx::Size* out) {
|
||||||
|
mate::Dictionary dict;
|
||||||
|
if (!ConvertFromV8(isolate, val, &dict))
|
||||||
|
return false;
|
||||||
|
int width, height;
|
||||||
|
if (!dict.Get("width", &width) || !dict.Get("height", &height))
|
||||||
|
return false;
|
||||||
|
*out = gfx::Size(width, height);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct Converter<gfx::Rect> {
|
||||||
|
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const gfx::Rect& val) {
|
||||||
|
mate::Dictionary dict(isolate, v8::Object::New(isolate));
|
||||||
|
dict.Set("x", val.x());
|
||||||
|
dict.Set("y", val.y());
|
||||||
|
dict.Set("width", val.width());
|
||||||
|
dict.Set("height", val.height());
|
||||||
|
return dict.GetHandle();
|
||||||
|
}
|
||||||
|
static bool FromV8(v8::Isolate* isolate, v8::Handle<v8::Value> val,
|
||||||
|
gfx::Rect* out) {
|
||||||
|
mate::Dictionary dict;
|
||||||
|
if (!ConvertFromV8(isolate, val, &dict))
|
||||||
|
return false;
|
||||||
|
int x, y, width, height;
|
||||||
|
if (!dict.Get("x", &x) || !dict.Get("y", &y) ||
|
||||||
|
!dict.Get("width", &width) || !dict.Get("height", &height))
|
||||||
|
return false;
|
||||||
|
*out = gfx::Rect(x, y, width, height);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct Converter<gfx::Display> {
|
||||||
|
static v8::Handle<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const gfx::Display& display) {
|
||||||
|
mate::Dictionary dict(isolate, v8::Object::New(isolate));
|
||||||
|
dict.Set("bounds", display.bounds());
|
||||||
|
dict.Set("workArea", display.work_area());
|
||||||
|
dict.Set("size", display.size());
|
||||||
|
dict.Set("workAreaSize", display.work_area_size());
|
||||||
|
dict.Set("scaleFactor", display.device_scale_factor());
|
||||||
|
return dict.GetHandle();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace mate
|
Loading…
Add table
Reference in a new issue