Documentation ¶
Overview ¶
Package emitter emits the translated trice strings.
Index ¶
- Constants
- Variables
- func BanOrPickFilter(b []byte) (n int)
- func ColorChannelEvents(ch string) int
- func PrintColorChannelEvents()
- func ScDisplayServer() error
- func ScShutdownRemoteDisplayServer(timeStamp int64, args ...string) error
- func SetPrefix()
- type ChannelArrayFlag
- type ColorChannel
- type ColorDisplay
- type LineTransformerANSI
- type LineWriter
- type LocalDisplay
- type RemoteDisplay
- type Server
- type TriceLineComposer
Examples ¶
Constants ¶
const SyncPacketPattern = "inf:[TRICE_SYNC_PACKET 0x89abcdef]"
SyncPacketPattern is used if a sync packet arrives
Variables ¶
var ( // Verbose gives mor information on output if set. The value is injected from main packages. Verbose bool // TimestampFormat is used tor line timestamps. // off = no timestamp // none = no timestamp // LOCmicro = local time with microseconds // UTCmicro = universal time with microseconds // zero = fixed "2006-01-02_1504-05" timestamp (for tests) TimestampFormat string // Prefix starts lines. It follows line timestamp, if any. Prefix string // Suffix lollows lines. Usually empty. Suffix string // ColorPalette determines the way color is handled. // off = no color handling at all. Lower case color prefixes are not removed. Use with care. // none = no colors. Lower case color prefixes are removed. // default = color codes added (TODO: change to ANSI) ColorPalette string // IPAddr ist the remote display IP address. IPAddr string // IPPort ist the remote display port number. IPPort string // DisplayRemote if set, sends trice lines over TCP. DisplayRemote bool // TestTableMode is set externally to avoid Prefix overwrite TestTableMode bool // NextLine is set true as help for decoder.TestTableMode, where it is clreared at line start. NextLine bool // Ban is a string slice containing all channel descriptors to suppress Ban ChannelArrayFlag // Pick is a string slice containing all channel descriptors only to display Pick ChannelArrayFlag )
var ColorChannels = []ColorChannel{ {0, []string{"Error", "e", "err", "error", "E", "ERR", "ERROR"}, colorizeERROR}, {0, []string{"m", "msg", "message", "M", "MSG", "MESSAGE"}, colorizeMESSAGE}, {0, []string{"rd", "rd_", "RD", "RD_"}, colorizeREAD}, {0, []string{"wr", "wr_", "WR", "WR_"}, colorizeWRITE}, {0, []string{"Timestamp", "tim", "time", "TIM", "TIME", "TIMESTAMP", "timestamp"}, colorizeTIME}, {0, []string{"att", "attention", "ATT", "ATTENTION"}, colorizeATTENTION}, {0, []string{"dia", "diag", "DIA", "DIAG"}, colorizeDIAG}, {0, []string{"int", "isr", "ISR", "INT", "interrupt", "INTERRUPT"}, colorizeINTERRUPT}, {0, []string{"s", "sig", "signal", "S", "SIG", "SIGNAL"}, colorizeSIGNAL}, {0, []string{"t", "tst", "test", "T", "TST", "TEST"}, colorizeTEST}, {0, []string{"Default", "DEFAULT", "default"}, colorizeDEFAULT}, {0, []string{"Debug", "d", "db", "dbg", "debug", "D", "DB", "DBG", "DEBUG"}, colorizeDEBUG}, {0, []string{"Info", "i", "inf", "info", "informal", "I", "INF", "INFO", "INFORMAL"}, colorizeINFO}, {0, []string{"Notice", "NOTICE", "notice", "Note", "note", "NOTE"}, colorizeNOTICE}, {0, []string{"Warning", "w", "wrn", "warning", "W", "WRN", "WARNING", "Warn", "warn", "WARN"}, colorizeWARNING}, {0, []string{"Critical", "critical", "CRITICAL", "crit", "Crit", "CRIT"}, colorizeCRITICAL}, {0, []string{"Alert", "alert", "ALERT"}, colorizeALERT}, {0, []string{"Emergency", "emergency", "EMERGENCY"}, colorizeEMERGENCY}, {0, []string{"Fatal", "fatal", "FATAL"}, colorizeFATAL}, {0, []string{"Trace", "trace", "TRACE"}, colorizeTRACE}, {0, []string{"Assert", "assert", "ASSERT"}, colorizeASSERT}, {0, []string{"Verbose", "verbose", "VERBOSE"}, colorizeVERBOSE}, {0, []string{"cycle", "CYCLE"}, colorizeCYCLE}, }
Functions ¶
func BanOrPickFilter ¶ added in v0.31.0
BanOrPickFilter returns len of b if b ist not filtered out, otherwise 0. If Ban and Pick are nil nothing is filtered out. If Ban and Pick are both not nil this is a fatal error (os.Exit). If b starts with a known channel specifier existent in Ban 0, is returned. If b starts with a known channel specifier existent in Pick len of b, is returned.
func ColorChannelEvents ¶ added in v0.34.0
ColorChannelEvents returns count of occurred channel events. If ch is unknown, the returned value is -1.
func PrintColorChannelEvents ¶ added in v0.34.0
func PrintColorChannelEvents()
PrintColorChannelEvents shows the amount of occurred channel events.
func ScDisplayServer ¶
func ScDisplayServer() error
ScDisplayServer is the endless function called when trice tool acts as remote display. All in Server struct registered RPC functions are reachable, when displayServer runs.
func ScShutdownRemoteDisplayServer ¶
ScShutdownRemoteDisplayServer connects to a client to send shutdown message to display server. 0==timeStamp -> no timestamp in shutdown message, use for tests. 1==timeStamp -> timestamp in shutdown message, use normally. It accepts 0 to 2 string arguments as args. More arguments are ignored. For not given parameters default values are taken. The parameters are in the following order. args[0] (ipa) is the IP address to be used to connect to the remote display. args[1] (ipp) is the IP port to be used to connect to the remote display.
Types ¶
type ChannelArrayFlag ¶ added in v0.31.0
type ChannelArrayFlag []string
func (*ChannelArrayFlag) Set ¶ added in v0.31.0
func (i *ChannelArrayFlag) Set(value string) error
Set is a needed method for multi flags.
func (*ChannelArrayFlag) String ¶ added in v0.31.0
func (i *ChannelArrayFlag) String() string
String method is the needed for interface satisfaction.
type ColorChannel ¶ added in v0.34.0
type ColorChannel struct {
// contains filtered or unexported fields
}
type ColorDisplay ¶
type ColorDisplay struct {
// contains filtered or unexported fields
}
ColorDisplay is an object used for displaying. It implements the Linewriter interface. It embeds a local display and a line transformer
func NewColorDisplay ¶
func NewColorDisplay(colorPalette string) *ColorDisplay
NewColorDisplay creates a ColorDisplay. It provides a Linewriter. It uses internally a local display combined with a line transformer.
Example ¶
p := NewColorDisplay("none") l1 := []string{"msg:This is ", "the 1st ", "line"} l2 := []string{"MSG:This is ", "the 2nd ", "line"} p.writeLine(l1) p.writeLine(l2)
Output: This is the 1st line MSG:This is the 2nd line
type LineTransformerANSI ¶
type LineTransformerANSI struct {
// contains filtered or unexported fields
}
LineTransformerANSI imnplements a Linewriter interface. It uses an internal Linewriter lw to write to. It converts the channel information to color data using colorPalette. In case of a remote display the lineTranslator should be used there.
func NewLineTransformerANSI ¶
func NewLineTransformerANSI(lw LineWriter, colorPalette string) *LineTransformerANSI
NewLineTransformerANSI translates lines to ANSI colors according to colorPalette. It provides a Linewriter interface and uses internally a Linewriter.
type LineWriter ¶
type LineWriter interface {
// contains filtered or unexported methods
}
LineWriter is the common interface for output devices. The string slice `line` contains all string parts of one line including prefix and suffix. The last string part is without newline char and must be handled by the output device.
type LocalDisplay ¶
type LocalDisplay struct {
Err error
}
LocalDisplay is an object used for displaying. LocalDisplay implements the Linewriter interface.
func NewLocalDisplay ¶
func NewLocalDisplay() *LocalDisplay
NewLocalDisplay creates a LocalDisplay. It provides a Linewriter. It uses internally
Example ¶
p := NewLocalDisplay() l1 := []string{"This is ", "the 1st ", "line"} l2 := []string{"This is ", "the 2nd ", "line"} p.writeLine(l1) p.writeLine(l2)
Output: This is the 1st line This is the 2nd line
func (*LocalDisplay) ErrorFatal ¶
func (p *LocalDisplay) ErrorFatal()
ErrorFatal ends in osExit(1) if err not nil.
type RemoteDisplay ¶
type RemoteDisplay struct { Err error Cmd string // remote server executable Params string // remote server additional parameters (despite "ds -ipa a.b.c.d -ipp nnnn") IPAddr string // IP addr IPPort string // IP port PtrRPC *rpc.Client // PtrRPC is a pointer for remote calls valid after a successful rpc.Dial() }
RemoteDisplay is transferring to a remote display object.
func NewRemoteDisplay ¶
func NewRemoteDisplay(args []string) *RemoteDisplay
NewRemoteDisplay creates a connection to a remote Display and implements the Linewriter inteface. It accepts 0 to 4 string arguments. More arguments are ignored. For not given parameters default values are taken. The parameters are in the following order. args[0] (exe), is a programm started to create a remote server instance if not already running. If the remote server is already running on ips:ipp than a start of a 2nd instace is not is possible. This is silently ignored. If args[0] is empty, a running display server is assumed and a connection is established if possible. args[1] (params) contains additional remote display (=trice) command parameters. This value is used only if the remote server gets started. args[2] (ipa) is the IP address to be used to connect to the remote display. args[3] (ipp) is the IP port to be used to connect to the remote display.
func (*RemoteDisplay) Connect ¶
func (p *RemoteDisplay) Connect()
Connect is called by the client and tries to dial. On success PtrRpc is valid afterwards and the output is re-directed. Otherwise an error code is stored inside remotDisplay.
func (*RemoteDisplay) ErrorFatal ¶
func (p *RemoteDisplay) ErrorFatal()
ErrorFatal ends in osExit(1) if p.Err not nil.
type Server ¶
type Server struct {
Display ColorDisplay // todo: LineWriter?
}
Server is the RPC struct for registered server dunctions
func (*Server) ColorPalette ¶
ColorPalette is the exported server function for color palette, if trice tool acts as display server. By declaring it as a Server struct method it is registered as RPC destination.
func (*Server) LogSetFlags ¶
LogSetFlags is called remotely to ...
type TriceLineComposer ¶
type TriceLineComposer struct { Line []string // line collector // contains filtered or unexported fields }
TriceLineComposer collects all partial strings forming one line.
func New ¶
func New() *TriceLineComposer
New creates the emitter instance and returns a string writer to be used for emitting.
func (*TriceLineComposer) Write ¶ added in v0.18.4
func (p *TriceLineComposer) Write(b []byte) (n int, err error)
Write treats received buffer as a string.
func (*TriceLineComposer) WriteString ¶
func (p *TriceLineComposer) WriteString(s string) (n int, err error)
WriteString implements the io.StringWriter interface. The triceLineComposer can use it. WriteString uses the internal line writer p.lw for writing out full lines. If s is empty, WriteString returns 0, nil. If p.line is empty, the actual timestamp and the prefix are added to p.line. If s is without newline it is added to p.line and WriteString returns. If s ends with newline it is added to p.line and also the suffix is added to p.line and pline is written to p.lw. If s contains several newlines it is split there and the substrings are handled accordingly. That means it writes internally a separate line for each substring (in s) ending with a newline.