// Copyright 2018 Google Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // Package cell implements cell options and attributes. package cell // Option is used to provide options for cells on a 2-D terminal. type Option interface { // Set sets the provided option. Set(*Options) } // Options stores the provided options. type Options struct { FgColor Color BgColor Color Bold bool Italic bool Underline bool Strikethrough bool Inverse bool Blink bool } // Set allows existing options to be passed as an option. func (o *Options) Set(other *Options) { *other = *o } // NewOptions returns a new Options instance after applying the provided options. func NewOptions(opts ...Option) *Options { o := &Options{} for _, opt := range opts { opt.Set(o) } return o } // option implements Option. type option func(*Options) // Set implements Option.set. func (co option) Set(opts *Options) { co(opts) } // FgColor sets the foreground color of the cell. func FgColor(color Color) Option { return option(func(co *Options) { co.FgColor = color }) } // BgColor sets the background color of the cell. func BgColor(color Color) Option { return option(func(co *Options) { co.BgColor = color }) } // Bold makes cell's text bold. func Bold() Option { return option(func(co *Options) { co.Bold = true }) } // Italic makes cell's text italic. Only works when using the tcell backend. func Italic() Option { return option(func(co *Options) { co.Italic = true }) } // Underline makes cell's text underlined. func Underline() Option { return option(func(co *Options) { co.Underline = true }) } // Strikethrough strikes through the cell's text. Only works when using the tcell backend. func Strikethrough() Option { return option(func(co *Options) { co.Strikethrough = true }) } // Inverse inverts the colors of the cell's text. func Inverse() Option { return option(func(co *Options) { co.Inverse = true }) } // Blink makes the cell's text blink. Only works when using the tcell backend. func Blink() Option { return option(func(co *Options) { co.Blink = true }) }