aboutsummaryrefslogtreecommitdiff
path: root/usr.bin/script/script.c
Commit message (Collapse)AuthorAgeFilesLines
* script: handle terminal resize on SIGWINCHKyle Evans2024-04-291-8/+54
| | | | | | | | | | | | Add a -w flag to forward terminal resize events on to the child, which can be useful in some circumstances to avoid terminal corruption. Reviewed by: des Co-authored-by: Xavier Beaudouin <xavier.beaudouin@klarasystems.com> Sponsored by: Modirum MDPay Sponsored by: Klara, Inc. (cherry picked from commit 8ceac8e13dccbe4e177c8f2f443b87b7d2e3edb3)
* script: minor style improvementsXavier Beaudouin2024-04-291-8/+10
| | | | | | | | | | | Fix some nits pointed out by checkstyle9.pl in advance of functional changes to script(1). Reviewed by: des Sponsored by: Modirum MDPay Sponsored by: Klara, Inc. (cherry picked from commit 4459abe334eb4dbd416fa8094a64afc065ccd1cc)
* Remove $FreeBSD$: one-line .c patternWarner Losh2023-08-161-1/+0
| | | | Remove /^[\s*]*__FBSDID\("\$FreeBSD\$"\);?\s*\n/
* Mark usage function as __dead2 in programs where it does not returnAlfonso Gregory2023-07-071-1/+1
| | | | | | | | In most cases, usage does not return, so mark them as __dead2. For the cases where they do return, they have not been marked __dead2. Reviewed by: imp Pull Request: https://github.com/freebsd/freebsd-src/pull/735
* script: Handle a missing 's' stamp gracefully.Dag-Erling Smørgrav2022-10-271-0/+2
| | | | | Sponsored by: Klara, Inc. Differential Revision: https://reviews.freebsd.org/D37182
* script: Further usage string nits.Dag-Erling Smørgrav2022-10-271-2/+2
| | | | | Sponsored by: Klara, Inc. Differential Revision: https://reviews.freebsd.org/D37177
* script: Use size_t / ssize_t where needed.Dag-Erling Smørgrav2022-10-271-3/+3
| | | | | Sponsored by: Klara, Inc. Differential Revision: https://reviews.freebsd.org/D37177
* script: Add usage string for playback mode.Dag-Erling Smørgrav2022-10-271-0/+2
| | | | | Sponsored by: Klara, Inc. Differential Revision: https://reviews.freebsd.org/D37138
* script: Correct -F in man page and usage string.Dag-Erling Smørgrav2022-10-271-1/+1
| | | | | | Sponsored by: Klara, Inc. MFC after: 1 week Differential Revision: https://reviews.freebsd.org/D37138
* script: use %n at the end of default tstamp_fmtSimon J. Gerraty2022-03-101-1/+1
| | | | | Since we are only outputting time-stamps when they differ ending it with a newline, interferes with the output less.
* script -T skip timstamps for same secondSimon J. Gerraty2022-03-101-3/+8
| | | | | The result is much more readable if we only output the time-stamp when it is at least 1s since last one.
* script add -T fmt to print time-stampsSimon J. Gerraty2022-03-091-9/+29
| | | | | | | | | | | | | | | | | script -r is useful for recording time-stamps of when output happened. With -T, rather than playback the script in real-time we simply print the time-stamps to show when the output happened. This is very useful for example, for analyzing boot time activity. If the fmt provided contains no % characters the default %n@ %s [%Y-%m-%d %T] is used, which lends itself to analysis by tools as well as humans. Sponsored by: Juniper Networks, Inc. Reviewed by: allanjude Differential Revision: https://reviews.freebsd.org/D34511
* script(1): work around slow reading childKonstantin Belousov2022-01-101-5/+51
| | | | | | | | | | | | | | | | | | | | If child is slow reading from its input, or even completely stops doing the read, script(1) hangs in write(2) to the pts master waiting until there is a space in the terminal discipline buffer. This also stops handling any outer io, as well as child output. Work around the problem by making pts master fd non-blocking, and be prepared for short writes to it. The data to be written to master is buffered in the tailq which is processed when select(2) detects that master is ready for write. PR: 260938 Reported by: наб <nabijaczleweli@nabijaczleweli.xyz> See also: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1003095 Reviewed by: markj Sponsored by: The FreeBSD Foundation MFC after: 1 week Differential revision: https://reviews.freebsd.org/D33789
* Fix typo in comment.Warner Losh2020-09-051-1/+1
| | | | | | | Noticed by: bapt@ Notes: svn path=/head/; revision=365358
* Have script accept and ignore -e for Linux compatWarner Losh2020-09-011-1/+3
| | | | | | | | | | | | In the util-linux version of script, it will always exit with succes. Except when run with -e, in which case it will have the exit value of the child. BSD Script already uses the child's exit value for its exit value. Some config and other helper scripts depend on being able to specify -e. Accept it for compatibility since we'll already to the right thing, but otherwise we ignore it. Notes: svn path=/head/; revision=365052
* script: Minor cleanups.Mark Johnston2020-08-111-10/+9
| | | | | | | | | | | | | | | - Instead of using isatty() to decide whether to call tcgetattr(), just call tcgetattr() directly, since that's all that isatty() does anyway. - Simplify error handling in termset(). Check for errno != ENOTTY from tcgetattr() to handle errors that may be raised while running script(1) under a debugger. PR: 248377 Submitted by: Soumendra Ganguly <soumendraganguly@gmail.com> MFC after: 1 week Notes: svn path=/head/; revision=364112
* script: Put the terminal in raw mode when playing back a session.Mark Johnston2020-08-071-0/+30
| | | | | | | | | | | | Otherwise recorded sessions of some interactive programs do not play back properly. PR: 248377 Submitted by: Soumendra Ganguly <0.gangzta@gmail.com> MFC after: 1 week Notes: svn path=/head/; revision=364039
* General further adoption of SPDX licensing ID tags.Pedro F. Giffuni2017-11-201-0/+2
| | | | | | | | | | | | | | | | | Mainly focus on files that use BSD 3-Clause license. The Software Package Data Exchange (SPDX) group provides a specification to make it easier for automated tools to detect and summarize well known opensource licenses. We are gradually adopting the specification, noting that the tags are considered only advisory and do not, in any way, superceed or replace the license texts. Special thanks to Wind River for providing access to "The Duke of Highlander" tool: an older (2014) run over FreeBSD tree was useful as a starting point. Notes: svn path=/head/; revision=326025
* Renumber copyright clause 4Warner Losh2017-02-281-1/+1
| | | | | | | | | | | | Renumber cluase 4 to 3, per what everybody else did when BSD granted them permission to remove clause 3. My insistance on keeping the same numbering for legal reasons is too pedantic, so give up on that point. Submitted by: Jan Schaumann <jschauma@stevens.edu> Pull Request: https://github.com/freebsd/freebsd/pull/96 Notes: svn path=/head/; revision=314436
* Directly set the O_CLOEXEC flags via the open(2) attributesBaptiste Daroussin2016-04-161-6/+3
| | | | | | | MFC after: 1 week Notes: svn path=/head/; revision=298112
* Record command exit status in the typescript file when running simple commands.Bryan Drewery2016-03-081-3/+9
| | | | | | | | | | | Also capitalize 'command:'. Relnotes: yes MFC after: 2 weeks Sponsored by: EMC / Isilon Storage Division Notes: svn path=/head/; revision=296526
* Just exit in the child if execve(2) fails.Bryan Drewery2016-03-081-9/+1
| | | | | | | | | | | | | | | | | No functional change. This is mostly addressing a false-positive from the clang static analyzer due to it thinking that done() was being called with freed memory, however the kill(0, SIGTERM) made the done() never reached. It doesn't make sense to the show the footer from the child anyhow, nor does it make sense to kill the process group here since the execve(2) failed in the child. This code was leftover from many years of refactoring. MFC after: 1 week Sponsored by: EMC / Isilon Storage Division Notes: svn path=/head/; revision=296525
* Filemon: Attach from the child to avoid racing with the parent attach.Bryan Drewery2016-03-081-4/+10
| | | | | | | | | | | | | This is the same as how the bmake filemon usage works. This also fixes failed attach not properly flushing the TTY. MFC after: 1 week Relnotes: yes Sponsored by: EMC / Isilon Storage Division Notes: svn path=/head/; revision=296524
* Bring back r226403, the fix for bin/161526, which was (accidentally?)Mikolaj Golub2014-01-171-3/+6
| | | | | | | | | | | reverted in r238896. PR: bin/161526 Reported by: Karli.Sjoberg slu.se MFC after: 3 days Notes: svn path=/head/; revision=260833
* Add -F to flush output after each write. With this, I canTom Rhodes2013-12-051-3/+8
| | | | | | | | | | | set up a pipe and allow a jr user to watch what I'm doing by running 'script -F pipefile' on it. While here, spell out the month in the .Dd tag like other manual pages. Notes: svn path=/head/; revision=258955
* Add "-f" to also output filemon(4) information.David E. O'Brien2012-10-261-9/+46
| | | | Notes: svn path=/head/; revision=242138
* Don't include both <sys/param.h> & <sys/types.h>.David E. O'Brien2012-10-231-6/+1
| | | | Notes: svn path=/head/; revision=241972
* Add d, p and r switches for recording script sessions with timing dataBrian Somers2012-07-301-22/+196
| | | | | | | | | | | and playing sessions back with or without time delays. PR: 114465 Submitted by: ighighi at gmail dot com MFC after: 3 weeks Notes: svn path=/head/; revision=238896
* In r225809 the intention was to send VEOF only once if STDIN was not aMikolaj Golub2011-10-151-3/+6
| | | | | | | | | | | | | | | | | | | terminal. Unfortunately the fix was incorrect and for flushtime > 0 it keept sending VEOF. Sent VEOF generates ^D\b\b echoed by the terminal, which was reported in bin/161526. Note, we still send VEOF at least once. Otherwise commands like below would hang forever: echo 1 |script /tmp/script.out cat PR: bin/161526 Reported by: Adrian Wontroba <aw1@stade.co.uk>, Stefan Bethke <stb@lassitu.de> Tested by: Stefan Bethke <stb@lassitu.de> MFC after: 3 days Notes: svn path=/head/; revision=226403
* When script(1) reads EOF from input it starts spinning on zero-byteMikolaj Golub2011-09-271-12/+20
| | | | | | | | | | | | | | | | | | | reads eating 100% CPU. Fix this by skipping select on STDIN after reading EOF -- permanently if STDIN is not terminal and for one second if it is. Also after reading EOF from STDIN we have to pass it to the program being scripted. The previous approach was to write zero bytes into the pseudo-terminal. This does not work because zero-byte write does not have any effect on read. Fix this by sending VEOF instead. Submitted by: Ronald Klop <ronald-freebsd8@klop.yi.org> Discussed with: kib, Chris Torek <chris.torek@gmail.com> Approved by: kib MFC after: 1 week Notes: svn path=/head/; revision=225809
* Remove the advertising clause from UCB copyrighted files in usr.bin. ThisJoel Dahl2010-12-111-4/+0
| | | | | | | | | | | | is in accordance with the information provided at ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change Also add $FreeBSD$ to a few files to keep svn happy. Discussed with: imp, rwatson Notes: svn path=/head/; revision=216370
* + Add the SCRIPT environmental variable to the sub-shell. Its value isDavid E. O'Brien2010-09-161-0/+7
| | | | | | | | | | | the name of the typescript file. + Add the 'command' argument (if supplied on the command line) to the typescript file. This creates a more complete typescript when invoked this way - more equal to invoking script without supplying the 'command' argument. Notes: svn path=/head/; revision=212770
* Mark functions and variables as static.Ed Schouten2010-08-161-15/+14
| | | | | | | | | All these functions and variables are local to this compilation unit, so there is no reason why we shouldn't mark them static. This slightly reduces the binary size. Notes: svn path=/head/; revision=211394
* Remove WNOHANG flag from wait3().Ed Schouten2010-04-301-15/+9
| | | | | | | | | | | | | | | | | Because script(1) now reliably terminates when the TTY is closed, it may be the case that the call to wait3() occurs just before the child process exits. This causes error codes to be ignored. Just change script(1) to use waitpid() instead of wait3(). This makes it more portable and prevents the need for a loop, since waitpid() only returns a specified process. PR: bin/146189 Tested by: amdmi3@, older version MFC after: 2 weeks Notes: svn path=/head/; revision=207453
* Improve the change made in the previous commit.Ed Schouten2010-03-111-2/+1
| | | | | | | | doshell() never returns, so there is no need to see whether we are the parent process. Notes: svn path=/head/; revision=205009
* Make script(1) a little less broken.Ed Schouten2010-03-111-0/+2
| | | | | | | | | | | | Close the file descriptor to the TTY. There is no reason why the parent process should keep track of the descriptor. This ensures that the application inside properly drains the TTY during exit(2). Reported by: alfred MFC after: 2 weeks Notes: svn path=/head/; revision=205008
* Remove a warning by adding extra parentheses.Ed Schouten2010-01-021-1/+1
| | | | | | | | GCC generates warnings when using "if (foo = bar)". In this case its use is valid. Notes: svn path=/head/; revision=201384
* Attempt #2 to fix script(1) if the standard input is closed: If weColin Percival2004-02-151-1/+3
| | | | | | | | | | | | | | | | | | | read EOF from STDIN_FILENO, write zero bytes into the pseudo-terminal; this is interpreted as an EOF by the program being scripted. I've tested this with two non-interactive scripts: # echo 5 | script foo sh -c 'read x; sleep $x; echo bar' # echo bar | xargs script foo echo and one interactive program: # script foo more /etc/passwd and everything seems to work properly... PR: bin/56166, bin/57414, ports/57415, ports/60534 Approved by: rwatson (mentor) MFC after: 2 weeks Notes: svn path=/head/; revision=125848
* Back out part of 1.21, since it breaks `script interactive-program`. ThisColin Percival2004-01-271-2/+1
| | | | | | | | | | | | re-breaks non-interactive portupgrade (or at least old versions of portupgrade); I'll see if I can put together a solution which avoids breaking anything later. Approved by: rwatson (mentor) Noticed by: Stefan Farfeleder, Joshua Goodall Notes: svn path=/head/; revision=125101
* Fix SYNOPSIS of manual page, clustering no-arg options correctly.Sheldon Hearn2004-01-221-1/+1
| | | | | | | Sync usage with manpage. Notes: svn path=/head/; revision=124846
* Two fixes for script(1):Colin Percival2004-01-221-11/+22
| | | | | | | | | | | | | | | | 1. Don't do tty stuff to stdin if stdin isn't a tty. 2. When running in non-interactive mode, don't select(2) on the standard input. This un-breaks non-interactive portupgrade. PR: bin/59036 [1] PR: bin/56166, bin/57414, ports/57415, ports/60534 [2] MFC after: 7 days Approved by: rwatson (mentor) Notes: svn path=/head/; revision=124845
* ANSIify function definitions.David Malone2002-09-041-10/+6
| | | | | | | | | | | | Add some constness to avoid some warnings. Remove use register keyword. Deal with missing/unneeded extern/prototypes. Some minor type changes/casts to avoid warnings. Reviewed by: md5 Notes: svn path=/head/; revision=102944
* Use POSIX macros for wait(2)-style status information instead of theMike Barcroft2002-06-031-3/+3
| | | | | | | | deprecated 4.2/4.3BSD wait union. Fix some nearby pid_t/int confusion. Notes: svn path=/head/; revision=97788
* remove __PWarner Losh2002-03-221-6/+6
| | | | Notes: svn path=/head/; revision=92922
* Minor style stuff, use __FBSDID(), remove to-be-default WARNS=2.Mark Murray2001-12-121-8/+8
| | | | Notes: svn path=/head/; revision=87768
* Warns cleanups. Add FreeBSD ID.David Malone2001-12-031-2/+2
| | | | Notes: svn path=/head/; revision=87296
* Use STD{ERR,IN,OUT}_FILENO instead of their numeric values. TheSheldon Hearn2001-07-261-1/+1
| | | | | | | | | | definitions are more readable, and it's possible that they're more portable to pathalogical platforms. Submitted by: David Hill <david@phobia.ms> Notes: svn path=/head/; revision=80381
* Fix the type of the NULL arg to execl()Brian Somers2001-07-091-1/+1
| | | | | | | Idea from: Theo de Raadt <deraadt@openbsd.org> Notes: svn path=/head/; revision=79452
* Nuke unused variables.Dima Dorfman2001-06-241-1/+0
| | | | Notes: svn path=/head/; revision=78737
* Don't call warn() with no format string.Kris Kennaway2000-07-101-2/+2
| | | | Notes: svn path=/head/; revision=62897