# Buildsheet autogenerated by ravenadm tool -- Do not edit. NAMEBASE= python-cssutils VERSION= 2.11.1 KEYWORDS= python VARIANTS= v12 v13 SDESC[v12]= Cascading Style Sheets library (3.12) SDESC[v13]= Cascading Style Sheets library (3.13) HOMEPAGE= https://github.com/jaraco/cssutils CONTACT= Python_Automaton[python@ironwolf.systems] DOWNLOAD_GROUPS= main SITES[main]= PYPIWHL/a7/ec/bb273b7208c606890dc36540fe667d06ce840a6f62f9fae7e658fcdc90fb DISTFILE[1]= cssutils-2.11.1-py3-none-any.whl:main DIST_SUBDIR= python-src DF_INDEX= 1 SPKGS[v12]= single SPKGS[v13]= single OPTIONS_AVAILABLE= PY312 PY313 OPTIONS_STANDARD= none VOPTS[v12]= PY312=ON PY313=OFF VOPTS[v13]= PY312=OFF PY313=ON DISTNAME= cssutils-2.11.1.dist-info GENERATED= yes [PY312].RUN_DEPENDS_ON= python-more-itertools:single:v12 [PY312].USES_ON= python:v12,wheel [PY313].RUN_DEPENDS_ON= python-more-itertools:single:v13 [PY313].USES_ON= python:v13,wheel [FILE:3894:descriptions/desc.single] :alt: tests :alt: Ruff Overview ======== A Python package to parse and build CSS Cascading Style Sheets. DOM only, not any rendering facilities! Based upon and partly implementing the following specifications : `CSS 2.1rev1 `__ General CSS rules and properties are defined here `CSS3 Module: Syntax `__ Used in parts since cssutils 0.9.4. cssutils tries to use the features from CSS 2.1 and CSS 3 with preference to CSS3 but as this is not final yet some parts are from CSS 2.1 [CSS Fonts Module Level 3] Added changes and additional stuff (since cssutils v0.9.6) [MediaQueries] MediaQueries are part of ``stylesheets.MediaList`` since v0.9.4, used in @import and @media rules. [Namespaces] Added in v0.9.1, updated to definition in CSSOM in v0.9.4, updated in 0.9.5 for dev version `CSS3 Module: Pages Media `__ Most properties of this spec are implemented including MarginRules [Selectors] The selector syntax defined here (and not in CSS 2.1) should be parsable with cssutils (*should* mind though ;) ) [CSS Backgrounds and Borders Module Level 3], [CSS3 Basic User Interface Module], [CSS Text Level 3] Some validation for properties included, mainly `cursor`, `outline`, `resize`, `box-shadow`, `text-shadow` [Variables] / [CSS Custom Properties] Experimental specification of CSS Variables which cssutils implements partly. The vars defined in the newer CSS Custom Properties spec should in main parts be at least parsable with cssutils. [DOM Level 2 Style CSS] DOM for package css. 0.9.8 removes support for CSSValue and related API, see PropertyValue and Value API for now [DOM Level 2 Style Stylesheets] DOM for package stylesheets [CSSOM] A few details (mainly the NamespaceRule DOM) are taken from here. Plan is to move implementation to the stuff defined here which is newer but still no REC so might change anytime... The cssutils tokenizer is a customized implementation of `CSS3 Module: Syntax (W3C Working Draft 13 August 2003) `_ which itself is based on the CSS 2.1 tokenizer. It tries to be as compliant as possible but uses some (helpful) parts of the CSS 2.1 tokenizer. I guess cssutils is neither CSS 2.1 nor CSS 3 compliant but tries to at least be able to parse both grammars including some more real world cases (some CSS hacks are actually parsed and serialized). Both official grammars are not final nor bugfree but still feasible. cssutils aim is not to be fully compliant to any CSS specification (the specifications seem to be in a constant flow anyway) but cssutils *should* be able to read and write as many as possible CSS stylesheets "in the wild" while at the same time implement the official APIs which are well documented. Some minor extensions are provided as well. Compatibility ============= cssutils is developed on modern Python versions. Check the package metadata for compatibilty. Beware, cssutils is known to be thread unsafe. Example ======= :: import cssutils css = '''/* a comment with umlaut ä */ @namespace html "http://www.w3.org/1999/xhtml"; @variables { BG: #fff } html|a { color:red; background: var(BG) }''' sheet = cssutils.parseString(css) for rule in sheet: if rule.type == rule.STYLE_RULE: # find property for property in rule.style: if property.name == 'color': property.value = 'green' property.priority = 'IMPORTANT' break # or simply: rule.style['margin'] = '01.0eM' # or: ('1em', 'important') sheet.encoding = 'ascii' sheet.namespaces['xhtml'] = 'http://www.w3.org/1999/xhtml' sheet.namespaces['atom'] = 'http://www.w3.org/2005/Atom' [FILE:122:distinfo] a67bfdfdff4f3867fab43698ec4897c1a828eca5973f4073321b3bccaf1199b1 385747 python-src/cssutils-2.11.1-py3-none-any.whl