Patch title: Release 91 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/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"


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_tree files options path -> status
  arg List:FileInfo files ; arg Str options ; arg Str path ;
function cdrom_tree files path -> status
  arg List:FileInfo files ; arg Str path ; arg ExtendedStatus status
  var Pointer:FileInfo file :> files first
  while exists:file
    var Str name := file:options option "cdname" Str
    if name=""
      name := file_os_name file:name
    file_tree_create (path_concat path name)
    file_link file:name (path_concat path name)
    file :> files next file


function cdrom_record image options -> status
  arg Str image options ; arg ExtendedStatus status
  var Str engraver := "engraver"+(options option "engraver" 
  var Pointer:FileInfo file :> files first
  while exists:file
    var Str name := file:options option "cdname" Str
    if name=""
      name := file_os_name file:name
    file_tree_create (path_concat path name)
    file_link file:name (path_concat path name)
    file :> files next file


function cdrom_record image options -> status
  arg Str image options ; arg ExtendedStatus status
  var Str engraver := "engraver"+(options option "engraver" 
  var Str device := this_computer:env:"hardware":engraver:"d
  var Str interface := this_computer:env:"hardware":engraver
  var Str interface := this_computer:env:"hardware":engraver
  var Str medium := this_computer:env:"hardware":engraver:"medium"
  if medium=""
    medium := "cd"
  var Str device := this_computer:env:"hardware":engraver:"device"
  if device=""
    device := shunt interface="ide" "device:/hdc" interface="usb" or interface="scsi" "device:/scd0" ""
  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"
  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"
    execute "rmmod ide-cd" quiet
    execute "rmmod cdrom" quiet
    execute "insmod scsi_mod" quiet
    execute "insmod ide-scsi" quiet
    execute "insmod sg" quiet
    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"
  eif interface="usb"
    execute "insmod usbcore" quiet
    execute "insmod ehci-hcd" quiet
    execute "insmod usb-storage" quiet
    execute "insmod scsi_mod" quiet
    execute "insmod cdrom" quiet
    execute "insmod sr_mod" quiet
    execute "insmod sg" quiet
    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 "scsi_mod"
    kernel_load_module "cdrom"
    kernel_load_module "sr_mod"
    kernel_load_module "sg"
    sleep 5
  eif interface="scsi"
    sleep 5
  eif interface="scsi"
    execute "rmmod sr_mod" quiet
    execute "rmmod cdrom" quiet
    execute "insmod sg" quiet
    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=""
  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 := "0,0,0"
    dev := file_os_name (replace device "device:/scd" "device:/sg") # "0,0,0"
  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 := "-"
  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 (engraver_options option "growisofs")
  if medium<>"cd"
    rec := "growisofs -dvd-compat -use-the-force-luke -Z "+f
    stdin := "/proc/self/fd/0"
  var Int err
  part engrave
    rec := "growisofs -dvd-compat -use-the-force-luke -Z "+f
    stdin := "/proc/self/fd/0"
  var Int err
  part engrave
    if (options option "rw") and (engraver_options option "b
    if medium="cd" and (options option "rw") and (engraver_options option "blank" Str)<>"no"
      var Str blank := "cdrecord"
      blank += " dev="+dev
      blank += shunt speed=defined " speed="+string:speed ""
      blank += " blank="+(engraver_options option "blank" St
      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
        err := execute rec+file_os_name:image output "file:/
      else
        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"
      var Str blank := "cdrecord"
      blank += " dev="+dev
      blank += shunt speed=defined " speed="+string:speed ""
      blank += " blank="+(engraver_options option "blank" St
      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
        err := execute rec+file_os_name:image output "file:/
      else
        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"
    execute "rmmod sg" quiet
    execute "rmmod ide-scsi" quiet
    execute "rmmod scsi_mod" quiet
    execute "insmod cdrom" quiet
    execute "insmod ide-cd" quiet
    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"
  eif interface="scsi"
    execute "rmmod sg" quiet
    execute "insmod cdrom" quiet
    execute "insmod sr_mod" quiet
    kernel_unload_module "sg"
    kernel_load_module "cdrom"
    kernel_load_module "sr_mod"


function cdrom_engrave files options -> status
  arg List:FileInfo files ; arg Str options ; arg ExtendedSt
  var Str engraver := "engraver"+(options option "engraver" 
  var Str engraver_options := this_computer:env:"hardware":e
  var CBool indirect := (engraver_options option "indirect")
  if (options option "macintosh") and (options option "capac
    indirect := true
  var Str path := options option "path" Str
  if (options option "buggy") and path="" # workaround mkiso
    var Str temp := file_temporary+"/"


function cdrom_engrave files options -> status
  arg List:FileInfo files ; arg Str options ; arg ExtendedSt
  var Str engraver := "engraver"+(options option "engraver" 
  var Str engraver_options := this_computer:env:"hardware":e
  var CBool indirect := (engraver_options option "indirect")
  if (options option "macintosh") and (options option "capac
    indirect := true
  var Str path := options option "path" Str
  if (options option "buggy") and path="" # workaround mkiso
    var Str temp := file_temporary+"/"
    cdrom_tree files options temp
    cdrom_tree files temp
    status := cdrom_engrave (var List:FileInfo empty_list) o
    file_tree_delete temp
    return
  var Int capacity_mb := options option "capacity_mb" Int
  if capacity_mb=defined
    if ((cdrom_image files options+" query_size" ""):message
      if size>=capacity_mb*2n^20
        status := failure string:size+" bytes is too much fo
  if indirect
    var Str image := file_temporary
    status := cdrom_image files options image
    if status=success
      status := cdrom_record image options
    if status=success
      var Intn imagesize := (file_query image standard):size
      status message := string:imagesize+" bytes in the CD i
    file_delete image
  else
    var Str extra := ""
    if (engraver_options option "size") and ((cdrom_image fi
      extra += " size "+string:size
    stream_pipe (var Str pipe_in) (var Str pipe_out)
    var ExtendedStatus status1 status2
    part pipe "CD engraving pipe"
      parallel threads 2
        task
          share status1 := cdrom_image files options pipe_ou
        task
          share status2 := cdrom_record pipe_in options+extr
    status := shunt status1=failure status1 status2
  if debug and status=success
    file_delete "file:/tmp/mkisofs.log"



export cdrom_engrave
export cdrom_image cdrom_record
export cdrom_file
    status := cdrom_engrave (var List:FileInfo empty_list) o
    file_tree_delete temp
    return
  var Int capacity_mb := options option "capacity_mb" Int
  if capacity_mb=defined
    if ((cdrom_image files options+" query_size" ""):message
      if size>=capacity_mb*2n^20
        status := failure string:size+" bytes is too much fo
  if indirect
    var Str image := file_temporary
    status := cdrom_image files options image
    if status=success
      status := cdrom_record image options
    if status=success
      var Intn imagesize := (file_query image standard):size
      status message := string:imagesize+" bytes in the CD i
    file_delete image
  else
    var Str extra := ""
    if (engraver_options option "size") and ((cdrom_image fi
      extra += " size "+string:size
    stream_pipe (var Str pipe_in) (var Str pipe_out)
    var ExtendedStatus status1 status2
    part pipe "CD engraving pipe"
      parallel threads 2
        task
          share status1 := cdrom_image files options pipe_ou
        task
          share status2 := cdrom_record pipe_in options+extr
    status := shunt status1=failure status1 status2
  if debug and status=success
    file_delete "file:/tmp/mkisofs.log"



export cdrom_engrave
export cdrom_image cdrom_record
export cdrom_file