docs/unix-phil

changeset 24:2335f5658fca

added poster and slides
author meillo@marmaro.de
date Fri, 05 Mar 2010 23:56:48 +0100 (2010-03-05)
parents f0511a56416e
children e6ac51dc18bf
files cs-2010-03_poster.ms makefile slides unix-phil-slides.ms
diffstat 4 files changed, 461 insertions(+), 1 deletions(-) [+]
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/cs-2010-03_poster.ms	Fri Mar 05 23:56:48 2010 +0100
     1.3 @@ -0,0 +1,56 @@
     1.4 +.fp 1 R pplr8a.afm uplr8a.pfb
     1.5 +.fp 2 I pplri8a.afm uplri8a.pfb
     1.6 +.fp 3 B pplb8a.afm uplb8a.pfb
     1.7 +.fp 4 BI pplbi8a.afm uplbi8a.pfb
     1.8 +.fi
     1.9 +.ad b
    1.10 +.hy 14
    1.11 +.de P
    1.12 +.br
    1.13 +.sp 0.8
    1.14 +..
    1.15 +
    1.16 +.sp 1i
    1.17 +.ps 30
    1.18 +.vs 32
    1.19 +ChaosSeminar
    1.20 +.br
    1.21 +des CCC Ulm
    1.22 +
    1.23 +.sp 1.0i
    1.24 +.ps 44
    1.25 +.ft BI
    1.26 +.ce
    1.27 +Die Unix Philosophie
    1.28 +
    1.29 +.sp 0.7i
    1.30 +.ft R
    1.31 +.ps 18
    1.32 +.vs 20
    1.33 +.nr PD 10p
    1.34 +Ein Vortrag von \fBMarkus Schnalke\fP
    1.35 +über die wahre Genialität von Unix.
    1.36 +.P
    1.37 +Unix ist ein beeindruckendes Betriebssystem und eine 
    1.38 +erstklassige Programmsammlung.
    1.39 +Doch dies ist beides letztlich nur eine Folge.
    1.40 +\fIDas eigentlich besondere an Unix ist seine Philosophie.\fP
    1.41 +Die Unix Philosophie ist eine Sammlung von Konzepte und
    1.42 +Designziele die in Unix umgesetzt wurden.
    1.43 +.P
    1.44 +Dieser Vortrag wird die Unix Philosophie vorstellen
    1.45 +und erklären weshalb sie zu hervorragender Software führt.
    1.46 +.P
    1.47 +Neben den rein technischen Aspekten bietet die
    1.48 +Unix Philosophie aber auch Anreize für das tägliche Leben.
    1.49 +Sie ist mehr als Richtlinien um gute Software zu erzeugen,
    1.50 +sie ist eine Inspiration in vielerlei Hinsicht.
    1.51 +
    1.52 +.sp 1i
    1.53 +.ps 30
    1.54 +.vs 36
    1.55 +.ce 2
    1.56 +Montag, 08. März
    1.57 +.br
    1.58 +20:00 Uhr, H20
    1.59 +.br
     2.1 --- a/makefile	Tue Mar 02 14:34:07 2010 +0100
     2.2 +++ b/makefile	Fri Mar 05 23:56:48 2010 +0100
     2.3 @@ -1,7 +1,10 @@
     2.4 -all: unix-phil.ps unix-phil.txt
     2.5 +all: unix-phil.ps unix-phil.txt unix-phil-slides.ps
     2.6  
     2.7  unix-phil.ps: unix-phil.ms
     2.8  	sh -c "`doctype unix-phil.ms`" >unix-phil.ps
     2.9  
    2.10  unix-phil.txt: unix-phil.ms
    2.11  	sh -c "`doctype -n unix-phil.ms`" >unix-phil.txt
    2.12 +
    2.13 +unix-phil-slides.ps: unix-phil-slides.ms
    2.14 +	sed -n '/./p' unix-phil-slides.ms | hl troff -ms slides - | hl dpost | insline 1 "%%BoundingBox: 0 0 600 450" >unix-phil-slides.ps
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/slides	Fri Mar 05 23:56:48 2010 +0100
     3.3 @@ -0,0 +1,62 @@
     3.4 +.pl 7i
     3.5 +
     3.6 +.fp 1 R H
     3.7 +.fp 2 I HI
     3.8 +.fp 3 B HB
     3.9 +.fp 4 BI HX
    3.10 +
    3.11 +.nr PS 16
    3.12 +.nr VS 20p
    3.13 +.nr PD 12p
    3.14 +
    3.15 +.ds CH "
    3.16 +
    3.17 +.am TL
    3.18 +.sp 0.7i
    3.19 +.ps 24
    3.20 +.vs 28p
    3.21 +..
    3.22 +.am AU
    3.23 +.\"'sp 4.0i
    3.24 +.\".ps 14
    3.25 +.\".vs 20p
    3.26 +..
    3.27 +
    3.28 +
    3.29 +.de P
    3.30 +.ds CH "
    3.31 +.bp
    3.32 +\&
    3.33 +.sp 1.4i
    3.34 +.ce 1
    3.35 +\s+8\fB\\$1\fP\s-8
    3.36 +.na
    3.37 +..
    3.38 +
    3.39 +.de S
    3.40 +.ds CH \s+2\f3\\$1\fP\s-2
    3.41 +.bp
    3.42 +.LP
    3.43 +.na
    3.44 +..
    3.45 +
    3.46 +.de I
    3.47 +.if !"\\$1"" .ds BX \\$1
    3.48 +.if "\\$1"" .ds BX \(bu
    3.49 +.IP \\*(BX
    3.50 +..
    3.51 +
    3.52 +.de CW
    3.53 +\&\f(CW\\$1\fP\\$2
    3.54 +..
    3.55 +
    3.56 +
    3.57 +
    3.58 +.\" .nr PO 0.5i  \" page offset = left margin
    3.59 +.\" .nr HM 1i \" header margin
    3.60 +.\" .nr PS 12
    3.61 +.\" .nr VS 14p
    3.62 +.\" .nr PD 6p
    3.63 +.\" .nr LL 6.5i
    3.64 +.\" .pl 15c
    3.65 +.\" .ds RF "
     4.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     4.2 +++ b/unix-phil-slides.ms	Fri Mar 05 23:56:48 2010 +0100
     4.3 @@ -0,0 +1,339 @@
     4.4 +.TL
     4.5 +\fR\s-6Why\s0\fP
     4.6 +.br
     4.7 +the Unix Philosophy
     4.8 +.br
     4.9 +.vs -4
    4.10 +\fR\s-6(still) matters\s0\fP
    4.11 +.AU
    4.12 +.ft R
    4.13 +.sp 1.2i
    4.14 +.ps 11
    4.15 +markus schnalke <meillo@marmaro.de>
    4.16 +
    4.17 +
    4.18 +.S "goals of this talk
    4.19 +.I
    4.20 +introduce the Unix Phil
    4.21 +.I
    4.22 +explain why most modern software is crap
    4.23 +.I
    4.24 +explain why the Unix Phil leads to better software
    4.25 +.I
    4.26 +convince you that good software is of matter
    4.27 +.sp 2
    4.28 +.I
    4.29 +make you think
    4.30 +
    4.31 +
    4.32 +.S "roadmap
    4.33 +.I
    4.34 +Historical background
    4.35 +.I
    4.36 +What is the Unix Philosophy?
    4.37 +.I
    4.38 +The Unix Phil after Gancarz
    4.39 +.I
    4.40 +Discussion on real world examples
    4.41 +.I
    4.42 +The Unix Phil is more than software dev guidelines
    4.43 +
    4.44 +
    4.45 +
    4.46 +.S "me and the UP
    4.47 +.LP
    4.48 +first contact: through the suckless project
    4.49 +.LP
    4.50 +``cat -v Considered Harmful''
    4.51 +.LP
    4.52 +``The Unix and the Echo''
    4.53 +.LP
    4.54 +``The Unix Programming Environment''
    4.55 +.sp 1
    4.56 +.LP
    4.57 +better understanding through digging in the past
    4.58 +
    4.59 +
    4.60 +
    4.61 +
    4.62 +
    4.63 +.P "historical background
    4.64 +
    4.65 +
    4.66 +
    4.67 +
    4.68 +.S "historical background
    4.69 +.I
    4.70 +the late 60s and early 70s
    4.71 +.I
    4.72 +operating systems are complex
    4.73 +.I
    4.74 +MULTICS just failed
    4.75 +.I
    4.76 +Brooks' ``The Mythical Man-Month''
    4.77 +.I
    4.78 +a lot of different hardware
    4.79 +.I
    4.80 +limited computing power
    4.81 +.I
    4.82 +textual input and output (line printers)
    4.83 +
    4.84 +
    4.85 +.S "everything is a file
    4.86 +.LP
    4.87 +is the(?) basic concept in Unix (and even more in Plan9)
    4.88 +.LP
    4.89 +made simple operating systems possible
    4.90 +.LP
    4.91 +it is not covered by the Unix Phil; the Unix Phil is on a different level
    4.92 +.sp 2
    4.93 +.LP
    4.94 +Unix is mainly two things:
    4.95 +.I
    4.96 +an operating system (system calls)
    4.97 +.I
    4.98 +a toolchest (coreutils)
    4.99 +
   4.100 +
   4.101 +
   4.102 +.P "What is the Unix Phil
   4.103 +
   4.104 +
   4.105 +
   4.106 +.S "What is the Unix Phil *itself*?
   4.107 +.LP
   4.108 +``The Unix philosophy is a set of cultural norms and philosophical
   4.109 +approaches to developing software based on the experience of
   4.110 +leading developers of the Unix operating system.''
   4.111 +(wikipedia)
   4.112 +.sp 2
   4.113 +.LP
   4.114 +How the inventors of Unix write software.
   4.115 +.LP
   4.116 +Common things of classic Unix tools.
   4.117 +.sp 2
   4.118 +.LP
   4.119 +difficult to define
   4.120 +
   4.121 +
   4.122 +.S "Unix Phil vs. SW dev processes
   4.123 +.LP
   4.124 +the Unix Phil
   4.125 +.I
   4.126 +much: *what* to program
   4.127 +.I
   4.128 +few: *how* to program
   4.129 +
   4.130 +.LP
   4.131 +Software developments processes:
   4.132 +.I
   4.133 +few: *what* to program
   4.134 +.I
   4.135 +much: *how* to program
   4.136 +
   4.137 +.sp 2
   4.138 +.LP
   4.139 +Extreme Programming is like the Unix Phil
   4.140 +but with more *how* than *what*,
   4.141 +and with formalisms
   4.142 +
   4.143 +
   4.144 +
   4.145 +
   4.146 +
   4.147 +.S "What is the Unix Phil?
   4.148 +.I
   4.149 +Doug McIlroy (1978)
   4.150 +.I
   4.151 +Mike Gancarz: ``The Unix Philosophy'' (1994)
   4.152 +.I
   4.153 +Eric S. Raymond: ``The Art of Unix Programming'' (2003)
   4.154 +.sp 2
   4.155 +.I
   4.156 +Richard Gabriel: ``Worse is Better'' (1989)
   4.157 +
   4.158 +
   4.159 +.S "Doug McIlroy
   4.160 +.LP
   4.161 +This is the Unix philosophy:
   4.162 +.I
   4.163 +Write programs that do one thing and do it well.
   4.164 +.I
   4.165 +Write programs to work together.
   4.166 +.I
   4.167 +Write programs to handle text streams, because that is a universal interface.
   4.168 +
   4.169 +
   4.170 +.S "Mike Gancarz: ``The Unix Philosophy''
   4.171 +.I
   4.172 +Small is beautiful.
   4.173 +.I
   4.174 +Make each program do one thing well.
   4.175 +.I
   4.176 +Build a prototype as soon as possible.
   4.177 +.I
   4.178 +Choose portability over efficiency.
   4.179 +.I
   4.180 +Store data in flat text files.
   4.181 +.I
   4.182 +Use software leverage to your advantage.
   4.183 +.I
   4.184 +Use shell scripts to increase leverage and portability.
   4.185 +.I
   4.186 +Avoid captive user interfaces.
   4.187 +.I
   4.188 +Make every program a filter.
   4.189 +.sp 1
   4.190 +.LP
   4.191 +plus ten lesser tenets
   4.192 +
   4.193 +
   4.194 +
   4.195 +
   4.196 +.P "The Unix Phil after Gancarz
   4.197 +
   4.198 +.S "Small is beautiful.
   4.199 +.LP
   4.200 +foo
   4.201 +
   4.202 +
   4.203 +.S "Make each program do one thing well.
   4.204 +.LP
   4.205 +foo
   4.206 +
   4.207 +
   4.208 +.S "Build a prototype as soon as possible.
   4.209 +.LP
   4.210 +foo
   4.211 +
   4.212 +
   4.213 +.S "Choose portability over efficiency.
   4.214 +.LP
   4.215 +foo
   4.216 +
   4.217 +
   4.218 +.S "Store data in flat text files.
   4.219 +.LP
   4.220 +foo
   4.221 +
   4.222 +
   4.223 +.S "Use software leverage to your advantage.
   4.224 +.LP
   4.225 +foo
   4.226 +
   4.227 +
   4.228 +.S "Use shell scripts to increase leverage and portability.
   4.229 +.LP
   4.230 +foo
   4.231 +
   4.232 +
   4.233 +.S "Avoid captive user interfaces.
   4.234 +.LP
   4.235 +foo
   4.236 +
   4.237 +
   4.238 +.S "Make every program a filter.
   4.239 +.LP
   4.240 +foo
   4.241 +
   4.242 +
   4.243 +
   4.244 +
   4.245 +
   4.246 +.P "real world examples
   4.247 +
   4.248 +
   4.249 +.S "various
   4.250 +.LP
   4.251 +who uses
   4.252 +.CW "grep -R
   4.253 +?
   4.254 +
   4.255 +.sp 1
   4.256 +.LP
   4.257 +.CW "cat -v
   4.258 +
   4.259 +.sp 1
   4.260 +.LP
   4.261 +pagers are taken for granted
   4.262 +
   4.263 +.sp 1
   4.264 +.LP
   4.265 +what about the readline?
   4.266 +
   4.267 +
   4.268 +
   4.269 +.S "find -printf
   4.270 +.LP
   4.271 +How to reformat the output of find(1) to have ``FILENAME PATH''
   4.272 +instead of ``PATH/FILENAME''?
   4.273 +
   4.274 +.LP
   4.275 +the ``easy'' way:
   4.276 +\f(CWfind /dir -printf "%P %h\en"\fP
   4.277 +
   4.278 +.LP
   4.279 +the ``good'' way:
   4.280 +.br
   4.281 +.CW "\s-1find /dir | sed 's,\e(.*\e)/\e(.*\e),\e2 \e1,'
   4.282 +
   4.283 +.LP
   4.284 +The difference shows off when one wants, for instance,
   4.285 +the path to be manipulated further.
   4.286 +
   4.287 +
   4.288 +.S "MH / nmh
   4.289 +.LP
   4.290 +a Mail User Agent (MUA)
   4.291 +
   4.292 +
   4.293 +.S "uzbl
   4.294 +.LP
   4.295 +a web browser that adheres to the Unix Phil
   4.296 +
   4.297 +
   4.298 +
   4.299 +
   4.300 +
   4.301 +.P "more than software dev guidelines
   4.302 +
   4.303 +
   4.304 +
   4.305 +
   4.306 +
   4.307 +.P "literature
   4.308 +
   4.309 +
   4.310 +.S literature
   4.311 +.I
   4.312 +``\fBText Processing and Typesetting with Unix\fP''
   4.313 +by Barron and Rees
   4.314 +explains everything pretty good (focus on
   4.315 +.CW nroff )
   4.316 +.I
   4.317 +``\fBHeirloom Documentation Tools Nroff/Troff User's Manual\fP''
   4.318 +by Ossanna, Kernighan, and Ritter
   4.319 +is more a technical reference
   4.320 +.I
   4.321 +Various documents collected on
   4.322 +.CW \s-2http://troff.org\s+2
   4.323 +
   4.324 +
   4.325 +.S
   4.326 +.LP
   4.327 +this talk was prepared using tools of the Heirloom project:
   4.328 +.CW \s-2http://heirloom.sf.net\s+2
   4.329 +.LP
   4.330 +the slides macros are based on
   4.331 +.br
   4.332 +.CW \s-2http://repo.cat-v.org/troff-slider/\s+2
   4.333 +.sp
   4.334 +
   4.335 +.LP
   4.336 +the slides are available on my website
   4.337 +.CW \s-2http://marmaro.de/docs\s+2
   4.338 +and on
   4.339 +.CW \s-2http://ulm.ccc.de/ChaosSeminar/\s+2
   4.340 +.sp
   4.341 +
   4.342 +2010-03-08