-
-
Notifications
You must be signed in to change notification settings - Fork 22
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
Calc with internal parentheses being deleted. #5
Comments
I've taken a good crack at this myself, but been unable to make too much headway, due to simply not being familiar with the codebase. Regardless, here's the fruit of my labour and what I assume needs to be done here. cssutils/cssutils/css/cssvalue.py Lines 1208 to 1238 in cdffe59
cssutils/cssutils/css/value.py Lines 788 to 850 in cdffe59
Basically, somehow CalcValue and CSSCalc needs to recursively refer to themselves, with an Operator of either "(" or "calc(". The actual handling of calc as it currently exists is perfectly adequate at handling all other cases, at least in my testing and experience. Additionally, this particular check for a closing bracket probably needs to be removed or reworked: cssutils/cssutils/css/cssvalue.py Line 1230 in cdffe59
I've been unable to get anything to build that functions substantially different, but hopefully someone on the team can pick this up and move it further. If that's you, thanks so much for your time and effort in this library. |
I've adopted maintenance of this package, but unfortunately, I don't know the codebase much at all. I appreciate the work you've done and welcome you or others to do more. |
Pardon the unusually high specificity of this bug, but this has been a serious blocker for me, and has cost me most of a day.
Basically, from my research I've found that any line of CSS including parentheses inside a calc statement will be removed. To test, all I'm doing with my CSS currently is parsing and printing it (Using the current v2.2.0 version, ofc):
In my findings, even lengthy calcs like this will be left alone:
font-size: calc(15px * 100vw - 600px / 1320);
, but the moment any brackets are introduced it will fail, like this line:font-size: calc((100vw - 600px) * 10);
.Functions like this are supposedly meant to be handled according to the documents linked in the README, look at Example 29 for particulars. Regarding that same example, I've also tried nested calcs in the same fashion, to no avail:
font-size: calc(calc(100vw - 600px) * 10);
.Basically what I'm asking, is if there's any way for this bug to be fixed or worked around? Ideally, I'd love something I can do today, to either skip validating these lines or to find a way to get them to pass without changing the meaning.
The text was updated successfully, but these errors were encountered: