230 lines
4.6 KiB
Markdown
230 lines
4.6 KiB
Markdown
# Overview
|
|
Dscanner is a tool used to analyze D source code.
|
|
|
|
### Options
|
|
* **--dotComplete** _sourceFile_ _cursorPosition_ - Provide autocompletion for the
|
|
insertion of the dot operator. The cursor position is the character position in
|
|
the **file**, not the position in the line.
|
|
* **--sloc** _sourceFiles_ - count the number of logical lines of code in the given
|
|
source files.
|
|
* **--json** _sourceFile_ - Generate a JSON summary of the given source file
|
|
* **--parenComplete** _sourceFile_ _cursorPosition_ - Provides a listing of function
|
|
parameters or pre-defined version identifiers at the cursor position. The cursor
|
|
position is the character position in the **file**, not the line.
|
|
* **--highlight** _sourceFile_ - Syntax-highlight the given source file. The
|
|
resulting HTML will be written to standard output.
|
|
* **-I** _includePath_ - Include _includePath_ in the list of paths used to search
|
|
for imports. By default dscanner will search in the current working directory as
|
|
well as any paths specified in /etc/dmd.conf.
|
|
|
|
# Dot Completion
|
|
|
|
# Paren Completion
|
|
|
|
# JSON output
|
|
Generates a JSON summary of the input file.
|
|
|
|
### Example
|
|
The given D code:
|
|
module example;
|
|
|
|
import std.stdio;
|
|
|
|
interface Iface {
|
|
double interfaceMethod();
|
|
}
|
|
|
|
class SomeClass(T) if (isSomeString!T) : IFace {
|
|
public:
|
|
this() {}
|
|
void doStuff(T);
|
|
override double interfaceMethod() {}
|
|
private:
|
|
T theTee;
|
|
}
|
|
|
|
int freeFunction(int x) { return x + x; }
|
|
|
|
void main(string[] args) {
|
|
|
|
}
|
|
|
|
is transformed into the following JSON markup:
|
|
|
|
{
|
|
"name" : "example",
|
|
"imports" : [
|
|
"std.stdio"
|
|
],
|
|
"interfaces" : [
|
|
{
|
|
"name" : "Iface",
|
|
"line" : 5,
|
|
"protection" : "public",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"functions" : [
|
|
{
|
|
"name" : "interfaceMethod",
|
|
"line" : 6,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"parameters" : [
|
|
],
|
|
"returnType" : "double"
|
|
}
|
|
],
|
|
"variables" : [
|
|
],
|
|
"baseClasses" : [
|
|
]
|
|
}
|
|
],
|
|
"classes" : [
|
|
{
|
|
"name" : "SomeClass",
|
|
"line" : 9,
|
|
"protection" : "public",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "if (isSomeString!T)",
|
|
"templateParameters" : [
|
|
"T"
|
|
],
|
|
"functions" : [
|
|
{
|
|
"name" : "this",
|
|
"line" : 11,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"parameters" : [
|
|
],
|
|
"returnType" : ""
|
|
},
|
|
{
|
|
"name" : "doStuff",
|
|
"line" : 12,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"parameters" : [
|
|
{
|
|
"name" : "",
|
|
"line" : 0,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"type" : "T"
|
|
}
|
|
],
|
|
"returnType" : "void"
|
|
},
|
|
{
|
|
"name" : "interfaceMethod",
|
|
"line" : 13,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
"override"
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"parameters" : [
|
|
],
|
|
"returnType" : "double"
|
|
}
|
|
],
|
|
"variables" : [
|
|
{
|
|
"name" : "theTee",
|
|
"line" : 15,
|
|
"protection" : "private",
|
|
"attributes" : [
|
|
],
|
|
"type" : "T"
|
|
}
|
|
],
|
|
"baseClasses" : [
|
|
"IFace"
|
|
]
|
|
}
|
|
],
|
|
"structs" : [
|
|
],
|
|
"structs" : [
|
|
],
|
|
"functions" : [
|
|
{
|
|
"name" : "freeFunction",
|
|
"line" : 18,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"parameters" : [
|
|
{
|
|
"name" : "x",
|
|
"line" : 18,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"type" : "int"
|
|
}
|
|
],
|
|
"returnType" : "int"
|
|
},
|
|
{
|
|
"name" : "main",
|
|
"line" : 20,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"constraint" : "",
|
|
"templateParameters" : [
|
|
],
|
|
"parameters" : [
|
|
{
|
|
"name" : "args",
|
|
"line" : 20,
|
|
"protection" : "",
|
|
"attributes" : [
|
|
],
|
|
"type" : "string[]"
|
|
}
|
|
],
|
|
"returnType" : "void"
|
|
}
|
|
],
|
|
"variables" : [
|
|
],
|
|
"enums" : [
|
|
]
|
|
}
|
|
|
|
# Line of Code count
|
|
This option counts the logical lines of code in the given source files, not
|
|
simply the physical lines. More specifically, it counts the number of
|
|
semicolons, **if**, **while**, **case**, **foreach**, and **for** tokens in the
|
|
given files.
|
|
|
|
# Highlighting
|
|
Syntax highlights the given file in HTML format. Output is written to _stdout_.
|
|
The CSS styling information is currently hard-coded.
|
|
|