blob: cf79038031391ecc283d33a94e3cb35681739df4 [file] [log] [blame]
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You 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.
import re
class Grep:
# How many lines from command output send to server
OUTPUT_LAST_LINES = 10
# How many lines from command error output send to server (before Err phrase)
ERROR_LAST_LINES_BEFORE = 30
# How many lines from command error output send to server (after Err phrase)
ERROR_LAST_LINES_AFTER = 30
def __init__(self):
pass
def grep(self, string, phrase, before, after):
"""
Tries to find the last occurence of phrase in a given string. String should consist of lines,
separated by line separators. String trim is performed before search.
If occurence is found, grep () takes not more than 'before' lines above and 'after' lines below.
If phrase is not found, returns None. Search is not case sensitive, regexps are not supported.
"""
stripped_string = string.strip()
lines = stripped_string.splitlines(True)
first_occurence = None
for index in range(len(lines)):
line = lines[index]
if phrase.lower() in line.lower():
first_occurence = index
break
if first_occurence is None:
return None
bound_a = before
if first_occurence < before:
bound_a = first_occurence
result = None
if (len(lines) - first_occurence) < after:
result = lines[first_occurence - bound_a :]
else:
result = lines[first_occurence - bound_a : first_occurence + after + 1]
return "".join(result).strip()
def cleanByTemplate(self, string, template):
if string is not None:
stripped_string = string.strip()
lines = stripped_string.splitlines(True)
for line in lines[:]:
if template.lower() in line.lower():
lines.remove(line)
return "".join(lines).strip()
else:
return string
def tail(self, string, n):
"""
Copies last n lines from string to result. Also, string trim is performed.
"""
stripped_string = string.strip()
lines = stripped_string.splitlines(True)
if len(lines) <= n:
return stripped_string
else:
length = len(lines)
tailed = lines[length - n:]
return "".join(tailed)
def filterMarkup(self, string):
if string is None:
result = None
else:
regexp = "\x1b" + r"\[[\d;]{1,4}m"
result = re.sub(regexp, '', string)
return result