UTF8 in either unicode or ansi builds git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@33678 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			118 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|  
 | |
| def AddTextUTF8(self, text):
 | |
|     """
 | |
|     Add UTF8 encoded text to the document at the current position.
 | |
|     Works 'natively' in a unicode build of wxPython, and will also work
 | |
|     in an ansi build if the UTF8 text is compatible with the current
 | |
|     encoding.
 | |
|     """
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode('utf-8')
 | |
|         text = u.encode(wx.GetDefaultPyEncoding())
 | |
|     self.AddTextRaw(text)
 | |
| 
 | |
|     
 | |
| def InsertTextUTF8(self, pos, text):
 | |
|     """
 | |
|     Insert UTF8 encoded text at a position.  Works 'natively' in a
 | |
|     unicode build of wxPython, and will also work in an ansi build if
 | |
|     the UTF8 text is compatible with the current encoding.
 | |
|     """
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode('utf-8')
 | |
|         text = u.encode(wx.GetDefaultPyEncoding())
 | |
|     self.InsertTextRaw(pos, text)
 | |
| 
 | |
|     
 | |
| def GetCurLineUTF8(self):
 | |
|     """
 | |
|     Retrieve the UTF8 text of the line containing the caret, and also
 | |
|     the index of the caret on the line.  In an ansi build of wxPython
 | |
|     the text retrieved from the document is assumed to be in the
 | |
|     current default encoding.
 | |
|     """
 | |
|     text, pos = self.GetCurLineRaw()
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode(wx.GetDefaultPyEncoding())
 | |
|         text = u.encode('utf-8')
 | |
|     return text, pos
 | |
| 
 | |
|     
 | |
| def GetLineUTF8(self, line):
 | |
|     """
 | |
|     Retrieve the contents of a line as UTF8.  In an ansi build of wxPython
 | |
|     the text retrieved from the document is assumed to be in the
 | |
|     current default encoding.
 | |
|     """
 | |
|     text = self.GetLineRaw(line)
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode(wx.GetDefaultPyEncoding())
 | |
|         text = u.encode('utf-8')
 | |
|     return text
 | |
| 
 | |
| 
 | |
| def GetSelectedTextUTF8(self):
 | |
|     """
 | |
|     Retrieve the selected text as UTF8.  In an ansi build of wxPython
 | |
|     the text retrieved from the document is assumed to be in the
 | |
|     current default encoding.
 | |
|     """
 | |
|     text = self.GetSelectedTextRaw()
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode(wx.GetDefaultPyEncoding())
 | |
|         text = u.encode('utf-8')
 | |
|     return text
 | |
| 
 | |
| 
 | |
| def GetTextRangeUTF8(self, startPos, endPos):
 | |
|     """
 | |
|     Retrieve a range of text as UTF8.  In an ansi build of wxPython
 | |
|     the text retrieved from the document is assumed to be in the
 | |
|     current default encoding.
 | |
|     """
 | |
|     text = self.GetTextRangeRaw(startPos, endPos)
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode(wx.GetDefaultPyEncoding())
 | |
|         text = u.encode('utf-8')
 | |
|     return text
 | |
| 
 | |
| 
 | |
| def SetTextUTF8(self, text):
 | |
|     """
 | |
|     Replace the contents of the document with the UTF8 text given.
 | |
|     Works 'natively' in a unicode build of wxPython, and will also
 | |
|     work in an ansi build if the UTF8 text is compatible with the
 | |
|     current encoding.
 | |
|     """
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode('utf-8')
 | |
|         text = u.encode(wx.GetDefaultPyEncoding())
 | |
|     self.SetTextRaw(text)
 | |
| 
 | |
| 
 | |
| def GetTextUTF8(self):
 | |
|     """
 | |
|     Retrieve all the text in the document as UTF8.  In an ansi build
 | |
|     of wxPython the text retrieved from the document is assumed to be
 | |
|     in the current default encoding.
 | |
|     """
 | |
|     text = self.GetTextRaw()
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode(wx.GetDefaultPyEncoding())
 | |
|         text = u.encode('utf-8')
 | |
|     return text
 | |
| 
 | |
| 
 | |
| def AppendTextUTF8(self, text):
 | |
|     """
 | |
|     Append a UTF8 string to the end of the document without changing
 | |
|     the selection.  Works 'natively' in a unicode build of wxPython,
 | |
|     and will also work in an ansi build if the UTF8 text is compatible
 | |
|     with the current encoding.
 | |
|     """
 | |
|     if not wx.USE_UNICODE:
 | |
|         u = text.decode('utf-8')
 | |
|         text = u.encode(wx.GetDefaultPyEncoding())
 | |
|     self.AppendTextRaw(text)
 | |
| 
 |