mirror of
git://projects.qi-hardware.com/eda-tools.git
synced 2025-01-22 11:51:05 +02:00
9cafe23fb8
We now generate the operator map algorithmically, which is a bit less classy than solving the logical equations, but easier to get right. Also renamed the somewhat vague "redundant" to "unreachable".
308 lines
5.1 KiB
Bash
Executable File
308 lines
5.1 KiB
Bash
Executable File
#!/bin/bash
|
|
. ./Common
|
|
|
|
#
|
|
# Note: the hierarchy dump differs in some details from the input format.
|
|
# Its main purpose is to aid with debugging, not to produce a syntactically
|
|
# valid representation of the currently loaded hierarchy.
|
|
#
|
|
|
|
###############################################################################
|
|
|
|
tst "hierarchy: name rule" <<EOF
|
|
Animal=* {
|
|
Cat: { X=* };
|
|
Dog: { Y=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
Animal=* {
|
|
Cat: { X=* }
|
|
Dog: { Y=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: name set rule" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
p = <predation> {
|
|
mouse: { X=* };
|
|
cat: { Y=* };
|
|
dog: { Z=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
p=<predation> {
|
|
mouse: { X=* }
|
|
cat: { Y=* }
|
|
dog: { Z=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst_fail "hierarchy: name set rule (invalid value)" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
p = <predation> {
|
|
mouse: { X=* };
|
|
cat: { Y=* };
|
|
boat: { Z=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
h:6: invalid value in selection
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: name set rule (duplicate entry)" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
p = <predation> {
|
|
mouse: { X=* };
|
|
cat: { Y=* };
|
|
cat: { Z=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
h:6: warning: unreachable condition
|
|
p=<predation> {
|
|
mouse: { X=* }
|
|
cat: { Y=* }
|
|
cat: { Z=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: absolute value rule (with unit)" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
N=#R {
|
|
10R: { X=* };
|
|
10k: { Y=* };
|
|
1.2R: { Z=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
N=#R {
|
|
10R: { X=* }
|
|
10000R: { Y=* }
|
|
1.2R: { Z=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: absolute value rule (without unit)" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
N=## {
|
|
2: { X=* };
|
|
5k: { Y=* };
|
|
3.1: { Z=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
N=## {
|
|
2: { X=* }
|
|
5000: { Y=* }
|
|
3.1: { Z=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst_fail "hierarchy: absolute value rule (different unit)" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
N=#R {
|
|
1.0A: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
h:4: invalid value in selection
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst_fail "hierarchy: absolute value rule (letter-as-decimal syntax)" <<EOF
|
|
<predation> = mouse<cat<dog;
|
|
N=#R {
|
|
1k2: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
h:4: invalid value in selection
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (percent)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
1%: { X=* };
|
|
1.2%: { Y=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-1/+1%: { X=* }
|
|
-1.2/+1.2%: { Y=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (absolute, with unit)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
1R: { X=* };
|
|
1kR: { Y=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-1/+1R: { X=* }
|
|
-1000/+1000R: { Y=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (absolute, without unit)" <<EOF
|
|
{ V=## }
|
|
TOL=%V {
|
|
1: { X=* };
|
|
1k: { Y=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=## }
|
|
TOL=%# {
|
|
-1/+1: { X=* }
|
|
-1000/+1000: { Y=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (plus/minus percent)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
+10/-20%: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-20/+10%: { X=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (minus/plus percent)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
-10/+20%: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-10/+20%: { X=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (implicit minus/plus percent)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
10/20%: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-10/+20%: { X=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (plus/minus absolute)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
+10/-20R: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-20/+10R: { X=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (minus/plus absolute)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
-5/+10R: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-5/+10R: { X=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst "hierarchy: relative value rule (implicit minus/plus absolute)" <<EOF
|
|
{ V=#R }
|
|
TOL=%V {
|
|
0/10R: { X=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
{ V=#R }
|
|
TOL=%R {
|
|
-0/+10R: { X=* }
|
|
}
|
|
EOF
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
tst_fail "hierarchy: relative value rule (unknown field)" <<EOF
|
|
{ V=#R }
|
|
TOL=%X {
|
|
10%: { Y=* };
|
|
};
|
|
EOF
|
|
|
|
expect <<EOF
|
|
h:2: unknown field "X"
|
|
EOF
|
|
|
|
###############################################################################
|