Merge pull request #2 from qznc/master

Add dub support, basic tests, and --inplace option.
This commit is contained in:
Brian Schott 2015-01-13 22:02:46 +00:00
commit 008efd49d5
9 changed files with 68 additions and 1 deletions

3
.gitignore vendored
View File

@ -1,2 +1,5 @@
*.o
bin
*.d.out
.dub
dfmt

9
dub.json Normal file
View File

@ -0,0 +1,9 @@
{
"name": "dfmt",
"description": "Dfmt is a formatter for D source code",
"version": "0.0.1",
"targetType": "executable",
"dependencies": {
"libdparse": "~master"
},
}

View File

@ -6,3 +6,5 @@ FLAGS := -g -w $(INCLUDE_PATHS)
all: $(SRC)
$(COMPILER) $(FLAGS) $(SRC) -ofbin/dfmt
test: bin/dfmt
cd tests && ./test.sh

View File

@ -33,9 +33,14 @@ import std.d.parser;
import std.d.formatter;
import std.d.ast;
import std.array;
import std.getopt;
int main(string[] args)
{
bool inplace = false;
getopt(args,
"inplace", &inplace);
File output = stdout;
ubyte[] buffer;
if (args.length == 1)
{
@ -55,6 +60,8 @@ int main(string[] args)
File f = File(args[1]);
buffer = new ubyte[](f.size);
f.rawRead(buffer);
if (inplace)
output = File(args[1], "w");
}
LexerConfig config;
config.stringBehavior = StringBehavior.source;
@ -71,7 +78,7 @@ int main(string[] args)
visitor.visit(mod);
astInformation.cleanup();
auto tokens = byToken(buffer, config, &cache).array();
auto tokenFormatter = TokenFormatter(tokens, stdout, &astInformation,
auto tokenFormatter = TokenFormatter(tokens, output, &astInformation,
&formatterConfig);
tokenFormatter.format();
return 0;

15
tests/frontpage.d Normal file
View File

@ -0,0 +1,15 @@
// Computes average line length for standard input.
import std.stdio;
void main()
{
ulong lines = 0;
double sumLength = 0;
foreach (line; stdin.byLine())
{
++lines;
sumLength += line.length;
}
writeln("Average line length: ",
lines ? sumLength / lines : 0);
}

15
tests/frontpage.d.ref Normal file
View File

@ -0,0 +1,15 @@
// Computes average line length for standard input.
import std.stdio;
void main()
{
ulong lines = 0;
double sumLength = 0;
foreach (line; stdin.byLine())
{
++lines;
sumLength += line.length;
}
writeln("Average line length: ", lines ? sumLength / lines:0);
}

1
tests/hello.d Normal file
View File

@ -0,0 +1 @@
import std.stdio; void main() { writeln("Hello, world without explicit compilations!"); }

7
tests/hello.d.ref Normal file
View File

@ -0,0 +1,7 @@
import std.stdio;
void main()
{
writeln("Hello, world without explicit compilations!");
}

8
tests/test.sh Executable file
View File

@ -0,0 +1,8 @@
#!/usr/bin/env bash
set -e
for source in *.d
do
../bin/dfmt "${source}" >"${source}.out"
diff -u "${source}.ref" "${source}.out" || echo "fail ${source}"
done