Comments (4)
defopt actually used to require you to register parsers exactly like this (there was no option to pass arguments to run
), but I changed it in 1.0.0 because it felt over-engineered for my use cases and the way it works now felt simpler. However at this point you're certainly using the module more than I am, so I'm happy to defer to your judgement.
On assuming that foo(s: str)
is its own parser: yes, that sounds like a sensible thing to do by default. I'd be happy to accept that change if you'd like to implement it.
On your particular use case of defining comma_separated_int_list
: from a purist standpoint, I never wanted people to have to do things like that in order to manipulate the generated command line. In this particular case, with a small fix, this becomes possible:
diff --git a/defopt.py b/defopt.py
index 80c1445..ec0cbe2 100644
--- a/defopt.py
+++ b/defopt.py
@@ -335,7 +335,7 @@ def _get_type_from_hint(hint):
list, collections_abc.Iterable, collections_abc.Sequence, # Py>=3.7
]
if ti.get_origin(hint) in container_types:
- [type_] = ti.get_args(hint)
+ [type_] = ti.get_args(hint, evaluate=True)
return _Type(type_, list)
elif ti.is_union_type(hint):
# For Union[type, NoneType], just use type.
diff --git a/examples/list_parser.py b/examples/list_parser.py
new file mode 100644
index 0000000..89063d8
--- /dev/null
+++ b/examples/list_parser.py
@@ -0,0 +1,17 @@
+from typing import List
+
+import defopt
+
+
+def example(list_of_lists_of_ints: List[List[int]]):
+ print(list_of_lists_of_ints)
+
+
+def int_list(string):
+ if not string:
+ return []
+ return [int(x) for x in string.split(',')]
+
+
+if __name__ == '__main__':
+ defopt.run(example, parsers={List[int]: int_list})
$ PYTHONPATH=. python examples/list_parser.py -l 1,2,3 4,5 6
[[1, 2, 3], [4, 5], [6]]
from defopt.
However at this point you're certainly using the module more than I am, so I'm happy to defer to your judgement.
I definitely use it a lot, and it's really useful. Thanks again for writing it :)
On assuming that foo(s: str) is its own parser.
I think that's a slightly less invasive change than explicitly having a parser registry and will probably start by implementing that.
On your particular use case of defining comma_separated_int_list [...]
I agree my approach is a bit of a hack, and didn't think of adding a parser for List[int]. It looks like even the addition of evaluate=True
is unnecessary, though?
from defopt.
Thanks again for writing it :)
No problem, thank you for your many contributions!
It looks like even the addition of
evaluate=True
is unnecessary, though?
It was necessary for me in 3.6. The docstring for ti.get_args()
mentions the default value is True
on 3.7, so if you're using that, that explains why you don't need it.
from defopt.
I think this can be considered closed by #70 and #72.
from defopt.
Related Issues (20)
- Add a registry class HOT 4
- When subclassing enum with data mixin, choices are not present on CLI HOT 8
- Consume command line arguments in 2 function calls HOT 10
- Support URLs in docstring
- Reject duplicate options for a single parameter rather than silently dropping one HOT 2
- Any way to indent within tool help text without runtime / linting error? HOT 1
- Add support for datetime.date and datetime.datetime parsers HOT 5
- Argument name suffixes as workaround for name collisions HOT 4
- Should `Optional[Tuple[type1]]` be supported HOT 7
- PyInstaller, Nuitka compatibility? HOT 5
- pin setuptools_scm < 6.4 to support python3.6 HOT 2
- Consume command line arguments in 2 calls - help text has only one call's parameters HOT 17
- Using keyword only dataclass with `defopt.run` gives a docutils warning HOT 1
- py.typed file? HOT 3
- NotImplementedError: <class 'defopt._parse_docstring.<locals>.Visitor'> visiting unknown node type: definition_list HOT 3
- TypeError: can only join an iterable HOT 2
- Requestion: add an option to convert underscores to hyphens for all arguments HOT 2
- [BUG] Pyinstaller does not resolve defopt import HOT 5
- Support repeated options that take a single argument (action=append) HOT 2
- Support for blank lines and indentation in argument help HOT 2
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 defopt.