Comments (2)
based on this:
#148
I implemented something like this for my use case:
class Test(tr.HasTraits):
c = tr.Bool(default_value=True)
b = tr.Bool(default_value=True)
a = tr.Bool(default_value=True)
@tr.observe("a")
def _a(self, on_change):
print(f"a = {self.a}")
@tr.observe("b")
def _b(self, on_change):
print(f"b = {self.b}")
@tr.observe("c")
def _c(self, on_change):
print(f"c = {self.c}")
@classmethod
def trait_order(cls):
return [k for k, v in cls.__dict__.items() if isinstance(v, tr.TraitType)]
def __init__(self, **kwargs):
super().__init__()
kwargs = self.get_ordered_kwargs(kwargs)
{setattr(self, k, v) for k, v in kwargs.items()}
def get_ordered_kwargs(self, kwargs):
in_order = list(kwargs.keys())
tr_order = self.trait_order()
out_order = tr_order + [i for i in in_order if i not in tr_order]
return {o: kwargs[o] for o in out_order}
t1 = Test(a=False, b=False, c=False)
print("---")
t2 = Test(c=False, b=False, a=False)
# c = False
# b = False
# a = False
# ---
# c = False
# b = False
# a = False
I'll leave the isse open for a while in case someone can suggest a "more traitlets native" way to approach this
from traitlets.
Might not be directly related, but as a note, if multiple callbacks created with @observe
listen on the same trait, then they will be fired in alphabetical order.
Would be better to follow the definition order though.
class Test(tr.HasTraits):
trait = tr.Bool(default_value=True)
@tr.observe("trait")
def _b(self, on_change):
print("From _b")
@tr.observe("trait")
def _c(self, on_change):
print("From _c")
@tr.observe("trait")
def _a(self, on_change):
print("From _a")
t = Test()
t.trait = False
# From _a
# From _b
# From _c
This is due to for _, v in getmembers(cls)
in traitlets.py#L985 MetaHasDescriptors.setup_class(...)
where getmembers
uses python dir
, which in turns returns a sorted dictionary.
from traitlets.
Related Issues (20)
- Pyright diagnostic type incompatible
- Is there a way to only show base "--help" for explicitly defined options?
- pull request blocked by "Enforce PR label / enforce-label (pull_request)" HOT 1
- Issues with trait typing HOT 12
- Consider using mypyc HOT 1
- Promise not to remove Sentinel?
- One test fails HOT 3
- Singletons configurable allow multiple instances HOT 2
- `__doc__` no longer contains the traitlets help string for reference type traitlets (Dict, List, ...) HOT 2
- Fix License metadata in PyPi package
- More typing edge cases
- Uncaught Exception `TypeError: 'ExtendedCompletionFinder' object is not callable` caused by orphaned pyc in site-packages HOT 5
- Traitlets documentation incorrectly shows `__version__`
- Upgrade from traitlets `5.11.2` to `5.12.0` broke script HOT 1
- 5.13.0: pytest is failing with error in tests/test_typing.py HOT 1
- Changed behaviour since v5.12.0 of `traitlets.Set.set` if value is a string HOT 1
- Obeserve not works when showing result in widgets.Output()
- 26 tests fail
- test_complete_custom_completers failing HOT 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from traitlets.