2024-05-25 00:39:47 +02:00
|
|
|
|
//! In the following example, a <List Char> editor
|
|
|
|
|
//! as before is used, but its data is morphed into
|
|
|
|
|
//! representing a positional integer which is then
|
|
|
|
|
//! projected into different radices and displayed
|
|
|
|
|
//! in different views on screen
|
|
|
|
|
|
|
|
|
|
extern crate cgmath;
|
|
|
|
|
extern crate nested;
|
|
|
|
|
extern crate nested_tty;
|
|
|
|
|
extern crate r3vi;
|
|
|
|
|
extern crate termion;
|
|
|
|
|
|
|
|
|
|
use {
|
|
|
|
|
cgmath::Vector2,
|
|
|
|
|
nested::{
|
|
|
|
|
editors::{
|
|
|
|
|
ObjCommander
|
|
|
|
|
},
|
|
|
|
|
repr_tree::{Context, ReprTree, ReprTreeExt, ReprLeaf},
|
2024-06-03 17:02:08 +02:00
|
|
|
|
edit_tree::{EditTree, TreeNav, TreeCursor}
|
2024-05-25 00:39:47 +02:00
|
|
|
|
},
|
|
|
|
|
nested_tty::{
|
|
|
|
|
DisplaySegment, TTYApplication,
|
|
|
|
|
TerminalCompositor, TerminalStyle, TerminalView,
|
|
|
|
|
TerminalAtom, TerminalEvent
|
|
|
|
|
},
|
|
|
|
|
r3vi::{
|
|
|
|
|
buffer::{singleton::*, vec::*},
|
2024-06-03 17:02:08 +02:00
|
|
|
|
view::{port::UpdateTask, singleton::*, list::*, sequence::*},
|
2024-05-25 00:39:47 +02:00
|
|
|
|
projection::*
|
|
|
|
|
},
|
|
|
|
|
std::sync::{Arc, RwLock},
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#[async_std::main]
|
|
|
|
|
async fn main() {
|
|
|
|
|
/* setup context
|
|
|
|
|
*/
|
|
|
|
|
let ctx = Arc::new(RwLock::new(Context::new()));
|
|
|
|
|
nested::editors::char::init_ctx( ctx.clone() );
|
|
|
|
|
nested::editors::digit::init_ctx( ctx.clone() );
|
|
|
|
|
nested::editors::integer::init_ctx( ctx.clone() );
|
|
|
|
|
nested::editors::list::init_ctx( ctx.clone() );
|
|
|
|
|
nested_tty::setup_edittree_hook(&ctx);
|
|
|
|
|
|
2024-05-25 19:21:16 +02:00
|
|
|
|
/* Create a Representation-Tree of type `ℕ`
|
2024-05-25 00:39:47 +02:00
|
|
|
|
*/
|
|
|
|
|
let mut rt_int = ReprTree::new_arc( Context::parse(&ctx, "ℕ") );
|
|
|
|
|
|
2024-05-25 19:21:16 +02:00
|
|
|
|
/* Add a specific Representation-Path (big-endian hexadecimal)
|
|
|
|
|
*/
|
|
|
|
|
rt_int.create_branch(
|
2024-06-03 17:02:08 +02:00
|
|
|
|
Context::parse(&ctx, "<PosInt 16 BigEndian> ~ <Seq <Digit 16>> ~ <List <Digit 16>~Char>")
|
|
|
|
|
);
|
|
|
|
|
rt_int.create_branch(
|
|
|
|
|
Context::parse(&ctx, "<PosInt 16 LittleEndian> ~ <Seq <Digit 16>> ~ <List <Digit 16>~Char>")
|
|
|
|
|
);
|
|
|
|
|
rt_int.create_branch(
|
|
|
|
|
Context::parse(&ctx, "<PosInt 10 BigEndian> ~ <Seq <Digit 10>> ~ <List <Digit 10>~Char>")
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
eprintln!("make big endian hex repr");
|
|
|
|
|
let mut b = VecBuffer::with_data(vec![ 'c', 'f', 'f' ]);
|
|
|
|
|
rt_int.insert_leaf(
|
|
|
|
|
Context::parse(&ctx, "<PosInt 16 BigEndian>~<Seq <Digit 16>>~<List <Digit 16>>~<List Char>"),
|
|
|
|
|
nested::repr_tree::ReprLeaf::from_view( b.get_port().to_list() )
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
let mut b_le = VecBuffer::with_data(vec!['3', '2', '1']);
|
|
|
|
|
rt_int.insert_leaf(
|
|
|
|
|
Context::parse(&ctx, "<PosInt 16 LittleEndian>~<Seq <Digit 16>>~<List <Digit 16>>~<List Char>"),
|
|
|
|
|
nested::repr_tree::ReprLeaf::from_view( b_le.get_port().to_list() )
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>>
|
|
|
|
|
~ <List Char>
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char~EditTree>")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16> >
|
|
|
|
|
~ <List <Digit 16>~Char~EditTree >
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List EditTree>"),
|
|
|
|
|
&Context::parse(&ctx, "<List EditTree>~<Vec EditTree>")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>~Char>
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>~<List EditTree>~<Vec EditTree>"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>~EditTree")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>~Char >
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>~EditTree"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.clone(),
|
|
|
|
|
&Context::parse(&ctx, "
|
|
|
|
|
ℕ
|
|
|
|
|
~ <PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>>
|
|
|
|
|
~ <List Char>
|
|
|
|
|
"),
|
|
|
|
|
&Context::parse(&ctx, "
|
|
|
|
|
ℕ
|
|
|
|
|
~ <PosInt 16 BigEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>>
|
|
|
|
|
~ <List Char>
|
|
|
|
|
")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.clone(),
|
|
|
|
|
&Context::parse(&ctx, "
|
|
|
|
|
ℕ
|
|
|
|
|
~ <PosInt 16 BigEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>>
|
|
|
|
|
~ <List Char>
|
|
|
|
|
"),
|
|
|
|
|
&Context::parse(&ctx, "
|
|
|
|
|
ℕ
|
|
|
|
|
~ <PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>>
|
|
|
|
|
~ <List Char>
|
|
|
|
|
")
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
let edittree_hex_le_list = ctx.read().unwrap()
|
|
|
|
|
.setup_edittree(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx,"
|
|
|
|
|
<PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>~Char >
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
SingletonBuffer::new(0).get_port()
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 BigEndian>~<Seq <Digit 16>>~<List <Digit 16>~Char>
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char~EditTree>")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 BigEndian>~<Seq <Digit 16>>~<List <Digit 16>~Char~EditTree>
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List EditTree>"),
|
|
|
|
|
&Context::parse(&ctx, "<List EditTree>~<Vec EditTree>")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 BigEndian>~<Seq <Digit 16>>~<List <Digit 16>~Char>
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>~<List EditTree>~<Vec EditTree>"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>~EditTree")
|
|
|
|
|
);
|
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 BigEndian>~<Seq <Digit 16>>~<List <Digit 16>~Char>
|
|
|
|
|
")).expect("descend"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>~EditTree"),
|
|
|
|
|
&Context::parse(&ctx, "<List Char>")
|
2024-05-25 19:21:16 +02:00
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
/* Setup an Editor for the big-endian hexadecimal representation
|
|
|
|
|
* (this will add the representation `<List <Digit 16>>~EditTree` to the ReprTree)
|
2024-05-25 00:39:47 +02:00
|
|
|
|
*/
|
2024-06-03 17:02:08 +02:00
|
|
|
|
let edittree_hex_be_list = ctx.read().unwrap()
|
2024-05-25 00:39:47 +02:00
|
|
|
|
.setup_edittree(
|
2024-05-25 19:21:16 +02:00
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 BigEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>>
|
2024-06-03 17:02:08 +02:00
|
|
|
|
~ <List Char>
|
2024-05-25 19:21:16 +02:00
|
|
|
|
")).expect("cant descend reprtree"),
|
2024-05-25 00:39:47 +02:00
|
|
|
|
SingletonBuffer::new(0).get_port()
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* map seq of chars to seq of u64 digits
|
2024-05-25 19:21:16 +02:00
|
|
|
|
* and add this projection to the ReprTree
|
2024-05-25 00:39:47 +02:00
|
|
|
|
*/
|
2024-05-25 19:21:16 +02:00
|
|
|
|
//
|
|
|
|
|
//VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV
|
|
|
|
|
let mut chars_view = rt_int.descend(Context::parse(&ctx, "
|
2024-06-03 17:02:08 +02:00
|
|
|
|
<PosInt 16 BigEndian>
|
|
|
|
|
~ <Seq <Digit 16>>
|
|
|
|
|
~ <List <Digit 16>~Char>
|
2024-05-25 19:21:16 +02:00
|
|
|
|
")).expect("cant descend")
|
2024-05-25 00:39:47 +02:00
|
|
|
|
.read().unwrap()
|
|
|
|
|
.get_port::<dyn ListView<char>>()
|
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
|
|
let mut digits_view = chars_view
|
|
|
|
|
.to_sequence()
|
|
|
|
|
.filter_map(
|
|
|
|
|
|digit_char|
|
|
|
|
|
|
2024-05-25 19:21:16 +02:00
|
|
|
|
/* TODO: call morphism for each item
|
2024-05-25 00:39:47 +02:00
|
|
|
|
*/
|
|
|
|
|
match digit_char.to_digit(16) {
|
2024-05-25 19:21:16 +02:00
|
|
|
|
Some(d) => Some(d as u64),
|
2024-05-25 00:39:47 +02:00
|
|
|
|
None => None
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
|
2024-05-25 19:21:16 +02:00
|
|
|
|
rt_int.insert_leaf(Context::parse(&ctx, "
|
|
|
|
|
<PosInt 16 BigEndian>
|
|
|
|
|
~ <Seq <Digit 16>
|
|
|
|
|
~ ℤ_2^64
|
|
|
|
|
~ machine.UInt64 >
|
|
|
|
|
"),
|
2024-05-25 00:39:47 +02:00
|
|
|
|
nested::repr_tree::ReprLeaf::from_view( digits_view.clone() )
|
|
|
|
|
);
|
2024-05-25 19:21:16 +02:00
|
|
|
|
//ΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛ
|
2024-05-25 00:39:47 +02:00
|
|
|
|
//
|
|
|
|
|
|
2024-05-25 19:21:16 +02:00
|
|
|
|
/* convert to little endian
|
|
|
|
|
*/
|
2024-05-25 00:39:47 +02:00
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.clone(),
|
2024-06-03 17:02:08 +02:00
|
|
|
|
&Context::parse(&ctx, "
|
|
|
|
|
ℕ
|
|
|
|
|
~ <PosInt 16 BigEndian>
|
|
|
|
|
~ <Seq <Digit 16>
|
|
|
|
|
~ ℤ_2^64
|
|
|
|
|
~ machine.UInt64 >
|
|
|
|
|
"),
|
|
|
|
|
&Context::parse(&ctx, "
|
|
|
|
|
ℕ
|
|
|
|
|
~ <PosInt 16 LittleEndian>
|
|
|
|
|
~ <Seq <Digit 16>
|
|
|
|
|
~ ℤ_2^64
|
|
|
|
|
~ machine.UInt64 >
|
|
|
|
|
")
|
2024-05-25 00:39:47 +02:00
|
|
|
|
);
|
2024-05-25 19:21:16 +02:00
|
|
|
|
|
|
|
|
|
/* convert to decimal
|
|
|
|
|
*/
|
2024-05-25 00:39:47 +02:00
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.clone(),
|
|
|
|
|
&Context::parse(&ctx, "ℕ ~ <PosInt 16 LittleEndian> ~ <Seq <Digit 16>~ℤ_2^64~machine.UInt64>"),
|
|
|
|
|
&Context::parse(&ctx, "ℕ ~ <PosInt 10 LittleEndian> ~ <Seq <Digit 10>~ℤ_2^64~machine.UInt64>")
|
|
|
|
|
);
|
2024-05-25 19:21:16 +02:00
|
|
|
|
|
|
|
|
|
/* convert back to big endian
|
|
|
|
|
*/
|
2024-05-25 00:39:47 +02:00
|
|
|
|
ctx.read().unwrap().morphisms.apply_morphism(
|
|
|
|
|
rt_int.clone(),
|
|
|
|
|
&Context::parse(&ctx, "ℕ ~ <PosInt 10 LittleEndian> ~ <Seq <Digit 10>~ℤ_2^64~machine.UInt64>"),
|
|
|
|
|
&Context::parse(&ctx, "ℕ ~ <PosInt 10 BigEndian> ~ <Seq <Digit 10>~ℤ_2^64~machine.UInt64>")
|
|
|
|
|
);
|
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
|
2024-05-25 19:21:16 +02:00
|
|
|
|
/* map seq of u64 digits to seq of chars
|
|
|
|
|
* and add this projection to the ReprTree
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
//VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV
|
|
|
|
|
let dec_digits_view =
|
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
< PosInt 10 BigEndian >
|
|
|
|
|
~ < Seq <Digit 10>
|
|
|
|
|
~ ℤ_2^64
|
|
|
|
|
~ machine.UInt64 >
|
|
|
|
|
")).expect("cant descend repr tree")
|
2024-05-25 00:39:47 +02:00
|
|
|
|
.read().unwrap()
|
2024-05-25 19:21:16 +02:00
|
|
|
|
.get_port::<dyn SequenceView<Item = u64>>().unwrap()
|
|
|
|
|
.map(|digit| TerminalAtom::from(char::from_digit(*digit as u32, 10)))
|
2024-05-25 00:39:47 +02:00
|
|
|
|
.to_grid_horizontal();
|
2024-05-25 19:21:16 +02:00
|
|
|
|
//ΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛ
|
|
|
|
|
//
|
|
|
|
|
//VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV
|
2024-05-25 00:39:47 +02:00
|
|
|
|
let hex_digits_view =
|
2024-05-25 19:21:16 +02:00
|
|
|
|
rt_int.descend(Context::parse(&ctx, "
|
|
|
|
|
< PosInt 16 BigEndian >
|
|
|
|
|
~ < Seq <Digit 16>
|
|
|
|
|
~ ℤ_2^64
|
|
|
|
|
~ machine.UInt64 >
|
|
|
|
|
")).expect("cant descend")
|
2024-05-25 00:39:47 +02:00
|
|
|
|
.read().unwrap()
|
2024-05-25 19:21:16 +02:00
|
|
|
|
.view_seq::< u64 >()
|
|
|
|
|
.map(|digit| TerminalAtom::from(char::from_digit(*digit as u32, 16)))
|
|
|
|
|
.to_grid_horizontal();
|
|
|
|
|
//ΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛΛ
|
|
|
|
|
//
|
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
/* list of both editors
|
|
|
|
|
*/
|
|
|
|
|
let mut list_editor = nested::editors::list::ListEditor::new(ctx.clone(), Context::parse(&ctx, "<Seq Char>"));
|
|
|
|
|
list_editor.data.push( edittree_hex_be_list.value.clone() );
|
|
|
|
|
list_editor.data.push( edittree_hex_le_list.value.clone() );
|
|
|
|
|
let mut edittree = list_editor.into_node(SingletonBuffer::new(0).get_port());
|
2024-05-25 19:21:16 +02:00
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
/* cursors are a bit screwed initially so fix them up
|
|
|
|
|
* TODO: how to fix this generally?
|
|
|
|
|
*/
|
|
|
|
|
edittree_hex_be_list.get().goto(TreeCursor::none());
|
|
|
|
|
edittree_hex_le_list.get().goto(TreeCursor::none());
|
|
|
|
|
edittree.goto(TreeCursor{
|
|
|
|
|
leaf_mode: nested::editors::list::ListCursorMode::Insert,
|
|
|
|
|
tree_addr: vec![0,0]
|
|
|
|
|
});
|
|
|
|
|
let edittree = Arc::new(RwLock::new(edittree));
|
|
|
|
|
|
2024-05-25 00:39:47 +02:00
|
|
|
|
/* setup terminal
|
|
|
|
|
*/
|
|
|
|
|
let app = TTYApplication::new({
|
|
|
|
|
/* event handler
|
|
|
|
|
*/
|
|
|
|
|
let ctx = ctx.clone();
|
|
|
|
|
move |ev| {
|
2024-06-03 17:02:08 +02:00
|
|
|
|
edittree.write().unwrap().send_cmd_obj(ev.to_repr_tree(&ctx));
|
2024-05-25 00:39:47 +02:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/* Setup the compositor to serve as root-view
|
|
|
|
|
* by routing it to the `app.port` Viewport,
|
|
|
|
|
* so it will be displayed on TTY-output.
|
|
|
|
|
*/
|
|
|
|
|
let compositor = TerminalCompositor::new(app.port.inner());
|
|
|
|
|
|
|
|
|
|
/* Now add some views to our compositor
|
|
|
|
|
*/
|
|
|
|
|
{
|
|
|
|
|
let mut comp = compositor.write().unwrap();
|
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
fn show_edit_tree( ctx: &Arc<RwLock<Context>>, comp: &mut TerminalCompositor, rt: &Arc<RwLock<ReprTree>>, y: i16 )
|
|
|
|
|
{
|
|
|
|
|
let rt_edittree = rt.descend(Context::parse(&ctx, "EditTree")).expect("descend");
|
|
|
|
|
let halo_type = rt_edittree.read().unwrap().get_halo_type().clone();
|
|
|
|
|
let edittree = rt_edittree.read().unwrap().get_view::<dyn r3vi::view::singleton::SingletonView<Item = EditTree>>().unwrap().get();
|
|
|
|
|
|
|
|
|
|
comp.push( nested_tty::make_label( &ctx.read().unwrap().type_term_to_str(&halo_type) )
|
2024-05-25 00:39:47 +02:00
|
|
|
|
.map_item(|_pt, atom| atom.add_style_front(TerminalStyle::fg_color((90,90,90))))
|
2024-06-03 17:02:08 +02:00
|
|
|
|
.offset(Vector2::new(1,y)));
|
|
|
|
|
|
|
|
|
|
comp.push( edittree.display_view()
|
|
|
|
|
.offset(Vector2::new(1,y+1)));
|
|
|
|
|
}
|
2024-05-25 00:39:47 +02:00
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
show_edit_tree(&ctx, &mut comp, &rt_int.descend(Context::parse(&ctx, "<PosInt 16 BigEndian> ~ <Seq~List <Digit 16>~Char>")).expect(""), 1);
|
|
|
|
|
show_edit_tree(&ctx, &mut comp, &rt_int.descend(Context::parse(&ctx, "<PosInt 16 LittleEndian> ~ <Seq <Digit 16>> ~ <List <Digit 16>~Char>")).expect(""), 4);
|
2024-05-25 00:39:47 +02:00
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
/* project the seq of u64 representations to a view
|
|
|
|
|
*/
|
|
|
|
|
comp.push(nested_tty::make_label("dec: ").offset(Vector2::new(3,7)));
|
|
|
|
|
comp.push(dec_digits_view.offset(Vector2::new(8,7)).map_item(|_,a| {
|
2024-05-25 19:21:16 +02:00
|
|
|
|
a.add_style_back(TerminalStyle::fg_color((30,90,200)))
|
|
|
|
|
}));
|
|
|
|
|
|
2024-06-03 17:02:08 +02:00
|
|
|
|
comp.push(nested_tty::make_label("hex: ").offset(Vector2::new(3,8)));
|
|
|
|
|
comp.push(hex_digits_view.offset(Vector2::new(8,8)).map_item(|_,a| {
|
2024-05-25 19:21:16 +02:00
|
|
|
|
a.add_style_back(TerminalStyle::fg_color((200, 200, 30)))
|
|
|
|
|
}));
|
2024-05-25 00:39:47 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* write the changes in the view of `term_port` to the terminal
|
|
|
|
|
*/
|
|
|
|
|
app.show().await.expect("output error!");
|
|
|
|
|
}
|
2024-05-25 19:21:16 +02:00
|
|
|
|
|