-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Solution for "python3" as OS 'features' #13
Comments
We need to make sure that the expanded format is also writable and readable without using the compact notation. And using the ordering of triplets will fail with a standard alphabetical export. I'd suggest using a few more characters while using a special prefix something like feature_true_python3 feature_false_python3. The exact prefix could probably find better wording, but if that specific prefix is encountered it causes the resolution to descend into the subtrees. Also since we're possibly doing the same key munging as #10 so maybe feature==python3, feature!=python3 and use the same syntax and parsing. |
Your whole comment including the last bit suggesting Yes, i fully agree that the expanded version needs to be write/readable as well. The idea with rules expansion is that it transforms shorthand notation suitable for humans to a more explicit form suitable for lookup. But rules expansion should be idempotent and valid YAML that can be written and read. Unfortunately when I made this post I messed up with updating read-the-docs and it was actually not linking to the latest version of that text. It is fixed now and I have made slight adjustments to the internal format to use dicts instead of ordered lists. Does that address your concern? (The examples in the text don't actually have alphabetical ordering for the dicts, but the order for dicts does not matter anyway). Also, for the shorthand format the negative Anyway with the previous format I don't think the ordering would have been a problem, since the triplets were supposed to be lists, which retain their order. I also did not want to introduce names such as One point regarding using only |
Regarding clean unicode support: you might want to make all code use Python 3 by default. Making it work for Python 2 afterwards is much easier then the other way around. |
@dirk-thomas: At the moment I'm (trying to) write code that works on py2 and py3. In particular tests are run for both (testsuite is not so big yet, though). The strategy regarding unicode is representing all text data internally as |
I was referring to e.g. Line 1 in ab0c4a4
I usually find it easier to make Python 3 the default (for new development) since it is much more "picky" when it comes to |
Ah ok. Yes, maybe it makes sense to do local development/testing with python 3, however I don't actually use that script but rather the setuptools generated script, which should use the correct verison when installed with I think for a helper script such as the one you pointed out it makes sense reference the default By the way tools like python-modernize help to write py2/3 compatible code, e.g. by making sure you have |
Yes, my whole comment was about the expanded version. The dictionary |
Here is a proposal for how to realize this:
http://xylem.readthedocs.org/en/latest/design.html#os-options
This also includes a discussion why using "derivative OS" is not a good choice IMO.
Feel free to comment / discuss in this issue.
The text was updated successfully, but these errors were encountered: