Hex Artifact Content
Not logged in

Artifact 43d9521e941bcd9d3e44901e04f2672e6eaf405c:

Wiki page [Experiment: mmmv_silkexec] by martin_vahi on 2017-03-19 20:05:49.
0000: 44 20 32 30 31 37 2d 30 33 2d 31 39 54 32 30 3a  D 2017-03-19T20:
0010: 30 35 3a 34 39 2e 34 30 31 0a 4c 20 45 78 70 65  05:49.401.L Expe
0020: 72 69 6d 65 6e 74 3a 5c 73 6d 6d 6d 76 5f 73 69  riment:\smmmv_si
0030: 6c 6b 65 78 65 63 0a 50 20 31 65 66 35 37 34 34  lkexec.P 1ef5744
0040: 62 33 65 65 62 31 32 33 39 66 63 35 30 30 39 30  b3eeb1239fc50090
0050: 37 30 66 64 31 61 30 38 64 32 63 63 36 66 31 39  70fd1a08d2cc6f19
0060: 36 0a 55 20 6d 61 72 74 69 6e 5f 76 61 68 69 0a  6.U martin_vahi.
0070: 57 20 31 38 32 35 39 0a 3c 70 3e 3c 62 72 3e 0a  W 18259.<p><br>.
0080: 3c 2f 70 3e 0a 0a 3c 68 31 3e 44 65 70 72 65 63  </p>..<h1>Deprec
0090: 61 74 65 64 20 56 65 72 73 69 6f 6e 73 20 6f 66  ated Versions of
00a0: 20 74 68 69 73 20 53 70 65 63 69 66 69 63 61 74   this Specificat
00b0: 69 6f 6e 3c 2f 68 31 3e 0a 0a 3c 70 3e 3c 2f 70  ion</h1>..<p></p
00c0: 3e 0a 3c 75 6c 3e 0a 3c 6c 69 3e 3c 61 20 68 72  >.<ul>.<li><a hr
00d0: 65 66 3d 22 2e 2f 77 69 6b 69 3f 6e 61 6d 65 3d  ef="./wiki?name=
00e0: 45 78 70 65 72 69 6d 65 6e 74 3a 2b 6d 6d 6d 76  Experiment:+mmmv
00f0: 5f 73 69 6c 6b 65 78 65 63 3a 2b 44 65 70 72 65  _silkexec:+Depre
0100: 63 61 74 65 64 2b 56 65 72 73 69 6f 6e 2b 31 22  cated+Version+1"
0110: 3e 44 65 70 72 65 63 61 74 65 64 0a 56 65 72 73  >Deprecated.Vers
0120: 69 6f 6e 20 31 3c 2f 61 3e 2c 20 77 68 69 63 68  ion 1</a>, which
0130: 20 69 73 20 63 6f 6d 70 6c 65 74 65 2c 20 62 75   is complete, bu
0140: 74 20 66 6c 61 77 65 64 2e 26 6e 62 73 70 3b 3c  t flawed.&nbsp;<
0150: 2f 6c 69 3e 0a 3c 2f 75 6c 3e 0a 0a 3c 70 3e 3c  /li>.</ul>..<p><
0160: 2f 70 3e 0a 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70  /p>..<p><br>.</p
0170: 3e 0a 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a  >..<p><br>.</p>.
0180: 0a 3c 68 31 3e 54 68 65 20 43 75 72 72 65 6e 74  .<h1>The Current
0190: 20 61 6e 64 20 3c 66 6f 6e 74 20 63 6f 6c 6f 72   and <font color
01a0: 3d 22 23 66 66 30 30 30 30 22 3e 49 6e 63 6f 6d  ="#ff0000">Incom
01b0: 70 6c 65 74 65 3c 2f 66 6f 6e 74 3e 20 56 65 72  plete</font> Ver
01c0: 73 69 6f 6e 20 6f 66 20 74 68 69 73 0a 53 70 65  sion of this.Spe
01d0: 63 69 66 69 63 61 74 69 6f 6e 3c 2f 68 31 3e 0a  cification</h1>.
01e0: 0a 3c 70 3e 3c 66 6f 6e 74 20 63 6f 6c 6f 72 3d  .<p><font color=
01f0: 22 23 66 66 30 30 30 30 22 3e 43 75 72 72 65 6e  "#ff0000">Curren
0200: 74 6c 79 20 63 6f 64 65 20 66 6f 72 20 74 68 65  tly code for the
0210: 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 20 64   mmmv_silkexec d
0220: 6f 65 73 20 6e 6f 74 20 65 78 69 73 74 2e 0a 54  oes not exist..T
0230: 68 65 20 66 6c 61 77 73 20 74 68 61 74 20 74 68  he flaws that th
0240: 65 20 63 75 72 72 65 6e 74 20 76 65 72 73 69 6f  e current versio
0250: 6e 20 6d 75 73 74 20 65 6c 69 6d 69 6e 61 74 65  n must eliminate
0260: 20 61 72 65 20 64 65 73 63 72 69 62 65 64 20 61   are described a
0270: 74 20 74 68 65 20 70 61 67 65 20 6f 66 0a 74 68  t the page of.th
0280: 65 20 3c 61 20 68 72 65 66 3d 22 2e 2f 77 69 6b  e <a href="./wik
0290: 69 3f 6e 61 6d 65 3d 45 78 70 65 72 69 6d 65 6e  i?name=Experimen
02a0: 74 3a 2b 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63  t:+mmmv_silkexec
02b0: 3a 2b 44 65 70 72 65 63 61 74 65 64 2b 56 65 72  :+Deprecated+Ver
02c0: 73 69 6f 6e 2b 31 22 3e 6d 6f 73 74 0a 63 75 72  sion+1">most.cur
02d0: 72 65 6e 74 20 64 65 70 72 65 63 61 74 65 64 20  rent deprecated 
02e0: 76 65 72 73 69 6f 6e 3c 2f 61 3e 2e 3c 2f 66 6f  version</a>.</fo
02f0: 6e 74 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a 3c 70  nt><br>.</p>..<p
0300: 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 41  ><br>.</p>..<p>A
0310: 20 3c 62 3e 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65   <b>mmmv_silkexe
0320: 63 20 61 70 70 6c 69 63 61 74 69 6f 6e 20 28 68  c application (h
0330: 65 72 65 61 66 74 65 72 3a 20 73 69 6c 6b 65 78  ereafter: silkex
0340: 61 70 70 29 20 69 73 20 77 72 61 70 70 65 72 20  app) is wrapper 
0350: 74 6f 20 6f 74 68 65 72 0a 61 70 70 6c 69 63 61  to other.applica
0360: 74 69 6f 6e 73 3c 2f 62 3e 2c 20 69 6e 63 6c 75  tions</b>, inclu
0370: 64 69 6e 67 20 6f 74 68 65 72 20 6d 6d 6d 76 5f  ding other mmmv_
0380: 73 69 6c 6b 65 78 65 63 20 61 70 70 6c 69 63 61  silkexec applica
0390: 74 69 6f 6e 73 2e 20 3c 62 3e 54 68 65 20 70 75  tions. <b>The pu
03a0: 72 70 6f 73 65 20 6f 66 0a 74 68 65 20 77 72 61  rpose of.the wra
03b0: 70 70 69 6e 67 20 69 73 20 74 6f 20 75 73 65 20  pping is to use 
03c0: 65 78 74 72 61 20 74 61 67 73 20 61 6e 64 20 75  extra tags and u
03d0: 73 65 72 20 73 70 65 63 69 66 69 63 20 63 6f 6e  ser specific con
03e0: 66 69 67 75 72 61 74 69 6f 6e 20 70 61 72 61 6d  figuration param
03f0: 65 74 65 72 73 3c 2f 62 3e 0a 66 6f 72 20 75 73  eters</b>.for us
0400: 69 6e 67 20 74 68 65 20 77 72 61 70 70 61 62 6c  ing the wrappabl
0410: 65 20 61 70 70 6c 69 63 61 74 69 6f 6e 2e 3c 2f  e application.</
0420: 70 3e 0a 0a 3c 70 3e 54 68 65 20 6d 6d 6d 76 5f  p>..<p>The mmmv_
0430: 73 69 6c 6b 65 78 65 63 20 70 72 6f 6a 65 63 74  silkexec project
0440: 20 63 6f 6e 73 69 73 74 73 20 6f 66 20 74 68 65   consists of the
0450: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 6f 6f 6c 73   following tools
0460: 3a 3c 2f 70 3e 0a 0a 3c 70 3e 3c 2f 70 3e 0a 3c  :</p>..<p></p>.<
0470: 75 6c 3e 0a 3c 6c 69 3e 54 68 65 20 6d 6d 6d 76  ul>.<li>The mmmv
0480: 5f 73 69 6c 6b 65 78 65 63 20 63 6f 6d 6d 61 6e  _silkexec comman
0490: 64 20 6c 69 6e 65 20 74 6f 6f 6c 20 66 6f 72 20  d line tool for 
04a0: 65 78 65 63 75 74 69 6e 67 20 73 69 6c 6b 65 78  executing silkex
04b0: 61 70 70 73 20 62 79 0a 61 75 74 6f 6d 61 74 69  apps by.automati
04c0: 63 61 6c 6c 79 20 70 72 65 66 69 78 69 6e 67 20  cally prefixing 
04d0: 74 68 65 20 50 41 54 48 20 77 69 74 68 20 61 20  the PATH with a 
04e0: 73 69 6c 6b 65 78 61 70 70 20 73 70 65 63 69 66  silkexapp specif
04f0: 69 63 20 50 41 54 48 20 76 61 6c 75 65 2e 20 43  ic PATH value. C
0500: 61 6c 6c 0a 73 79 6e 74 61 78 3a 20 26 6e 62 73  all.syntax: &nbs
0510: 70 3b 3c 2f 6c 69 3e 0a 3c 2f 75 6c 3e 0a 0a 3c  p;</li>.</ul>..<
0520: 62 6c 6f 63 6b 71 75 6f 74 65 3e 6d 6d 6d 76 5f  blockquote>mmmv_
0530: 73 69 6c 6b 65 78 65 63 20 26 6c 74 3b 66 75 6c  silkexec &lt;ful
0540: 6c 20 70 61 74 68 20 6f 66 20 6f 72 20 61 20 6e  l path of or a n
0550: 61 6d 65 20 6f 6e 20 74 68 65 20 50 41 54 48 26  ame on the PATH&
0560: 67 74 3b 20 26 6c 74 3b 74 68 65 0a 63 6f 6d 6d  gt; &lt;the.comm
0570: 61 6e 64 20 6c 69 6e 65 20 61 72 67 73 20 6f 66  and line args of
0580: 20 74 68 65 20 73 69 6c 6b 65 78 61 70 70 26 67   the silkexapp&g
0590: 74 3b 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a  t;</blockquote>.
05a0: 0a 3c 64 69 76 3e 3c 62 72 3e 0a 3c 2f 64 69 76  .<div><br>.</div
05b0: 3e 0a 3c 75 6c 3e 0a 3c 6c 69 3e 41 6e 20 61 70  >.<ul>.<li>An ap
05c0: 70 6c 69 63 61 74 69 6f 6e 20 66 6f 72 20 6d 61  plication for ma
05d0: 69 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 74 61  intaining the ta
05e0: 67 73 2c 20 66 6f 72 20 65 78 61 6d 70 6c 65 2c  gs, for example,
05f0: 20 74 65 73 74 65 72 20 73 70 65 63 69 66 69 63   tester specific
0600: 20 74 65 73 74 0a 72 65 73 75 6c 74 73 2e 3c 2f   test.results.</
0610: 6c 69 3e 0a 3c 6c 69 3e 41 6e 20 61 70 70 6c 69  li>.<li>An appli
0620: 63 61 74 69 6f 6e 20 66 6f 72 20 6d 61 69 6e 74  cation for maint
0630: 61 69 6e 69 6e 67 20 6d 6d 6d 76 5f 73 69 6c 6b  aining mmmv_silk
0640: 65 78 65 63 20 6c 6f 63 61 6c 20 69 6e 73 74 61  exec local insta
0650: 6c 6c 61 74 69 6f 6e 20 73 70 65 63 69 66 69 63  llation specific
0660: 0a 67 6c 6f 62 61 6c 20 63 6f 6e 66 69 67 75 72  .global configur
0670: 61 74 69 6f 6e 20 61 6e 64 20 74 68 65 20 63 6f  ation and the co
0680: 6c 6c 65 63 74 69 6f 6e 20 6f 66 20 73 69 6c 6b  llection of silk
0690: 65 78 61 70 70 73 2e 3c 62 72 3e 0a 3c 2f 6c 69  exapps.<br>.</li
06a0: 3e 0a 3c 2f 75 6c 3e 0a 0a 3c 70 3e 3c 2f 70 3e  >.</ul>..<p></p>
06b0: 0a 0a 3c 70 3e 4e 6f 20 74 65 63 68 6e 69 63 61  ..<p>No technica
06c0: 6c 20 73 6f 6c 75 74 69 6f 6e 20 69 73 20 67 6f  l solution is go
06d0: 69 6e 67 20 74 6f 20 63 6f 6d 70 65 6e 73 61 74  ing to compensat
06e0: 65 20 66 6f 72 20 63 72 61 70 70 79 20 77 6f 72  e for crappy wor
06f0: 6b 2c 20 62 65 63 61 75 73 65 0a 74 65 63 68 6e  k, because.techn
0700: 69 63 61 6c 20 74 6f 6f 6c 73 20 63 61 6e 20 62  ical tools can b
0710: 65 20 73 77 69 74 63 68 65 64 20 6f 66 66 20 6f  e switched off o
0720: 72 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 61  r the original a
0730: 75 74 68 6f 72 73 20 6f 66 20 73 6f 66 74 77 61  uthors of softwa
0740: 72 65 20 6d 61 79 0a 6c 65 61 76 65 20 65 64 67  re may.leave edg
0750: 65 20 63 61 73 65 73 20 6f 75 74 20 6f 66 20 63  e cases out of c
0760: 6f 6e 73 69 64 65 72 61 74 69 6f 6e 2e 20 54 68  onsideration. Th
0770: 65 20 6d 61 69 6e 20 69 64 65 61 73 20 62 65 68  e main ideas beh
0780: 69 6e 64 20 74 68 65 20 6d 6d 6d 76 5f 73 69 6c  ind the mmmv_sil
0790: 6b 65 78 65 63 0a 61 72 65 3c 62 3e 26 6e 62 73  kexec.are<b>&nbs
07a0: 70 3b 3c 2f 62 3e 74 6f 20 3c 62 3e 61 6c 6c 6f  p;</b>to <b>allo
07b0: 77 20 74 68 65 20 65 78 65 63 75 74 69 6f 6e 20  w the execution 
07c0: 6f 66 20 6f 6e 6c 79 20 74 68 6f 73 65 20 73 69  of only those si
07d0: 6c 6b 65 78 61 70 70 73 20 74 68 61 74 20 68 61  lkexapps that ha
07e0: 76 65 0a 62 65 65 6e 20 74 65 73 74 65 64 20 61  ve.been tested a
07f0: 6e 64 2f 6f 72 20 76 65 72 69 66 69 65 64 20 62  nd/or verified b
0800: 79 20 74 72 75 73 74 65 64 20 70 61 72 74 69 65  y trusted partie
0810: 73 3c 2f 62 3e 2c 20 74 68 65 0a 3c 61 20 68 72  s</b>, the.<a hr
0820: 65 66 3d 22 68 74 74 70 73 3a 2f 2f 6e 69 78 6f  ef="https://nixo
0830: 73 2e 6f 72 67 2f 6e 69 78 2f 22 3e 4e 69 78 4f  s.org/nix/">NixO
0840: 53 20 70 61 63 6b 61 67 65 20 6d 61 6e 61 67 65  S package manage
0850: 72 3c 2f 61 3e 20 69 64 65 61 20 74 68 61 74 20  r</a> idea that 
0860: 65 61 63 68 0a 61 70 70 6c 69 63 61 74 69 6f 6e  each.application
0870: 20 69 73 20 65 78 65 63 75 74 65 64 20 69 6e 20   is executed in 
0880: 61 6e 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 2c 20  an environment, 
0890: 77 68 65 72 65 20 3c 62 3e 74 68 65 20 4c 44 5f  where <b>the LD_
08a0: 4c 49 42 52 41 52 59 5f 50 41 54 48 20 61 6e 64  LIBRARY_PATH and
08b0: 20 74 68 65 0a 50 41 54 48 20 68 61 76 65 20 73   the.PATH have s
08c0: 69 6c 6b 65 78 61 70 70 20 73 70 65 63 69 66 69  ilkexapp specifi
08d0: 63 20 70 72 65 66 69 78 65 73 3c 2f 62 3e 2c 20  c prefixes</b>, 
08e0: 74 68 65 20 72 65 6c 69 61 6e 63 65 20 6f 6e 20  the reliance on 
08f0: 6f 70 65 72 61 74 69 6e 67 20 73 79 73 74 65 6d  operating system
0900: 0a 73 65 72 76 69 63 65 73 20 69 73 26 6e 62 73  .services is&nbs
0910: 70 3b 3c 62 3e 6c 69 6d 69 74 65 64 20 74 6f 20  p;<b>limited to 
0920: 74 68 65 20 55 4e 49 58 20 73 74 61 6e 64 61 72  the UNIX standar
0930: 64 3c 2f 62 3e 20 74 6f 20 67 69 76 65 20 74 68  d</b> to give th
0940: 65 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 0a  e mmmv_silkexec.
0950: 61 20 63 68 61 6e 63 65 20 74 6f 20 62 65 20 70  a chance to be p
0960: 6f 72 74 65 64 20 74 6f 20 61 6c 6c 20 6f 70 65  orted to all ope
0970: 72 61 74 69 6e 67 20 73 79 73 74 65 6d 73 20 74  rating systems t
0980: 68 61 74 20 68 61 76 65 20 74 68 65 20 55 4e 49  hat have the UNI
0990: 58 20 6c 61 79 65 72 20 3c 69 3e 28 4c 69 6e 75  X layer <i>(Linu
09a0: 78 2c 0a 42 53 44 2c 20 47 4e 55 20 48 75 72 64  x,.BSD, GNU Hurd
09b0: 2c 20 47 65 6e 6f 64 65 20 4f 53 2c 20 4d 69 6e  , Genode OS, Min
09c0: 69 78 33 29 2c 3c 2f 69 3e 20 74 68 65 26 6e 62  ix3),</i> the&nb
09d0: 73 70 3b 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63  sp;mmmv_silkexec
09e0: 20 6d 75 73 74 20 62 65 20 66 75 6c 6c 79 20 3c   must be fully <
09f0: 62 3e 75 73 61 62 6c 65 0a 77 69 74 68 6f 75 74  b>usable.without
0a00: 20 68 61 76 69 6e 67 20 61 6e 79 20 72 6f 6f 74   having any root
0a10: 20 61 63 63 65 73 73 3c 2f 62 3e 2e 3c 2f 70 3e   access</b>.</p>
0a20: 0a 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a  ..<p><br>.</p>..
0a30: 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a 3c 68  <p><br>.</p>..<h
0a40: 31 3e 53 69 6c 6b 65 78 61 70 70 20 46 6f 72 6d  1>Silkexapp Form
0a50: 61 74 3c 2f 68 31 3e 0a 0a 3c 70 3e 4e 6f 6e 65  at</h1>..<p>None
0a60: 20 6f 66 20 74 68 65 20 73 69 6c 6b 65 78 61 70   of the silkexap
0a70: 70 20 73 74 61 6e 64 61 72 64 20 66 69 6c 65 20  p standard file 
0a80: 61 6e 64 20 66 6f 6c 64 65 72 20 6e 61 6d 65 73  and folder names
0a90: 20 63 6f 6e 74 61 69 6e 20 61 6e 79 20 73 70 61   contain any spa
0aa0: 63 65 73 2c 0a 74 61 62 75 6c 61 74 69 6f 6e 20  ces,.tabulation 
0ab0: 63 68 61 72 61 63 74 65 72 73 2c 20 6c 69 6e 65  characters, line
0ac0: 20 62 72 65 61 6b 73 2e 20 41 6c 6c 20 73 69 6c   breaks. All sil
0ad0: 6b 65 78 61 70 70 20 63 6f 6e 66 69 67 75 72 61  kexapp configura
0ae0: 74 69 6f 6e 20 74 65 78 74 20 66 69 6c 65 73 2c  tion text files,
0af0: 20 74 68 65 0a 6f 6e 65 73 20 61 74 20 74 68 65   the.ones at the
0b00: 20 73 69 6c 6b 65 78 61 70 70 20 65 74 63 20 66   silkexapp etc f
0b10: 6f 6c 64 65 72 2c 20 61 72 65 20 70 72 65 70 72  older, are prepr
0b20: 6f 63 65 73 73 65 64 20 62 79 20 72 65 6d 6f 76  ocessed by remov
0b30: 69 6e 67 20 61 6c 6c 20 73 70 61 63 65 73 2c 0a  ing all spaces,.
0b40: 74 61 62 75 6c 61 74 69 6f 6e 20 63 68 61 72 61  tabulation chara
0b50: 63 74 65 72 73 2c 20 3c 62 3e 73 69 6e 67 6c 65  cters, <b>single
0b60: 2d 6c 69 6e 65 2d 63 6f 6d 6d 65 6e 74 73 20 74  -line-comments t
0b70: 68 61 74 20 73 74 61 72 74 20 77 69 74 68 20 65  hat start with e
0b80: 69 74 68 65 72 20 22 23 22 20 6f 72 0a 22 2f 2f  ither "#" or."//
0b90: 22 3c 2f 62 3e 2e 20 41 66 74 65 72 20 74 68 65  "</b>. After the
0ba0: 20 73 69 6e 67 6c 65 2d 6c 69 6e 65 2d 63 6f 6d   single-line-com
0bb0: 6d 65 6e 74 73 20 64 65 6c 65 74 69 6f 6e 20 70  ments deletion p
0bc0: 72 65 70 72 6f 63 65 73 73 69 6e 67 20 73 74 65  reprocessing ste
0bd0: 70 20 61 6c 6c 20 6f 66 20 74 68 65 0a 6c 69 6e  p all of the.lin
0be0: 65 62 72 65 61 6b 73 20 61 72 65 20 64 65 6c 65  ebreaks are dele
0bf0: 74 65 64 2c 20 65 78 63 65 70 74 20 66 6f 72 20  ted, except for 
0c00: 74 68 65 20 6c 69 73 74 5f 6f 66 5f 69 6d 6d 65  the list_of_imme
0c10: 64 69 61 74 65 5f 64 65 70 65 6e 64 65 6e 63 69  diate_dependenci
0c20: 65 73 2e 74 78 74 2e 3c 2f 70 3e 0a 0a 3c 70 3e  es.txt.</p>..<p>
0c30: 3c 62 72 3e 0a 3c 2f 70 3e 0a 3c 70 72 65 3e 26  <br>.</p>.<pre>&
0c40: 6c 74 3b 72 65 6c 61 74 65 69 76 65 20 49 44 20  lt;relateive ID 
0c50: 61 73 20 66 6f 6c 64 65 72 20 6e 61 6d 65 26 67  as folder name&g
0c60: 74 3b 0d 0a 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e  t;..</pre>.<pre>
0c70: 20 20 20 20 7c 3c 2f 70 72 65 3e 0a 3c 70 72 65      |</pre>.<pre
0c80: 3e 3c 70 72 65 3e 20 20 20 20 2b 2d 2d 62 69 6e  ><pre>    +--bin
0c90: 20 20 23 20 69 73 20 61 20 73 79 6d 6c 69 6e 6b    # is a symlink
0ca0: 20 74 6f 20 2e 2f 62 75 69 6c 64 2f 62 69 6e 20   to ./build/bin 
0cb0: 2e 20 54 68 65 20 73 79 6d 6c 69 6e 6b 20 67 65  . The symlink ge
0cc0: 74 73 20 63 72 65 61 74 65 64 20 62 79 3c 2f 70  ts created by</p
0cd0: 72 65 3e 3c 70 72 65 3e 3c 70 72 65 3e 20 20 20  re><pre><pre>   
0ce0: 20 7c 20 20 20 20 20 20 20 23 20 74 68 65 20 6d   |       # the m
0cf0: 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 20 61 66 74  mmv_silkexec aft
0d00: 65 72 20 74 68 65 20 62 75 69 6c 64 69 6e 67 20  er the building 
0d10: 6f 66 20 74 68 65 20 73 69 6c 6b 65 78 61 70 70  of the silkexapp
0d20: 20 68 61 73 20 73 75 63 63 65 65 64 65 64 2e 20   has succeeded. 
0d30: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
0d40: 20 20 20 20 20 20 20 23 20 54 68 65 20 6d 6d 6d         # The mmm
0d50: 76 5f 73 69 6c 6b 65 78 65 63 20 64 65 6c 65 74  v_silkexec delet
0d60: 65 73 20 74 68 69 73 20 73 79 6d 6c 69 6e 6b 20  es this symlink 
0d70: 62 65 66 6f 72 65 20 74 68 65 20 65 78 65 63 75  before the execu
0d80: 74 69 6f 6e 20 6f 66 20 74 68 65 20 62 75 69 6c  tion of the buil
0d90: 64 5f 73 63 72 69 70 74 2e 62 61 73 68 20 2e 3c  d_script.bash .<
0da0: 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20  /pre><pre>    | 
0db0: 20 20 20 20 20 20 23 20 49 66 20 74 68 65 20 62        # If the b
0dc0: 75 69 6c 64 5f 73 63 72 69 70 74 2e 62 61 73 68  uild_script.bash
0dd0: 20 65 78 69 74 65 64 20 77 69 74 68 20 61 6e 20   exited with an 
0de0: 65 72 72 6f 72 2c 20 74 68 65 20 6d 6d 6d 76 5f  error, the mmmv_
0df0: 73 69 6c 6b 65 78 65 63 20 64 6f 65 73 20 6e 6f  silkexec does no
0e00: 74 20 63 72 65 61 74 65 20 74 68 69 73 20 73 79  t create this sy
0e10: 6d 6c 69 6e 6b 2e 3c 2f 70 72 65 3e 3c 2f 70 72  mlink.</pre></pr
0e20: 65 3e 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20 20  e></pre>.<pre>  
0e30: 20 20 7c 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20    |</pre>.<pre> 
0e40: 20 20 20 2b 2d 2d 64 6f 63 20 20 23 20 69 73 20     +--doc  # is 
0e50: 61 6e 20 6f 70 74 69 6f 6e 61 6c 20 73 79 6d 6c  an optional syml
0e60: 69 6e 6b 20 74 6f 20 2e 2f 62 75 69 6c 64 2f 64  ink to ./build/d
0e70: 6f 63 20 2e 20 54 68 65 20 73 79 6d 6c 69 6e 6b  oc . The symlink
0e80: 20 67 65 74 73 20 63 72 65 61 74 65 64 20 62 79   gets created by
0e90: 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 3c 70 72 65  </pre>.<pre><pre
0ea0: 3e 20 20 20 20 7c 20 20 20 20 20 20 20 23 20 74  >    |       # t
0eb0: 68 65 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63  he mmmv_silkexec
0ec0: 20 61 66 74 65 72 20 74 68 65 20 62 75 69 6c 64   after the build
0ed0: 69 6e 67 20 6f 66 20 74 68 65 20 73 69 6c 6b 65  ing of the silke
0ee0: 78 61 70 70 20 68 61 73 20 73 75 63 63 65 65 64  xapp has succeed
0ef0: 65 64 2e 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  ed. </pre><pre> 
0f00: 20 20 20 7c 20 20 20 20 20 20 20 23 20 54 68 65     |       # The
0f10: 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 20 64   mmmv_silkexec d
0f20: 65 6c 65 74 65 73 20 74 68 69 73 20 73 79 6d 6c  eletes this syml
0f30: 69 6e 6b 20 62 65 66 6f 72 65 20 74 68 65 20 65  ink before the e
0f40: 78 65 63 75 74 69 6f 6e 20 6f 66 20 74 68 65 20  xecution of the 
0f50: 62 75 69 6c 64 5f 73 63 72 69 70 74 2e 62 61 73  build_script.bas
0f60: 68 20 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  h .</pre><pre>  
0f70: 20 20 7c 20 20 20 20 20 20 20 23 20 49 66 20 74    |       # If t
0f80: 68 65 20 62 75 69 6c 64 5f 73 63 72 69 70 74 2e  he build_script.
0f90: 62 61 73 68 20 65 78 69 74 65 64 20 77 69 74 68  bash exited with
0fa0: 20 61 6e 20 65 72 72 6f 72 2c 20 74 68 65 20 6d   an error, the m
0fb0: 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 20 64 6f 65  mmv_silkexec doe
0fc0: 73 20 6e 6f 74 20 63 72 65 61 74 65 20 74 68 69  s not create thi
0fd0: 73 20 73 79 6d 6c 69 6e 6b 2e 3c 2f 70 72 65 3e  s symlink.</pre>
0fe0: 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20 20 20 20  </pre>.<pre>    
0ff0: 7c 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20 20 20  |</pre>.<pre>   
1000: 20 2b 2d 2d 20 65 74 63 20 23 20 69 73 20 61 6e   +-- etc # is an
1010: 20 6f 70 74 69 6f 6e 61 6c 20 66 6f 6c 64 65 72   optional folder
1020: 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20 20 20 20  </pre>.<pre>    
1030: 7c 20 20 20 20 2b 2d 2d 72 75 6e 74 69 6d 65 5f  |    +--runtime_
1040: 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 23 20 69 73  environment # is
1050: 20 61 6e 20 6f 70 74 69 6f 6e 61 6c 20 66 6f 6c   an optional fol
1060: 64 65 72 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20  der</pre>.<pre> 
1070: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 3c 2f     |    |    |</
1080: 70 72 65 3e 0a 3c 70 72 65 3e 3c 70 72 65 3e 20  pre>.<pre><pre> 
1090: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 2b 2d 2d     |    |    +--
10a0: 6f 76 65 72 72 69 64 69 6e 67 5f 76 61 6c 75 65  overriding_value
10b0: 73 5f 6f 66 5f 65 6e 76 69 72 6f 6e 6d 65 6e 74  s_of_environment
10c0: 5f 76 61 72 69 61 62 6c 65 5f 76 61 6c 75 65 73  _variable_values
10d0: 20 20 20 23 20 74 68 65 20 65 78 69 73 74 65 6e     # the existen
10e0: 63 65 20 6f 66 20 74 68 69 73 20 66 6f 6c 64 65  ce of this folde
10f0: 72 20 69 73 20 6f 70 74 69 6f 6e 61 6c 3c 2f 70  r is optional</p
1100: 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20  re><pre>    |   
1110: 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20 23 20   |    |    |  # 
1120: 41 6c 6c 20 66 69 6c 65 73 20 69 6e 20 74 68 69  All files in thi
1130: 73 20 66 6f 6c 64 65 72 20 61 72 65 20 6f 70 74  s folder are opt
1140: 69 6f 6e 61 6c 2e 20 46 69 6c 65 20 6e 61 6d 65  ional. File name
1150: 73 20 77 69 74 68 6f 75 74 20 74 68 65 20 22 2e  s without the ".
1160: 74 78 74 22 20 73 75 66 66 69 78 3c 2f 70 72 65  txt" suffix</pre
1170: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
1180: 20 20 20 20 7c 20 20 20 20 7c 20 20 23 20 6d 75      |    |  # mu
1190: 73 74 20 6d 61 74 63 68 20 77 69 74 68 20 74 68  st match with th
11a0: 65 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 76 61  e environment va
11b0: 72 69 61 62 6c 65 20 6e 61 6d 65 2e 20 46 69 6c  riable name. Fil
11c0: 65 20 6e 61 6d 65 73 20 61 72 65 20 63 61 73 65  e names are case
11d0: 20 73 65 6e 73 69 74 69 76 65 2e 3c 2f 70 72 65   sensitive.</pre
11e0: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
11f0: 20 20 20 20 7c 20 20 20 20 7c 20 20 3c 2f 70 72      |    |  </pr
1200: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
1210: 7c 20 20 20 20 7c 20 20 20 20 2b 2d 2d 4c 44 5f  |    |    +--LD_
1220: 4c 49 42 52 41 52 59 5f 50 41 54 48 2e 74 78 74  LIBRARY_PATH.txt
1230: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
1240: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 2b 2d      |    |    +-
1250: 2d 50 41 54 48 2e 74 78 74 3c 2f 70 72 65 3e 3c  -PATH.txt</pre><
1260: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
1270: 20 20 7c 20 20 20 20 2b 2d 2d 43 46 4c 41 47 53    |    +--CFLAGS
1280: 2e 74 78 74 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  .txt</pre><pre> 
1290: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
12a0: 20 20 2b 2d 2d 26 6c 74 3b 6f 74 68 65 72 20 65    +--&lt;other e
12b0: 6e 76 69 72 6f 6e 6d 65 6e 74 20 76 61 72 69 61  nvironment varia
12c0: 62 6c 65 73 26 67 74 3b 3c 2f 70 72 65 3e 3c 70  bles&gt;</pre><p
12d0: 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20  re>    |    |   
12e0: 20 7c 3c 2f 70 72 65 3e 3c 2f 70 72 65 3e 0a 3c   |</pre></pre>.<
12f0: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
1300: 20 20 2b 2d 2d 70 72 65 66 69 78 65 73 5f 6f 66    +--prefixes_of
1310: 5f 65 6e 76 69 72 6f 6e 6d 65 6e 74 5f 76 61 72  _environment_var
1320: 69 61 62 6c 65 5f 76 61 6c 75 65 73 20 20 20 23  iable_values   #
1330: 20 74 68 65 20 65 78 69 73 74 65 6e 63 65 20 6f   the existence o
1340: 66 20 74 68 69 73 20 66 6f 6c 64 65 72 20 69 73  f this folder is
1350: 20 6f 70 74 69 6f 6e 61 6c 3c 2f 70 72 65 3e 0a   optional</pre>.
1360: 3c 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20  <pre><pre>    | 
1370: 20 20 20 7c 20 20 20 20 20 20 20 20 20 7c 20 20     |         |  
1380: 23 20 41 6c 6c 20 66 69 6c 65 73 20 69 6e 20 74  # All files in t
1390: 68 69 73 20 66 6f 6c 64 65 72 20 61 72 65 20 6f  his folder are o
13a0: 70 74 69 6f 6e 61 6c 2e 20 46 69 6c 65 20 6e 61  ptional. File na
13b0: 6d 65 73 20 77 69 74 68 6f 75 74 20 74 68 65 20  mes without the 
13c0: 22 2e 74 78 74 22 20 73 75 66 66 69 78 3c 2f 70  ".txt" suffix</p
13d0: 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20  re><pre>    |   
13e0: 20 7c 20 20 20 20 20 20 20 20 20 7c 20 20 23 20   |         |  # 
13f0: 6d 75 73 74 20 6d 61 74 63 68 20 77 69 74 68 20  must match with 
1400: 74 68 65 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20  the environment 
1410: 76 61 72 69 61 62 6c 65 20 6e 61 6d 65 2e 20 46  variable name. F
1420: 69 6c 65 20 6e 61 6d 65 73 20 61 72 65 20 63 61  ile names are ca
1430: 73 65 20 73 65 6e 73 69 74 69 76 65 2e 3c 2f 70  se sensitive.</p
1440: 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20  re><pre>    |   
1450: 20 7c 20 20 20 20 20 20 20 20 20 7c 20 20 3c 2f   |         |  </
1460: 70 72 65 3e 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e  pre></pre>.<pre>
1470: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20      |    |      
1480: 20 20 20 2b 2d 2d 4c 44 5f 4c 49 42 52 41 52 59     +--LD_LIBRARY
1490: 5f 50 41 54 48 2e 74 78 74 3c 2f 70 72 65 3e 0a  _PATH.txt</pre>.
14a0: 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20  <pre>    |    | 
14b0: 20 20 20 20 20 20 20 20 2b 2d 2d 50 41 54 48 2e          +--PATH.
14c0: 74 78 74 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 20  txt</pre>.<pre> 
14d0: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20     |    |       
14e0: 20 20 2b 2d 2d 43 46 4c 41 47 53 2e 74 78 74 3c    +--CFLAGS.txt<
14f0: 2f 70 72 65 3e 0a 3c 70 72 65 3e 20 20 20 20 7c  /pre>.<pre>    |
1500: 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 2b 2d      |         +-
1510: 2d 26 6c 74 3b 6f 74 68 65 72 20 65 6e 76 69 72  -&lt;other envir
1520: 6f 6e 6d 65 6e 74 20 76 61 72 69 61 62 6c 65 73  onment variables
1530: 26 67 74 3b 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e  &gt;</pre>.<pre>
1540: 20 20 20 20 7c 20 20 20 20 7c 3c 2f 70 72 65 3e      |    |</pre>
1550: 0a 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 2b  .<pre>    |    +
1560: 2d 2d 62 75 69 6c 64 74 69 6d 65 5f 65 6e 76 69  --buildtime_envi
1570: 72 6f 6e 6d 65 6e 74 20 23 20 69 73 20 61 6e 20  ronment # is an 
1580: 6f 70 74 69 6f 6e 61 6c 20 66 6f 6c 64 65 72 2e  optional folder.
1590: 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 3c 70 72 65  </pre>.<pre><pre
15a0: 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20  >    |    |     
15b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
15c0: 20 20 20 23 20 54 68 65 20 63 6f 6e 74 65 6e 74     # The content
15d0: 20 6f 66 20 74 68 69 73 20 66 6f 6c 64 65 72 20   of this folder 
15e0: 68 61 73 20 74 68 65 20 73 61 6d 65 20 66 6f 72  has the same for
15f0: 6d 61 74 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  mat</pre><pre>  
1600: 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20    |    |        
1610: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1620: 23 20 61 73 20 64 6f 65 73 20 74 68 65 20 66 6f  # as does the fo
1630: 6c 64 65 72 20 2e 2f 72 75 6e 74 69 6d 65 5f 65  lder ./runtime_e
1640: 6e 76 69 72 6f 6e 6d 65 6e 74 3c 2f 70 72 65 3e  nvironment</pre>
1650: 3c 2f 70 72 65 3e 0a 3c 70 72 65 3e 3c 70 72 65  </pre>.<pre><pre
1660: 3e 20 20 20 20 7c 20 20 20 20 7c 3c 2f 70 72 65  >    |    |</pre
1670: 3e 3c 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  ><pre><pre>    |
1680: 20 20 20 20 2b 2d 2d 6c 69 73 74 5f 6f 66 5f 69      +--list_of_i
1690: 6d 6d 65 64 69 61 74 65 5f 64 65 70 65 6e 64 65  mmediate_depende
16a0: 6e 63 69 65 73 2e 74 78 74 20 23 20 4f 70 74 69  ncies.txt # Opti
16b0: 6f 6e 61 6c 2e 20 49 66 20 65 78 69 73 74 73 2c  onal. If exists,
16c0: 20 74 68 65 6e 20 3c 2f 70 72 65 3e 3c 70 72 65   then </pre><pre
16d0: 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20  >    |    |     
16e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
16f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1700: 23 20 74 68 65 72 65 20 69 73 20 6f 6e 65 20 3c  # there is one <
1710: 61 20 68 72 65 66 3d 22 68 74 74 70 3a 2f 2f 77  a href="http://w
1720: 77 77 2e 73 6f 66 74 66 31 2e 63 6f 6d 2f 63 67  ww.softf1.com/cg
1730: 69 2d 62 69 6e 2f 74 72 65 65 31 2f 74 65 63 68  i-bin/tree1/tech
1740: 6e 6f 6c 6f 67 79 2f 66 6c 61 77 73 2f 73 69 6c  nology/flaws/sil
1750: 6b 74 6f 72 72 65 6e 74 2e 62 61 73 68 2f 77 69  ktorrent.bash/wi
1760: 6b 69 3f 6e 61 6d 65 3d 41 6c 67 6f 72 69 74 68  ki?name=Algorith
1770: 6d 2b 61 6e 64 2b 49 6d 70 6c 65 6d 65 6e 74 61  m+and+Implementa
1780: 74 69 6f 6e 22 3e 53 69 6c 6b 74 6f 72 72 65 6e  tion">Silktorren
1790: 74 20 70 61 63 6b 65 74 3c 2f 61 3e 20 6e 61 6d  t packet</a> nam
17a0: 65 20 70 65 72 20 6c 69 6e 65 2e 3c 2f 70 72 65  e per line.</pre
17b0: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
17c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
17d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
17e0: 20 20 20 20 20 23 20 41 6c 6c 20 6f 66 20 74 68       # All of th
17f0: 65 20 53 69 6c 6b 74 6f 72 72 65 6e 74 20 70 61  e Silktorrent pa
1800: 63 6b 65 74 73 20 61 72 65 20 72 65 71 75 69 72  ckets are requir
1810: 65 64 20 74 6f 20 3c 2f 70 72 65 3e 3c 70 72 65  ed to </pre><pre
1820: 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20  >    |    |     
1830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1850: 23 20 63 6f 6e 66 6f 72 6d 20 74 6f 20 74 68 65  # conform to the
1860: 20 53 69 6c 6b 65 78 61 70 70 20 66 6f 72 6d 61   Silkexapp forma
1870: 74 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  t.</pre><pre>   
1880: 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20 20   |    |         
1890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
18a0: 20 20 20 20 20 20 20 20 20 20 20 20 23 20 54 68              # Th
18b0: 65 20 6c 69 73 74 20 69 6e 63 6c 75 64 65 73 20  e list includes 
18c0: 62 75 69 6c 64 20 64 65 70 65 6e 64 65 6e 63 69  build dependenci
18d0: 65 73 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  es.</pre><pre>  
18e0: 20 20 7c 20 20 20 20 7c 3c 2f 70 72 65 3e 3c 2f    |    |</pre></
18f0: 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20  pre><pre>    |  
1900: 20 20 2b 2d 2d 6c 69 73 74 5f 6f 66 5f 61 67 67    +--list_of_agg
1910: 72 65 67 61 74 65 5f 53 69 6c 6b 74 6f 72 72 65  regate_Silktorre
1920: 6e 74 5f 70 61 63 6b 65 74 73 2e 74 78 74 20 23  nt_packets.txt #
1930: 20 4f 70 74 69 6f 6e 61 6c 2e 20 49 66 20 65 78   Optional. If ex
1940: 69 73 74 73 2c 20 74 68 65 6e 20 3c 2f 70 72 65  ists, then </pre
1950: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 20  ><pre>    |     
1960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1970: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1980: 20 20 20 20 20 20 20 20 20 20 20 20 23 20 74 68              # th
1990: 65 72 65 20 69 73 20 6f 6e 65 20 3c 61 20 68 72  ere is one <a hr
19a0: 65 66 3d 22 2e 2f 77 69 6b 69 3f 6e 61 6d 65 3d  ef="./wiki?name=
19b0: 41 6c 67 6f 72 69 74 68 6d 2b 61 6e 64 2b 49 6d  Algorithm+and+Im
19c0: 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 22 3e 53 69  plementation">Si
19d0: 6c 6b 74 6f 72 72 65 6e 74 20 70 61 63 6b 65 74  lktorrent packet
19e0: 3c 2f 61 3e 20 6e 61 6d 65 20 70 65 72 20 6c 69  </a> name per li
19f0: 6e 65 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  ne.</pre><pre>  
1a00: 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20    |             
1a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a30: 20 20 20 20 23 20 46 72 6f 6d 20 74 68 65 20 70      # From the p
1a40: 6f 69 6e 74 20 6f 66 20 76 69 65 77 20 6f 66 20  oint of view of 
1a50: 74 68 69 73 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78  this mmmv_silkex
1a60: 65 63 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  ec</pre><pre>   
1a70: 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20 20   |              
1a80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1aa0: 20 20 20 23 20 73 70 65 63 69 66 69 63 61 74 69     # specificati
1ab0: 6f 6e 20 74 68 65 20 63 6f 6e 74 65 6e 74 20 6f  on the content o
1ac0: 66 20 74 68 6f 73 65 20 53 69 6c 6b 74 6f 72 72  f those Silktorr
1ad0: 65 6e 74 20 70 61 63 6b 65 74 73 3c 2f 70 72 65  ent packets</pre
1ae0: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 20  ><pre>    |     
1af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1b00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1b10: 20 20 20 20 20 20 20 20 20 20 20 20 23 20 69 73              # is
1b20: 20 6e 6f 74 20 64 65 74 65 72 6d 69 6e 65 64 2e   not determined.
1b30: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
1b40: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 2b  </pre><pre>    +
1b50: 2d 2d 73 72 63 20 23 20 41 66 74 65 72 20 75 6e  --src # After un
1b60: 70 61 63 6b 69 6e 67 20 69 74 20 69 73 20 72 65  packing it is re
1b70: 63 75 72 73 69 76 65 6c 79 20 73 65 74 20 74 6f  cursively set to
1b80: 20 66 69 6c 65 20 70 65 72 6d 69 73 73 69 6f 6e   file permission
1b90: 73 20 30 34 41 42 2c 20 3c 2f 70 72 65 3e 3c 70  s 04AB, </pre><p
1ba0: 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 23 20  re>    |    | # 
1bb0: 77 68 65 72 65 20 41 2c 42 20 69 6e 53 65 74 7b  where A,B inSet{
1bc0: 34 2c 30 7d 20 61 6e 64 20 65 61 63 68 20 6f 66  4,0} and each of
1bd0: 20 74 68 65 6d 2c 20 74 68 65 20 41 20 61 6e 64   them, the A and
1be0: 20 74 68 65 20 42 2c 20 69 73 20 3c 2f 70 72 65   the B, is </pre
1bf0: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
1c00: 20 23 20 64 65 74 65 72 6d 69 6e 65 64 20 62 79   # determined by
1c10: 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 20 73   mmmv_silkexec s
1c20: 65 74 74 69 6e 67 73 2c 20 77 68 69 63 68 20 61  ettings, which a
1c30: 72 65 20 6d 61 6e 69 70 75 6c 61 74 65 64 20 62  re manipulated b
1c40: 79 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  y </pre><pre>   
1c50: 20 7c 20 20 20 20 7c 20 23 20 6d 6d 6d 76 5f 73   |    | # mmmv_s
1c60: 69 6c 6b 65 78 65 63 20 73 79 73 2d 63 6f 6d 6d  ilkexec sys-comm
1c70: 61 6e 64 73 2e 20 45 76 65 72 79 74 68 69 6e 67  ands. Everything
1c80: 20 69 6e 20 74 68 65 20 74 68 69 73 20 66 6f 6c   in the this fol
1c90: 64 65 72 2c 20 74 68 65 20 73 72 63 2c 3c 2f 70  der, the src,</p
1ca0: 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20  re><pre>    |   
1cb0: 20 7c 20 23 20 69 73 20 61 75 74 6f 6d 61 74 69   | # is automati
1cc0: 63 61 6c 6c 79 20 63 6f 70 69 65 64 20 74 6f 20  cally copied to 
1cd0: 74 68 65 20 62 75 69 6c 64 20 66 6f 6c 64 65 72  the build folder
1ce0: 20 62 65 66 6f 72 65 20 62 75 69 6c 64 69 6e 67   before building
1cf0: 2e 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  . </pre><pre>   
1d00: 20 7c 20 20 20 20 7c 3c 2f 70 72 65 3e 3c 70 72   |    |</pre><pr
1d10: 65 3e 20 20 20 20 7c 20 20 20 20 2b 2d 2d 73 69  e>    |    +--si
1d20: 6c 6b 65 78 61 70 70 5f 63 6f 6e 74 72 6f 6c 3c  lkexapp_control<
1d30: 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20  /pre><pre>    | 
1d40: 20 20 20 7c 20 20 20 20 7c 3c 2f 70 72 65 3e 3c     |    |</pre><
1d50: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
1d60: 20 20 2b 2d 2d 62 75 69 6c 64 5f 73 63 72 69 70    +--build_scrip
1d70: 74 2e 62 61 73 68 20 23 20 69 73 20 65 78 65 63  t.bash # is exec
1d80: 75 74 65 64 20 61 73 20 61 20 63 6f 70 79 20 69  uted as a copy i
1d90: 6e 20 74 68 65 20 73 75 62 66 6f 6c 64 65 72 20  n the subfolder 
1da0: 6f 66 20 74 68 65 20 62 75 69 6c 64 20 66 6f 6c  of the build fol
1db0: 64 65 72 2e 20 3c 2f 70 72 65 3e 3c 70 72 65 3e  der. </pre><pre>
1dc0: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20      |    |    | 
1dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1de0: 20 20 20 23 20 42 75 69 6c 64 69 6e 67 20 61 6c     # Building al
1df0: 77 61 79 73 20 69 6e 63 6c 75 64 65 73 20 62 6f  ways includes bo
1e00: 6f 74 73 74 72 61 70 70 69 6e 67 2e 20 49 66 20  otstrapping. If 
1e10: 74 68 65 20 62 75 69 6c 64 20 66 61 69 6c 73 2c  the build fails,
1e20: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
1e30: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20      |    |      
1e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20                # 
1e50: 74 68 65 6e 20 74 68 65 20 62 75 69 6c 64 5f 73  then the build_s
1e60: 63 72 69 70 74 2e 62 61 73 68 20 6d 75 73 74 20  cript.bash must 
1e70: 65 78 69 74 20 77 69 74 68 20 61 20 6e 6f 6e 2d  exit with a non-
1e80: 30 20 65 72 72 6f 72 20 63 6f 64 65 2e 3c 2f 70  0 error code.</p
1e90: 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20  re><pre>    |   
1ea0: 20 7c 20 20 20 20 7c 3c 2f 70 72 65 3e 3c 70 72   |    |</pre><pr
1eb0: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
1ec0: 7c 20 20 20 20 2b 2d 2d 72 75 6e 5f 61 6c 6c 5f  |    +--run_all_
1ed0: 74 65 73 74 73 5f 61 6e 64 5f 65 78 69 74 5f 77  tests_and_exit_w
1ee0: 69 74 68 5f 30 5f 69 66 5f 61 6c 6c 5f 74 65 73  ith_0_if_all_tes
1ef0: 74 73 5f 70 61 73 73 5f 74 31 2e 62 61 73 68 20  ts_pass_t1.bash 
1f00: 23 20 73 68 6f 75 6c 64 20 64 65 73 63 72 69 62  # should describ
1f10: 65 20 66 61 69 6c 75 72 65 73 20 61 74 20 73 74  e failures at st
1f20: 64 6f 75 74 20 6f 72 20 73 74 64 65 72 72 3c 2f  dout or stderr</
1f30: 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20  pre><pre>    |  
1f40: 20 20 7c 20 20 20 20 7c 3c 2f 70 72 65 3e 3c 70    |    |</pre><p
1f50: 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20  re>    |    |   
1f60: 20 2b 2d 2d 73 69 5f 73 74 6f 72 61 67 65 5f 73   +--si_storage_s
1f70: 70 61 63 65 5f 73 69 7a 65 5f 69 6e 5f 62 79 74  pace_size_in_byt
1f80: 65 73 5f 77 69 74 68 6f 75 74 5f 69 6e 63 6c 75  es_without_inclu
1f90: 64 69 6e 67 5f 64 65 70 65 6e 64 65 6e 63 69 65  ding_dependencie
1fa0: 73 2e 62 61 73 68 20 23 20 50 72 69 6e 74 73 20  s.bash # Prints 
1fb0: 61 20 6e 75 6d 62 65 72 20 74 6f 20 63 6f 6e 73  a number to cons
1fc0: 6f 6c 65 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  ole.</pre><pre> 
1fd0: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
1fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2000: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2010: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2020: 20 20 20 23 20 54 68 65 20 70 72 69 6e 74 6f 75     # The printou
2030: 74 20 6d 61 79 20 69 6e 63 6c 75 64 65 20 3c 2f  t may include </
2040: 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20  pre><pre>    |  
2050: 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20    |    |        
2060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2070: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2090: 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20 61               # a
20a0: 20 6c 69 6e 65 20 62 72 65 61 6b 2e 3c 2f 70 72   line break.</pr
20b0: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
20c0: 7c 20 20 20 20 7c 3c 2f 70 72 65 3e 3c 70 72 65  |    |</pre><pre
20d0: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
20e0: 20 20 20 20 2b 2d 2d 73 69 5f 72 65 63 75 72 73      +--si_recurs
20f0: 69 76 65 5f 73 74 6f 72 61 67 65 5f 73 70 61 63  ive_storage_spac
2100: 65 5f 73 69 7a 65 5f 6f 66 5f 61 6c 6c 5f 69 6d  e_size_of_all_im
2110: 6d 65 64 69 61 74 65 5f 64 65 70 65 6e 64 65 6e  mediate_dependen
2120: 63 69 65 73 5f 69 6e 5f 62 79 74 65 73 2e 62 61  cies_in_bytes.ba
2130: 73 68 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  sh </pre><pre>  
2140: 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20 20    |    |    |   
2150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2160: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2170: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2180: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2190: 20 20 23 20 50 72 69 6e 74 73 20 61 20 6e 75 6d    # Prints a num
21a0: 62 65 72 20 74 6f 20 63 6f 6e 73 6f 6c 65 2e 3c  ber to console.<
21b0: 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20  /pre><pre>    | 
21c0: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20     |    |       
21d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
21e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
21f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20                # 
2210: 54 68 65 20 70 72 69 6e 74 6f 75 74 20 6d 61 79  The printout may
2220: 20 69 6e 63 6c 75 64 65 20 3c 2f 70 72 65 3e 3c   include </pre><
2230: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
2240: 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20    |             
2250: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2270: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2280: 20 20 20 20 20 20 20 20 23 20 61 20 6c 69 6e 65          # a line
2290: 20 62 72 65 61 6b 2e 3c 2f 70 72 65 3e 3c 70 72   break.</pre><pr
22a0: 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20  e>    |    |    
22b0: 7c 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20  |</pre><pre>    
22c0: 7c 20 20 20 20 7c 20 20 20 20 2b 2d 2d 73 5f 73  |    |    +--s_s
22d0: 69 6c 6b 65 78 61 70 70 5f 63 6f 72 65 5f 76 65  ilkexapp_core_ve
22e0: 72 73 69 6f 6e 2e 62 61 73 68 20 23 20 50 72 69  rsion.bash # Pri
22f0: 6e 74 73 20 61 20 73 74 72 69 6e 67 20 74 6f 20  nts a string to 
2300: 63 6f 6e 73 6f 6c 65 2e 20 54 6f 20 66 61 63 69  console. To faci
2310: 6c 69 74 61 74 65 20 3c 2f 70 72 65 3e 3c 70 72  litate </pre><pr
2320: 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20  e>    |    |    
2330: 7c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  |               
2340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2350: 20 23 20 74 68 65 20 75 73 65 20 6f 66 20 73 69   # the use of si
2360: 67 6e 61 74 75 72 65 73 2c 20 74 68 65 20 73 74  gnatures, the st
2370: 72 69 6e 67 20 69 73 20 61 6c 6c 6f 77 65 64 20  ring is allowed 
2380: 74 6f 20 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  to  </pre><pre> 
2390: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
23a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
23b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20                # 
23c0: 69 6e 63 6c 75 64 65 20 6c 69 6e 65 20 62 72 65  include line bre
23d0: 61 6b 73 2c 20 73 70 61 63 65 73 2c 20 74 61 62  aks, spaces, tab
23e0: 75 6c 61 74 69 6f 6e 20 63 68 61 72 61 63 74 65  ulation characte
23f0: 72 73 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  rs.</pre><pre>  
2400: 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20 20    |    |    |   
2410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2420: 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20 3c               # <
2430: 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20  /pre><pre>    | 
2440: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20     |    |       
2450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2460: 20 20 20 20 20 20 20 20 20 23 20 54 68 65 20 69           # The i
2470: 64 65 61 20 69 73 20 74 68 61 74 20 64 69 66 66  dea is that diff
2480: 65 72 65 6e 74 20 73 69 6c 6b 65 78 61 70 70 73  erent silkexapps
2490: 20 63 61 6e 20 75 73 65 20 74 68 65 20 73 61 6d   can use the sam
24a0: 65 20 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20  e  </pre><pre>  
24b0: 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20 20    |    |    |   
24c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
24d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20 76               # v
24e0: 65 72 73 69 6f 6e 20 6f 66 20 61 6e 20 61 70 70  ersion of an app
24f0: 6c 69 63 61 74 69 6f 6e 20 73 6f 75 72 63 65 2c  lication source,
2500: 20 62 75 74 20 74 68 65 20 61 70 70 6c 69 63 61   but the applica
2510: 74 69 6f 6e 20 73 6f 75 72 63 65 20 3c 2f 70 72  tion source </pr
2520: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
2530: 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 20  |    |          
2540: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2550: 20 20 20 20 20 20 23 20 63 61 6e 20 62 65 20 62        # can be b
2560: 75 69 6c 74 20 62 79 20 75 73 69 6e 67 20 64 69  uilt by using di
2570: 66 66 65 72 65 6e 74 20 62 75 69 6c 64 20 70 61  fferent build pa
2580: 72 61 6d 65 74 65 72 73 2e 20 3c 2f 70 72 65 3e  rameters. </pre>
2590: 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20  <pre>    |    | 
25a0: 20 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20     |            
25b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
25c0: 20 20 20 20 23 20 44 69 66 66 65 72 65 6e 74 20      # Different 
25d0: 73 69 6c 6b 65 78 61 70 70 73 20 74 68 61 74 20  silkexapps that 
25e0: 62 75 69 6c 64 20 74 68 65 20 61 70 70 6c 69 63  build the applic
25f0: 61 74 69 6f 6e 20 62 79 20 3c 2f 70 72 65 3e 3c  ation by </pre><
2600: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
2610: 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20    |             
2620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2630: 20 20 20 23 20 75 73 69 6e 67 20 74 68 65 20 73     # using the s
2640: 61 6d 65 20 62 75 69 6c 64 20 70 61 72 61 6d 65  ame build parame
2650: 74 65 72 73 2c 20 63 61 6e 20 68 61 76 65 20 0d  ters, can have .
2660: 0a 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20  .</pre><pre>    
2670: 7c 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20  |    |    |     
2680: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2690: 20 20 20 20 20 20 20 20 20 20 20 23 20 64 69 66             # dif
26a0: 66 65 72 65 6e 74 20 73 69 6c 6b 65 78 61 70 70  ferent silkexapp
26b0: 20 73 63 72 69 70 74 73 20 61 6e 64 20 64 69 66   scripts and dif
26c0: 66 65 72 65 6e 74 20 64 65 76 65 6c 6f 70 65 72  ferent developer
26d0: 73 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  s.</pre><pre>   
26e0: 20 7c 20 20 20 20 7c 20 20 20 20 7c 3c 2f 70 72   |    |    |</pr
26f0: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
2700: 7c 20 20 20 20 2b 2d 2d 73 62 5f 69 73 5f 72 65  |    +--sb_is_re
2710: 61 64 79 5f 34 5f 73 69 6c 6b 65 78 61 70 70 5f  ady_4_silkexapp_
2720: 70 61 63 6b 61 67 65 5f 66 6f 72 6d 61 74 5f 74  package_format_t
2730: 65 73 74 73 2e 62 61 73 68 20 23 20 50 72 69 6e  ests.bash # Prin
2740: 74 73 20 61 20 73 74 72 69 6e 67 20 66 72 6f 6d  ts a string from
2750: 20 74 68 65 20 73 65 74 20 7b 22 74 22 2c 22 66   the set {"t","f
2760: 22 7d 2c 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  "}, </pre><pre> 
2770: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
2780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2790: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
27a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
27b0: 20 20 23 20 77 68 65 72 65 20 22 74 22 20 73 74    # where "t" st
27c0: 61 6e 64 73 20 66 6f 72 20 22 74 72 75 65 22 20  ands for "true" 
27d0: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
27e0: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20      |    |      
27f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2800: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20                # 
2820: 61 6e 64 20 22 66 22 20 73 74 61 6e 64 73 20 66  and "f" stands f
2830: 6f 72 20 22 66 61 6c 73 65 22 2e 3c 2f 70 72 65  or "false".</pre
2840: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
2850: 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 20 20      |           
2860: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2870: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2880: 20 20 20 20 20 20 20 20 20 23 20 54 68 65 20 73           # The s
2890: 74 72 69 6e 67 20 64 6f 65 73 20 6e 6f 74 20 65  tring does not e
28a0: 6e 64 20 77 69 74 68 20 61 20 6c 69 6e 65 20 62  nd with a line b
28b0: 72 65 61 6b 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e  reak.</pre><pre>
28c0: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20      |    |    | 
28d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2900: 20 20 20 23 20 0d 0a 3c 2f 70 72 65 3e 3c 70 72     # ..</pre><pr
2910: 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20  e>    |    |    
2920: 7c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  |               
2930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2940: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2950: 20 20 20 20 20 23 20 54 68 65 20 22 66 22 20 69       # The "f" i
2960: 6e 64 69 63 61 74 65 73 20 74 68 61 74 20 6e 6f  ndicates that no
2970: 74 20 61 6c 6c 20 0d 0a 3c 2f 70 72 65 3e 3c 70  t all ..</pre><p
2980: 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20  re>    |    |   
2990: 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20 20   |              
29a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
29b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
29c0: 20 20 20 20 20 20 23 20 73 69 6c 6b 65 78 61 70        # silkexap
29d0: 70 20 66 6f 72 6d 61 74 20 73 70 65 63 69 66 69  p format specifi
29e0: 63 20 73 63 72 69 70 74 73 20 61 6e 64 20 3c 2f  c scripts and </
29f0: 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20  pre><pre>    |  
2a00: 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20    |    |        
2a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2a20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2a30: 20 20 20 20 20 20 20 20 20 20 20 20 23 20 66 6f              # fo
2a40: 6c 64 65 72 73 20 61 72 65 20 70 72 65 73 65 6e  lders are presen
2a50: 74 20 6f 72 20 72 65 61 64 79 20 74 6f 20 62 65  t or ready to be
2a60: 20 75 73 65 64 2e 3c 2f 70 72 65 3e 3c 70 72 65   used.</pre><pre
2a70: 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c  >    |    |    |
2a80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2a90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2aa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ab0: 20 20 20 20 23 20 54 68 65 20 22 74 22 20 69 6e      # The "t" in
2ac0: 64 69 63 61 74 65 73 20 74 68 61 74 20 74 68 65  dicates that the
2ad0: 20 63 75 72 72 65 6e 74 20 3c 2f 70 72 65 3e 3c   current </pre><
2ae0: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
2af0: 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20    |             
2b00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b20: 20 20 20 20 20 20 20 23 20 73 70 65 63 69 66 69         # specifi
2b30: 63 61 74 69 6f 6e 20 69 73 20 65 78 70 65 63 74  cation is expect
2b40: 65 64 20 74 6f 20 62 65 20 6d 65 74 3c 2f 70 72  ed to be met</pr
2b50: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
2b60: 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 20  |    |          
2b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b90: 20 20 20 20 20 20 20 20 20 20 23 20 74 6f 20 74            # to t
2ba0: 68 65 20 65 78 74 65 6e 74 20 74 68 61 74 20 74  he extent that t
2bb0: 68 65 20 73 69 6c 6b 65 78 61 70 70 20 73 63 72  he silkexapp scr
2bc0: 69 70 74 73 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  ipts</pre><pre> 
2bd0: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
2be0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2bf0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c10: 20 20 23 20 63 61 6e 20 62 65 20 74 65 73 74 65    # can be teste
2c20: 64 2e 20 54 68 65 20 6f 75 74 70 75 74 20 76 61  d. The output va
2c30: 6c 75 65 20 63 61 6e 20 62 65 0d 0a 3c 2f 70 72  lue can be..</pr
2c40: 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20  e><pre>    |    
2c50: 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 20  |    |          
2c60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c80: 20 20 20 20 20 20 20 20 20 20 23 20 63 61 6c 63            # calc
2c90: 75 6c 61 74 65 64 20 64 75 72 69 6e 67 20 72 75  ulated during ru
2ca0: 6e 74 69 6d 65 2c 20 64 79 6e 61 6d 69 63 61 6c  ntime, dynamical
2cb0: 6c 79 2e 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  ly. </pre><pre> 
2cc0: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
2cd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ce0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cf0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2d00: 20 20 23 20 46 6f 72 20 65 78 61 6d 70 6c 65 2c    # For example,
2d10: 20 74 68 65 20 73 63 72 69 70 74 20 6d 61 79 20   the script may 
2d20: 73 74 75 64 79 20 74 68 65 20 3c 2f 70 72 65 3e  study the </pre>
2d30: 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20  <pre>    |    | 
2d40: 20 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20     |            
2d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2d70: 20 20 20 20 20 20 20 20 23 20 76 61 6c 75 65 20          # value 
2d80: 6f 66 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 76  of environment v
2d90: 61 72 69 61 62 6c 65 73 20 61 6e 64 20 74 68 65  ariables and the
2da0: 20 70 72 65 73 65 6e 63 65 3c 2f 70 72 65 3e 3c   presence</pre><
2db0: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
2dc0: 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20    |             
2dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2df0: 20 20 20 20 20 20 20 23 20 61 6e 64 20 63 6f 6e         # and con
2e00: 74 65 6e 74 20 6f 66 20 66 69 6c 65 73 2e 3c 2f  tent of files.</
2e10: 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20  pre><pre>    |  
2e20: 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20    |    |        
2e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e50: 20 20 20 20 20 20 20 20 20 20 20 20 23 20 3c 2f              # </
2e60: 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20  pre><pre>    |  
2e70: 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20 20    |    |        
2e80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ea0: 20 20 20 20 20 20 20 20 20 20 20 20 23 20 41 6e              # An
2eb0: 20 6f 70 74 69 6f 6e 61 6c 20 63 6f 6d 6d 61 6e   optional comman
2ec0: 64 20 6c 69 6e 65 20 70 61 72 61 6d 65 74 65 72  d line parameter
2ed0: 2c 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  , </pre><pre>   
2ee0: 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20   |    |    |    
2ef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f20: 23 20 22 65 78 70 6c 61 6e 61 74 69 6f 6e 22 2c  # "explanation",
2f30: 20 77 69 74 68 6f 75 74 20 74 68 65 20 71 75 6f   without the quo
2f40: 74 65 73 2c 20 3c 2f 70 72 65 3e 3c 70 72 65 3e  tes, </pre><pre>
2f50: 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20      |    |    | 
2f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f90: 20 20 20 23 20 69 73 20 65 78 70 65 63 74 65 64     # is expected
2fa0: 20 74 6f 20 63 68 61 6e 67 65 20 74 68 65 20 6f   to change the o
2fb0: 75 74 70 75 74 20 6d 6f 64 65 20 3c 2f 70 72 65  utput mode </pre
2fc0: 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c  ><pre>    |    |
2fd0: 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 20 20      |           
2fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3000: 20 20 20 20 20 20 20 20 20 23 20 66 72 6f 6d 20           # from 
3010: 74 68 65 20 22 74 22 20 61 6e 64 20 22 66 22 20  the "t" and "f" 
3020: 74 6f 20 61 20 66 72 65 65 73 74 79 6c 65 20 3c  to a freestyle <
3030: 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20  /pre><pre>    | 
3040: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 20 20 20     |    |       
3050: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3070: 20 20 20 20 20 20 20 20 20 20 20 20 20 23 20 74               # t
3080: 65 78 74 20 74 68 61 74 20 65 78 70 6c 61 69 6e  ext that explain
3090: 73 20 74 68 65 20 63 69 72 63 75 6d 73 74 61 6e  s the circumstan
30a0: 63 65 73 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20  ces </pre><pre> 
30b0: 20 20 20 7c 20 20 20 20 7c 20 20 20 20 7c 20 20     |    |    |  
30c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30f0: 20 20 23 20 74 68 61 74 20 65 66 66 65 63 74 20    # that effect 
3100: 74 68 65 20 63 68 6f 69 63 65 20 62 65 74 77 65  the choice betwe
3110: 65 6e 20 74 68 65 20 3c 2f 70 72 65 3e 3c 70 72  en the </pre><pr
3120: 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20 20  e>    |    |    
3130: 7c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  |               
3140: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3160: 20 20 20 20 20 23 20 22 74 22 20 61 6e 64 20 22       # "t" and "
3170: 66 22 2e 20 54 68 65 20 66 72 65 65 73 74 79 6c  f". The freestyl
3180: 65 20 74 65 78 74 20 63 61 6e 3c 2f 70 72 65 3e  e text can</pre>
3190: 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20  <pre>    |    | 
31a0: 20 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20     |            
31b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
31c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
31d0: 20 20 20 20 20 20 20 20 23 20 63 6f 6e 74 61 69          # contai
31e0: 6e 20 6c 69 6e 65 20 62 72 61 6b 65 73 2c 20 74  n line brakes, t
31f0: 61 62 75 6c 61 74 69 6f 6e 20 63 68 61 72 61 63  abulation charac
3200: 74 65 72 73 20 61 6e 64 20 3c 2f 70 72 65 3e 3c  ters and </pre><
3210: 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20  pre>    |    |  
3220: 20 20 7c 20 20 20 20 20 20 20 20 20 20 20 20 20    |             
3230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3240: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3250: 20 20 20 20 20 20 20 23 20 73 70 61 63 65 73 2e         # spaces.
3260: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
3270: 20 20 20 20 7c 20 20 20 20 7c 0d 0a 3c 2f 70 72      |    |..</pr
3280: 65 3e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20  e></pre><pre>   
3290: 20 7c 20 20 20 20 7c 20 20 20 20 2b 2d 2d 64 65   |    |    +--de
32a0: 6c 65 74 65 5f 63 61 63 68 65 5f 63 6f 6e 74 65  lete_cache_conte
32b0: 6e 74 5f 74 31 2e 62 61 73 68 20 23 20 73 65 74  nt_t1.bash # set
32c0: 73 20 73 69 6c 6b 65 78 61 70 70 20 73 74 61 74  s silkexapp stat
32d0: 65 20 74 6f 20 61 73 20 69 66 20 69 74 20 77 65  e to as if it we
32e0: 72 65 20 69 6e 73 74 61 6c 6c 65 64 20 74 68 65  re installed the
32f0: 20 31 2e 20 74 69 6d 65 3c 2f 70 72 65 3e 3c 70   1. time</pre><p
3300: 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20  re>    |    |   
3310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3330: 20 23 20 49 66 20 62 75 69 6c 64 20 73 75 63 63   # If build succ
3340: 65 65 64 73 20 61 6e 64 20 74 68 69 73 20 66 69  eeds and this fi
3350: 6c 65 20 65 78 69 73 74 73 2c 20 74 68 65 6e 20  le exists, then 
3360: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c  </pre><pre>    |
3370: 20 20 20 20 7c 20 20 20 20 20 20 20 20 20 20 20      |           
3380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3390: 20 20 20 20 20 20 20 20 20 23 20 69 74 20 69 73           # it is
33a0: 20 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79 20 63   automatically c
33b0: 61 6c 6c 65 64 20 62 79 20 74 68 65 20 6d 6d 6d  alled by the mmm
33c0: 76 5f 73 69 6c 6b 65 78 65 63 3c 2f 70 72 65 3e  v_silkexec</pre>
33d0: 3c 70 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20  <pre>    |    | 
33e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3400: 20 20 20 23 20 61 66 74 65 72 20 74 68 65 20 62     # after the b
3410: 75 69 6c 64 2e 20 49 74 20 6d 75 73 74 20 62 65  uild. It must be
3420: 20 61 62 6c 65 20 74 6f 20 68 61 6e 64 6c 65 20   able to handle 
3430: 61 20 63 61 73 65 2c 20 3c 2f 70 72 65 3e 3c 70  a case, </pre><p
3440: 72 65 3e 20 20 20 20 7c 20 20 20 20 7c 20 20 20  re>    |    |   
3450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3460: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3470: 20 23 20 77 68 65 72 65 20 74 68 65 72 65 20 69   # where there i
3480: 73 20 6e 6f 20 63 6f 70 79 20 6f 66 20 74 68 65  s no copy of the
3490: 20 63 61 63 68 65 2e 3c 2f 70 72 65 3e 3c 2f 70   cache.</pre></p
34a0: 72 65 3e 3c 70 72 65 3e 20 20 20 20 7c 20 20 20  re><pre>    |   
34b0: 20 7c 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20   |</pre><pre>   
34c0: 20 7c 20 20 20 20 2b 2d 2d 75 70 73 74 72 65 61   |    +--upstrea
34d0: 6d 5f 64 65 6c 69 76 65 72 61 62 6c 65 73 20 23  m_deliverables #
34e0: 20 69 73 20 61 20 66 6f 6c 64 65 72 20 66 6f 72   is a folder for
34f0: 20 75 6e 70 61 74 63 68 65 64 2c 20 75 6e 6d 6f   unpatched, unmo
3500: 64 69 66 69 65 64 2c 20 6f 72 69 67 69 6e 61 6c  dified, original
3510: 73 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20  s</pre><pre>    
3520: 7c 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20  |</pre><pre>    
3530: 2b 2d 2d 62 75 69 6c 64 20 20 23 20 69 73 20 64  +--build  # is d
3540: 65 6c 65 74 65 64 20 62 79 20 74 68 65 20 6d 6d  eleted by the mm
3550: 6d 76 5f 73 69 6c 6b 65 78 65 63 20 65 76 65 72  mv_silkexec ever
3560: 79 20 74 69 6d 65 20 62 65 66 6f 72 65 20 74 68  y time before th
3570: 65 20 73 69 6c 6b 65 78 61 70 70 20 69 73 20 62  e silkexapp is b
3580: 75 69 6c 74 20 2e 3c 2f 70 72 65 3e 3c 2f 70 72  uilt .</pre></pr
3590: 65 3e 0a 3c 70 72 65 3e 3c 70 72 65 3e 20 20 20  e>.<pre><pre>   
35a0: 20 20 20 20 20 20 7c 20 20 20 20 23 20 54 68 65        |    # The
35b0: 20 6d 6d 6d 76 5f 73 69 6c 6b 65 78 65 63 20 73   mmmv_silkexec s
35c0: 65 74 73 20 69 74 73 20 66 69 6c 65 20 70 65 72  ets its file per
35d0: 6d 69 73 73 69 6f 6e 73 20 72 65 63 75 72 73 69  missions recursi
35e0: 76 65 6c 79 20 3c 2f 70 72 65 3e 3c 70 72 65 3e  vely </pre><pre>
35f0: 20 20 20 20 20 20 20 20 20 7c 20 20 20 20 23 20           |    # 
3600: 74 6f 20 30 37 41 42 20 62 65 66 6f 72 65 20 65  to 07AB before e
3610: 78 65 63 75 74 69 6e 67 20 74 68 65 20 62 75 69  xecuting the bui
3620: 6c 64 5f 73 63 72 69 70 74 2e 62 61 73 68 2e 20  ld_script.bash. 
3630: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 20  </pre><pre>     
3640: 20 20 20 20 7c 20 20 20 20 23 20 54 68 65 20 41      |    # The A
3650: 20 61 6e 64 20 74 68 65 20 42 20 61 72 65 20 74   and the B are t
3660: 68 65 20 73 61 6d 65 20 61 73 20 77 69 74 68 20  he same as with 
3670: 74 68 65 20 73 72 63 20 66 6f 6c 64 65 72 2e 3c  the src folder.<
3680: 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 20 20  /pre><pre>      
3690: 20 20 20 7c 20 3c 2f 70 72 65 3e 3c 70 72 65 3e     | </pre><pre>
36a0: 20 20 20 20 20 20 20 20 20 2b 2d 2d 62 69 6e 20           +--bin 
36b0: 23 20 69 73 20 74 68 65 20 74 61 72 67 65 74 20  # is the target 
36c0: 6f 66 20 74 68 65 20 73 69 6c 6b 65 78 61 70 70  of the silkexapp
36d0: 20 62 69 6e 20 66 6f 6c 64 65 72 20 73 79 6d 6c   bin folder syml
36e0: 69 6e 6b 2e 20 54 68 69 73 20 66 6f 6c 64 65 72  ink. This folder
36f0: 20 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20   </pre><pre>    
3700: 20 20 20 20 20 7c 20 20 20 20 20 20 23 20 69 73       |      # is
3710: 20 63 72 65 61 74 65 64 20 61 75 74 6f 6d 61 74   created automat
3720: 69 63 61 6c 6c 79 20 62 65 66 6f 72 65 20 74 68  ically before th
3730: 65 20 62 75 69 6c 64 5f 73 63 72 69 70 74 2e 62  e build_script.b
3740: 61 73 68 20 69 73 20 72 75 6e 2e 3c 2f 70 72 65  ash is run.</pre
3750: 3e 3c 70 72 65 3e 20 20 20 20 20 20 20 20 20 7c  ><pre>         |
3760: 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20 20  </pre><pre>     
3770: 20 20 20 20 2b 2d 2d 64 6f 63 20 23 20 61 6e 20      +--doc # an 
3780: 6f 70 74 69 6f 6e 61 6c 20 66 6f 6c 64 65 72 20  optional folder 
3790: 74 68 61 74 20 69 73 20 6d 65 61 6e 74 20 74 6f  that is meant to
37a0: 20 62 65 20 63 72 65 61 74 65 64 20 62 79 20 74   be created by t
37b0: 68 65 20 62 75 69 6c 64 5f 73 63 72 69 70 74 2e  he build_script.
37c0: 62 61 73 68 20 2e 3c 2f 70 72 65 3e 3c 70 72 65  bash .</pre><pre
37d0: 3e 20 20 20 20 20 20 20 20 20 7c 20 20 20 20 20  >         |     
37e0: 20 23 20 49 66 20 74 68 69 73 20 66 6f 6c 64 65   # If this folde
37f0: 72 20 65 78 69 73 74 73 20 61 6e 64 20 74 68 65  r exists and the
3800: 20 62 75 69 6c 64 5f 73 63 72 69 70 74 2e 62 61   build_script.ba
3810: 73 68 20 68 61 73 20 3c 2f 70 72 65 3e 3c 70 72  sh has </pre><pr
3820: 65 3e 20 20 20 20 20 20 20 20 20 7c 20 20 20 20  e>         |    
3830: 20 20 23 20 65 78 69 74 65 64 20 77 69 74 68 6f    # exited witho
3840: 75 74 20 61 6e 79 20 65 72 72 6f 72 73 2c 20 69  ut any errors, i
3850: 64 20 65 73 74 20 77 69 74 68 20 65 72 72 6f 72  d est with error
3860: 20 63 6f 64 65 20 30 2c 20 3c 2f 70 72 65 3e 3c   code 0, </pre><
3870: 70 72 65 3e 20 20 20 20 20 20 20 20 20 7c 20 20  pre>         |  
3880: 20 20 20 20 23 20 74 68 65 6e 20 6d 6d 6d 76 5f      # then mmmv_
3890: 73 69 6c 6b 65 78 65 63 20 63 72 65 61 74 65 73  silkexec creates
38a0: 20 61 20 73 79 6d 6c 69 6e 6b 20 74 6f 20 74 68   a symlink to th
38b0: 69 73 20 66 6f 6c 64 65 72 20 3c 2f 70 72 65 3e  is folder </pre>
38c0: 3c 70 72 65 3e 20 20 20 20 20 20 20 20 20 7c 20  <pre>         | 
38d0: 20 20 20 20 20 23 20 66 72 6f 6d 20 74 68 65 20       # from the 
38e0: 73 69 6c 6b 65 78 61 70 70 20 66 6f 6c 64 65 72  silkexapp folder
38f0: 2e 3c 2f 70 72 65 3e 3c 70 72 65 3e 20 20 20 20  .</pre><pre>    
3900: 20 20 20 20 20 7c 3c 2f 70 72 65 3e 3c 70 72 65       |</pre><pre
3910: 3e 20 20 20 20 20 20 20 20 20 2b 2d 2d 73 69 6c  >         +--sil
3920: 6b 65 78 61 70 70 5f 63 6f 6e 74 72 6f 6c 20 20  kexapp_control  
3930: 23 20 63 6f 70 79 20 6f 66 20 74 68 65 20 66 6f  # copy of the fo
3940: 6c 64 65 72 20 66 72 6f 6d 20 74 68 65 20 73 72  lder from the sr
3950: 63 3c 2f 70 72 65 3e 3c 70 72 65 3e 3c 62 72 3e  c</pre><pre><br>
3960: 0a 0d 0a 0d 0a 3c 2f 70 72 65 3e 0d 0a 3c 2f 70  .....</pre>..</p
3970: 72 65 3e 0a 0a 3c 70 3e 53 69 6c 6b 65 78 61 70  re>..<p>Silkexap
3980: 70 73 20 61 72 65 20 69 6e 73 74 61 6c 6c 65 64  ps are installed
3990: 2f 75 6e 70 61 63 6b 65 64 20 74 6f 3c 2f 70 3e  /unpacked to</p>
39a0: 0a 3c 75 6c 3e 0a 3c 6c 69 3e 7e 2f 2e 73 69 6c  .<ul>.<li>~/.sil
39b0: 6b 74 6f 72 72 65 6e 74 2f 6d 6d 6d 76 5f 73 69  ktorrent/mmmv_si
39c0: 6c 6b 65 78 65 63 2f 73 69 6c 6b 65 78 61 70 70  lkexec/silkexapp
39d0: 73 2f 26 6c 74 3b 76 61 72 69 6f 75 73 20 66 6f  s/&lt;various fo
39e0: 6c 64 65 72 73 20 74 68 61 74 20 68 61 76 65 20  lders that have 
39f0: 74 68 65 69 72 0a 6e 61 6d 65 20 64 65 72 69 76  their.name deriv
3a00: 65 64 20 66 72 6f 6d 20 73 69 6c 6b 65 78 61 70  ed from silkexap
3a10: 70 20 53 69 6c 6b 74 6f 72 72 65 6e 74 20 70 61  p Silktorrent pa
3a20: 63 6b 65 74 20 6e 61 6d 65 26 67 74 3b 2f 26 6c  cket name&gt;/&l
3a30: 74 3b 53 69 6c 6b 65 78 61 70 70 0a 53 69 6c 6b  t;Silkexapp.Silk
3a40: 74 6f 72 72 65 6e 74 20 70 61 63 6b 65 74 20 6e  torrent packet n
3a50: 61 6d 65 26 67 74 3b 5f 64 69 72 3c 2f 6c 69 3e  ame&gt;_dir</li>
3a60: 0a 3c 2f 75 6c 3e 0a 0a 3c 70 3e 54 6f 20 6d 61  .</ul>..<p>To ma
3a70: 6b 65 20 69 74 20 70 6f 73 73 69 62 6c 65 20 74  ke it possible t
3a80: 6f 20 73 68 61 72 65 20 73 69 6c 6b 65 78 61 70  o share silkexap
3a90: 70 73 20 62 65 74 77 65 65 6e 20 64 69 66 66 65  ps between diffe
3aa0: 72 65 6e 74 20 75 73 65 72 73 20 6f 66 20 61 20  rent users of a 
3ab0: 73 61 6d 65 0a 73 79 73 74 65 6d 2c 20 70 61 63  same.system, pac
3ac0: 6b 61 67 65 73 20 61 72 65 20 61 6c 6c 6f 77 65  kages are allowe
3ad0: 64 20 74 6f 20 61 73 73 75 6d 65 20 74 68 61 74  d to assume that
3ae0: 20 74 68 65 79 20 68 61 76 65 20 77 72 69 74 65   they have write
3af0: 20 61 63 63 65 73 73 20 6f 6e 6c 79 20 74 6f 26   access only to&
3b00: 6e 62 73 70 3b 3c 2f 70 3e 0a 0a 3c 70 3e 3c 2f  nbsp;</p>..<p></
3b10: 70 3e 0a 3c 75 6c 3e 0a 3c 6c 69 3e 2f 74 6d 70  p>.<ul>.<li>/tmp
3b20: 3c 2f 6c 69 3e 0a 3c 6c 69 3e 7e 2f 2e 73 69 6c  </li>.<li>~/.sil
3b30: 6b 74 6f 72 72 65 6e 74 2f 6d 6d 6d 76 5f 73 69  ktorrent/mmmv_si
3b40: 6c 6b 65 78 65 63 2f 61 70 70 6c 69 63 61 74 69  lkexec/applicati
3b50: 6f 6e 73 5f 77 72 69 74 65 5f 61 72 65 61 2f 26  ons_write_area/&
3b60: 6c 74 3b 60 77 68 6f 61 6d 69 60 26 67 74 3b 2f  lt;`whoami`&gt;/
3b70: 26 6c 74 3b 72 65 6c 61 74 69 76 65 0a 70 61 74  &lt;relative.pat
3b80: 68 20 66 72 6f 6d 20 70 61 63 6b 61 67 65 20 63  h from package c
3b90: 6f 6c 6c 65 63 74 69 6f 6e 20 72 6f 6f 74 26 67  ollection root&g
3ba0: 74 3b 3c 2f 6c 69 3e 0a 3c 6c 69 3e 26 6c 74 3b  t;</li>.<li>&lt;
3bb0: 6c 69 73 74 20 6f 66 20 66 6f 6c 64 65 72 73 20  list of folders 
3bc0: 74 68 61 74 20 63 61 6e 20 62 65 20 71 75 65 72  that can be quer
3bd0: 69 65 64 20 62 79 20 22 6d 6d 6d 76 5f 73 69 6c  ied by "mmmv_sil
3be0: 6b 65 78 65 63 20 73 79 73 5f 26 6c 74 3b 73 6f  kexec sys_&lt;so
3bf0: 6d 65 74 68 69 6e 67 26 67 74 3b 2c 0a 66 6f 72  mething&gt;,.for
3c00: 20 65 78 61 6d 70 6c 65 3a 20 6d 6d 6d 76 5f 73   example: mmmv_s
3c10: 69 6c 6b 65 78 65 63 20 73 79 73 5f 73 5f 66 70  ilkexec sys_s_fp
3c20: 5f 72 61 6d 64 69 73 6b 5f 31 20 26 67 74 3b 3c  _ramdisk_1 &gt;<
3c30: 2f 6c 69 3e 0a 3c 2f 75 6c 3e 0a 0a 3c 70 3e 3c  /li>.</ul>..<p><
3c40: 2f 70 3e 0a 0a 3c 70 3e 54 68 65 20 6d 6d 6d 76  /p>..<p>The mmmv
3c50: 5f 73 69 6c 6b 65 78 65 63 20 70 72 65 70 72 6f  _silkexec prepro
3c60: 63 65 73 73 65 73 20 73 69 6c 6b 65 78 61 70 70  cesses silkexapp
3c70: 20 6e 61 6d 65 73 20 62 79 20 72 65 6d 6f 76 69   names by removi
3c80: 6e 67 20 61 20 73 69 6e 67 6c 65 20 69 6e 73 74  ng a single inst
3c90: 61 6e 63 65 0a 6f 66 20 74 68 65 20 66 6f 6c 6c  ance.of the foll
3ca0: 6f 77 69 6e 67 20 70 72 65 66 69 78 65 73 3a 3c  owing prefixes:<
3cb0: 62 3e 20 22 73 79 73 5f 22 2c 20 22 75 73 72 5f  b> "sys_", "usr_
3cc0: 22 2e 3c 2f 62 3e 20 41 20 73 69 6c 6b 65 78 61  ".</b> A silkexa
3cd0: 70 70 20 74 68 61 74 20 69 73 20 6f 6e 20 50 41  pp that is on PA
3ce0: 54 48 0a 61 6e 64 20 68 61 73 20 61 20 6e 61 6d  TH.and has a nam
3cf0: 65 20 6f 66 20 22 73 79 73 5f 66 6f 6f 22 20 73  e of "sys_foo" s
3d00: 68 6f 75 6c 64 20 62 65 20 65 78 65 63 75 74 65  hould be execute
3d10: 64 20 61 73 20 22 6d 6d 6d 76 5f 73 69 6c 6b 65  d as "mmmv_silke
3d20: 78 65 63 20 75 73 72 5f 73 79 73 5f 66 6f 6f 22  xec usr_sys_foo"
3d30: 2e 0a 54 68 65 3c 62 3e 20 70 72 65 66 69 78 20  ..The<b> prefix 
3d40: 22 73 79 73 5f 22 20 69 73 20 72 65 73 65 72 76  "sys_" is reserv
3d50: 65 64 20 66 6f 72 20 6d 6d 6d 76 5f 73 69 6c 6b  ed for mmmv_silk
3d60: 65 78 65 63 20 63 6f 6d 6d 61 6e 64 73 2e 3c 2f  exec commands.</
3d70: 62 3e 20 50 72 65 70 72 6f 63 65 73 73 69 6e 67  b> Preprocessing
3d80: 0a 69 73 20 6e 6f 74 20 61 70 70 6c 69 65 64 2c  .is not applied,
3d90: 20 77 68 65 6e 20 74 68 65 20 73 69 6c 6b 65 78   when the silkex
3da0: 61 70 70 20 65 78 65 63 75 74 61 62 6c 65 20 69  app executable i
3db0: 73 20 72 65 66 65 72 72 65 64 20 74 68 72 6f 75  s referred throu
3dc0: 67 68 20 61 20 66 75 6c 6c 20 70 61 74 68 2e 0a  gh a full path..
3dd0: 26 6e 62 73 70 3b 54 68 65 20 6d 6d 6d 76 5f 73  &nbsp;The mmmv_s
3de0: 69 6c 6b 65 78 65 63 20 73 65 74 73 20 74 68 65  ilkexec sets the
3df0: 20 76 61 6c 75 65 73 20 6f 66 20 73 69 6c 6b 65   values of silke
3e00: 78 61 70 70 20 72 75 6e 74 69 6d 65 20 61 6e 64  xapp runtime and
3e10: 20 62 75 69 6c 64 74 69 6d 65 0a 65 6e 69 72 6f   buildtime.eniro
3e20: 6e 6d 65 6e 74 20 76 61 72 69 61 62 6c 65 73 20  nment variables 
3e30: 61 63 63 6f 72 64 69 6e 67 20 74 6f 20 74 68 65  according to the
3e40: 20 66 6f 6c 6c 6f 77 69 6e 67 20 70 72 65 63 65   following prece
3e50: 64 65 6e 63 65 3a 26 6e 62 73 70 3b 3c 2f 70 3e  dence:&nbsp;</p>
3e60: 0a 0a 3c 70 3e 3c 2f 70 3e 0a 3c 6f 6c 3e 0a 3c  ..<p></p>.<ol>.<
3e70: 6c 69 3e 49 66 20 63 6f 6e 66 69 67 75 72 61 74  li>If configurat
3e80: 69 6f 6e 20 65 78 69 73 74 73 2c 20 6f 76 65 72  ion exists, over
3e90: 72 69 64 65 20 74 68 65 20 76 61 6c 75 65 20 6f  ride the value o
3ea0: 66 20 74 68 65 20 65 6e 76 69 72 6f 6e 6d 65 6e  f the environmen
3eb0: 74 20 76 61 72 69 61 62 6c 65 2e 3c 2f 6c 69 3e  t variable.</li>
3ec0: 0a 3c 6c 69 3e 50 72 65 66 69 78 20 74 68 65 20  .<li>Prefix the 
3ed0: 76 61 6c 75 65 20 66 72 6f 6d 20 74 68 65 20 73  value from the s
3ee0: 74 65 70 20 31 20 77 69 74 68 20 74 68 65 20 76  tep 1 with the v
3ef0: 61 6c 75 65 20 66 72 6f 6d 20 74 68 65 20 63 6f  alue from the co
3f00: 6e 66 69 67 75 72 61 74 69 6f 6e 0a 66 69 6c 65  nfiguration.file
3f10: 2e 3c 2f 6c 69 3e 0a 3c 6c 69 3e 50 72 65 66 69  .</li>.<li>Prefi
3f20: 78 20 74 68 65 20 76 61 6c 75 65 20 66 72 6f 6d  x the value from
3f30: 20 74 68 65 20 73 74 65 70 20 32 20 77 69 74 68   the step 2 with
3f40: 20 74 68 65 20 66 75 6c 6c 20 70 61 74 68 20 6f   the full path o
3f50: 66 20 74 68 65 20 73 69 6c 6b 65 78 61 70 70 20  f the silkexapp 
3f60: 62 69 6e 0a 66 6f 6c 64 65 72 2e 3c 2f 6c 69 3e  bin.folder.</li>
3f70: 0a 3c 6c 69 3e 26 6c 74 3b 45 78 65 63 75 74 65  .<li>&lt;Execute
3f80: 20 74 68 65 20 65 78 65 63 75 74 61 62 6c 65 20   the executable 
3f90: 66 72 6f 6d 20 74 68 65 20 73 69 6c 6b 65 78 61  from the silkexa
3fa0: 70 70 20 62 69 6e 20 66 6f 6c 64 65 72 20 6f 72  pp bin folder or
3fb0: 0a 73 69 6c 6b 65 78 61 70 70 5f 63 6f 6e 74 72  .silkexapp_contr
3fc0: 6f 6c 20 66 6f 6c 64 65 72 2e 26 67 74 3b 3c 2f  ol folder.&gt;</
3fd0: 6c 69 3e 0a 3c 2f 6f 6c 3e 0a 0a 3c 70 3e 3c 2f  li>.</ol>..<p></
3fe0: 70 3e 0a 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e  p>..<p><br>.</p>
3ff0: 0a 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a  ..<p><br>.</p>..
4000: 3c 68 31 3e 54 65 73 74 69 6e 67 20 28 49 6e 63  <h1>Testing (Inc
4010: 6c 75 64 69 6e 67 20 56 65 72 69 66 69 63 61 74  luding Verificat
4020: 69 6f 6e 20 61 6e 64 20 41 75 64 69 74 73 29 3c  ion and Audits)<
4030: 2f 68 31 3e 0a 0a 3c 70 3e 53 69 6c 6b 65 78 65  /h1>..<p>Silkexe
4040: 63 61 70 70 20 69 73 20 65 78 65 63 75 74 65 64  capp is executed
4050: 20 6f 6e 6c 79 2c 20 69 66 20 61 6c 6c 20 6f 66   only, if all of
4060: 20 69 74 73 20 64 65 70 65 6e 64 65 6e 63 69 65   its dependencie
4070: 73 20 68 61 76 65 20 62 65 65 6e 0a 72 65 63 75  s have been.recu
4080: 72 73 69 76 65 6c 79 20 61 75 64 69 74 65 64 2f  rsively audited/
4090: 74 65 73 74 65 64 20 62 79 20 74 72 75 73 74 65  tested by truste
40a0: 64 20 70 61 72 74 69 65 73 2e 20 44 69 66 66 65  d parties. Diffe
40b0: 72 65 6e 74 20 70 61 72 74 69 65 73 20 74 72 75  rent parties tru
40c0: 73 74 0a 64 69 66 66 65 72 65 6e 74 20 6f 74 68  st.different oth
40d0: 65 72 20 70 61 72 74 69 65 73 2e 20 54 72 75 73  er parties. Trus
40e0: 74 20 69 73 20 61 20 6d 75 6c 74 69 64 69 6d 65  t is a multidime
40f0: 6e 73 69 6f 6e 61 6c 20 76 61 6c 75 65 2e 20 41  nsional value. A
4100: 20 76 65 72 79 20 6b 69 6e 64 68 65 61 72 74 65   very kindhearte
4110: 64 0a 61 6e 64 20 6e 6f 74 20 63 6f 72 72 75 70  d.and not corrup
4120: 74 20 70 65 72 73 6f 6e 20 63 61 6e 20 62 65 20  t person can be 
4130: 74 6f 74 61 6c 6c 79 20 75 6e 74 72 75 73 74 77  totally untrustw
4140: 6f 72 74 68 79 20 66 72 6f 6d 20 74 68 65 69 72  orthy from their
4150: 20 63 61 70 61 62 69 6c 69 74 69 65 73 0a 70 6f   capabilities.po
4160: 69 6e 74 20 6f 66 20 76 69 65 77 2e 20 4f 6e 20  int of view. On 
4170: 74 68 65 20 6f 74 68 65 72 20 68 61 6e 64 2c 20  the other hand, 
4180: 73 6f 6d 65 74 69 6d 65 73 2c 20 61 74 20 73 6f  sometimes, at so
4190: 6d 65 20 6e 61 72 72 6f 77 20 63 6f 6e 74 65 78  me narrow contex
41a0: 74 73 2c 20 65 6e 65 6d 69 65 73 0a 63 61 6e 20  ts, enemies.can 
41b0: 62 65 20 6d 6f 72 65 20 74 72 75 73 74 77 6f 72  be more trustwor
41c0: 74 68 79 20 74 68 61 6e 20 66 72 69 65 6e 64 73  thy than friends
41d0: 2e 20 46 6f 72 20 65 78 61 6d 70 6c 65 2c 20 65  . For example, e
41e0: 6e 65 6d 69 65 73 20 6d 69 67 68 74 20 68 61 76  nemies might hav
41f0: 65 20 61 20 67 6f 6f 64 0a 74 72 61 63 6b 20 72  e a good.track r
4200: 65 63 6f 72 64 20 6f 66 20 66 69 6e 65 20 73 6b  ecord of fine sk
4210: 69 6c 6c 73 20 61 6e 64 20 62 65 69 6e 67 20 72  ills and being r
4220: 69 67 6f 72 6f 75 73 20 61 6e 64 20 74 68 65 79  igorous and they
4230: 20 6d 69 67 68 74 20 75 73 65 20 73 6f 6d 65 0a   might use some.
4240: 63 6f 6d 70 6f 6e 65 6e 74 2c 20 73 6f 66 74 77  component, softw
4250: 61 72 65 20 70 61 63 6b 61 67 65 2c 20 61 74 20  are package, at 
4260: 73 6f 6d 65 20 73 65 63 75 72 69 74 79 20 77 69  some security wi
4270: 73 65 20 65 78 74 72 65 6d 65 6c 79 20 63 72 69  se extremely cri
4280: 74 69 63 61 6c 20 72 6f 6c 65 2c 0a 77 68 69 6c  tical role,.whil
4290: 65 20 62 65 69 6e 67 20 76 65 72 79 20 72 69 67  e being very rig
42a0: 6f 72 6f 75 73 20 61 74 20 74 68 65 20 63 6f 6e  orous at the con
42b0: 73 74 72 75 63 74 69 6f 6e 20 6f 66 20 74 68 65  struction of the
42c0: 69 72 20 73 6f 66 74 77 61 72 65 20 63 6f 6d 70  ir software comp
42d0: 6f 6e 65 6e 74 2e 3c 2f 70 3e 0a 0a 3c 70 3e 47  onent.</p>..<p>G
42e0: 69 76 65 6e 20 74 68 61 74 0a 3c 61 20 68 72 65  iven that.<a hre
42f0: 66 3d 22 68 74 74 70 3a 2f 2f 6d 61 72 74 69 6e  f="http://martin
4300: 2e 73 6f 66 74 66 31 2e 63 6f 6d 2f 67 2f 79 65  .softf1.com/g/ye
4310: 6c 6c 6f 77 5f 73 6f 61 70 5f 6f 70 65 72 61 5f  llow_soap_opera_
4320: 62 6c 6f 67 2f 74 68 65 2d 66 75 74 75 72 65 2d  blog/the-future-
4330: 6f 66 2d 73 65 63 75 72 69 74 79 2d 61 75 64 69  of-security-audi
4340: 74 73 2d 65 70 69 73 6f 64 65 2d 30 22 3e 74 68  ts-episode-0">th
4350: 65 0a 6f 6e 6c 79 20 70 72 6f 70 65 72 20 77 61  e.only proper wa
4360: 79 20 74 6f 20 76 65 72 69 66 79 2f 72 65 76 69  y to verify/revi
4370: 65 77 20 63 6f 64 65 20 69 73 20 74 6f 20 73 74  ew code is to st
4380: 75 64 79 20 69 74 20 69 6e 20 61 20 66 75 6c 6c  udy it in a full
4390: 79 20 61 75 74 6f 6d 61 74 65 64 20 77 61 79 3c  y automated way<
43a0: 2f 61 3e 3c 69 3e 28 3c 61 20 68 72 65 66 3d 22  /a><i>(<a href="
43b0: 68 74 74 70 73 3a 2f 2f 61 72 63 68 69 76 65 2e  https://archive.
43c0: 69 73 2f 68 33 48 4a 34 22 3e 61 72 63 68 69 76  is/h3HJ4">archiv
43d0: 61 6c 0a 63 6f 70 79 3c 2f 61 3e 29 3c 2f 69 3e  al.copy</a>)</i>
43e0: 2c 20 74 68 65 72 65 20 68 61 73 20 74 6f 20 62  , there has to b
43f0: 65 20 61 20 77 61 79 20 74 6f 20 73 75 62 73 63  e a way to subsc
4400: 72 69 62 65 20 74 6f 20 74 68 65 20 74 65 73 74  ribe to the test
4410: 69 6e 67 2f 76 65 72 69 66 69 63 61 74 69 6f 6e  ing/verification
4420: 0a 73 79 73 74 65 6d 20 6f 66 20 74 68 65 20 74  .system of the t
4430: 72 75 73 74 65 64 20 70 61 72 74 69 65 73 2e 20  rusted parties. 
4440: 54 6f 20 61 76 6f 69 64 20 61 20 44 65 6e 69 61  To avoid a Denia
4450: 6c 20 6f 66 20 53 65 72 76 69 63 65 20 61 74 74  l of Service att
4460: 61 63 6b 20 62 79 20 68 61 63 6b 69 6e 67 0a 69  ack by hacking.i
4470: 6e 74 6f 20 74 68 65 20 74 65 73 74 69 6e 67 2f  nto the testing/
4480: 76 65 72 69 66 69 63 61 74 69 6f 6e 20 73 79 73  verification sys
4490: 74 65 6d 73 20 6f 66 20 6f 6e 65 20 6f 66 20 74  tems of one of t
44a0: 68 65 20 74 72 75 73 74 65 64 20 70 61 72 74 69  he trusted parti
44b0: 65 73 2c 20 74 68 65 20 6c 6f 63 61 6c 0a 73 65  es, the local.se
44c0: 74 74 69 6e 67 73 20 6f 66 20 74 68 65 20 6d 6d  ttings of the mm
44d0: 6d 76 5f 73 69 6c 6b 65 78 65 63 20 73 68 6f 75  mv_silkexec shou
44e0: 6c 64 20 74 72 65 61 74 20 61 20 74 65 73 74 20  ld treat a test 
44f0: 66 61 69 6c 75 72 65 20 6f 66 20 61 20 66 6f 72  failure of a for
4500: 6d 65 72 6c 79 0a 61 63 63 65 70 74 65 64 20 63  merly.accepted c
4510: 6f 6d 70 6f 6e 65 6e 74 20 61 73 20 61 20 74 69  omponent as a ti
4520: 6d 65 64 20 77 61 72 6e 69 6e 67 2c 20 77 68 65  med warning, whe
4530: 72 65 20 74 68 65 20 77 61 72 6e 69 6e 67 20 73  re the warning s
4540: 74 61 74 65 20 6d 6f 76 65 73 20 74 6f 20 61 0a  tate moves to a.
4550: 62 6c 6f 63 6b 65 64 2f 66 61 69 6c 65 64 20 73  blocked/failed s
4560: 74 61 74 65 20 77 69 74 68 20 61 20 64 65 6c 61  tate with a dela
4570: 79 2e 20 54 68 65 20 64 65 6c 61 79 20 67 69 76  y. The delay giv
4580: 65 73 20 74 68 65 20 74 72 75 73 74 65 64 20 70  es the trusted p
4590: 61 72 74 79 20 74 69 6d 65 20 74 6f 0a 68 61 6e  arty time to.han
45a0: 64 6c 65 20 74 68 65 20 68 61 63 6b 2e 3c 2f 70  dle the hack.</p
45b0: 3e 0a 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a  >..<p><br>.</p>.
45c0: 0a 3c 70 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a 3c  .<p><br>.</p>..<
45d0: 68 31 3e 43 6f 6d 70 6f 6e 65 6e 74 73 20 74 6f  h1>Components to
45e0: 20 53 74 75 64 79 3c 2f 68 31 3e 0a 0a 3c 70 3e   Study</h1>..<p>
45f0: 3c 2f 70 3e 0a 3c 75 6c 3e 0a 3c 6c 69 3e 3c 61  </p>.<ul>.<li><a
4600: 20 68 72 65 66 3d 22 68 74 74 70 73 3a 2f 2f 66   href="https://f
4610: 69 72 65 6a 61 69 6c 2e 77 6f 72 64 70 72 65 73  irejail.wordpres
4620: 73 2e 63 6f 6d 2f 22 3e 46 69 72 65 6a 61 69 6c  s.com/">Firejail
4630: 3c 2f 61 3e 20 28 3c 61 20 68 72 65 66 3d 22 68  </a> (<a href="h
4640: 74 74 70 73 3a 2f 2f 67 69 74 68 75 62 2e 63 6f  ttps://github.co
4650: 6d 2f 6e 65 74 62 6c 75 65 33 30 2f 66 69 72 65  m/netblue30/fire
4660: 6a 61 69 6c 22 3e 73 72 63 3c 2f 61 3e 29 0a 69  jail">src</a>).i
4670: 73 20 61 20 4c 69 6e 75 78 20 73 70 65 63 69 66  s a Linux specif
4680: 69 63 20 63 6f 6d 70 6f 6e 65 6e 74 2c 20 62 75  ic component, bu
4690: 74 20 69 74 20 6d 69 67 68 74 20 62 65 20 61 20  t it might be a 
46a0: 75 73 65 66 75 6c 20 61 64 64 2d 6f 6e 20 6f 6e  useful add-on on
46b0: 20 4c 69 6e 75 78 2e 3c 2f 6c 69 3e 0a 3c 2f 75   Linux.</li>.</u
46c0: 6c 3e 0a 0a 3c 70 3e 3c 2f 70 3e 0a 0a 3c 70 3e  l>..<p></p>..<p>
46d0: 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 3c 62  <br>.</p>..<p><b
46e0: 72 3e 0a 3c 2f 70 3e 0a 0a 3c 68 31 3e 3c 61 20  r>.</p>..<h1><a 
46f0: 68 72 65 66 3d 22 2e 2f 77 69 6b 69 3f 6e 61 6d  href="./wiki?nam
4700: 65 3d 45 78 70 65 72 69 6d 65 6e 74 3a 2b 6d 6d  e=Experiment:+mm
4710: 6d 76 5f 73 69 6c 6b 65 78 65 63 3a 2b 73 75 62  mv_silkexec:+sub
4720: 2d 73 70 65 63 69 66 69 63 61 74 69 6f 6e 73 3a  -specifications:
4730: 22 3e 45 78 70 65 72 69 6d 65 6e 74 61 6c 0a 53  ">Experimental.S
4740: 75 62 73 70 65 63 69 66 69 63 61 74 69 6f 6e 73  ubspecifications
4750: 3c 2f 61 3e 3c 2f 68 31 3e 0a 0a 3c 70 3e 3c 62  </a></h1>..<p><b
4760: 72 3e 0a 3c 2f 70 3e 0a 0a 3c 68 31 3e 3c 61 20  r>.</p>..<h1><a 
4770: 68 72 65 66 3d 22 2e 2f 77 69 6b 69 3f 6e 61 6d  href="./wiki?nam
4780: 65 3d 45 78 70 65 72 69 6d 65 6e 74 3a 2b 6d 6d  e=Experiment:+mm
4790: 6d 76 5f 73 69 6c 6b 65 78 65 63 3a 2b 52 65 66  mv_silkexec:+Ref
47a0: 65 72 65 6e 63 65 73 22 3e 52 65 66 65 72 65 6e  erences">Referen
47b0: 63 65 73 3c 2f 61 3e 3c 2f 68 31 3e 0a 0a 3c 70  ces</a></h1>..<p
47c0: 3e 3c 62 72 3e 0a 3c 2f 70 3e 0a 0a 5a 20 39 35  ><br>.</p>..Z 95
47d0: 39 32 38 35 65 62 65 66 39 63 30 31 65 30 39 36  9285ebef9c01e096
47e0: 36 39 66 62 30 34 61 62 65 62 36 66 63 37 0a     69fb04abeb6fc7.