Add Shell API.
Include APIs: shell.showItemInFolder shell.openItem shell.openExternal shell.moveItemToTrash
This commit is contained in:
parent
fbad5bc822
commit
157c978aa8
7 changed files with 159 additions and 0 deletions
12
atom.gyp
12
atom.gyp
|
@ -13,6 +13,7 @@
|
|||
'browser/atom/objects_registry.coffee',
|
||||
'browser/atom/rpc_server.coffee',
|
||||
'common/api/lib/id_weak_map.coffee',
|
||||
'common/api/lib/shell.coffee',
|
||||
'renderer/api/lib/ipc.coffee',
|
||||
'renderer/api/lib/remote.coffee',
|
||||
],
|
||||
|
@ -47,6 +48,8 @@
|
|||
'common/api/atom_api_idle_gc.cc',
|
||||
'common/api/atom_api_id_weak_map.cc',
|
||||
'common/api/atom_api_id_weak_map.h',
|
||||
'common/api/atom_api_shell.cc',
|
||||
'common/api/atom_api_shell.h',
|
||||
'common/api/atom_api_v8_util.cc',
|
||||
'common/api/atom_bindings.cc',
|
||||
'common/api/atom_bindings.h',
|
||||
|
@ -160,6 +163,15 @@
|
|||
'.',
|
||||
'vendor',
|
||||
],
|
||||
'conditions': [
|
||||
['OS=="mac"', {
|
||||
'link_settings': {
|
||||
'libraries': [
|
||||
'$(SDKROOT)/System/Library/Frameworks/Carbon.framework',
|
||||
],
|
||||
},
|
||||
}],
|
||||
],
|
||||
},
|
||||
{
|
||||
'target_name': 'generated_sources',
|
||||
|
|
95
common/api/atom_api_shell.cc
Normal file
95
common/api/atom_api_shell.cc
Normal file
|
@ -0,0 +1,95 @@
|
|||
// Copyright (c) 2013 GitHub, Inc. All rights reserved.
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#include "common/api/atom_api_shell.h"
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "base/files/file_path.h"
|
||||
#include "common/platform_util.h"
|
||||
#include "googleurl/src/gurl.h"
|
||||
#include "vendor/node/src/node.h"
|
||||
|
||||
namespace atom {
|
||||
|
||||
namespace api {
|
||||
|
||||
namespace {
|
||||
|
||||
bool V8ValueToFilePath(v8::Handle<v8::Value> value, base::FilePath* path) {
|
||||
if (!value->IsString())
|
||||
return false;
|
||||
|
||||
std::string file_path_string(*v8::String::Utf8Value(value));
|
||||
base::FilePath file_path = base::FilePath::FromUTF8Unsafe(file_path_string);
|
||||
|
||||
if (file_path.empty())
|
||||
return false;
|
||||
|
||||
*path = file_path;
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
// static
|
||||
v8::Handle<v8::Value> Shell::ShowItemInFolder(const v8::Arguments &args) {
|
||||
v8::HandleScope scope;
|
||||
|
||||
base::FilePath file_path;
|
||||
if (!V8ValueToFilePath(args[0], &file_path))
|
||||
return node::ThrowTypeError("Bad argument");
|
||||
|
||||
platform_util::ShowItemInFolder(file_path);
|
||||
return v8::Undefined();
|
||||
}
|
||||
|
||||
// static
|
||||
v8::Handle<v8::Value> Shell::OpenItem(const v8::Arguments &args) {
|
||||
v8::HandleScope scope;
|
||||
|
||||
base::FilePath file_path;
|
||||
if (!V8ValueToFilePath(args[0], &file_path))
|
||||
return node::ThrowTypeError("Bad argument");
|
||||
|
||||
platform_util::OpenItem(file_path);
|
||||
return v8::Undefined();
|
||||
}
|
||||
|
||||
// static
|
||||
v8::Handle<v8::Value> Shell::OpenExternal(const v8::Arguments &args) {
|
||||
v8::HandleScope scope;
|
||||
|
||||
if (!args[0]->IsString())
|
||||
return node::ThrowTypeError("Bad argument");
|
||||
|
||||
platform_util::OpenExternal(GURL(*v8::String::Utf8Value(args[0])));
|
||||
return v8::Undefined();
|
||||
}
|
||||
|
||||
// static
|
||||
v8::Handle<v8::Value> Shell::MoveItemToTrash(const v8::Arguments &args) {
|
||||
v8::HandleScope scope;
|
||||
|
||||
base::FilePath file_path;
|
||||
if (!V8ValueToFilePath(args[0], &file_path))
|
||||
return node::ThrowTypeError("Bad argument");
|
||||
|
||||
platform_util::MoveItemToTrash(file_path);
|
||||
return v8::Undefined();
|
||||
}
|
||||
|
||||
// static
|
||||
void Shell::Initialize(v8::Handle<v8::Object> target) {
|
||||
node::SetMethod(target, "showItemInFolder", ShowItemInFolder);
|
||||
node::SetMethod(target, "openItem", OpenItem);
|
||||
node::SetMethod(target, "openExternal", OpenExternal);
|
||||
node::SetMethod(target, "moveItemToTrash", MoveItemToTrash);
|
||||
}
|
||||
|
||||
} // namespace api
|
||||
|
||||
} // namespace atom
|
||||
|
||||
NODE_MODULE(atom_common_shell, atom::api::Shell::Initialize)
|
32
common/api/atom_api_shell.h
Normal file
32
common/api/atom_api_shell.h
Normal file
|
@ -0,0 +1,32 @@
|
|||
// Copyright (c) 2013 GitHub, Inc. All rights reserved.
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#ifndef ATOM_COMMON_API_ATOM_API_SHELL_H_
|
||||
#define ATOM_COMMON_API_ATOM_API_SHELL_H_
|
||||
|
||||
#include "base/basictypes.h"
|
||||
#include "v8/include/v8.h"
|
||||
|
||||
namespace atom {
|
||||
|
||||
namespace api {
|
||||
|
||||
class Shell {
|
||||
public:
|
||||
static void Initialize(v8::Handle<v8::Object> target);
|
||||
|
||||
private:
|
||||
static v8::Handle<v8::Value> ShowItemInFolder(const v8::Arguments &args);
|
||||
static v8::Handle<v8::Value> OpenItem(const v8::Arguments &args);
|
||||
static v8::Handle<v8::Value> OpenExternal(const v8::Arguments &args);
|
||||
static v8::Handle<v8::Value> MoveItemToTrash(const v8::Arguments &args);
|
||||
|
||||
DISALLOW_IMPLICIT_CONSTRUCTORS(Shell);
|
||||
};
|
||||
|
||||
} // namespace api
|
||||
|
||||
} // namespace atom
|
||||
|
||||
#endif // ATOM_COMMON_API_ATOM_API_SHELL_H_
|
|
@ -20,6 +20,7 @@ NODE_EXT_LIST_ITEM(atom_renderer_ipc)
|
|||
// renderer processes.
|
||||
NODE_EXT_LIST_ITEM(atom_common_idle_gc)
|
||||
NODE_EXT_LIST_ITEM(atom_common_id_weak_map)
|
||||
NODE_EXT_LIST_ITEM(atom_common_shell)
|
||||
NODE_EXT_LIST_ITEM(atom_common_v8_util)
|
||||
|
||||
NODE_EXT_LIST_END
|
||||
|
|
1
common/api/lib/shell.coffee
Normal file
1
common/api/lib/shell.coffee
Normal file
|
@ -0,0 +1 @@
|
|||
module.exports = process.atomBinding 'shell'
|
|
@ -25,6 +25,9 @@ void OpenItem(const base::FilePath& full_path);
|
|||
// (For example, mailto: URLs in the default mail user agent.)
|
||||
void OpenExternal(const GURL& url);
|
||||
|
||||
// Move a file to trash.
|
||||
void MoveItemToTrash(const base::FilePath& full_path);
|
||||
|
||||
} // platform_util
|
||||
|
||||
#endif // ATOM_COMMON_PLATFORM_UTIL_H_
|
||||
|
|
|
@ -126,4 +126,19 @@ void OpenExternal(const GURL& url) {
|
|||
LOG(WARNING) << "NSWorkspace failed to open URL " << url;
|
||||
}
|
||||
|
||||
void MoveItemToTrash(const base::FilePath& full_path) {
|
||||
DCHECK([NSThread isMainThread]);
|
||||
NSString* path_string = base::SysUTF8ToNSString(full_path.value());
|
||||
NSArray* file_array =
|
||||
[NSArray arrayWithObject:[path_string lastPathComponent]];
|
||||
if (!path_string || !file_array || ![[NSWorkspace sharedWorkspace]
|
||||
performFileOperation:NSWorkspaceRecycleOperation
|
||||
source:[path_string stringByDeletingLastPathComponent]
|
||||
destination:@""
|
||||
files:file_array
|
||||
tag:nil])
|
||||
LOG(WARNING) << "NSWorkspace failed to move file " << full_path.value()
|
||||
<< " to trash";
|
||||
}
|
||||
|
||||
} // namespace platform_util
|
||||
|
|
Loading…
Reference in a new issue