Merge pull request #4 from atom/master

update as upstream
This commit is contained in:
Heilig Benedek 2016-02-11 02:36:10 +01:00
commit f8fd5dc2a3
3 changed files with 44 additions and 1 deletions

View file

@ -60,6 +60,11 @@ void Write(const mate::Dictionary& data,
if (data.Get("text", &text))
writer.WriteText(text);
if (data.Get("rtf", &text)) {
std::string rtf = base::UTF16ToUTF8(text);
writer.WriteRTF(rtf);
}
if (data.Get("html", &html))
writer.WriteHTML(html, std::string());
@ -88,6 +93,18 @@ void WriteText(const base::string16& text, mate::Arguments* args) {
writer.WriteText(text);
}
base::string16 ReadRtf(mate::Arguments* args) {
std::string data;
ui::Clipboard* clipboard = ui::Clipboard::GetForCurrentThread();
clipboard->ReadRTF(GetClipboardType(args), &data);
return base::UTF8ToUTF16(data);
}
void WriteRtf(const std::string& text, mate::Arguments* args) {
ui::ScopedClipboardWriter writer(GetClipboardType(args));
writer.WriteRTF(text);
}
base::string16 ReadHtml(mate::Arguments* args) {
base::string16 data;
base::string16 html;
@ -129,6 +146,8 @@ void Initialize(v8::Local<v8::Object> exports, v8::Local<v8::Value> unused,
dict.SetMethod("write", &Write);
dict.SetMethod("readText", &ReadText);
dict.SetMethod("writeText", &WriteText);
dict.SetMethod("readRtf", &ReadRtf);
dict.SetMethod("writeRtf", &WriteRtf);
dict.SetMethod("readHtml", &ReadHtml);
dict.SetMethod("writeHtml", &WriteHtml);
dict.SetMethod("readImage", &ReadImage);

View file

@ -61,6 +61,20 @@ Returns the content in the clipboard as a [NativeImage](native-image.md).
Writes `image` to the clipboard.
### `clipboard.readRtf([type])`
* `type` String (optional)
Returns the content in the clipboard as RTF.
### `clipboard.writeRtf(text[, type])`
* `text` String
* `type` String (optional)
Writes the `text` into the clipboard in RTF.
### `clipboard.clear([type])`
* `type` String (optional)

View file

@ -35,20 +35,30 @@ describe('clipboard module', function() {
return assert.equal(clipboard.readHtml(), markup);
});
});
describe('clipboard.readRtf', function() {
return it('returns rtf text correctly', function() {
var rtf = "{\\rtf1\\ansi{\\fonttbl\\f0\\fswiss Helvetica;}\\f0\\pard\nThis is some {\\b bold} text.\\par\n}";
clipboard.writeRtf(rtf);
return assert.equal(clipboard.readRtf(), rtf);
});
});
return describe('clipboard.write()', function() {
return it('returns data correctly', function() {
var i, markup, p, text;
var i, markup, p, text, rtf;
text = 'test';
rtf = '{\\rtf1\\utf8 text}';
p = path.join(fixtures, 'assets', 'logo.png');
i = nativeImage.createFromPath(p);
markup = process.platform === 'darwin' ? '<meta charset=\'utf-8\'><b>Hi</b>' : process.platform === 'linux' ? '<meta http-equiv="content-type" ' + 'content="text/html; charset=utf-8"><b>Hi</b>' : '<b>Hi</b>';
clipboard.write({
text: "test",
html: '<b>Hi</b>',
rtf: '{\\rtf1\\utf8 text}',
image: p
});
assert.equal(clipboard.readText(), text);
assert.equal(clipboard.readHtml(), markup);
assert.equal(clipboard.readRtf(), rtf);
return assert.equal(clipboard.readImage().toDataURL(), i.toDataURL());
});
});