mirror of
https://github.com/pion/mediadevices.git
synced 2025-10-23 16:43:11 +08:00
Add IsFloat, IsBigEndian, and IsInterleaved props
* Add bool constraint * Add IsFloat, IsBigEndian, and IsInterleaved properties
This commit is contained in:
30
pkg/prop/bool.go
Normal file
30
pkg/prop/bool.go
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
package prop
|
||||||
|
|
||||||
|
// BoolConstraint is an interface to represent bool value constraint.
|
||||||
|
type BoolConstraint interface {
|
||||||
|
Compare(bool) (float64, bool)
|
||||||
|
Value() bool
|
||||||
|
}
|
||||||
|
|
||||||
|
// BoolExact specifies exact bool value.
|
||||||
|
type BoolExact bool
|
||||||
|
|
||||||
|
// Compare implements BoolConstraint.
|
||||||
|
func (b BoolExact) Compare(o bool) (float64, bool) {
|
||||||
|
if bool(b) == o {
|
||||||
|
return 0.0, true
|
||||||
|
}
|
||||||
|
return 1.0, false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Value implements BoolConstraint.
|
||||||
|
func (b BoolExact) Value() bool { return bool(b) }
|
||||||
|
|
||||||
|
// Bool specifies ideal bool value.
|
||||||
|
type Bool BoolExact
|
||||||
|
|
||||||
|
// Compare implements BoolConstraint.
|
||||||
|
func (b Bool) Compare(o bool) (float64, bool) {
|
||||||
|
dist, _ := BoolExact(b).Compare(o)
|
||||||
|
return dist, true
|
||||||
|
}
|
@@ -89,6 +89,8 @@ func (p *Media) MergeConstraints(o MediaConstraints) {
|
|||||||
if v, ok := c.Value(); ok {
|
if v, ok := c.Value(); ok {
|
||||||
fieldA.Set(reflect.ValueOf(v))
|
fieldA.Set(reflect.ValueOf(v))
|
||||||
}
|
}
|
||||||
|
case BoolConstraint:
|
||||||
|
fieldA.Set(reflect.ValueOf(c.Value()))
|
||||||
default:
|
default:
|
||||||
panic("unsupported property type")
|
panic("unsupported property type")
|
||||||
}
|
}
|
||||||
@@ -106,6 +108,9 @@ func (p *MediaConstraints) FitnessDistance(o Media) (float64, bool) {
|
|||||||
cmps.add(p.SampleRate, o.SampleRate)
|
cmps.add(p.SampleRate, o.SampleRate)
|
||||||
cmps.add(p.Latency, o.Latency)
|
cmps.add(p.Latency, o.Latency)
|
||||||
cmps.add(p.ChannelCount, o.ChannelCount)
|
cmps.add(p.ChannelCount, o.ChannelCount)
|
||||||
|
cmps.add(p.IsBigEndian, o.IsBigEndian)
|
||||||
|
cmps.add(p.IsFloat, o.IsFloat)
|
||||||
|
cmps.add(p.IsInterleaved, o.IsInterleaved)
|
||||||
|
|
||||||
return cmps.fitnessDistance()
|
return cmps.fitnessDistance()
|
||||||
}
|
}
|
||||||
@@ -161,6 +166,12 @@ func (c *comparisons) fitnessDistance() (float64, bool) {
|
|||||||
} else {
|
} else {
|
||||||
panic("wrong type of actual value")
|
panic("wrong type of actual value")
|
||||||
}
|
}
|
||||||
|
case BoolConstraint:
|
||||||
|
if actual, typeOK := field.actual.(bool); typeOK {
|
||||||
|
d, ok = c.Compare(actual)
|
||||||
|
} else {
|
||||||
|
panic("wrong type of actual value")
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
panic("unsupported constraint type")
|
panic("unsupported constraint type")
|
||||||
}
|
}
|
||||||
@@ -192,6 +203,9 @@ type AudioConstraints struct {
|
|||||||
Latency DurationConstraint
|
Latency DurationConstraint
|
||||||
SampleRate IntConstraint
|
SampleRate IntConstraint
|
||||||
SampleSize IntConstraint
|
SampleSize IntConstraint
|
||||||
|
IsBigEndian BoolConstraint
|
||||||
|
IsFloat BoolConstraint
|
||||||
|
IsInterleaved BoolConstraint
|
||||||
}
|
}
|
||||||
|
|
||||||
// Audio represents an audio's constraints
|
// Audio represents an audio's constraints
|
||||||
@@ -200,4 +214,7 @@ type Audio struct {
|
|||||||
Latency time.Duration
|
Latency time.Duration
|
||||||
SampleRate int
|
SampleRate int
|
||||||
SampleSize int
|
SampleSize int
|
||||||
|
IsBigEndian bool
|
||||||
|
IsFloat bool
|
||||||
|
IsInterleaved bool
|
||||||
}
|
}
|
||||||
|
@@ -139,6 +139,24 @@ func TestCompareMatch(t *testing.T) {
|
|||||||
}},
|
}},
|
||||||
true,
|
true,
|
||||||
},
|
},
|
||||||
|
"BoolExactUnmatch": {
|
||||||
|
MediaConstraints{AudioConstraints: AudioConstraints{
|
||||||
|
IsFloat: BoolExact(true),
|
||||||
|
}},
|
||||||
|
Media{Audio: Audio{
|
||||||
|
IsFloat: false,
|
||||||
|
}},
|
||||||
|
false,
|
||||||
|
},
|
||||||
|
"BoolExactMatch": {
|
||||||
|
MediaConstraints{AudioConstraints: AudioConstraints{
|
||||||
|
IsFloat: BoolExact(true),
|
||||||
|
}},
|
||||||
|
Media{Audio: Audio{
|
||||||
|
IsFloat: true,
|
||||||
|
}},
|
||||||
|
true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for name, testData := range testDataSet {
|
for name, testData := range testDataSet {
|
||||||
|
Reference in New Issue
Block a user