[bug-notifications] [screen 0004133]: Color support impaired, screen windows default to TERM=vt100

Mantis Bug Tracker noreply at opencsw.org
Mon Jan 11 14:12:11 CET 2010


The following issue requires your FEEDBACK. 
====================================================================== 
http://www.opencsw.org/mantis/view.php?id=4133 
====================================================================== 
Reported By:                skayser
Assigned To:                yann
====================================================================== 
Project:                    screen
Issue ID:                   4133
Category:                   packaging
Reproducibility:            N/A
Severity:                   feature
Priority:                   low
Status:                     feedback
====================================================================== 
Date Submitted:             2010-01-09 18:28 CET
Last Modified:              2010-01-11 14:12 CET
====================================================================== 
Summary:                    Color support impaired, screen windows default to
TERM=vt100
Description: 
Screen is linked to the standard Solaris curses which doesn't know about
"screen" in its terminfo database (/usr/lib/share/terminfo). Thus, screen
windows default to TERM=vt100 and even "screen -T screen" reverts back to
TERM=vt100. The problem with this is that the vt100 terminfo entry doesn't
support colors, so applications like vim running inside screen don't
colorize their output even though screen comes with color support.

To work around it, one can point the system curses libs to the terminfo
database that comes with CSW ncurses (it contains a terminfo description
for screen) and then start screen. "TERMINFO=/opt/csw/share/terminfo
screen". This way screen windows default to TERM=screen and color support
for applications running inside these windows is working. This is a
workaround though.

As a possible fix from the packaging side, screen could be compiled
against CSW ncurses (for comparison: the screen from sunfreeware.com is
also linked against their ncurses). Then the terminfo database defaults to
/opt/csw/share/terminfo and screen windows would have TERM=screen as
described above. The problem with this approach would be that applications
linked against system curses (like /usr/bin/less) running inside our CSW
screen would be presented with TERM=screen which is unknown to their
/usr/lib/share/terminfo database.

I don't see this as a major problem though: users are already advised to
put /opt/csw/bin first in their $PATH. If we make sure that our packages
are built against CSWncurses, our stack is fully functional within such a
screen and comes with functional color support out of-the-box. "Legacy"
tools linked against system curses which are running inside such a screen
session would require the TERMINFO workaround from above to understand
TERM=screen or would need to be run with TERM=vt100.

Filing this as a "feature request", which is up for discussion. Right now,
there is no out-of-the-box color support within screen windows.
====================================================================== 

---------------------------------------------------------------------- 
 (0007206) yann (manager) - 2010-01-11 14:12
 http://www.opencsw.org/mantis/view.php?id=4133#c7206 
---------------------------------------------------------------------- 
You will find fixed packages in testing: 
http://buildfarm.opencsw.org/testing/screen-4.0.3,REV=2010.01.10-SunOS5.8-i386-CSW.pkg.gz
http://buildfarm.opencsw.org/testing/screen-4.0.3,REV=2010.01.10-SunOS5.8-sparc-CSW.pkg.gz

Could you test if that packages work correctly in your environment ?

I included cswmigrateconf class action script to migrate configuration
from /opt/csw/etc/screenrc to /etc/opt/csw/screenrc in case someone
manually created a system-wide screenrc file, but I will probably wait for
an answer on this bug:
http://www.opencsw.org/mantis/view.php?id=4143
before releasing the package.




More information about the bug-notifications mailing list