import java.util.*;
import java.util.zip.*;
import java.util.List;
import java.util.regex.*;
import java.util.concurrent.*;
import java.util.concurrent.atomic.*;
import java.util.concurrent.locks.*;
import javax.swing.*;
import javax.swing.event.*;
import javax.swing.text.*;
import javax.swing.table.*;
import java.io.*;
import java.net.*;
import java.lang.reflect.*;
import java.lang.ref.*;
import java.lang.management.*;
import java.security.*;
import java.security.spec.*;
import java.awt.*;
import java.awt.event.*;
import java.awt.image.*;
import javax.imageio.*;
import java.math.*;
// currently collection and map only
class main {
static void pnlStruct(Object o) {
if (o instanceof Collection) pnlStruct(((Collection) o));
else if (o instanceof Map) pnlStruct(((Map) o));
else if (o != null) pnlStruct(ll(o));
}
static > B pnlStruct(B l) {
pnlStruct((Iterable) l);
return l;
}
static Iterable pnlStruct(Iterable l) {
int i = 0;
if (l != null) for (A a : l) print((++i) + ". " + struct_noStringSharing(a));
return l;
}
static A[] pnlStruct(A[] l) {
pnlStruct(asList(l));
return l;
}
static Map pnlStruct(Map map) {
pnl(map(map, new F2() { Object get(A a, B b) { try { return sfu(a) + " = " + sfu(b); } catch (Exception __e) { throw rethrow(__e); } }
public String toString() { return "sfu(a) + \" = \" + sfu(b)"; }}));
return map;
}
static List ll(A... a) {
ArrayList l = new ArrayList(a.length);
if (a != null) for (A x : a) l.add(x);
return l;
}
static volatile StringBuffer local_log = new StringBuffer(); // not redirected
static volatile Appendable print_log = local_log; // might be redirected, e.g. to main bot
// in bytes - will cut to half that
static volatile int print_log_max = 1024*1024;
static volatile int local_log_max = 100*1024;
static boolean print_silent; // total mute if set
static Object print_byThread_lock = new Object();
static volatile ThreadLocal