Skip to content
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

Parse simple expressions #389

Open
wants to merge 13 commits into
base: main
Choose a base branch
from

Conversation

raxbg
Copy link
Contributor

@raxbg raxbg commented Sep 19, 2022

Fixes #388
Builds on top of #390

public function functionArithmeticInFile()
{
$oDoc = self::parsedStructureForFile('function-arithmetic', Settings::create()->withMultibyteSupport(true));
$sExpected = 'div {height: max(300,vh + 10);}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

AFAICT, vh without a number in front is still not valid and I’d prefer it would throw an error in strict mode.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Indeed, it is invalid, however this seems to be outside of the scope of these changes. I guess we need a separate issue for this. Also is it a concern of the parser to validate the semantic meaning of identifiers it encounters?

Copy link
Contributor

@JakeQZ JakeQZ Feb 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also is it a concern of the parser to validate the semantic meaning of identifiers it encounters?

I agree it's not.

Moving forwards, we've agreed to replace strict mode parsing with a logging mechanism. And try to replicate what most browsers do when encountering invalid syntax. A unit with no number in front should therefore probably be parsed as zero of that unit. And, as a bonus, a separate PR would log the lack of a number.

So, for now, we don't need to worry about strict mode, but should create issues for things that could be logged in future.

@westonruter
Copy link
Contributor

For what it's worth, I'm including this patch in ampproject/amp-wp#7487 and it is passing all tests in our project.

@oliverklee oliverklee deleted the branch MyIntervals:main February 7, 2024 11:36
@oliverklee oliverklee closed this Feb 7, 2024
@westonruter
Copy link
Contributor

@oliverklee was this closed as well as other PRs (e.g. #185 and #193) just because the master branch was deleted?

@oliverklee
Copy link
Contributor

@westonruter Oh no! It indeed was. ;-(

@oliverklee oliverklee reopened this Feb 7, 2024
@oliverklee
Copy link
Contributor

I have now reinstated the legacy master branch and will reopen the PRs in a minute. So sorry for this.

@sabberworm
Copy link
Contributor

I have now reinstated the legacy master branch and will reopen the PRs in a minute. So sorry for this.

I would prefer we delete the master branch and just change all the PRs to point to main instead.

@oliverklee
Copy link
Contributor

@sabberworm Oh, I wasn't aware that this was possible in the first place! Will do.

@oliverklee oliverklee changed the base branch from master to main February 7, 2024 22:34
@oliverklee
Copy link
Contributor

I have now moved all PRs over to main and dropped the master branch again.

Copy link
Contributor

@JakeQZ JakeQZ left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like this. I'd be happy for this to be merged. @oliverklee, @sabberworm WDYT?

public function functionArithmeticInFile()
{
$oDoc = self::parsedStructureForFile('function-arithmetic', Settings::create()->withMultibyteSupport(true));
$sExpected = 'div {height: max(300,vh + 10);}
Copy link
Contributor

@JakeQZ JakeQZ Feb 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also is it a concern of the parser to validate the semantic meaning of identifiers it encounters?

I agree it's not.

Moving forwards, we've agreed to replace strict mode parsing with a logging mechanism. And try to replicate what most browsers do when encountering invalid syntax. A unit with no number in front should therefore probably be parsed as zero of that unit. And, as a bonus, a separate PR would log the lack of a number.

So, for now, we don't need to worry about strict mode, but should create issues for things that could be logged in future.

Comment on lines 36 to 64
/**
* @param ParserState $oParserState
* @param bool $bIgnoreCase
*
* @return string
*
* @throws SourceException
* @throws UnexpectedEOFException
* @throws UnexpectedTokenException
*/
public static function parseName(ParserState $oParserState, $bIgnoreCase = false)
{
return $oParserState->parseIdentifier($bIgnoreCase);
}

/**
* @param ParserState $oParserState
*
* @return array
*
* @throws SourceException
* @throws UnexpectedEOFException
* @throws UnexpectedTokenException
*/
public static function parseArgs(ParserState $oParserState)
{
return Value::parseValue($oParserState, ['=', ' ', ',']);
}

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice refactoring. Could this be put through as a separate PR?

@JakeQZ JakeQZ requested a review from oliverklee February 15, 2024 02:30
Copy link
Contributor

@JakeQZ JakeQZ left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need a changelog entry, though.

Comment on lines 1 to 32
<?php

namespace Sabberworm\CSS\Value;

use Sabberworm\CSS\OutputFormat;
use Sabberworm\CSS\Parsing\ParserState;

/**
* An `Expression` represents a special kind of value that is comprised of multiple components wrapped in parenthesis.
* Examle `height: (vh - 10);`.
*/
class Expression extends CSSFunction
{
/**
* @param ParserState $oParserState
* @param bool $bIgnoreCase
*
* @return Expression
*
* @throws SourceException
* @throws UnexpectedEOFException
* @throws UnexpectedTokenException
*/
public static function parse(ParserState $oParserState, $bIgnoreCase = false)
{
$oParserState->consume('(');
$aArguments = self::parseArgs($oParserState);
$mResult = new Expression("", $aArguments, ',', $oParserState->currentLine());
$oParserState->consume(')');
return $mResult;
}
}
Copy link
Contributor

@JakeQZ JakeQZ Feb 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There should be a class-specific unit test for this new class. The overall parser tests are good, but we also want to make sure each individual class behaves as it should.

Copy link
Contributor

@JakeQZ JakeQZ Feb 15, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@raxbg, would you be willing to create a corresponding TestExpression class to test this new class as a standalone?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There should be a class-specific unit test for this new class. The overall parser tests are good, but we also want to make sure each individual class behaves as it should.

Makes sense. How does that look like: 14118a2

@JakeQZ
Copy link
Contributor

JakeQZ commented Feb 15, 2024

I like this. I'd be happy for this to be merged. @oliverklee, @sabberworm WDYT?

On further looking, a class-specific unit test is also needed for the new class (inherited from the terribly misnomered TestCase - Rename That!).

@oliverklee
Copy link
Contributor

Also, according to the original commit message, this builds on on top of #390. So we should get that in first and then rebase.

Copy link
Contributor

@oliverklee oliverklee left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's get #390 in first.

@raxbg
Copy link
Contributor Author

raxbg commented Jul 10, 2024

#390 is closed now and seems like it's no longer needed. There shouldn't be anything else blocking the merge of this PR :)

Let me know if you have any concerns

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Expressions are not being parsed
5 participants