docs/unix-phil
changeset 0:cecef8bfa812
early version, mainly the outline
author | meillo@marmaro.de |
---|---|
date | Fri, 05 Feb 2010 11:09:35 +0100 (2010-02-05) |
parents | |
children | 9b555c009f19 |
files | makefile unix-phil.ms |
diffstat | 2 files changed, 198 insertions(+), 0 deletions(-) [+] |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/makefile Fri Feb 05 11:09:35 2010 +0100 1.3 @@ -0,0 +1,7 @@ 1.4 +all: unix-phil.ps unix-phil.txt 1.5 + 1.6 +unix-phil.ps: unix-phil.ms 1.7 + sh -c "`doctype unix-phil.ms`" >unix-phil.ps 1.8 + 1.9 +unix-phil.txt: unix-phil.ms 1.10 + sh -c "`doctype -n unix-phil.ms`" >unix-phil.txt
2.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 2.2 +++ b/unix-phil.ms Fri Feb 05 11:09:35 2010 +0100 2.3 @@ -0,0 +1,191 @@ 2.4 +.if n .pl 1000i 2.5 +.de XX 2.6 +.pl 1v 2.7 +.. 2.8 +.em XX 2.9 +.nr PI 0 2.10 +.if t .nr PD .5v 2.11 +.if n .nr PD 1v 2.12 +.nr lu 0 2.13 +.de CW 2.14 +.nr PQ \\n(.f 2.15 +.if t .ft CW 2.16 +.ie \\$1 .if n .ul 999 2.17 +.el .if n .ul 1 2.18 +.if t .if !\\$1 \&\\$1\f\\n(PQ\\$2 2.19 +.if n .if \\n(.$=1 \&\\$1 2.20 +.if n .if \\n(.$>1 \&\\$1\c 2.21 +.if n .if \\n(.$>1 \&\\$2 2.22 +.. 2.23 +.ds [. \ [ 2.24 +.ds .] ] 2.25 +.TL 2.26 +Why the Unix Philosophy matters 2.27 +.AU 2.28 +markus schnalke <meillo@marmaro.de> 2.29 +.\" .AI 2.30 +.\" .ce 0 2.31 +.\" .fi 2.32 +.\" Der Autor liebt Unix und dessen Skripting-Möglichkeiten. 2.33 +.\" So auch den Shebang-Mechanismus der die Ausführung von Skripten deutlich erleichtert. 2.34 +.AB 2.35 +This term paper discusses the importance of the Unix Philosophy in software design. 2.36 +Today, few software designers are aware of these concepts, 2.37 +and thus most modern software is limited and does not use software leverage. 2.38 +Knowing and following the tenets of the Unix Philosophy makes software more valuable. 2.39 +.AE 2.40 + 2.41 +.2C 2.42 +.NH 1 2.43 +Introduction 2.44 +.LP 2.45 +Building a software is a process from an idea of the purpose of the software 2.46 +to the finished program. 2.47 +No matter \fIhow\fP the process is run, two things are common: 2.48 +the initial idea and the release. 2.49 +But the the process inbetween can be of any shape. 2.50 +The time of release and the maintainance work after the release are ignored here, for the moment. 2.51 +.LP 2.52 +The process of building splits mainly in two parts: 2.53 +the planning of what and how to build, and implementing the plan by writing code. 2.54 +This paper focuses on the planning \(en the design \(en of software. 2.55 +The here discussed ideas may be applied to any development process. 2.56 +Though the Unix Philosphy does recommend how the software development process should look like, 2.57 +this shall not be of matter here. 2.58 +Similar, the question of how to write the code is out of focus. 2.59 +.LP 2.60 + 2.61 + 2.62 + 2.63 + 2.64 + 2.65 +.[ 2.66 +%O .CW http://en.wikipedia.org/wiki/Unix_philosophy 2.67 +.] 2.68 + 2.69 +.NH 1 2.70 +Importance of software design 2.71 +.LP 2.72 +why design at all 2.73 + 2.74 +- for dev mainly: extendability and maintainability 2.75 + 2.76 +- for users: usability and flexibility (but you need to learn how to use it) 2.77 + 2.78 +no design and bad design limit the use of software 2.79 + 2.80 +.NH 2 2.81 +Architecture 2.82 +.LP 2.83 +the most important design decision. 2.84 + 2.85 +the topic here 2.86 + 2.87 +.NH 1 2.88 +The Unix Philosophy 2.89 + 2.90 +.NH 2 2.91 +what it is 2.92 +.LP 2.93 +definitions by McIlroy, Gancarz, ESR (maybe already in the intro) 2.94 +.LP 2.95 +cf. unix tool chain 2.96 +.LP 2.97 +enabler pipe 2.98 + 2.99 +.NH 2 2.100 +Interface architecture 2.101 +.LP 2.102 +standalone vs. tool chain 2.103 +.LP 2.104 +software leverage 2.105 +.LP 2.106 +possiblities 2.107 + 2.108 +.NH 2 2.109 +Results 2.110 +.LP 2.111 +The unix phil is an answer to the sw design question 2.112 +.LP 2.113 +tool chains empower the uses of sw 2.114 + 2.115 +.NH 1 2.116 +Case study: nmh 2.117 + 2.118 +.NH 2 2.119 +History 2.120 +.LP 2.121 +MH, nmh. 2.122 +They are old. 2.123 + 2.124 +.NH 2 2.125 +Contrasts to similar sw 2.126 +.LP 2.127 +vs. Thunderbird, mutt, mailx, pine 2.128 +.LP 2.129 +flexibility, no redundancy, use the shell 2.130 + 2.131 +.NH 2 2.132 +Gains of the design 2.133 +.LP 2.134 + 2.135 +.NH 2 2.136 +Problems 2.137 +.LP 2.138 + 2.139 +.NH 1 2.140 +Case study: uzbl 2.141 + 2.142 +.NH 2 2.143 +History 2.144 +.LP 2.145 +uzbl is young 2.146 + 2.147 +.NH 2 2.148 +Contrasts to similar sw 2.149 +.LP 2.150 +like with nmh 2.151 +.LP 2.152 +addons, plugins, modules 2.153 + 2.154 +.NH 2 2.155 +Gains of the design 2.156 +.LP 2.157 + 2.158 +.NH 2 2.159 +Problems 2.160 +.LP 2.161 +broken web 2.162 + 2.163 +.NH 1 2.164 +Final thoughts 2.165 + 2.166 +.NH 2 2.167 +Quick summary 2.168 +.LP 2.169 +good design 2.170 +.LP 2.171 +unix phil 2.172 +.LP 2.173 +case studies 2.174 + 2.175 +.NH 2 2.176 +Why people should choose 2.177 +.LP 2.178 +Make the right choice! 2.179 + 2.180 +.nr PI .5i 2.181 +.rm ]< 2.182 +.de ]< 2.183 +.LP 2.184 +.de FP 2.185 +.IP \\\\$1. 2.186 +\\.. 2.187 +.rm FS FE 2.188 +.. 2.189 +.SH 2.190 +References 2.191 +.[ 2.192 +$LIST$ 2.193 +.] 2.194 +.wh -1p