Skip to content

Commit

Permalink
Merge pull request #125 from izapolsk/get_rid_of_increment_in_row
Browse files Browse the repository at this point in the history
[RFR] make TableRow use index 0 for first row
  • Loading branch information
mshriver authored Nov 8, 2018
2 parents aa499a9 + cebc9d8 commit 997ff8c
Showing 1 changed file with 10 additions and 17 deletions.
27 changes: 10 additions & 17 deletions src/widgetastic/widget/table.py
Original file line number Diff line number Diff line change
Expand Up @@ -138,9 +138,7 @@ class TableRow(Widget, ClickableMixin):

def __init__(self, parent, index, logger=None):
Widget.__init__(self, parent, logger=logger)
# todo: get rid of all these indexes
needs_increment = parent._is_header_in_body or self.table.has_rowcolspan
self.index = index + 1 if needs_increment else index or 1
self.index = index + 1 if parent._is_header_in_body else index

@property
def table(self):
Expand All @@ -150,7 +148,7 @@ def __repr__(self):
return '{}({!r}, {!r})'.format(type(self).__name__, self.parent, self.index)

def __locator__(self):
loc = self.parent.ROW_AT_INDEX.format(self.index)
loc = self.parent.ROW_AT_INDEX.format(self.index + 1)
return self.browser.element(loc, parent=self.parent)

def position_to_column_name(self, position):
Expand All @@ -168,7 +166,7 @@ def __getitem__(self, item):
if self.table.table_tree:
# todo: add support of xpath and/or iteration to anytree lib
return self.table.resolver.glob(self.table.table_tree,
'/table/tbody/tr[{}]/*[{}]'.format(self.index-1,
'/table/tbody/tr[{}]/*[{}]'.format(self.index,
index))[0].obj

else:
Expand Down Expand Up @@ -363,7 +361,7 @@ def _process_negative_index(self, nindex):
if (- nindex) > max_index:
raise IndexError('Negative index {} wanted but we only have {} rows'
.format(nindex, max_index))
return max_index + nindex + 1
return max_index + nindex

def clear_cache(self):
"""Clear all cached properties."""
Expand Down Expand Up @@ -455,7 +453,7 @@ def __getitem__(self, item):

if self.table_tree:
nodes = self.resolver.glob(self.table_tree, '/table/tbody/tr*')
at_index = at_index + 1 if self._is_header_in_body else at_index or 1
at_index = at_index + 1 if self._is_header_in_body else at_index
try:
return six.next(n.obj for n in nodes if n.position == at_index)
except StopIteration:
Expand Down Expand Up @@ -522,7 +520,7 @@ def _all_rows(self):
for node in self.resolver.glob(self.table_tree, '/table/tbody/tr*'):
yield node.obj
else:
for row_pos in range(1, self.row_count + 1):
for row_pos in range(self.row_count):
yield self.Row(self, row_pos, logger=create_item_logger(self.logger, row_pos))

def _process_filters(self, *extra_filters, **filters):
Expand Down Expand Up @@ -641,12 +639,11 @@ def _filter_rows_by_query(self, query):
for row_element in self.browser.elements(query, parent=self):
row_pos = self._get_number_preceeding_rows(row_element)
# get_number_preceeding_rows is javascript driven, and does not account for thead
# When it counts rows, if the header is in the body of the table, then our index
# for this element is correct
# When it counts rows, if the header is in the body of the table, then our index is
# incorrect and has to be decreased
# If the header is not in the body of the table, number of preceeding rows is 0-based
# and we add 1 to the index to get correct XPATH index offset
row_pos = row_pos if self._is_header_in_body else row_pos + 1
rows.append(self.Row(self, row_pos,
# what is correct
rows.append(self.Row(self, row_pos - 1 if self._is_header_in_body else row_pos,
logger=create_item_logger(self.logger, row_pos)))
return rows

Expand Down Expand Up @@ -692,7 +689,6 @@ def _apply_processed_filters(self, rows, processed_filters):
for row in rows:
next_row = False
for column_index, matchers in six.iteritems(processed_filters):
# fixme: check maybe +1 isn't necessary
column = row[column_index]
for method, value in matchers:
if method is None:
Expand Down Expand Up @@ -758,7 +754,6 @@ def row_by_cell_or_widget_value(self, column, value):
Raises:
:py:class:`RowNotFound`
"""
# todo: add support of rowspan
try:
return self.row((column, value))
except RowNotFound:
Expand Down Expand Up @@ -895,8 +890,6 @@ def _process_table(self):
cur_tag = self.browser.tag(child)
if cur_tag == 'tr':
# todo: add logger
# position has been decremented for rows because it is incremented
# if 0 in TableRow.__init__ for some reason
cur_obj = TableRow(parent=self._get_ancestor_node_obj(node), index=position)
cur_node = Node(name=cur_tag, parent=node, obj=cur_obj, position=position)
queue.append(cur_node)
Expand Down

0 comments on commit 997ff8c

Please sign in to comment.