Skip to content

Commit b4199d5

Browse files
---
yaml --- r: 191230 b: refs/heads/try c: 07240d6 h: refs/heads/master v: v3
1 parent 56654b4 commit b4199d5

File tree

135 files changed

+3276
-2904
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

135 files changed

+3276
-2904
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
refs/heads/master: 809a554fca2d0ebc2ba50077016fe282a4064752
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: c64d671671aea2e44ee7fc6eb00ee75fc30ed7b9
5-
refs/heads/try: 79dd393a4f144fa5e6f81c720c782de3175810d7
5+
refs/heads/try: 07240d6026e9de5da5f061aa00563f91b42163eb
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/dist-snap: ba4081a5a8573875fed17545846f6f6902c8ba8d
88
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596

branches/try/src/compiletest/compiletest.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,7 @@
2020
#![feature(std_misc)]
2121
#![feature(test)]
2222
#![feature(core)]
23+
#![feature(path)]
2324
#![feature(io)]
2425
#![feature(net)]
2526
#![feature(path_ext)]

branches/try/src/compiletest/procsrv.rs

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -8,8 +8,6 @@
88
// option. This file may not be copied, modified, or distributed
99
// except according to those terms.
1010

11-
#![allow(deprecated)] // for old path, for dynamic_lib
12-
1311
use std::process::{ExitStatus, Command, Child, Output, Stdio};
1412
use std::io::prelude::*;
1513
use std::dynamic_lib::DynamicLibrary;

