Source code for robot.parsing.datarow

#  Copyright 2008-2015 Nokia Networks
#  Copyright 2016-     Robot Framework Foundation
#
#  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.

from robot.output import LOGGER
from robot.utils import py2to3


[docs]@py2to3 class DataRow(object): _row_continuation_marker = '...' def __init__(self, cells, source=None): self.source = source self.cells, self.comments = self._parse(cells) def _parse(self, row): data = [] comments = [] for cell in row: cell = self._collapse_whitespace(cell) if cell and cell[0] == '#' or comments: comments.append(cell) else: data.append(cell) if self._row_continuation_marker in data and self.source: self._deprecate_escaped_cells_before_continuation(data) return self._purge_empty_cells(data), self._purge_empty_cells(comments) def _collapse_whitespace(self, cell): return ' '.join(cell.split()) def _deprecate_escaped_cells_before_continuation(self, data): index = data.index(self._row_continuation_marker) if any(cell == '\\' for cell in data[:index]): LOGGER.warn("Error in file '%s': Escaping empty cells with " "'\\' before line continuation marker '...' is " "deprecated. Remove escaping before Robot " "Framework 3.2." % self.source) def _purge_empty_cells(self, row): while row and not row[-1]: row.pop() # Cells with only a single backslash are considered empty return [cell if cell != '\\' else '' for cell in row] @property def head(self): return self.cells[0] if self.cells else '' @property def tail(self): return self.cells[1:] @property def all(self): return self.cells @property def data(self): if self.is_continuing(): index = self.cells.index(self._row_continuation_marker) + 1 return self.cells[index:] return self.cells
[docs] def dedent(self): datarow = DataRow([]) datarow.cells = self.tail datarow.comments = self.comments return datarow
[docs] def starts_for_loop(self): head = self.head if head.startswith(':'): return head.replace(':', '').replace(' ', '').upper() == 'FOR' return head == 'FOR'
[docs] def starts_test_or_user_keyword_setting(self): head = self.head return head and head[0] == '[' and head[-1] == ']'
[docs] def test_or_user_keyword_setting_name(self): return self.head[1:-1].strip()
[docs] def is_indented(self): return self.head == ''
[docs] def is_continuing(self): for cell in self.cells: if cell == self._row_continuation_marker: return True if cell: return False
[docs] def is_commented(self): return bool(not self.cells and self.comments)
def __nonzero__(self): return bool(self.cells or self.comments)