Patch title: Release 92 bulk changes
Abstract:
File: /linux/storage/cdrom.pli
Key:
    Removed line
    Added line
   
module "/pliant/language/context.pli"
module "/pliant/language/stream.pli"
module "/pliant/language/stream/pipe.pli"
module "/pliant/fullpliant/this_computer.pli"
module "/pliant/linux/kernel/module.pli"
module "/pliant/linux/kernel/device.pli"
module "/pliant/admin/execute.pli"
module "/pliant/admin/file.pli"
module "/pliant/language/ui/ansi_terminal.pli"


function cdrom_image files options image -> status
  arg List:FileInfo files ; arg Str options ; arg Str image 
  var CBool query_size := options option "query_size"
  var Str path := options option "path" Str
  var Str boot := options option "boot" Str
  if path="" and not (exists  files:first)
    return failure:"Nothing to engrave"
  if path="" and boot<>""
    return failure:"Cannot engrave a bootable CD from a file
  var CBool backup := options option "backup"
  var Str mk:= "mkisofs -quiet -D"
  if (options option "linktransparent")
    mk += " -f"
  if boot<>""
    mk += " -R -b "+boot
  eif backup
    mk += " -R"
  else
    mk += " -r"
  var Str title := options option "title" Str
  if title<>""
    mk += " -V "+title
  if (options option "macintosh") and (options option "osx")
    mk += " -hfs --netatalk --osx-double"
  eif (options option "macintosh")
    mk += " -hfs --netatalk"
  eif (options option "osx")
    mk += " -hfs --osx-double"
  if (options option "windows")
    mk += " -J"
   var Str file_in file_out
  if query_size
    mk += " -print-size"
  eif file_os_name:image<>""
    mk += " -o "+file_os_name:image
  if path<>""
    mk += " "+file_os_name:path
  else
    var Str flist := file_temporary
    mk += " -graft-points -path-list "+file_os_name:flist+" 
    (var Stream s) open flist out+safe
    var Pointer:FileInfo file :> files next files:first
    while exists:file
      s writeline mkisofs_name:file
      file :> files next file
    if s:close=failure
      file_delete flist
      return failure:"Failed to generate files list temporar
module "/pliant/language/context.pli"
module "/pliant/language/stream.pli"
module "/pliant/language/stream/pipe.pli"
module "/pliant/fullpliant/this_computer.pli"
module "/pliant/linux/kernel/module.pli"
module "/pliant/linux/kernel/device.pli"
module "/pliant/admin/execute.pli"
module "/pliant/admin/file.pli"
module "/pliant/language/ui/ansi_terminal.pli"


