mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 00:52:43 +00:00 
			
		
		
		
	 649d2faeab
			
		
	
	
		649d2faeab
		
	
	
	
	
		
			
			We had some inconsistencies before: - Sometimes "The", sometimes "the" - Sometimes trailing ".", sometimes no trailing "." I picked the most common one (lowecase "the", trailing ".") and applied it to all copyright headers. By using the exact same string everywhere we can ensure nothing gets missed during a global search (and replace), and that these inconsistencies are not spread any further (as copyright headers are commonly copied to new files).
		
			
				
	
	
		
			225 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			225 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020-2021, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <AK/String.h>
 | |
| #include <LibWeb/CSS/Parser/Token.h>
 | |
| 
 | |
| namespace Web::CSS {
 | |
| 
 | |
| String Token::to_string() const
 | |
| {
 | |
|     StringBuilder builder;
 | |
| 
 | |
|     switch (m_type) {
 | |
|     case TokenType::Invalid:
 | |
|         VERIFY_NOT_REACHED();
 | |
| 
 | |
|     case TokenType::EndOfFile:
 | |
|         builder.append("__EOF__");
 | |
|         break;
 | |
|     case TokenType::Ident:
 | |
|         //builder.append("Identifier");
 | |
|         builder.append(m_value.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::Function:
 | |
|         builder.append("Function");
 | |
|         break;
 | |
|     case TokenType::AtKeyword:
 | |
|         builder.append("@");
 | |
|         break;
 | |
|     case TokenType::Hash:
 | |
|         builder.append("#");
 | |
|         builder.append(m_value.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::String:
 | |
|         //builder.append("String");
 | |
|         builder.append(m_value.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::BadString:
 | |
|         builder.append("Invalid String");
 | |
|         break;
 | |
|     case TokenType::Url:
 | |
|         builder.append("Url");
 | |
|         break;
 | |
|     case TokenType::BadUrl:
 | |
|         builder.append("Invalid Url");
 | |
|         break;
 | |
|     case TokenType::Delim:
 | |
|         //builder.append("Delimiter");
 | |
|         builder.append(m_value.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::Number:
 | |
|         //builder.append("Number");
 | |
|         builder.append(m_value.to_string());
 | |
|         builder.append(m_unit.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::Percentage:
 | |
|         //builder.append("Percentage");
 | |
|         builder.append(m_value.to_string());
 | |
|         builder.append(m_unit.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::Dimension:
 | |
|         //builder.append("Dimension");
 | |
|         builder.append(m_value.to_string());
 | |
|         builder.append(m_unit.to_string());
 | |
|         return builder.to_string();
 | |
|     case TokenType::Whitespace:
 | |
|         builder.append("Whitespace");
 | |
|         break;
 | |
|     case TokenType::CDO:
 | |
|         builder.append("CDO");
 | |
|         break;
 | |
|     case TokenType::CDC:
 | |
|         builder.append("CDC");
 | |
|         break;
 | |
|     case TokenType::Colon:
 | |
|         builder.append(":");
 | |
|         break;
 | |
|     case TokenType::Semicolon:
 | |
|         builder.append(";");
 | |
|         break;
 | |
|     case TokenType::Comma:
 | |
|         builder.append(",");
 | |
|         break;
 | |
|     case TokenType::OpenSquare:
 | |
|         builder.append("[");
 | |
|         break;
 | |
|     case TokenType::CloseSquare:
 | |
|         builder.append("]");
 | |
|         break;
 | |
|     case TokenType::OpenParen:
 | |
|         builder.append("(");
 | |
|         break;
 | |
|     case TokenType::CloseParen:
 | |
|         builder.append(")");
 | |
|         break;
 | |
|     case TokenType::OpenCurly:
 | |
|         builder.append("{");
 | |
|         break;
 | |
|     case TokenType::CloseCurly:
 | |
|         builder.append("}");
 | |
|         break;
 | |
|     }
 | |
| 
 | |
|     if (m_value.is_empty()) {
 | |
|         return builder.to_string();
 | |
|     }
 | |
| 
 | |
|     builder.append(" ");
 | |
| 
 | |
|     builder.append(" { value: '");
 | |
|     builder.append(m_value.to_string());
 | |
| 
 | |
|     if (m_type == Token::TokenType::Hash) {
 | |
|         builder.append("', hash_type: '");
 | |
|         if (m_hash_type == Token::HashType::Unrestricted) {
 | |
|             builder.append("Unrestricted");
 | |
|         } else {
 | |
|             builder.append("Id");
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if (m_type == Token::TokenType::Number) {
 | |
|         builder.append("', number_type: '");
 | |
|         if (m_number_type == Token::NumberType::Integer) {
 | |
|             builder.append("Integer");
 | |
|         } else {
 | |
|             builder.append("Number");
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if (m_type == Token::TokenType::Dimension) {
 | |
|         builder.append("', number_type: '");
 | |
|         if (m_number_type == Token::NumberType::Integer) {
 | |
|             builder.append("Integer");
 | |
|         } else {
 | |
|             builder.append("Number");
 | |
|         }
 | |
| 
 | |
|         builder.append("', unit: '");
 | |
|         builder.append(m_unit.to_string());
 | |
|     }
 | |
| 
 | |
|     builder.append("' }");
 | |
|     return builder.to_string();
 | |
| }
 | |
| 
 | |
| Token::TokenType Token::mirror_variant() const
 | |
| {
 | |
|     if (is_open_curly()) {
 | |
|         return TokenType::CloseCurly;
 | |
|     }
 | |
| 
 | |
|     if (is_open_square()) {
 | |
|         return TokenType::CloseSquare;
 | |
|     }
 | |
| 
 | |
|     if (is_open_paren()) {
 | |
|         return TokenType::CloseParen;
 | |
|     }
 | |
| 
 | |
|     return TokenType::Invalid;
 | |
| }
 | |
| 
 | |
| String Token::bracket_string() const
 | |
| {
 | |
|     if (is_open_curly()) {
 | |
|         return "{";
 | |
|     }
 | |
| 
 | |
|     if (is_close_curly()) {
 | |
|         return "}";
 | |
|     }
 | |
| 
 | |
|     if (is_open_square()) {
 | |
|         return "[";
 | |
|     }
 | |
| 
 | |
|     if (is_close_square()) {
 | |
|         return "]";
 | |
|     }
 | |
| 
 | |
|     if (is_open_paren()) {
 | |
|         return "(";
 | |
|     }
 | |
| 
 | |
|     if (is_close_paren()) {
 | |
|         return ")";
 | |
|     }
 | |
| 
 | |
|     return "";
 | |
| }
 | |
| 
 | |
| String Token::bracket_mirror_string() const
 | |
| {
 | |
|     if (is_open_curly()) {
 | |
|         return "}";
 | |
|     }
 | |
| 
 | |
|     if (is_close_curly()) {
 | |
|         return "{";
 | |
|     }
 | |
| 
 | |
|     if (is_open_square()) {
 | |
|         return "]";
 | |
|     }
 | |
| 
 | |
|     if (is_close_square()) {
 | |
|         return "[";
 | |
|     }
 | |
| 
 | |
|     if (is_open_paren()) {
 | |
|         return ")";
 | |
|     }
 | |
| 
 | |
|     if (is_close_paren()) {
 | |
|         return "(";
 | |
|     }
 | |
| 
 | |
|     return "";
 | |
| }
 | |
| 
 | |
| }
 |