OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [insight/] [gdb/] [gdbtcl/] [helpviewer.itb] - Rev 578

Go to most recent revision | Compare with Previous | Blame | View Log

# Viewer for HTML help info
# Copyright 1998, 1999 Cygnus Solutions
#
# This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License (GPL) as published by
# the Free Software Foundation; either version 2 of the License, or (at
# your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.


# -----------------------------------------------------------------------------
# NAME: 
#       HtmlViewer::constructor
#
# SYNOPSIS:     
#       constructor args
#
# DESC: 
#       Creates the Help Viewer window.
# -----------------------------------------------------------------------------
body HtmlViewer::constructor {args} {
  window_name "Help"
  eval itk_initialize $args
  _buildwin
}


# -----------------------------------------------------------------------------
# NAME: 
#       private method HtmlViewer::_buildwin
#
# SYNOPSIS:     
#       _buildwin args
#
# DESC: 
#       This function is called by the constructor to build the widget. It
#       creates pulldown menus, buttons, a stack, and a scrolledhtml widget.
#       Finally it loads help/index.html.  This last step should change if
#       this widget is ever used for anything but help.
# -----------------------------------------------------------------------------
body HtmlViewer::_buildwin {} {
  global GDBTK_LIBRARY gdb_ImageDir

  set _links [PageStack \#auto]
  
  # create pulldown menu
  set menu [menu $itk_interior.m -tearoff 0]
  $menu add cascade -menu $menu.file -label "File" -underline 0
  set _m [menu $menu.file]
  $_m add command -label "Back" -underline 0 -command "$this back"
  $_m add command -label "Forward" -underline 0 -command "$this forward"
  $_m add command -label "Home" -underline 0 -command "$this link $file"
  $_m add separator
  $_m add command -label "Close" -underline 0 -command "delete object $this"
  $menu add cascade -menu $menu.topic -label "Topics" -underline 0
  set _t [menu $menu.topic]
  foreach t $topics {
    $_t add command -label [lindex $t 0] -command "$this link [lindex $t 1]"
  }
  [winfo toplevel $itk_interior] configure -menu $menu
  
  # create buttons
  set _f [frame $itk_interior.b]
  button $_f.back -command "$this back" \
    -image [image create photo -file [file join $gdb_ImageDir back.gif]]
  button $_f.fore -command "$this forward" \
    -image [image create photo -file [file join $gdb_ImageDir fore.gif]]
  button $_f.home -command "$this link $file" \
    -image [image create photo -file [file join $gdb_ImageDir home.gif]]
  standard_toolbar $_f $_f.back $_f.fore $_f.home
  
  _enable 0 back fore

  # create html widget
  set _html [iwidgets::scrolledhtml $itk_interior.a -linkcommand "$this link"]

  # get things going by loading index.html
  $_html import [file join $GDBTK_LIBRARY help $file]
  $_links push $file
  
  pack $_f -side top -fill x
  pack $_html -expand yes -fill both

}

# -----------------------------------------------------------------------------
# NAME:         public method PageStack::push
# SYNOPSIS:     push val
# DESC:         Pushes a value onto the stack.
# -----------------------------------------------------------------------------
body PageStack::push {val} {
  incr _ptr
  incr _max
  if {$_ptr < $_max} {
    set _max $_ptr
  }
  set _stack($_ptr) $val
}

# -----------------------------------------------------------------------------
# NAME:         public method PageStack::back
# SYNOPSIS:     back
# DESC:         Moves the stack pointer back by one.
# RETURNS:      Returns the value on the stack, or 0 on error.
# -----------------------------------------------------------------------------
body PageStack::back {} {
  if {$_ptr > 0} {
    incr _ptr -1
    return $_stack($_ptr)
  }
  return 0
}

# -----------------------------------------------------------------------------
# NAME:         public method PageStack::next
# SYNOPSIS:     next
# DESC:         Moves the stack pointer forward by one.
# RETURNS:      Returns the value on the stack, or 0 on error.
# -----------------------------------------------------------------------------
body PageStack::next {} {
  if {$_ptr < $_max} {
    incr _ptr
    return $_stack($_ptr)
  }
  return 0
}

# -----------------------------------------------------------------------------
# NAME:         public method PageStack:more
# SYNOPSIS:     more
# DESC:         Indicates if the stack pointer is not at the top.
# RETURNS:      Returns 1 if PageStack::next will suceed, 0 otherwise.
# -----------------------------------------------------------------------------
body PageStack::more {} {
  if {$_ptr < $_max} {
    return 1
  }
  return 0
}

# -----------------------------------------------------------------------------
# NAME:         public method PageStack:less
# SYNOPSIS:     less
# DESC:         Indicates if the stack pointer is not at the bottom of stack.
# RETURNS:      Returns 1 if PageStack::back will suceed, 0 otherwise.
# -----------------------------------------------------------------------------
body PageStack::less {} {
  if {$_ptr > 0} {
    return 1
  }
  return 0
}

# -----------------------------------------------------------------------------
# NAME:         public method PageStack:current
# SYNOPSIS:     current
# RETURNS:      Returns the current value on the stack.
# -----------------------------------------------------------------------------
body PageStack::current {} {
  if {$_ptr > 0} {
    return $_stack($_ptr)
  }
  return 0
}

# ------------------------------------------------------------------------------
# NAME:         
#       private method HtmlViewer::_enable
#
# SYNOPSIS:     
#       _enable { on args }
#
# DESC:         
#       Enables or disables buttons and menus.
#
# ARGS: 
#       on - "1" to enable, "0" to disable
#       args - things to enable/disable.  May include "back",
#       "fore", and "home"
#
# ------------------------------------------------------------------------------
body HtmlViewer::_enable { on args } {
  if {$on} {
    set state normal
  } else {
    set state disabled
  }
  
  foreach a $args {
    switch $a {
      back {
        # set state of "back"
        $_m entryconfigure 0 -state $state
        $_f.back configure -state $state
      }
      fore {
        # set state of "forward"
        $_m entryconfigure 1 -state $state
        $_f.fore configure -state $state
      }
      home {
        # set state of "home"
        $_m entryconfigure 2 -state $state
        $_f.home configure -state $state
      }
    }
  }
}

# ------------------------------------------------------------------------------
# NAME:         public method HtmlViewer::back
# SYNOPSIS:     back
# DESC:         Moves to the previous page
# ------------------------------------------------------------------------------
body HtmlViewer::back {} {
  set res [$_links back]
  if {$res != 0} {
    load $res
    if {![$_links less]} {
      _enable 0 back
    }
  }
}

# ------------------------------------------------------------------------------
# NAME:         public method HtmlViewer::forward
# SYNOPSIS:     forward
# DESC:         Moves to the next page
# ------------------------------------------------------------------------------
body HtmlViewer::forward {} {
  set res [$_links next]
  if {$res != 0} {
    load $res
    if {![$_links more]} {
      _enable 0 fore
    }
  }
}

# ------------------------------------------------------------------------------
# NAME:         public method HtmlViewer::link
# SYNOPSIS:     link page
# ARDS:         page - link to the page to load
# DESC:         Saves the page on the stack and calls the "load" method
# ------------------------------------------------------------------------------
body HtmlViewer::link {page} {
  if {$page != [$_links current]} {
    $_links push $page
    load $page
    if {![$_links more]} {
      _enable 0 fore
    }
  }
}

# ------------------------------------------------------------------------------
# NAME:         private method HtmlViewer::load
# SYNOPSIS:     load link
# DESC:         Disables menus and buttons, sets cursor, loads a page into 
#               the html widget, then resets cursor and enables the menus 
#               and buttons
# ------------------------------------------------------------------------------
body HtmlViewer::load {link} {
  _enable 0 back fore home
  $itk_interior configure -cursor watch
  $_html import -link $link
  $itk_interior configure -cursor ""    
  _enable 1 back fore home
}

# ------------------------------------------------------------------------------
# NAME:         public proc HtmlViewer::open_help
# SYNOPSIS:     HtmlViewer::open_help file
# DESC:         If the prefs are set to use a browser, attempts
#               to do so. Otherwise, uses builtin HtmlViewer class.
# ------------------------------------------------------------------------------
body HtmlViewer::open_help {hfile} {
  set link file://[file join $::GDBTK_LIBRARY help $hfile]
  if {![pref get gdb/help/browser] || ![::open_url $link]} {
    ManagedWin::open HtmlViewer -file $hfile
  }
}

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.