aboutsummaryrefslogtreecommitdiff
path: root/files/ja/mozilla/developer_guide/callgraph
diff options
context:
space:
mode:
Diffstat (limited to 'files/ja/mozilla/developer_guide/callgraph')
-rw-r--r--files/ja/mozilla/developer_guide/callgraph/index.html24
-rw-r--r--files/ja/mozilla/developer_guide/callgraph/schema_reference/index.html87
2 files changed, 111 insertions, 0 deletions
diff --git a/files/ja/mozilla/developer_guide/callgraph/index.html b/files/ja/mozilla/developer_guide/callgraph/index.html
new file mode 100644
index 0000000000..8bc4e0c2be
--- /dev/null
+++ b/files/ja/mozilla/developer_guide/callgraph/index.html
@@ -0,0 +1,24 @@
+---
+title: Callgraph
+slug: Mozilla/Developer_guide/Callgraph
+tags:
+ - Callgraph
+ - Developing Mozilla
+ - NeedsTranslation
+ - TopicStub
+translation_of: Mozilla/Developer_guide/Callgraph
+---
+<p>The Callgraph project is intended to produce a complete callgraph covering C and C++ code within Mozilla. This can be used for performing static analysis based on the relationship between functions and methods. For instance, given the C++ code:</p>
+<pre class="eval">int foo() {
+ return good();
+}
+
+int good() {
+ return evil() ? 0 : 1;
+}
+</pre>
+<p>The callgraph would be <code>foo() -&gt; good() -&gt; evil()</code>. Given the knowledge that <code>evil()</code> does evil things, one could then determine <code>foo()</code> also does evil things.</p>
+<p>The Callgraph project uses gcc and <a href="/en/Treehydra" title="en/Treehydra">Treehydra</a> to generate information about function and method calls at compile time, and aggregates it into a sqlite database.</p>
+<h2 id="Documentation">Documentation</h2>
+<dl> <dt><a href="/en/Developing_Mozilla/Callgraph/Installing_Callgraph" title="En/Callgraph/Installing_Callgraph">Installing Callgraph</a></dt> <dd>Download and installation of Callgraph</dd> <dt><a href="/en/Developing_Mozilla/Callgraph/Schema_Reference" title="En/Callgraph/Schema_Reference">Schema Reference</a></dt> <dd>Explanation of the database schema</dd> <dt><a href="https://bugzilla.mozilla.org/show_bug.cgi?id=callgraph" class="link-https">Further details</a></dt> <dd>Implementation ideas for Callgraph</dd>
+</dl>
diff --git a/files/ja/mozilla/developer_guide/callgraph/schema_reference/index.html b/files/ja/mozilla/developer_guide/callgraph/schema_reference/index.html
new file mode 100644
index 0000000000..6bd8d1b191
--- /dev/null
+++ b/files/ja/mozilla/developer_guide/callgraph/schema_reference/index.html
@@ -0,0 +1,87 @@
+---
+title: スキーマリファレンス
+slug: Mozilla/Developer_guide/Callgraph/Schema_Reference
+tags:
+ - Callgraph
+ - Developing Mozilla
+ - リファレンス
+translation_of: Mozilla/Developer_guide/Callgraph/Schema_Reference
+---
+<p>The schema used in <code>graph.sqlite</code> is defined by <code>schema.sql</code>. Since Callgraph is new, the schema is fairly simple and is expected to evolve. If you have suggestions or use cases that require changes, please file a bug. (In particular, there are several pending improvements mentioned below.)</p>
+
+<p>The schema contains the following tables:</p>
+
+<ul>
+ <li><code>node</code>. This represents a function, and contains the following fields:
+
+ <ul>
+ <li><code>id INTEGER PRIMARY KEY</code>, a unique identifier for the node</li>
+ <li><code>name TEXT</code>, the fully-qualified function or method name, including return type and parameters. See below.</li>
+ <li><code>isPtr INTEGER</code>, 1 if the function call (in this case, the callee) is a function pointer, 0 otherwise.</li>
+ <li><code>isVirtual INTEGER</code>, 1 if the function call is a virtual method, 0 otherwise.</li>
+ <li><code>loc TEXT</code>, the fully-resolved source file containing the declaration or definition of the function. See below.</li>
+ <li><code>UNIQUE (name, loc) ON CONFLICT IGNORE</code></li>
+ </ul>
+
+ <p> </p>
+
+ <p>The fully-qualified method name includes the return value, namespaces, class name, method or function name, and parameter types. For instance, the code</p>
+
+ <pre class="brush: cpp">namespace ns {
+ class cs {
+ int method(float, double);
+ };
+};
+ </pre>
+
+ <p>would result in a <code>name</code> of <code>int ns::cs::method(float,double)</code>. For nonstatic methods, <code>this</code> is excluded from the parameter list, though we may want to denote nonstatic methods with a separate field. The global namespace is indicated by a leading <code>::</code>. (Types are currently not fully-qualified.) The <code>loc</code> refers to the source file in which the declaration or definition appeared. For classes, the declaration context will always be available, and this location will refer to the file containing the declaration (for instance, <code>foo.h</code>). For function calls, this location may refer to the declaration or definition, and cannot presently be used in concert with <code>name</code> as a reliably unique identifier. (This could potentially be solved by implementing linker-style name resolution rules in Callgraph.) For function pointers, it is impossible to determine a location, and <code>loc</code> will be the empty string. (You should guard on this case using <code>isPtr</code>.) For compiler built-ins, <code>loc</code> will be <code>&lt;built-in&gt;</code>. Since symlinks are prevalent in the Mozilla build process, the path in <code>loc</code> is always fully-resolved; that is, it will be an absolute path which is guaranteed to have a one-to-one mapping with a particular file in the source or object tree. (In the case of generated files, such as from xpidlgen, it will point into the object tree. Note also that one can override gcc's notion of the current source file using the <code>#file</code> directive; in the likely case where this file doesn't exist, the resulting <code>loc</code> will not be fully-resolved. Caveat emptor. Thankfully, this practice is uncommon.)</p>
+
+ <p>The <code>(name, loc)</code> pair is intended to be a unique identifier for a given function or method call. (Though this currently breaks down for functions and function pointers.) In the future, we may include a <code>mangledName</code> field in the table, which would allow more consistency with linker rules regarding function name resolution and uniqueness. We may also add a field indicating whether the function definition has been seen (which would distinguish, say, calls into library functions from functions who simply don't call anyone else).</p>
+ </li>
+ <li><code>edge</code>. This represents a call between functions, and contains the following fields:
+ <ul>
+ <li><code>caller INTEGER REFERENCES node</code>, the <code>id</code> of a <code>node</code> representing the caller function.</li>
+ <li><code>callee INTEGER REFERENCES node</code>, likewise for the callee.</li>
+ <li><code>PRIMARY KEY(caller, callee) ON CONFLICT IGNORE</code></li>
+ </ul>
+
+ <p> </p>
+
+ <p>The primary key is currently unique on caller and callee, meaning that if the caller calls the callee multiple times, only one edge will exist in the table. We may change this if there are cases where the number of calls is relevant.</p>
+ </li>
+ <li><code>implementors</code>. This table provides information about the inheritance chain of C++ classes, specifically which virtual interface methods are overridden or implemented by which classes.
+ <ul>
+ <li><code>implementor TEXT</code>, the fully-qualified class name of the class which implements the method.</li>
+ <li><code>interface TEXT</code>, the fully-qualified class name of the class which declares the method to be pure virtual. See below.</li>
+ <li><code>method TEXT</code>, the method name (not including return type or arguments).</li>
+ <li><code>loc TEXT</code>, the fully-resolved source file containing the declaration of the interface class.</li>
+ <li><code>id INTEGER PRIMARY KEY</code>, a unique identifier for the entry.</li>
+ <li><code>UNIQUE (implementor, interface, method, loc) ON CONFLICT IGNORE</code></li>
+ </ul>
+
+ <p> </p>
+
+ <p>An interface is considered a class which declares the method in question to be virtual (either pure or non-pure), while an implementor overrides it with a declaration that is non-pure. (Whether the implementor actually defines the function is not considered.) For instance, consider the code</p>
+
+ <pre class="brush: cpp">class iFoo {
+ public:
+ virtual void method1(float) = 0;
+ virtual void method2(float) = 0;
+};
+
+class iBar : public iFoo {
+ public:
+ virtual void method1(float) = 0;
+ virtual void method2(float);
+};
+
+class Bar : public iBar {
+ public:
+ virtual void method1(float);
+ virtual void method2(float);
+};
+</pre>
+
+ <p>The class <code>iBar</code> would be considered an implementor of <code>method2</code>, while class <code>Bar</code> would be an implementor of both <code>method1</code> and <code>method2</code>. For implementor <code>iBar</code>, <code>iFoo::method2</code> would be considered an interface method. For implementor <code>Bar</code>, both methods on <code>iFoo</code> and <code>iBar</code> would be listed as interface methods. Uniqueness is determined by implementor, interface, method, and loc. (Note that the parameter list to the virtual method is also required to determine uniqueness, and will be added.)</p>
+ </li>
+</ul>