Source code for libkatepate.pred

#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Copyright 2010-2012 by Alex Turbov <i.zaufi@gmail.com>
#
# This software is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This software is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this software.  If not, see <http://www.gnu.org/licenses/>.
#

''' Reusable code for Kate/Pâté plugins: predicates for text processing '''


[docs]def blockCommentStart(line): ''' True if line contains C/C++ block-comment-start ''' return '/*' in line
[docs]def blockCommentEnd(line): ''' True if line contains C/C++ block-comment-end ''' return '*/' in line
[docs]def startsWith(start): ''' True if passed line starts with a given string ''' def wrapper(line): print( "** startsWith predicate: %s.startswith(%s) = %s" % (repr(line.lstrip()), repr(start), line.lstrip().startswith(start)) ) return line.lstrip().startswith(start) return wrapper
[docs]def equalTo(text): ''' True if passed line equals to a given string ''' def wrapper(line): print("** equalTo predicate: %s == %s" % (repr(line), repr(text))) return line.strip() == text return wrapper
[docs]def onlySingleLineComment(line): ''' True if line contains only single line comment ''' return line.lstrip().startswith('//')
[docs]def neg(predicate): ''' Negate given predicate ''' def wrp(*args, **kwargs): return not predicate(*args, **kwargs) return wrp
[docs]def any_of(*predicates): ''' Evaluate given predicates list 'till one of 'em is True ''' def wrp(*args, **kwargs): for predicate in predicates: if predicate(*args, **kwargs): return True return False return wrp
[docs]def all_of(*predicates): ''' Evaluate given predicates list 'till one of 'em is False ''' def wrp(*args, **kwargs): for predicate in predicates: if not predicate(*args, **kwargs): return False return True return wrp