install.dt.ibm.src 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. XCOMM $XConsortium: install.dt.ibm.src /main/3 1996/04/21 19:06:56 drk $
  2. XCOMM ==========================================================================
  3. XCOMM ==========================================================================
  4. XCOMM install.dt.ibm
  5. XCOMM
  6. XCOMM Platform specific function overrides for the April 1994 Snapshot
  7. XCOMM install script, install.dt.
  8. XCOMM
  9. XCOMM This file is sourced by the install.dt script to allow platform
  10. XCOMM specific behavior for certain functionality. These functions are:
  11. XCOMM
  12. XCOMM DtiClearScreen() - clear the screen
  13. XCOMM DtiFreeSpace() - return available bytes in a directory
  14. XCOMM DtiVerifyConfiguration() - verify system configuration
  15. XCOMM DtiWhoami() - return user name
  16. XCOMM
  17. XCOMM ==========================================================================
  18. XCOMM ==========================================================================
  19. XCOMM
  20. XCOMM DtiClearScreen() - clears the screen
  21. XCOMM
  22. XCOMM The default DtiClearScreen() uses the 'clear' command to clear the
  23. XCOMM screen. If this platform does not have the 'clear' command,
  24. XCOMM declare DtiClearScreen() here with the appropriate functionality.
  25. XCOMM
  26. XCOMM Note: The default DtiClearScreen() writes to stderr, rather than stdout,
  27. XCOMM so be sure to do the same here. DtiPrint() does this automatically, so
  28. XCOMM use it if possible.
  29. XCOMM
  30. XCOMM Example:
  31. XCOMM
  32. XCOMM DtiClearScreen()
  33. XCOMM {
  34. XCOMM DtiPrint "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n"
  35. XCOMM DtiPrint "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n"
  36. XCOMM }
  37. XCOMM
  38. XCOMM Input - none
  39. XCOMM Output - none
  40. XCOMM Return -none
  41. XCOMM ==========================================================================
  42. XCOMM DtiClearScreen() {
  43. XCOMM clear 1>&2
  44. XCOMM }
  45. XCOMM ==========================================================================
  46. XCOMM
  47. XCOMM DtiFreeSpace
  48. XCOMM
  49. XCOMM The default DtiFreeSpace() does not check for free space, rather it
  50. XCOMM simply returns a BigNumber that install.dt will assume is large
  51. XCOMM enough in which to install the desktop.
  52. XCOMM
  53. XCOMM Declare DtiFreeSpace() here to return the actual available space for
  54. XCOMM a particular directory.
  55. XCOMM
  56. XCOMM The $1 parameter will contain the directory name to test. The directory
  57. XCOMM specified will exist. DtiFreeSpace() should return the number of bytes
  58. XCOMM available via the DtiReturn() function.
  59. XCOMM
  60. XCOMM Input
  61. XCOMM $1 - directory name
  62. XCOMM Output - none
  63. XCOMM Return
  64. XCOMM number of bytes available
  65. XCOMM
  66. XCOMM ==========================================================================
  67. DtiFreeSpace()
  68. {
  69. dtspace=`df $1 | awk '
  70. BEGIN{
  71. a = 1
  72. }
  73. {
  74. if($1 == "Filesystem") {
  75. getline
  76. space = $3*1024
  77. }
  78. }
  79. END{
  80. a = space
  81. print a
  82. } ' `
  83. DtiReturn $dtspace
  84. }
  85. XCOMM ==========================================================================
  86. XCOMM
  87. XCOMM DtiVerifyConfiguration
  88. XCOMM
  89. XCOMM The default DtiVerifyConfiguration() does no system configuration
  90. XCOMM testing. For a particular platform, one might want to test for
  91. XCOMM the presence of X11R5 or the OS version, for example, before allowing
  92. XCOMM the desktop to be installed.
  93. XCOMM
  94. XCOMM Declare this function to make such platform specific tests. Return
  95. XCOMM "yes" if the system passed, or "<message text>" if the system failed
  96. XCOMM in which case install.dt will display the <message text> as the reason.
  97. XCOMM
  98. XCOMM Input - none
  99. XCOMM Output - none
  100. XCOMM Return
  101. XCOMM "yes" - system configuration verified
  102. XCOMM "<message text>" - verification failed, display message text
  103. XCOMM
  104. XCOMM ==========================================================================
  105. DtiVerifyConfiguration()
  106. {
  107. IsX11R5=`lslpp -h | awk '
  108. BEGIN {
  109. X11R5=0
  110. }
  111. /X11rte.obj/ {
  112. getline
  113. if(($1 == "01.02.0003.0000") && ($2 == "COMPLETE")) {
  114. X11R5=1
  115. exit 1
  116. }
  117. }
  118. END {
  119. print X11R5
  120. }'`
  121. if [ $IsX11R5 = 1 ];
  122. then
  123. DtiReturn "yes"
  124. else
  125. DtiReturn "The Desktop requires that X11R5 be installed on your system.\n
  126. 0) Continue with Desktop Installation
  127. 99) Exit Desktop Installation
  128. Please enter selection: "
  129. fi
  130. }
  131. XCOMM ==========================================================================
  132. XCOMM
  133. XCOMM DtiWhoami
  134. XCOMM
  135. XCOMM The default DtiWhoami() uses the 'whoami' command to determine
  136. XCOMM the user name. If this platform does not have the 'whoami' command,
  137. XCOMM declare DtiWhoami() here with the appropriate functionality.
  138. XCOMM
  139. XCOMM Input - none
  140. XCOMM Output - none
  141. XCOMM Return
  142. XCOMM result of system 'whoami' command
  143. XCOMM
  144. XCOMM ==========================================================================
  145. XCOMM DtiWhoami()
  146. XCOMM {
  147. XCOMM whoami
  148. XCOMM }