branches/try/src/doc/reference.md

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -229,14 +229,14 @@ cases mentioned in [Number literals](#number-literals) below.
229229

230230
##### Characters and strings
231231

232-
| | Example | `#` sets | Characters | Escapes |
233-
|----------------------------------------------|-----------------|------------|-------------|---------------------|
234-
| [Character](#character-literals) | `'H'` | `N/A` | All Unicode | `\'` & [Byte](#byte-escapes) & [Unicode](#unicode-escapes) |
235-
| [String](#string-literals) | `"hello"` | `N/A` | All Unicode | `\"` & [Byte](#byte-escapes) & [Unicode](#unicode-escapes) |
236-
| [Raw](#raw-string-literals) | `r#"hello"#` | `0...` | All Unicode | `N/A` |
237-
| [Byte](#byte-literals) | `b'H'` | `N/A` | All ASCII | `\'` & [Byte](#byte-escapes) |
238-
| [Byte string](#byte-string-literals) | `b"hello"` | `N/A` | All ASCII | `\"` & [Byte](#byte-escapes) |
239-
| [Raw byte string](#raw-byte-string-literals) | `br#"hello"#` | `0...` | All ASCII | `N/A` |
232+
| | Example | # sets | Characters | Escapes |
233+
|----------------------------------------------|---------------|--------|-------------|---------------------|
234+
| [Character](#character-literals) | 'H' | N/A | All Unicode | \' & [Byte](#byte-escapes) & [Unicode](#unicode-escapes) |
235+
| [String](#string-literals) | "hello" | N/A | All Unicode | \" & [Byte](#byte-escapes) & [Unicode](#unicode-escapes) |
236+
| [Raw](#raw-string-literals) | r#"hello"# | 0... | All Unicode | N/A |
237+
| [Byte](#byte-literals) | b'H' | N/A | All ASCII | \' & [Byte](#byte-escapes) |
238+
| [Byte string](#byte-string-literals) | b"hello" | N/A | All ASCII | \" & [Byte](#byte-escapes) |
239+
| [Raw byte string](#raw-byte-string-literals) | br#"hello"# | 0... | All ASCII | N/A |
240240

241241
##### Byte escapes
242242

branches/try/src/etc/lldb_rust_formatters.py

Lines changed: 77 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -40,31 +40,12 @@ def print_struct_val(val, internal_dict):
4040

4141
if is_vec_slice(val):
4242
return print_vec_slice_val(val, internal_dict)
43+
elif is_std_vec(val):
44+
return print_std_vec_val(val, internal_dict)
4345
else:
4446
return print_struct_val_starting_from(0, val, internal_dict)
4547

4648

47-
def print_vec_slice_val(val, internal_dict):
48-
length = val.GetChildAtIndex(1).GetValueAsUnsigned()
49-
50-
data_ptr_val = val.GetChildAtIndex(0)
51-
data_ptr_type = data_ptr_val.GetType()
52-
assert data_ptr_type.IsPointerType()
53-
54-
element_type = data_ptr_type.GetPointeeType()
55-
element_type_size = element_type.GetByteSize()
56-
57-
start_address = data_ptr_val.GetValueAsUnsigned()
58-
59-
def render_element(i):
60-
address = start_address + i * element_type_size
61-
element_val = val.CreateValueFromAddress(val.GetName() +
62-
("[%s]" % i), address, element_type)
63-
return print_val(element_val, internal_dict)
64-
65-
return "&[%s]" % (', '.join([render_element(i) for i in range(length)]))
66-
67-
6849
def print_struct_val_starting_from(field_start_index, val, internal_dict):
6950
'''
7051
Prints a struct, tuple, or tuple struct value with Rust syntax.
@@ -100,6 +81,16 @@ def render_child(child_index):
10081
this += field_name + ": "
10182

10283
field_val = val.GetChildAtIndex(child_index)
84+
85+
if not field_val.IsValid():
86+
field = t.GetFieldAtIndex(child_index)
87+
# LLDB is not good at handling zero-sized values, so we have to help
88+
# it a little
89+
if field.GetType().GetByteSize() == 0:
90+
return this + extract_type_name(field.GetType().GetName())
91+
else:
92+
return this + "<invalid value>"
93+
10394
return this + print_val(field_val, internal_dict)
10495

10596
body = separator.join([render_child(idx) for idx in range(field_start_index, num_children)])
@@ -195,6 +186,30 @@ def print_fixed_size_vec_val(val, internal_dict):
195186
return output
196187

197188

189+
def print_vec_slice_val(val, internal_dict):
190+
length = val.GetChildAtIndex(1).GetValueAsUnsigned()
191+
192+
data_ptr_val = val.GetChildAtIndex(0)
193+
data_ptr_type = data_ptr_val.GetType()
194+
195+
return "&[%s]" % print_array_of_values(val.GetName(),
196+
data_ptr_val,
197+
length,
198+
internal_dict)
199+
200+
201+
def print_std_vec_val(val, internal_dict):
202+
length = val.GetChildAtIndex(1).GetValueAsUnsigned()
203+
204+
# Vec<> -> Unique<> -> NonZero<> -> *T
205+
data_ptr_val = val.GetChildAtIndex(0).GetChildAtIndex(0).GetChildAtIndex(0)
206+
data_ptr_type = data_ptr_val.GetType()
207+
208+
return "vec![%s]" % print_array_of_values(val.GetName(),
209+
data_ptr_val,
210+
length,
211+
internal_dict)
212+
198213
#=--------------------------------------------------------------------------------------------------
199214
# Helper Functions
200215
#=--------------------------------------------------------------------------------------------------
@@ -243,3 +258,44 @@ def is_vec_slice(val):
243258

244259
type_name = extract_type_name(ty.GetName()).replace("&'static", "&").replace(" ", "")
245260
return type_name.startswith("&[") and type_name.endswith("]")
261+
262+
def is_std_vec(val):
263+
ty = val.GetType()
264+
if ty.GetTypeClass() != lldb.eTypeClassStruct:
265+
return False
266+
267+
if ty.GetNumberOfFields() != 3:
268+
return False
269+
270+
if ty.GetFieldAtIndex(0).GetName() != "ptr":
271+
return False
272+
273+
if ty.GetFieldAtIndex(1).GetName() != "len":
274+
return False
275+
276+
if ty.GetFieldAtIndex(2).GetName() != "cap":
277+
return False
278+
279+
return ty.GetName().startswith("collections::vec::Vec<")
280+
281+
282+
def print_array_of_values(array_name, data_ptr_val, length, internal_dict):
283+
'''Prints a contigous memory range, interpreting it as values of the
284+
pointee-type of data_ptr_val.'''
285+
286+
data_ptr_type = data_ptr_val.GetType()
287+
assert data_ptr_type.IsPointerType()
288+
289+
element_type = data_ptr_type.GetPointeeType()
290+
element_type_size = element_type.GetByteSize()
291+
292+
start_address = data_ptr_val.GetValueAsUnsigned()
293+
294+
def render_element(i):
295+
address = start_address + i * element_type_size
296+
element_val = data_ptr_val.CreateValueFromAddress(array_name + ("[%s]" % i),
297+
address,
298+
element_type)
299+
return print_val(element_val, internal_dict)
300+
301+
return ', '.join([render_element(i) for i in range(length)])

0 commit comments

Comments
 (0)