function cdrom_image files options image -> status
  arg List:FileInfo files ; arg Str options ; arg Str image 
  var CBool query_size := options option "query_size"
  var Str path := options option "path" Str
  var Str boot := options option "boot" Str
  if path="" and not (exists  files:first)
    return failure:"Nothing to engrave"
  if path="" and boot<>""
    return failure:"Cannot engrave a bootable CD from a file
  var CBool backup := options option "backup"
  var Str mk:= "mkisofs -quiet -D"
  if (options option "linktransparent")
    mk += " -f"
  if boot<>""
    mk += " -R -b "+boot
  eif backup
    mk += " -R"
  else
    mk += " -r"
  var Str title := options option "title" Str
  if title<>""
    mk += " -V "+title
  if (options option "macintosh") and (options option "osx")
    mk += " -hfs --netatalk --osx-double"
  eif (options option "macintosh")
    mk += " -hfs --netatalk"
  eif (options option "osx")
    mk += " -hfs --osx-double"
  if (options option "windows")
    mk += " -J"
   var Str file_in file_out
  if query_size
    mk += " -print-size"
  eif file_os_name:image<>""
    mk += " -o "+file_os_name:image
  if path<>""
    mk += " "+file_os_name:path
  else
    var Str flist := file_temporary
    mk += " -graft-points -path-list "+file_os_name:flist+" 
    (var Stream s) open flist out+safe
    var Pointer:FileInfo file :> files next files:first
    while exists:file
      s writeline mkisofs_name:file
      file :> files next file
    if s:close=failure
      file_delete flist
      return failure:"Failed to generate files list temporar
  if debug
    console mk eol
  if query_size
    var Str ofile := file_temporary
    var Str efile := file_temporary
    var Int err := execute mk output ofile error efile
    s open ofile in+safe
    var Str oanswer := s readline
    s close
    file_delete ofile
    s open efile in+safe
    var Str eanswer := s readline
    s close
    file_delete efile
    status := shunt err=0 success (failure "mkisofs returned
    if (oanswer parse (var Intn sectors)) or (eanswer parse 
      status message := string sectors*2048n
  else
    var Int err
    part mk "Building CD "+title+" ISO9660 image"
      if file_os_name:image<>""
        err := execute mk output "file:/tmp/cdrom.log" mixed
      else
        err := execute mk output image error "file:/tmp/cdro
    status := shunt err=0 success failure:"Failed to build I
    if file_os_name:image<>"" and status=success and (file_q
      status := failure "mkisofs internal bug"
      if debug and path<>""
        file_tree_delete "file:/tmp/bug/"
        var Array:FileInfo pfiles := file_list path standard
        for (var Int i) 0 pfiles:size-1
          if (pfiles:i:name search ".AppleDouble/" -1)<>(-1)
            var Intn remain := pfiles:i:size
            (var Stream src) open path+pfiles:i:name in+safe
            (var Stream dest) open "file:/tmp/bug/"+pfiles:i
            var Address buf := memory_zallocate 4096 null
            while remain>0
              var Int step := shunt remain>4096 4096 (cast r
              src raw_read buf step
              dest raw_write buf step
              remain -= step
            memory_free buf
            src close
            dest close
          else
            var Intn remain := pfiles:i:size
            (var Stream dest) open "file:/tmp/bug/"+pfiles:i
            var Address buf := memory_zallocate 4096 null
            while remain>0
              var Int step := shunt remain>4096 4096 (cast r
              dest raw_write buf step
              remain -= step
            memory_free buf
            dest close
    if status=success
      file_delete "file:/tmp/cdrom.log"
    eif path=""
      file_delete "file:/tmp/cdrom.list"
      file_move flist "file:/tmp/cdrom.list"
  if path=""
    file_delete flist
  if debug
    (var Stream s) open "file:/tmp/mkisofs.log" out+safe
  if query_size
    var Str ofile := file_temporary
    var Str efile := file_temporary
    var Int err := execute mk output ofile error efile
    s open ofile in+safe
    var Str oanswer := s readline
    s close
    file_delete ofile
    s open efile in+safe
    var Str eanswer := s readline
    s close
    file_delete efile
    status := shunt err=0 success (failure "mkisofs returned
    if (oanswer parse (var Intn sectors)) or (eanswer parse 
      status message := string sectors*2048n
  else
    var Int err
    part mk "Building CD "+title+" ISO9660 image"
      if file_os_name:image<>""
        err := execute mk output "file:/tmp/cdrom.log" mixed
      else
        err := execute mk output image error "file:/tmp/cdro
    status := shunt err=0 success failure:"Failed to build I
    if file_os_name:image<>"" and status=success and (file_q
      status := failure "mkisofs internal bug"
      if debug and path<>""
        file_tree_delete "file:/tmp/bug/"
        var Array:FileInfo pfiles := file_list path standard
        for (var Int i) 0 pfiles:size-1
          if (pfiles:i:name search ".AppleDouble/" -1)<>(-1)
            var Intn remain := pfiles:i:size
            (var Stream src) open path+pfiles:i:name in+safe
            (var Stream dest) open "file:/tmp/bug/"+pfiles:i
            var Address buf := memory_zallocate 4096 null
            while remain>0
              var Int step := shunt remain>4096 4096 (cast r
              src raw_read buf step
              dest raw_write buf step
              remain -= step
            memory_free buf
            src close
            dest close
          else
            var Intn remain := pfiles:i:size
            (var Stream dest) open "file:/tmp/bug/"+pfiles:i
            var Address buf := memory_zallocate 4096 null
            while remain>0
              var Int step := shunt remain>4096 4096 (cast r
              dest raw_write buf step
              remain -= step
            memory_free buf
            dest close
    if status=success
      file_delete "file:/tmp/cdrom.log"
    eif path=""
      file_delete "file:/tmp/cdrom.list"
      file_move flist "file:/tmp/cdrom.list"
  if path=""
    file_delete flist
  if debug
    (var Stream s) open "file:/tmp/mkisofs.log" out+safe
    s writeline mk
    if path<>""
      s writeline "path is "+string:path
      var Array:FileInfo pfiles := file_list path standard+r
      var Intn total := 0
      for (var Int i) 0 pfiles:size-1
        # s writeline "  "+pfiles:i:name+"  "+(string pfiles
        total += pfiles:i:size
      s writeline (string pfiles:size)+" files "+string:tota
    else
      var Int count := 0 ; var Intn total := 0
      var Pointer:FileInfo file :> files next files:first
      while exists:file
        # s writeline "  "+file:name+"  "+(string file:size)
        count += 1 ; total += file size
        file :> files next file
      s writeline string:count+" files "+string:total+" byte
    if file_os_name:image<>""
      s writeline "ISO9660 file size is "+(string (file_quer
    if status=failure
      s writeline "error message is "+status:message


function cdrom_record image options -> status
  arg Str image options ; arg ExtendedStatus status
  var Str engraver := "engraver"+(options option "engraver" 
  var Str interface := this_computer:env:"hardware":engraver
  var Str medium := this_computer:env:"hardware":engraver:"m
  if medium=""
    medium := "cd"
  var Str device := this_computer:env:"hardware":engraver:"d
  if device=""
    device := shunt interface="ide" "device:/hdc" interface=
  var Str engraver_options := this_computer:env:"hardware":e
  if not (this_computer:env:"hardware":engraver:"speed" pars
    speed := undefined    
  if not (this_computer:env:"hardware":engraver:"cache_mb" p
    cache_mb := memory_assigned\16\2^20
    cache_mb := max (min cache_mb 16) 4
  if interface="ide"
    kernel_unload_module "ide-cd"
    kernel_unload_module "cdrom"
    kernel_load_module "scsi_mod"
    kernel_load_module "ide-scsi"
    kernel_load_module "sg"
  eif interface="usb"
    kernel_load_module "usbcore"
    if path<>""
      s writeline "path is "+string:path
      var Array:FileInfo pfiles := file_list path standard+r
      var Intn total := 0
      for (var Int i) 0 pfiles:size-1
        # s writeline "  "+pfiles:i:name+"  "+(string pfiles
        total += pfiles:i:size
      s writeline (string pfiles:size)+" files "+string:tota
    else
      var Int count := 0 ; var Intn total := 0
      var Pointer:FileInfo file :> files next files:first
      while exists:file
        # s writeline "  "+file:name+"  "+(string file:size)
        count += 1 ; total += file size
        file :> files next file
      s writeline string:count+" files "+string:total+" byte
    if file_os_name:image<>""
      s writeline "ISO9660 file size is "+(string (file_quer
    if status=failure
      s writeline "error message is "+status:message


function cdrom_record image options -> status
  arg Str image options ; arg ExtendedStatus status
  var Str engraver := "engraver"+(options option "engraver" 
  var Str interface := this_computer:env:"hardware":engraver
  var Str medium := this_computer:env:"hardware":engraver:"m
  if medium=""
    medium := "cd"
  var Str device := this_computer:env:"hardware":engraver:"d
  if device=""
    device := shunt interface="ide" "device:/hdc" interface=
  var Str engraver_options := this_computer:env:"hardware":e
  if not (this_computer:env:"hardware":engraver:"speed" pars
    speed := undefined    
  if not (this_computer:env:"hardware":engraver:"cache_mb" p
    cache_mb := memory_assigned\16\2^20
    cache_mb := max (min cache_mb 16) 4
  if interface="ide"
    kernel_unload_module "ide-cd"
    kernel_unload_module "cdrom"
    kernel_load_module "scsi_mod"
    kernel_load_module "ide-scsi"
    kernel_load_module "sg"
  eif interface="usb"
    kernel_load_module "usbcore"
    kernel_load_module "ehci-hcd" # 2.4
    kernel_load_module "ehci_hcd" # 2.6
    kernel_load_module "usb-storage"
    kernel_load_module "ehci_hcd"
    kernel_load_module "scsi_mod"
    kernel_load_module "cdrom"
    kernel_load_module "sr_mod"
    kernel_load_module "scsi_mod"
    kernel_load_module "cdrom"
    kernel_load_module "sr_mod"
    kernel_load_module "usb_storage"
    kernel_load_module "sg"
    kernel_load_module "sg"
    sleep 5
  eif interface="scsi"
    kernel_unload_module "sr_mod"
    kernel_unload_module "cdrom"
    kernel_load_module "sg"
  if (engraver_options option "pio")
    execute "hdparm -d0 "+file_os_name:device quiet
  eif (engraver_options option "dma")
    execute "hdparm -d1 "+file_os_name:device quiet
  if this_computer:env:"pliant":"system":"distribution"="ful
    for (var Int i) 0 15
      kernel_make_device "device:/sg"+string:i
    for (var Int i) 0 3
      kernel_make_device "device:/pg"+string:i
  var Str dev := this_computer:env:"hardware":engraver:"scsi
  if dev=""
  eif interface="scsi"
    kernel_unload_module "sr_mod"
    kernel_unload_module "cdrom"
    kernel_load_module "sg"
  if (engraver_options option "pio")
    execute "hdparm -d0 "+file_os_name:device quiet
  eif (engraver_options option "dma")
    execute "hdparm -d1 "+file_os_name:device quiet
  if this_computer:env:"pliant":"system":"distribution"="ful
    for (var Int i) 0 15
      kernel_make_device "device:/sg"+string:i
    for (var Int i) 0 3
      kernel_make_device "device:/pg"+string:i
  var Str dev := this_computer:env:"hardware":engraver:"scsi
  if dev=""
    dev := file_os_name (replace device "device:/scd" "devic
    dev := shunt interface="ide" "0,0,0" file_os_name:(replace device "device:/scd" "device:/sg")
  eif (dev parse (var Int scsi_id))
    dev := "0,"+dev+",0"
  eif (dev parse (var Int scsi_channel) "," (var Int scsi_id
    dev := dev+",0"
  var Str rec := "cdrecord"
  rec += shunt (options option "dummy") " -dummy" ""
  rec += shunt (engraver_options option "dao") " -dao" ""
  rec += shunt (engraver_options option "packet") " -packet"
  rec += shunt (engraver_options option "eject") " -eject" "
  rec += " dev="+dev
  rec += shunt speed=defined " speed="+string:speed ""
  rec += shunt cache_mb=defined " fs="+string:cache_mb+"m" "
  if file_os_name:image="" and (options option "size")
    rec += " tsize="+(string (options option "size" Intn)\20
  rec += " "
  var Str stdin := "-"
  if medium<>"cd"
  eif (dev parse (var Int scsi_id))
    dev := "0,"+dev+",0"
  eif (dev parse (var Int scsi_channel) "," (var Int scsi_id
    dev := dev+",0"
  var Str rec := "cdrecord"
  rec += shunt (options option "dummy") " -dummy" ""
  rec += shunt (engraver_options option "dao") " -dao" ""
  rec += shunt (engraver_options option "packet") " -packet"
  rec += shunt (engraver_options option "eject") " -eject" "
  rec += " dev="+dev
  rec += shunt speed=defined " speed="+string:speed ""
  rec += shunt cache_mb=defined " fs="+string:cache_mb+"m" "
  if file_os_name:image="" and (options option "size")
    rec += " tsize="+(string (options option "size" Intn)\20
  rec += " "
  var Str stdin := "-"
  if medium<>"cd"
    rec := "growisofs -dvd-compat -use-the-force-luke -Z "+f
    rec := "growisofs -dvd-compat"+(shunt (options option "rw") " -use-the-force-luke" "")+" -Z "+file_os_name:device+"="
    stdin := "/proc/self/fd/0"
  var Int err
  part engrave
    if medium="cd" and (options option "rw") and (engraver_o
      var Str blank := "cdrecord"
      blank += " dev="+dev
      blank += shunt speed=defined " speed="+string:speed ""
      blank += " blank="+(engraver_options option "blank" St
    stdin := "/proc/self/fd/0"
  var Int err
  part engrave
    if medium="cd" and (options option "rw") and (engraver_o
      var Str blank := "cdrecord"
      blank += " dev="+dev
      blank += shunt speed=defined " speed="+string:speed ""
      blank += " blank="+(engraver_options option "blank" St
      if debug
        console blank eol
      part blank "Blanking read/write CD"
        var Int seconds := engraver_options option "keyboard
        if seconds=defined
          stream_pipe (var Str pipe_in) (var Str pipe_out)
          thread
            (var Stream kbd) open pipe_out out+safe
            sleep seconds
            kbd writeline ""
            kbd flush anytime
          err := execute blank input pipe_in output "file:/t
        else
          err := execute blank output "file:/tmp/cdrom.log" 
      if err=0
        file_delete "file:/tmp/cdrom.log"
      else
        status := failure "Failed to blank RW CD"
        if file_os_name:image=""
          (var Stream pipe) open image in+safe ; pipe close
        leave engrave
    part record "Engraving ISO9660 image on CD "+(options op
      if file_os_name:image<>""
      part blank "Blanking read/write CD"
        var Int seconds := engraver_options option "keyboard
        if seconds=defined
          stream_pipe (var Str pipe_in) (var Str pipe_out)
          thread
            (var Stream kbd) open pipe_out out+safe
            sleep seconds
            kbd writeline ""
            kbd flush anytime
          err := execute blank input pipe_in output "file:/t
        else
          err := execute blank output "file:/tmp/cdrom.log" 
      if err=0
        file_delete "file:/tmp/cdrom.log"
      else
        status := failure "Failed to blank RW CD"
        if file_os_name:image=""
          (var Stream pipe) open image in+safe ; pipe close
        leave engrave
    part record "Engraving ISO9660 image on CD "+(options op
      if file_os_name:image<>""
        console rec+file_os_name:image eol
        if debug
          console rec+file_os_name:image eol
        err := execute rec+file_os_name:image output "file:/
      else
        err := execute rec+file_os_name:image output "file:/
      else
        console rec+stdin eol
        if debug
          console rec+stdin eol
        err := execute rec+stdin input image output "file:/t
    if err=0
      file_delete "file:/tmp/cdrom.log"
      status := success
    else
      status := failure "Failed to engrave the CD ISO9660 im
      if file_os_name:image<>""
        status message += " ("+(string (file_query image sta
  if interface="ide"
    kernel_unload_module "sg"
    kernel_unload_module "ide-scsi"
    kernel_unload_module "scsi_mod"
    kernel_load_module "cdrom"
    kernel_load_module "ide-cd"
  eif interface="scsi"
    kernel_unload_module "sg"
    kernel_load_module "cdrom"
    kernel_load_module "sr_mod"



export cdrom_engrave
export cdrom_image cdrom_record
export cdrom_file
        err := execute rec+stdin input image output "file:/t
    if err=0
      file_delete "file:/tmp/cdrom.log"
      status := success
    else
      status := failure "Failed to engrave the CD ISO9660 im
      if file_os_name:image<>""
        status message += " ("+(string (file_query image sta
  if interface="ide"
    kernel_unload_module "sg"
    kernel_unload_module "ide-scsi"
    kernel_unload_module "scsi_mod"
    kernel_load_module "cdrom"
    kernel_load_module "ide-cd"
  eif interface="scsi"
    kernel_unload_module "sg"
    kernel_load_module "cdrom"
    kernel_load_module "sr_mod"



export cdrom_engrave
export cdrom_image cdrom_record
export cdrom_file