File: script_runtime_manager.h

package info (click to toggle)
google-gadgets 0.11.2-3
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 16,820 kB
  • ctags: 20,323
  • sloc: cpp: 116,722; ansic: 18,000; sh: 9,269; makefile: 2,676; xml: 2,138; lex: 459
file content (94 lines) | stat: -rw-r--r-- 2,533 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*
  Copyright 2008 Google Inc.

  Licensed under the Apache License, Version 2.0 (the "License");
  you may not use this file except in compliance with the License.
  You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

  Unless required by applicable law or agreed to in writing, software
  distributed under the License is distributed on an "AS IS" BASIS,
  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  See the License for the specific language governing permissions and
  limitations under the License.
*/

#ifndef GGADGET_SCRIPT_RUNTIME_MANAGER_H__
#define GGADGET_SCRIPT_RUNTIME_MANAGER_H__

#include <ggadget/common.h>
#include <ggadget/script_runtime_interface.h>
#include <ggadget/script_context_interface.h>
#include <ggadget/slot.h>
#include <ggadget/signals.h>

namespace ggadget {

/**
 * @defgroup ScriptRuntime Script runtime
 * @ingroup CoreLibrary
 * Script runtime related classes
 * @{
 */

/**
 * Manager to manage multiple script runtime objects.
 */
class ScriptRuntimeManager {
 public:
  /**
   * Registers a new ScriptRuntimeInterface implementation object.
   * @param tag_name The tag name of the subclass, shall be file suffix for
   *     that kind of script file, such as "js", "py", etc.
   * @param runtime Pointer to the ScriptRuntimeInterface implementation
   *     object.
   * @return @c true if registered successfully, or @c false if the specified
   *     tag name already exists.
   */
  bool RegisterScriptRuntime(const char *tag_name,
                             ScriptRuntimeInterface *runtime);

  /**
   * Create a new @c ScriptContextInterface instance.
   * Must call @c DestroyContext after use.
   * @return the created context.
   */
  ScriptContextInterface *CreateScriptContext(const char *tag_name);

  /**
   * Returns the ScriptRuntimeInterface implementation object for a
   * script file type.
   */
  ScriptRuntimeInterface *GetScriptRuntime(const char *tag_name);

 public:
  /**
   * Get the singleton of ScriptRuntimeManager.
   */
  static ScriptRuntimeManager *get();

 private:
  class Impl;
  Impl *impl_;

  /**
   * Private constructor to prevent creating ScriptRuntimeManager object
   * directly.
   */
  ScriptRuntimeManager();

  /**
   * Private destructor to prevent deleting ScriptRuntimeManager object
   * directly.
   */
  ~ScriptRuntimeManager();

  DISALLOW_EVIL_CONSTRUCTORS(ScriptRuntimeManager);
};

/** @} */

} // namespace ggadget

#endif // GGADGET_SCRIPT_RUNTIME_MANAGER_H__