You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
1.9 KiB
54 lines
1.9 KiB
"""
|
|
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 Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
See https://llvm.org/LICENSE.txt for license information.
|
|
SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
"""
|
|
|
|
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)
|
|
# utf8 is safe to emit as-is on OSX
|
|
return '"%s"' % (string_data.decode('utf-16').encode('utf-8'))
|
|
|
|
|
|
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)
|
|
# utf8 is safe to emit as-is on OSX
|
|
return '"%s"' % (string_data.decode('utf-32').encode('utf-8'))
|