Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/master'
Browse files Browse the repository at this point in the history
  • Loading branch information
burner committed Sep 15, 2024
2 parents c561af5 + fb9e095 commit 0bcd632
Show file tree
Hide file tree
Showing 14 changed files with 64,383 additions and 299 deletions.
9 changes: 8 additions & 1 deletion graphql.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -139,6 +139,7 @@ ListType:
Values:
Val: [Value#val]
Vals: [Value#val, comma, Values#follow]
ValsNoComma: [Value#val, Values#follow]

Array:
Empty: [lbrack, rbrack]
Expand Down Expand Up @@ -224,7 +225,7 @@ NamedTypes:

ArgumentsDefinition:
A: [lparen, InputValueDefinitions, rparen]
DA: [lparen, Description#des, InputValueDefinitions, rparen]
NA: [lparen, rparen]

InputValueDefinitions:
I: [InputValueDefinition#iv]
Expand All @@ -236,6 +237,10 @@ InputValueDefinition:
TD: [name#name, colon, Type#type, Directives#dirs]
TV: [name#name, colon, Type#type, DefaultValue#df]
T: [name#name, colon, Type#type]
DTVD: [Description#des, name#name, colon, Type#type, DefaultValue#df, Directives#dirs]
DTD: [Description#des, name#name, colon, Type#type, Directives#dirs]
DTV: [Description#des, name#name, colon, Type#type, DefaultValue#df]
DT: [Description#des, name#name, colon, Type#type]

InterfaceTypeDefinition:
NDF: [interface_, name#name, Directives#dirs, lcurly,
Expand Down Expand Up @@ -264,6 +269,8 @@ EnumValueDefinitions:
EnumValueDefinition:
ED: [name#name, Directives#dirs]
E: [name#name]
DED: [Description#des, name#name, Directives#dirs]
DE: [Description#des, name#name]

InputTypeDefinition:
NDE: [input, name#name, Directives#dir, lcurly,
Expand Down
137 changes: 137 additions & 0 deletions perftest/calc.d
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
import std;

string[] strs =
[ "Command being timed:"
, "Percent of CPU this job got:"
];

string[] floats =
[ "User time (seconds):"
, "System time (seconds):"
];

string[] floats2 =
[ "Elapsed (wall clock) time (h:mm:ss or m:ss):"
];

string[] longs =
[ "Average shared text size (kbytes):"
, "Average unshared data size (kbytes):"
, "Average stack size (kbytes):"
, "Average total size (kbytes):"
, "Maximum resident set size (kbytes):"
, "Average resident set size (kbytes):"
, "Major (requiring I/O) page faults:"
, "Minor (reclaiming a frame) page faults:"
, "Voluntary context switches:"
, "Involuntary context switches:"
, "Swaps:"
, "File system inputs:"
, "File system outputs:"
, "Socket messages sent:"
, "Socket messages received:"
, "Signals delivered:"
, "Page size (bytes):"
, "Exit status:"
];

string[] perf =
[ "cache-references:u"
, "cache-misses:u"
, "cycles:u"
, "instructions:u"
, "branches:u"
, "faults:u"
, "migrations:u"
, "L1-dcache-loads:u"
, "L1-dcache-load-misses:u"
, "ic_tag_hit_miss.all_instruction_cache_accesses:u"
];

double wallClock(string s) {
s = s.strip();
s = s[3 .. $];
return to!(double)(s);
}

void main(string[] args) {
long[string] longV;
double[string] floatV;

string[] lines = readText("out")
.splitter("\n")
.map!(l => l.strip())
.filter!(l => !l.empty)
.array;
o: foreach(l; lines) {
foreach(p; perf) {
ptrdiff_t i = l.indexOf(p);
if(i != -1) {
long v = l[0 .. i].strip().to!(long)();
if(p in longV) {
longV[p] += v;
} else {
longV[p] = v;
}
continue o;
}
}
foreach(p; longs) {
ptrdiff_t i = l.indexOf(p);
if(i != -1) {
long v = l[i + p.length .. $].strip().to!(long)();
if(p in longV) {
longV[p] += v;
} else {
longV[p] = v;
}
continue o;
}
}
foreach(string p; floats) {
ptrdiff_t i = l.indexOf(p);
if(i != -1) {
string s = l[0 .. i].strip();
if(s.empty) {
continue o;
}
double v = s.to!(double)();
if(p in floatV) {
floatV[p] += v;
} else {
floatV[p] = v;
}
continue o;
}
}
foreach(string p; floats2) {
ptrdiff_t i = l.indexOf(p);
if(i != -1) {
string s = l[p.length .. $].strip();
if(s.empty) {
continue o;
}
double v = wallClock(s);
if(p in floatV) {
floatV[p] += v;
} else {
floatV[p] = v;
}
continue o;
}
}
}
JSONValue j;
foreach(k, v; longV) {
j[k] = v;
}
foreach(k, v; floatV) {
j[k] = v;
}
j["l1misses"] = ((cast(double)longV["L1-dcache-load-misses:u"] /
longV["L1-dcache-loads:u"]) * 100);
j["cache_misses"] = ((cast(double)longV["cache-misses:u"] /
longV["cache-references:u"]) * 100);
auto f = File(args[1], "w");
f.writeln(j.toPrettyString());
}
12 changes: 12 additions & 0 deletions perftest/dub.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"authors": [
"Robert Schadek"
],
"dependencies": {
"graphqld": { "path" : "../" }
},
"copyright": "Copyright © 2024, Robert Schadek",
"description": "A minimal D application.",
"license": "GPL-3.0-or-later",
"name": "perftest"
}
6 changes: 6 additions & 0 deletions perftest/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/bash

for i in $(seq 1 10);
do
/usr/bin/time -v perf stat -B -e cache-references,cache-misses,cycles,instructions,branches,faults,migrations,L1-dcache-loads,L1-dcache-load-misses,ic_tag_hit_miss.all_instruction_cache_accesses ./perftest
done
Loading

0 comments on commit 0bcd632

Please sign in to comment.