Mercurial > fife-parpg
view engine/extensions/pychan/widgets/common.py @ 354:dfd48d49c044
* Removed shebang and svn:executable for python files which are not meant to be executed directly
* Made sure all executable files with shebang has svn:executable
author | cheesesucker@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Mon, 21 Sep 2009 19:48:00 +0000 |
parents | a9482d3d989e |
children |
line wrap: on
line source
# -*- coding: utf-8 -*- # #################################################################### # Copyright (C) 2005-2009 by the FIFE team # http://www.fifengine.de # This file is part of FIFE. # # FIFE 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 2.1 of the License, or (at your option) any later version. # # This library 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 library; if not, write to the # Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA # #################################################################### import fife import pychan.tools as tools import pychan.events as events from pychan.exceptions import * from pychan.attrs import Attr,UnicodeAttr, PointAttr,ColorAttr,BoolAttr,IntAttr,FloatAttr from pychan.properties import ColorProperty AlignTop, AlignBottom, AlignLeft, AlignRight, AlignCenter = range(5) def get_manager(): import pychan return pychan.manager def text2gui(text): """ This function is applied to all text set on widgets. It replaces tabs by four spaces. It assumes the text to be a unicode object. """ if not isinstance(text,unicode): print "Widget text needs to be set from an unicode object. Got: '%s'" % repr(text) text = unicode(text,"utf8") return text.encode("utf8",*get_manager().unicodePolicy).replace("\t"," "*4).replace("[br]","\n") def gui2text(text): """ This function is applied to all text get from widgets. Translates the encoded string into a unicode object. """ return unicode(text,"utf8",*get_manager().unicodePolicy) def gui2str(text): """ This function returns an 8-bit representation of the unicode string. This is useful for passing strings to SWIG functions. """ try: return text.__str__() except: # String contains non-ascii characters return text.encode("utf-8") def isLayouted(widget): from layout import LayoutBase return isinstance(widget,LayoutBase)