blob: ca314c54c7f5e7ddd56dd5b09fc183b9127a453d [file] [log] [blame]
// Copyright 2014 The Cobalt Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef COBALT_CSSOM_TYPE_SELECTOR_H_
#define COBALT_CSSOM_TYPE_SELECTOR_H_
#include <string>
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "cobalt/base/tokens.h"
#include "cobalt/cssom/selector_tree.h"
#include "cobalt/cssom/simple_selector.h"
#include "cobalt/cssom/specificity.h"
namespace cobalt {
namespace cssom {
class SelectorVisitor;
// A type selector represents an instance of the element type in the document
// tree.
// https://www.w3.org/TR/selectors4/#type-selector
class TypeSelector : public SimpleSelector {
public:
explicit TypeSelector(const std::string& element_name)
: SimpleSelector(kTypeSelector, base::Token(),
base::Token(element_name)) {}
~TypeSelector() override {}
// From Selector.
void Accept(SelectorVisitor* visitor) override;
Specificity GetSpecificity() const override { return Specificity(0, 0, 1); }
// From SimpleSelector.
void IndexSelectorTreeNode(SelectorTree::Node* parent_node,
SelectorTree::Node* child_node,
CombinatorType combinator) override;
// Rest of public methods.
base::Token element_name() const { return text(); }
private:
DISALLOW_COPY_AND_ASSIGN(TypeSelector);
};
} // namespace cssom
} // namespace cobalt
#endif // COBALT_CSSOM_TYPE_SELECTOR_H_