mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-31 20:04:25 -05:00
d00ebf445b
* upgrade to most recent bluemonday * make vendor * update tests for bluemonday * update tests for bluemonday * update tests for bluemonday
33 lines
1.1 KiB
Go
33 lines
1.1 KiB
Go
// Copyright 2012 The Gorilla Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
/*
|
|
Package gorilla/css/scanner generates tokens for a CSS3 input.
|
|
|
|
It follows the CSS3 specification located at:
|
|
|
|
http://www.w3.org/TR/css3-syntax/
|
|
|
|
To use it, create a new scanner for a given CSS string and call Next() until
|
|
the token returned has type TokenEOF or TokenError:
|
|
|
|
s := scanner.New(myCSS)
|
|
for {
|
|
token := s.Next()
|
|
if token.Type == scanner.TokenEOF || token.Type == scanner.TokenError {
|
|
break
|
|
}
|
|
// Do something with the token...
|
|
}
|
|
|
|
Following the CSS3 specification, an error can only occur when the scanner
|
|
finds an unclosed quote or unclosed comment. In these cases the text becomes
|
|
"untokenizable". Everything else is tokenizable and it is up to a parser
|
|
to make sense of the token stream (or ignore nonsensical token sequences).
|
|
|
|
Note: the scanner doesn't perform lexical analysis or, in other words, it
|
|
doesn't care about the token context. It is intended to be used by a
|
|
lexer or parser.
|
|
*/
|
|
package scanner
|