diff --git a/wiki/tail.m4 b/wiki/tail.m4 new file mode 100644 index 0000000..e04310f --- /dev/null +++ b/wiki/tail.m4 @@ -0,0 +1,2 @@ + + diff --git a/wiki/unix/C.m4 b/wiki/unix/C.m4 index 0155def..69eb1d3 100644 --- a/wiki/unix/C.m4 +++ b/wiki/unix/C.m4 @@ -7,7 +7,7 @@ On Alpine Linux, the standard library headers are in the _package(`musl-dev') pa

Many Linux software distributions' system package managers have meta-packages that pull all necessities for C development as dependencies. -Alpine has _code(`build-base') and Debian has _code(`build-essential'). +Alpine has _package(`build-base') and Debian has _package(`build-essential').

For linking to libraries, see _ref(`#pkg-config'). @@ -31,7 +31,9 @@ The language evolved out of the former B programming language, which was a produ

(The Development of the C Language)
-

[Thompson 69] references K. Thompson, `Bon—an Interactive Language,' undated AT&T Bell Laboratories internal memorandum (ca. 1969). This is possibly Bon User's Manual. +

+[Thompson 69] references _cite(`K. Thompson, "Bon—an Interactive Language," undated AT&T Bell Laboratories internal memorandum (ca. 1969)'). +This is possibly Bon User's Manual but it's not conclusive. Please get in touch if you have a hyperlink for this document as I can't find it indexed on any search engines.

This language described in The C Programming Language isn't the C programming language known by most. @@ -39,18 +41,10 @@ It was a pre-standardization, relatively prototypical C, and rather than being c This was known as "pre-ANSI C" or "K&R C" and dubbed "C78" for the purposes of naming this page, in the same style as the later "C89", described in ANSI X3.159-1989, or "C11", described in ISO/IEC 9899:2011. "C78" was also the name given to historical C by the c78(7) manual page on FreeBSD 9.0.

-

-"C78" is incompatible with "C89" and later standards. -This page documents those incompatibilities and relative oddities. -

-

-I have never done (and probably never will do) extensive programming in pre-ANSI C. -These incompatibilities were discovered out of Appendix C in The C Programming Language, 2nd ed. but are described further. -

-

8 and 9 as valid octal digits

- +_subsubheader(`_italic(`8') and _italic(`9') as valid octal digits') +_bibliography(` +_bentr(`_ref(`#Unix#V6') - see /usr/source/c/ in the Sixth Edition root tree') +')
 main()
 {
@@ -60,7 +54,7 @@ main()
 }
 

-On my machine, the GNU C compiler emits the following errors (this omits warnings) for the preceding piece of code: +The GNU C compiler emits the following errors (this omits warnings) for the preceding piece of code:

 snippet.c:4:49: error: invalid digit "8" in octal constant
@@ -72,8 +66,8 @@ snippet.c:4:53: error: invalid digit "9" in octal constant
 

This is because in C (both pre-standardization and post-ANSI) integer constants with leading zeroes are parsed as octal (base 8) numbers. -In pre-ANSI C, 8 and 9 were valid octal digits corresponding to 010(b8) and 011(b8). -This is documented in The C Programming Language, Appendix A, subsection 2.4.1, and evidenced by the preceding code block. +In pre-ANSI C, _italic(`8') and _italic(`9') were valid octal digits corresponding to _italic(`010')(b8) and _italic(`011')(b8). +This is documented in _cite(`The C Programming Language'), Appendix A, subsection 2.4.1, and evidenced by the preceding code block. The following is output of the compiled program in UNIX V6 on an emulated PDP-11:

@@ -89,21 +83,30 @@ The following is output of the compiled program in UNIX V6 on an emulated PDP-11
 9
 

-This behavior exists within /usr/source/c/c0t.s, which is a PDP-11 assembler file that parses integer constants (as far as I can tell). -This file provides getnum, a function used in /usr/source/c/c00.c. +This behavior exists within _code(`/usr/source/c/c0t.s'), which is a PDP-11 assembler file that parses integer constants (as far as I can tell). +This file provides _program(`getnum'), a function used in _code(`/usr/source/c/c00.c'). My theory is that this behavior is a side-effect of a very efficient but imperfect method of parsing integer constants from a file stream.

-This wouldn't be a significant or even noticeable error; most programmers wouldn't use 8 or 9 as octal digits anyway. -If not for its documentation within The C Programming Language it would probably be an obscure bug. -This is also mentioned in The C Programming Language, 2nd ed. in Appendix C. +This wouldn't be a significant or even noticeable error; most programmers wouldn't use _italic(`8') or _italic(`9') as octal digits anyway. +If not for its documentation within _cite(`The C Programming Language') it might have totally faded into obscurity. +This is also mentioned in _cite(`The C Programming Language, 2nd ed.') in Appendix C. +

+_subheader(`Standardization') +_bibliography(` +_bentr(`_link(`Standard C: The ANSI Draft Grows Up', `https://archive.org/details/PC-Mag-1988-09-13/page/n115/')') +_bentr(`_link(`A Brief History of GCC', `https://gcc.gnu.org/wiki/History')') +') +

+In 1987, Richard M. Stallman, then a former MIT hacker who was working full time on the _italic(`GNU Project'), a re-implementation of the Unix operating system, +released the first beta release of _italic(`GCC'), then the _italic(`GNU C Compiler') and later re-named the _italic(`GNU Compiler Collection').

_subheader(`C1989') _subheader(`C1999') - +_bibliography(` +_bentr(`_link(`C99', `https://en.wikipedia.org/wiki/C99') (Wikipedia)') +_bentr(`_link(`c99(1p)', `https://www.man7.org/linux/man-pages/man1/c99.1p.html')') +') _subheader(`C2011') _subheader(`C2017') _subheader(`C202x') diff --git a/wiki/unix/Makefile b/wiki/unix/Makefile index f39a484..b3dad50 100644 --- a/wiki/unix/Makefile +++ b/wiki/unix/Makefile @@ -1,5 +1,6 @@ SOURCES = \ ../wiki.m4 \ + ../tail.m4 \ macros.m4 \ unix.m4 \ posix.m4 \ @@ -11,7 +12,6 @@ SOURCES = \ fonts.m4 \ fstab.m4 \ linux.m4 \ - m4.m4 \ netbsd.m4 \ manual.m4 \ multitasking.m4 \ diff --git a/wiki/unix/index.m4 b/wiki/unix/index.m4 index 7caff86..e693b1c 100644 --- a/wiki/unix/index.m4 +++ b/wiki/unix/index.m4 @@ -1,19 +1,7 @@ - - - - - - - - - - -UNIX - be.murderu.us - - -include(`../wiki.m4') -include(`macros.m4') -

be.murderu.us/unix

+define(`_DESCRIPTION', `Unix is a multitasking operating system designed with simplicity in mind.')dnl +define(`_PAGE', `Unix')dnl +include(`../wiki.m4')dnl +include(`macros.m4')dnl include(`unix.m4') @@ -35,8 +23,6 @@ include(`fstab.m4') include(`linux.m4') -include(`m4.m4') - include(`netbsd.m4') include(`manual.m4') @@ -53,5 +39,4 @@ include(`volumes.m4') include(`X.m4') - - +include(`../tail.m4')dnl diff --git a/wiki/unix/m4.m4 b/wiki/unix/m4.m4 deleted file mode 100644 index 3990a49..0000000 --- a/wiki/unix/m4.m4 +++ /dev/null @@ -1,4 +0,0 @@ -

m4

- diff --git a/wiki/unix/posix.m4 b/wiki/unix/posix.m4 index 1cae270..be955d5 100644 --- a/wiki/unix/posix.m4 +++ b/wiki/unix/posix.m4 @@ -171,6 +171,12 @@ A traditional _man(`ed(1)') implementation is in plan9ports. I'm pretty sure some later UNIX-based OSes doubled the _man(`ed(1)') buffers, there's pretty much no downside to doing so in the modern era but it should be very easy to do yourself if it hasn't already been done (just double some of the array sizes in the beginning of _code(`ed.c')).

+_subheader(`m4(1)') +_bibliography(` +_bentr(`_link(`m4', `https://en.wikipedia.org/wiki/`M4_'(computer_language)') (Wikipedia)') +_bentr(`_link(`Notes on the M4 Macro Language', `https://mbreen.com/m4.html')') +') + _subheader(`make(1)')

_man(`make(1)') in modern times is fragmented into the GNU version gmake and the BSD version bmake. diff --git a/wiki/unix/unix.m4 b/wiki/unix/unix.m4 index 0a4df82..2423a46 100644 --- a/wiki/unix/unix.m4 +++ b/wiki/unix/unix.m4 @@ -4,6 +4,7 @@ _bentr(`_link(`A Research Unix Reader', `https://www.cs.dartmouth.edu/~doug/read _bentr(`_link(`Dennis Ritchie', `https://en.wikipedia.org/wiki/Dennis_Ritchie') (Wikipedia)') _bentr(`_link(`Unix', `https://en.wikipedia.org/wiki/Unix') (Wikipedia)') _bentr(`_link(`unix-history-repo', `https://github.com/dspinellis/unix-history-repo') (GitHub)') +_bentr(`_link(`The UNIX Time-sharing System - A Retrospective', `https://web.archive.org/web/20080504013206/http://cm.bell-labs.com/cm/cs/who/dmr/retro.html')') ') _passage(`Wikipedia', `

Unix (/ˈjuːnɪks/; trademarked as UNIX) is a family of multitasking, multiuser computer operating systems that derive from the original AT&T Unix, whose development started in 1969 at the Bell Labs research center by Ken Thompson, Dennis Ritchie, and others. @@ -34,3 +35,7 @@ Thompson rewrote the game to run on a spare PDP-7 at Bell. Having written so much code already to get the PDP-7 to work, Thompson started to work on other things for it; a file system, some utilities for it, a command interpreter, and an assembler. Then, mid-1970, Brian Kernighan named the non-multiplexing Multics workalike _italic(`Unics'), which was somehow (see _cite(`Interview with Brian Kernighan')) bastardized into _italic(`Unix').

+_subheader(`V6') +_bibliography(` +_bentr(`_link(`Unix Sixth Edition root tree', `https://minnie.tuhs.org/cgi-bin/utree.pl?file=V6')') +') diff --git a/wiki/wiki.m4 b/wiki/wiki.m4 index 14cb4f5..b591c6d 100644 --- a/wiki/wiki.m4 +++ b/wiki/wiki.m4 @@ -1,4 +1,6 @@ changecom(`')dnl +define(`_ASCII_UPPER', `ABCDEFGHIJKLMNOPQRSTUVWXYZ')dnl +define(`_ASCII_LOWER', `abcdefghijklmnopqrstuvwxyz')dnl define(`_bibliography', `')dnl define(`_bibliography_entry', `
  • $1
  • ')dnl define(`_bentr', `_bibliography_entry($1)')dnl @@ -7,6 +9,7 @@ define(`_code', `$1')dnl define(`_header', `

    $1

    ')dnl define(`_italic', `$1')dnl define(`_link', `$1')dnl +define(`_lowercase', `translit(`$1', _ASCII_UPPER, _ASCII_LOWER)')dnl define(`_passage', `
    $2
    (_cite(`$1'))
    @@ -14,3 +17,17 @@ define(`_passage', `
    define(`_ref', `_link(`$1', `$1')')dnl define(`_subheader', `

    $1

    ')dnl define(`_subsubheader', `

    $1

    ')dnl + + + + + + + + + + +_PAGE - murderu.us wiki + + +

    _link(`be.murderu.us', `https://be.murderu.us/')/_lowercase(_PAGE)