// fill tmp region with new content // given input index and foreground color static void render_line(s16 idx, u8 fg) { const s16 opIdx = net_in_op_idx(idx); region_fill(lineRegion, 0x0); if(opIdx >= 0) { // operator input // build descriptor string clearln(); appendln_idx_lj(opIdx); appendln_char('.'); appendln( net_op_name(opIdx) ); appendln_char('/'); appendln( net_in_name(idx) ); endln(); font_string_region_clip(lineRegion, lineBuf, 4, 0, fg, 0); clearln(); op_print(lineBuf, net_get_in_value(idx)); font_string_region_clip(lineRegion, lineBuf, LINE_VAL_POS_SHORT, 0, fg, 0); } else { // parameter input clearln(); appendln_idx_lj( (int)net_param_idx(idx)); appendln_char('.'); appendln( net_in_name(idx)); endln(); font_string_region_clip(lineRegion, lineBuf, 4, 0, 0xa, 0); clearln(); // op_print(lineBuf, net_get_in_value(idx)); /// FIXME: this is pretty dumb, // params and inputs should just be on separate pages i guess net_get_param_value_string(lineBuf, idx); font_string_region_clip(lineRegion, lineBuf, LINE_VAL_POS_LONG, 0, fg, 0); } // draw something to indicate play mode visibility if(net_get_in_play(idx)) { font_string_region_clip(lineRegion, ".", 0, 0, fg, 0); } // draw something to indicate preset inclusion if(net_get_in_preset(idx)) { font_string_region_clip(lineRegion, ".", 126, 0, fg, 0); } }
// fill tmp region with new content // given input index static void render_line(s16 idx, u16 max) { region_fill(lineRegion, 0x0); if((idx > max) || (idx < 0)) { return; } clearln(); appendln((const char*)files_get_dsp_name(idx)); endln(); font_string_region_clip(lineRegion, lineBuf, 0, 0, 0xa, 0); }
// fill tmp region with new content // given input index and foreground color static void render_line(s16 idx, u8 fg) { region_fill(lineRegion, 0x0); if( (idx >= 0) && (idx <= maxPresetIdx) ) { clearln(); appendln((const char*)preset_name(idx)); endln(); font_string_region_clip(lineRegion, lineBuf, 2, 0, fg, 0); } }
// render new operator type name void render_op_type(void) { const char* name = op_registry[userOpTypes[newOpType]].name; // print_dbg("\r\n new op selection: "); // print_dbg(name); region_fill(headRegion, 0x0); clearln(); appendln_char('+'); appendln(name); endln(); font_string_region_clip(headRegion, lineBuf, 0, 0, 0xa, 0); }
int main(int argc, char **argv) { pthread_t tid0, tid1; init(); DEBUG(!); if (pthread_create(&tid0, NULL, listen_key, NULL)); if (pthread_create(&tid1, NULL, shine, NULL)); pthread_join(tid0, NULL); pthread_cancel(tid1); //listen_key(); endln(); return 0; }
// render a given line void render_line(s16 idx) { region_fill(lineRegion, 0x0); if((idx >= 0) && (idx < net_num_ops()) ) { clearln(); appendln_idx_lj((u8)idx); appendln_char('.'); appendln(net_op_name(idx)); endln(); font_string_region_clip(lineRegion, lineBuf, 0, 0, 0xa, 0); // region_fill_part(lineRegion, LINE_UNDERLINE_OFFSET, LINE_UNDERLINE_LEN, 0x1); } }
void GlobalEntry::typePrint(ostream& out, int indent) const { prtSpace(out, indent); typePrintST(out, indent, '\0', ';', true); prtln(out, indent); const vector<RuleNode*> pr = GlobalEntry::rules(); if(pr.size() == 0 ) prtln(out, indent); for(vector<RuleNode*>::const_iterator it = pr.begin(); it != pr.end(); it++) { (*it)->typePrint(out, indent + STEP_INDENT); endln(out, indent); } prtSpace(out, indent + STEP_INDENT); }
// fill tmp region with new content // given input index and foreground color static void render_line(s16 idx, u8 fg) { // const s16 opIdx = net_in_op_idx(idx); s16 target; s16 targetOpIdx = -1; s16 srcOpIdx; region_fill(lineRegion, 0x0); // print_dbg("\r\n page_outs: render_line"); if(idx >= net_num_outs() ) { return; } if(targetSelect) { // print_dbg(" , in targetSelect"); target = tmpTarget; } else { target = net_get_target(idx); } srcOpIdx = net_out_op_idx(idx); targetOpIdx = net_in_op_idx(target); /* print_dbg(" , target: "); */ /* print_dbg_ulong(target); */ if(target >= 0) { //// output has target // the network doesn't actually execute connections from an op to itself. // reflect this in UI by dimming this line if(targetOpIdx == srcOpIdx) { fg = 0x5; } // render output clearln(); appendln_idx_lj(srcOpIdx); appendln_char('.'); appendln( net_op_name(srcOpIdx)); appendln_char('/'); appendln( net_out_name(idx) ); endln(); font_string_region_clip(lineRegion, lineBuf, 2, 0, fg, 0); // render target targetOpIdx = net_in_op_idx(target); clearln(); appendln("-> "); if(targetOpIdx >= 0) { // print_dbg(" , target is op in"); // target is operator input appendln_idx_lj(net_in_op_idx(target)); appendln_char('.'); appendln( net_op_name(net_in_op_idx(target)) ); appendln_char('/'); appendln( net_in_name(target) ); } else { // print_dbg(" , target is param in"); // target is parameter input appendln_idx_lj( (int)net_param_idx(target)); appendln_char('.'); appendln( net_in_name(target)); } endln(); font_string_region_clip(lineRegion, lineBuf, 60, 0, fg, 0); clearln(); } else { //// no target // render output clearln(); appendln_idx_lj(net_out_op_idx(idx)); appendln_char('.'); appendln( net_op_name(net_out_op_idx(idx))); appendln_char('/'); appendln( net_out_name(idx) ); endln(); font_string_region_clip(lineRegion, lineBuf, 2, 0, fg, 0); } // draw something to indicate preset inclusion if(net_get_out_preset(idx)) { font_string_region_clip(lineRegion, ".", 125, 0, fg, 0); } // underline // region_fill_part(lineRegion, LINE_UNDERLINE_FSET, LINE_UNDERLINE_LEN, 0x1); }
// redraw based on provisional preset seleciton void redraw_ins_preset ( void ) { s32 max = net_num_ins() - 1; u8 i=0; u8 n = *pageSelect - 3; u8 enabled; io_t opVal; s32 paramVal; s16 opIdx; print_dbg("\r\n redraw_ins_preset() "); while(i<8) { region_fill(lineRegion, 0x0); opIdx = net_in_op_idx(n); if(n <= max) { enabled = net_get_in_preset(n); if(opIdx < 0 ) { // parameter... clearln(); appendln_idx_lj( (int)net_param_idx(n)); appendln_char('.'); appendln( net_in_name(n)) ; endln(); font_string_region_clip(lineRegion, lineBuf, 4, 0, 0xf, 0); clearln(); if(enabled) { paramVal = preset_get_selected()->ins[n].value; net_get_param_value_string_conversion(lineBuf, net_param_idx(n), paramVal); } else { net_get_param_value_string(lineBuf, n); } font_string_region_clip(lineRegion, lineBuf, LINE_VAL_POS_LONG, 0, 0xf, 0); } else { // op input clearln(); appendln_idx_lj(opIdx); appendln_char('.'); appendln( net_op_name(opIdx) ); appendln_char('/'); appendln( net_in_name(n) ); endln(); font_string_region_clip(lineRegion, lineBuf, 4, 0, 0xf, 0); if(enabled) { opVal = preset_get_selected()->ins[n].value; } else { opVal = net_get_in_value(n); } op_print(lineBuf, opVal); font_string_region_clip(lineRegion, lineBuf, LINE_VAL_POS_SHORT, 0, 0xf, 0); } // draw something to indicate preset inclusion if(enabled) { font_string_region_clip(lineRegion, ".", 126, 0, 0xf, 0); } } render_to_scroll_line(i, 0); ++i; ++n; } // print_dbg("\r\n\r\n"); draw_preset_name(); }
int main() { std::cout << 'a' << endl2 << 'b' << endln(3) << 'c' << '\n' ; std::wcout << L'd' << endl2 << L'e' << endln(3) << L'f' << L'\n' ; }
std::basic_ostream<C,T>& endl2( std::basic_ostream<C,T>& stm ) { return stm << endln(2) ; }
// redraw based on provisional preset seleciton void redraw_outs_preset (void) { // s32 max = net_num_outs() - 1; u8 i=0; u8 idx = *pageSelect - 3; u8 fg; u8 enabled; s16 target; s16 targetOpIdx = -1; s16 srcOpIdx; s32 preSel = preset_get_select(); // print_dbg("\r\n redraw_outs_preset()"); while(i<8) { region_fill(lineRegion, 0x0); if(idx >= net_num_outs() ) { return; } enabled = preset_out_enabled(preSel, idx); if(enabled) { // if it's enabled, show the preset's target (including if blank) target = preset_get_selected()->outs[idx].target; srcOpIdx = net_out_op_idx(idx); targetOpIdx = net_in_op_idx(target); if(target >= 0) { //// output has target // the network doesn't actually execute connections from an op to itself. // reflect this in UI by dimming this line if(targetOpIdx == srcOpIdx) { fg = 0x5; } // render output clearln(); appendln_idx_lj(srcOpIdx); appendln_char('.'); appendln( net_op_name(srcOpIdx)); appendln_char('/'); appendln( net_out_name(idx) ); endln(); font_string_region_clip(lineRegion, lineBuf, 2, 0, fg, 0); // render target targetOpIdx = net_in_op_idx(target); clearln(); appendln("-> "); if(targetOpIdx >= 0) { // target is operator input appendln_idx_lj(net_in_op_idx(target)); appendln_char('.'); appendln( net_op_name(net_in_op_idx(target)) ); appendln_char('/'); appendln( net_in_name(target) ); } else { // target is parameter input appendln_idx_lj( (int)net_param_idx(target)); appendln_char('.'); appendln( net_in_name(target)); } endln(); font_string_region_clip(lineRegion, lineBuf, 60, 0, fg, 0); clearln(); } else { //// no target // render output clearln(); appendln_idx_lj(net_out_op_idx(idx)); appendln_char('.'); appendln( net_op_name(net_out_op_idx(idx))); appendln_char('/'); appendln( net_out_name(idx) ); endln(); font_string_region_clip(lineRegion, lineBuf, 2, 0, fg, 0); } // draw something to indicate preset inclusion if(net_get_out_preset(idx)) { font_string_region_clip(lineRegion, ".", 126, 0, fg, 0); } } else { // not enabled, draw as normal with dim coloring render_line(idx, 0x5); } render_to_scroll_line(i, 0); ++i; ++idx; } draw_preset_name(); }