--- /dev/null
+"""
+Example data formatters for strings represented as (pointer,length) pairs
+encoded in UTF8/16/32 for use with the LLDB debugger
+
+To use in your projects, tweak the children names as appropriate for your data structures
+and use as summaries for your data types
+
+part of The LLVM Compiler Infrastructure
+This file is distributed under the University of Illinois Open Source
+License. See LICENSE.TXT for details.
+"""
+
+import lldb
+def utf8_summary(value,unused):
+ pointer = value.GetChildMemberWithName("first").GetValueAsUnsigned(0)
+ length = value.GetChildMemberWithName("second").GetValueAsUnsigned(0)
+ if pointer == 0:
+ return False
+ if length == 0:
+ return '""'
+ error = lldb.SBError()
+ string_data = value.process.ReadMemory(pointer, length, error)
+ return '"%s"' % (string_data) # utf8 is safe to emit as-is on OSX
+
+def utf16_summary(value,unused):
+ pointer = value.GetChildMemberWithName("first").GetValueAsUnsigned(0)
+ length = value.GetChildMemberWithName("second").GetValueAsUnsigned(0)
+ # assume length is in bytes - if in UTF16 chars, just multiply by 2
+ if pointer == 0:
+ return False
+ if length == 0:
+ return '""'
+ error = lldb.SBError()
+ string_data = value.process.ReadMemory(pointer, length, error)
+ return '"%s"' % (string_data.decode('utf-16').encode('utf-8')) # utf8 is safe to emit as-is on OSX
+
+def utf32_summary(value,unused):
+ pointer = value.GetChildMemberWithName("first").GetValueAsUnsigned(0)
+ length = value.GetChildMemberWithName("second").GetValueAsUnsigned(0)
+ # assume length is in bytes - if in UTF32 chars, just multiply by 4
+ if pointer == 0:
+ return False
+ if length == 0:
+ return '""'
+ error = lldb.SBError()
+ string_data = value.process.ReadMemory(pointer, length, error)
+ return '"%s"' % (string_data.decode('utf-32').encode('utf-8')) # utf8 is safe to emit as-is on OSX
+