2017-10-10 14:59:31 +00:00
|
|
|
# Copyright 2017 The Bazel 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.
|
|
|
|
|
|
|
|
"""Skylib module containing functions that operate on collections."""
|
|
|
|
|
|
|
|
def _after_each(separator, iterable):
|
2018-06-12 17:09:57 +00:00
|
|
|
"""Inserts `separator` after each item in `iterable`.
|
2018-04-26 16:08:01 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Args:
|
|
|
|
separator: The value to insert after each item in `iterable`.
|
|
|
|
iterable: The list into which to intersperse the separator.
|
2017-10-10 14:59:31 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Returns:
|
|
|
|
A new list with `separator` after each item in `iterable`.
|
|
|
|
"""
|
|
|
|
result = []
|
|
|
|
for x in iterable:
|
|
|
|
result.append(x)
|
|
|
|
result.append(separator)
|
2017-10-10 14:59:31 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
return result
|
2017-10-10 14:59:31 +00:00
|
|
|
|
|
|
|
def _before_each(separator, iterable):
|
2018-06-12 17:09:57 +00:00
|
|
|
"""Inserts `separator` before each item in `iterable`.
|
2017-10-10 14:59:31 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Args:
|
|
|
|
separator: The value to insert before each item in `iterable`.
|
|
|
|
iterable: The list into which to intersperse the separator.
|
2018-04-26 16:08:01 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Returns:
|
|
|
|
A new list with `separator` before each item in `iterable`.
|
|
|
|
"""
|
|
|
|
result = []
|
|
|
|
for x in iterable:
|
|
|
|
result.append(separator)
|
|
|
|
result.append(x)
|
2017-10-10 14:59:31 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
return result
|
2017-10-10 14:59:31 +00:00
|
|
|
|
|
|
|
def _uniq(iterable):
|
2018-06-12 17:09:57 +00:00
|
|
|
"""Returns a list of unique elements in `iterable`.
|
2017-10-10 14:59:31 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Requires all the elements to be hashable.
|
2018-04-26 16:08:01 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Args:
|
|
|
|
iterable: An iterable to filter.
|
2017-10-10 14:59:31 +00:00
|
|
|
|
2018-06-12 17:09:57 +00:00
|
|
|
Returns:
|
|
|
|
A new list with all unique elements from `iterable`.
|
|
|
|
"""
|
|
|
|
unique_elements = {element: None for element in iterable}
|
2019-01-10 20:26:52 +00:00
|
|
|
|
|
|
|
# list() used here for python3 compatibility.
|
|
|
|
# TODO(bazel-team): Remove when testing frameworks no longer require python compatibility.
|
|
|
|
return list(unique_elements.keys())
|
2017-10-10 14:59:31 +00:00
|
|
|
|
|
|
|
collections = struct(
|
2018-06-12 17:09:57 +00:00
|
|
|
after_each = _after_each,
|
|
|
|
before_each = _before_each,
|
|
|
|
uniq = _uniq,
|
2017-10-10 14:59:31 +00:00
|
|
|
)
|