Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
R
rocolib
Manage
Activity
Members
Labels
Plan
Issues
31
Issue boards
Milestones
Iterations
Wiki
Requirements
Code
Merge requests
3
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package Registry
Container Registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
roco
rocolib
Merge requests
!31
Overrides
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
Overrides
mehtank/rocolib:overrides
into
v0.3
Overview
0
Commits
5
Pipelines
1
Changes
9
Merged
mehtank
requested to merge
mehtank/rocolib:overrides
into
v0.3
3 years ago
Overview
0
Commits
5
Pipelines
1
Changes
9
Expand
auto-handle simple overrides outside of modifyParameters (
#3
)
0
0
Merge request reports
Compare
v0.3
v0.3 (base)
and
latest version
latest version
4e81da65
5 commits,
3 years ago
9 files
+
62
−
53
Expand all files
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Files
9
Search (e.g. *.vue) (Ctrl+P)
rocolib/api/Parameterized.py
+
33
−
5
Options
@@ -44,8 +44,8 @@ class Parameter:
self
.
name
=
name
if
defaultValue
is
None
and
not
kwargs
.
get
(
"
o
ptional
"
,
False
):
raise
ValueError
(
f
"
Must specify either defaultValue or optional
=True
for parameter
{
name
}
"
)
if
defaultValue
is
None
and
not
kwargs
.
get
(
"
o
verrides
"
,
False
):
raise
ValueError
(
f
"
Must specify either defaultValue or
overrides (implies
optional
)
for parameter
{
name
}
"
)
self
.
defaultValue
=
defaultValue
self
.
spec
=
{}
@@ -60,7 +60,7 @@ class Parameter:
self
.
assertValid
(
defaultValue
)
vt
=
self
.
spec
.
get
(
"
valueType
"
,
""
)
no
=
not
(
self
.
spec
.
get
(
"
o
ptional
"
,
False
))
no
=
not
(
self
.
spec
.
get
(
"
o
verrides
"
,
False
))
if
no
and
(
"
int
"
in
vt
or
"
float
"
in
vt
):
integer
=
None
@@ -94,11 +94,11 @@ class Parameter:
def
assertValid
(
self
,
value
):
if
value
is
None
:
if
self
.
spec
.
get
(
"
o
ptional
"
,
False
):
if
self
.
spec
.
get
(
"
o
verrides
"
,
False
):
self
.
value
=
value
return
else
:
raise
ValueError
(
f
"
Parameter
{
self
.
name
}
is not optional and cannot be set to None
"
)
raise
ValueError
(
f
"
Parameter
{
self
.
name
}
is not optional
(via overrides)
and cannot be set to None
"
)
def
check
(
spec
,
test
,
error
):
if
(
self
.
spec
.
get
(
spec
,
None
)
is
not
None
and
not
test
(
self
.
spec
[
spec
])):
@@ -116,6 +116,32 @@ class Parameter:
else
:
return
self
.
symbol
def
doOverrides
(
self
,
c
):
if
self
.
value
is
None
:
return
overrides
=
self
.
spec
.
get
(
"
overrides
"
,
[])
if
isinstance
(
overrides
,
dict
):
for
k
,
fn
in
overrides
.
items
():
try
:
import
rocolib.utils.numsym
as
np
value
=
eval
(
fn
,
locals
())
c
.
setParameter
(
k
,
value
)
except
ValueError
as
e
:
raise
ValueError
(
str
(
e
)
+
f
"
(via setting overriding parameter
{
self
.
name
}
to
{
self
.
value
}
)
"
)
except
KeyError
as
e
:
logging
.
debug
(
str
(
e
)
+
f
"
(via setting overriding parameter
{
self
.
name
}
to
{
self
.
value
}
) -- ignoring
"
)
elif
isinstance
(
overrides
,
(
list
,
tuple
)):
for
k
in
overrides
:
try
:
c
.
setParameter
(
k
,
self
.
value
)
except
KeyError
as
e
:
logging
.
debug
(
str
(
e
)
+
f
"
(via setting overriding parameter
{
self
.
name
}
to
{
self
.
value
}
) -- ignoring
"
)
else
:
try
:
c
.
setParameter
(
overrides
,
self
.
value
)
except
KeyError
as
e
:
logging
.
debug
(
str
(
e
)
+
f
"
(via setting overriding parameter
{
self
.
name
}
to
{
self
.
value
}
) -- ignoring
"
)
def
getInfo
(
self
,
keys
=
None
):
if
isinstance
(
keys
,
str
):
return
getattr
(
self
,
keys
)
@@ -158,6 +184,8 @@ class Parameterized(object):
"""
for
n
,
p
in
self
.
parameters
.
items
():
p
.
setDefault
(
force
)
for
n
,
p
in
self
.
parameters
.
items
():
p
.
doOverrides
(
self
)
def
setParameter
(
self
,
n
,
v
,
validate
=
True
):