Packages

  • package o1

    O1Library is a toolkit designed for the course Programming 1 (a.k.a. O1) at Aalto University.

    O1Library is a toolkit designed for the course Programming 1 (a.k.a. O1) at Aalto University. It contains an assortment of tools; most prominently, it provides a framework for simple graphical programming and utilities for playing sound.

    This is the front page of O1Library’s documentation. However, this is probably not the best place to start learning about O1Library as a student. That’s because the relevant content of this library is introduced bit by bit in the chapters of O1’s custom ebook alongside the associated programming concepts and assignments.

    You may still find this documentation useful as a reference. You can also find some optional content here that you may wish to try.

    This front page lists the content available in the top-level package called simply o1. These tools are available with the simple command import o1._ in your Scala programs. Some of them you’ll use a lot; some of them you won’t necessarily need at all.

    The tools listed here are actually implemented in a number of subpackages (o1.gui, o1.sound, etc.); what you see here are just “shortcut aliases” to those actual implementations. The aliases are here to make that convenient import command work and to provide you with this list of links to some of the more commonly used tools in O1Library. The subpackages also contain additional content not listed here.

    O1Library has been developed by Aleksi Lukkarinen and Juha Sorva. Several of the key components in o1.gui and o1.world are built upon Aleksi’s Scala Media Computation Library. Some parts of O1Library draw inspiration from the “teachpacks” of the Racket programming language.

    We are grateful to Riku Autio, Joonatan Honkamaa, Juhani Numminen, Leo Varis, Veera Kahva, and anonymous students for bug reports and fixes. We thank Otto Seppälä for helpful discussions.

    Definition Classes
    root
  • package gui

    This package contains tools for building simple GUIs.

    This package contains tools for building simple GUIs. The toolkit is particularly well suited to constructing GUIs that display information as 2D images and/or geometric shapes. It is not designed for demanding graphical needs that call for high efficiency. Some of the tools in this package are built on the Swing GUI library, and the two libraries can be used in combination.

    Some of the types in this package have aliases in the top-level package o1, so they are accessible to students simply via import o1._. Some of the package contents are not available in the top-level package or included in this documentation.

    Please note: One of this package’s key components (views) comes in multiple varieties, which which are defined in the subpackages o1.gui.mutable and o1.gui.immutable and not listed below. The View that is most commonly used in O1 (and aliased as o1.View in the top-level package) is o1.gui.mutable.ViewFrame.

    Definition Classes
    o1
  • object immutable

    This package contains a version of Views that is not much used in O1: views to immutable domain models.

    This package contains a version of Views that is not much used in O1: views to immutable domain models. In O1, the other implementation in o1.gui.mutable is more relevant.

    Definition Classes
    gui
  • abstract class ViewFrame[Model] extends ViewImpl.ViewFrame[Model] with ControlDefaults[Model]

    This class provides a framework for building simple GUIs.

    This class provides a framework for building simple GUIs. Each instance of the class is a graphical view to objects that represent the states of a domain model; those states can be (but are not required to be) immutable objects. A ViewFrame displays the model as graphics within a GUI frame.

    Note to students: this is not the view class that we commonly use in O1 but an alternative implementation. For the usual View, see here.

    The key method in the class is makePic, which the view calls automatically and repeatedly to determine which Pic to display in the frame at each moment in time. Concrete view objects must add an implementation for this abstract method.

    A view listens to GUI events within the frame, but it doesn’t really do anything when notified of an event; concrete instances of the class can override this behavior by overriding one of the “on methods” (onClick, onMouseMove, etc.). The view also runs an internal clock and can react to the passing of time (onTick).

    Just creating a view object is not enough to display it onscreen and start the clock; see the start method.

    Please note that even though this class is designed to work with immutable model states, the actual ViewFrame is not itself immutable.

    Model

    the type of the states of the model

    Definition Classes
    immutable
  • Traced

final class Traced[TraceData] extends ViewFrame[Model] with TraceGeneratingDefaults[Model, TraceData]

A view that wraps around another, collecting a log or trace of events while delegating its actual event-handling to the wrapped view. Provides additional methods for accessing such traces: trace, simulateAndGet, and startAndGet. A few examples of using these methods are given below.

simulate 500 clock ticks on the trace-collecing view and print the trace of clock ticks accompanied by descriptions of the view’äs model.

for((traceItem, traceEvent) <- myTracedView.simulateAndGet(500)) {
  println(traceEvent + ": " + traceItem)
}

Or, equivalently:

myTracedView.simulate(500)
for((traceItem, traceEvent) <- myTracedView.trace) {
  println(traceEvent + ": " + traceItem)
}

Alternatively, start the trace-collecting view and run it interactively until it is done or a tick limit is reached. Then print the trace of ticks and GUI events accompanied with descriptions of the view’s model.

val futureTrace = myTracedView.startAndGet(tickLimit=100) recover {
  case Aborted(message, partialTrace) => partialTrace
}
for(trace <- futureTrace; (traceItem, traceEvent) <- trace) {
  println(traceEvent + ": " + traceItem)
}
TraceData

the type of the model-state descriptions in the trace

Linear Supertypes
TraceGeneratingDefaults[Model, TraceData], GeneratesTrace[Model, TraceData], ViewFrame[Model], ControlDefaults[Model], TooltipDefaults, ViewImpl.ViewFrame[Model], View.Controls[Model], AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Traced
  2. TraceGeneratingDefaults
  3. GeneratesTrace
  4. ViewFrame
  5. ControlDefaults
  6. TooltipDefaults
  7. ViewFrame
  8. Controls
  9. AnyRef
  10. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Instance Constructors

  1. new Traced(extractTrace: (Model) => TraceData)

    extractTrace

    a function that determines how to describe a model state in the generated trace

Type Members

  1. final class Traced[TraceData] extends ViewFrame[Model] with TraceGeneratingDefaults[Model, TraceData]

    A view that wraps around another, collecting a log or trace of events while delegating its actual event-handling to the wrapped view.

    A view that wraps around another, collecting a log or trace of events while delegating its actual event-handling to the wrapped view. Provides additional methods for accessing such traces: trace, simulateAndGet, and startAndGet. A few examples of using these methods are given below.

    simulate 500 clock ticks on the trace-collecing view and print the trace of clock ticks accompanied by descriptions of the view’äs model.

    for((traceItem, traceEvent) <- myTracedView.simulateAndGet(500)) {
      println(traceEvent + ": " + traceItem)
    }

    Or, equivalently:

    myTracedView.simulate(500)
    for((traceItem, traceEvent) <- myTracedView.trace) {
      println(traceEvent + ": " + traceItem)
    }

    Alternatively, start the trace-collecting view and run it interactively until it is done or a tick limit is reached. Then print the trace of ticks and GUI events accompanied with descriptions of the view’s model.

    val futureTrace = myTracedView.startAndGet(tickLimit=100) recover {
      case Aborted(message, partialTrace) => partialTrace
    }
    for(trace <- futureTrace; (traceItem, traceEvent) <- trace) {
      println(traceEvent + ": " + traceItem)
    }
    TraceData

    the type of the model-state descriptions in the trace

    Definition Classes
    ViewFrame

Value Members

  1. final def adjustSpeed(newTickRate: Double): Unit

    Sets a new tick rate for the view, replacing any previously set by the constructor or this method.

    Sets a new tick rate for the view, replacing any previously set by the constructor or this method.

    Definition Classes
    ViewFrame
  2. final def close(): Unit

    Closes the view: stops it (as per stop), does any onClose effects, hides the GUI window, and possibly terminates the entire application (as per the constructor parameter).

    Closes the view: stops it (as per stop), does any onClose effects, hides the GUI window, and possibly terminates the entire application (as per the constructor parameter).

    Definition Classes
    ViewFrame
  3. val closeWhenDone: Boolean
    Definition Classes
    ViewFrame
  4. def icon: Option[Pic]

    The icon to be displayed in the title bar of this view’s GUI frame.

    The icon to be displayed in the title bar of this view’s GUI frame.

    Definition Classes
    ViewFrame
  5. final def icon_=(icon: Pic): Unit

    Sets the icon to be displayed in the title bar of this view’s GUI frame.

    Sets the icon to be displayed in the title bar of this view’s GUI frame.

    icon

    a picture to be used as the icon

    Definition Classes
    ViewFrame
  6. final def icon_=(icon: Option[Pic]): Unit

    Sets the icon to be displayed in the title bar of this view’s GUI frame.

    Sets the icon to be displayed in the title bar of this view’s GUI frame.

    icon

    a picture to be used as the icon; if None, en empty icon image will be displayed

    Definition Classes
    ViewFrame
  7. def isDone(state: Model): Boolean

    Determines if the given state is a “done state” for the view.

    Determines if the given state is a “done state” for the view. This implementation delegates to the underlying View that is being traced.

    state

    a state of the model (possibly a done state)

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  8. final def isPaused: Boolean

    Indicates whether the view is paused.

    Indicates whether the view is paused. This implementation delegates to the underlying View that is being traced.

    Definition Classes
    GeneratesTrace → Controls
  9. def makePic(state: Model): Pic

    Returns a Pic that graphically represents the current state of the view’s model object.

    Returns a Pic that graphically represents the current state of the view’s model object. This implementation delegates to the underlying View that is being traced.

    state

    a state of the model to be displayed

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  10. def onClick(state: Model, event: event.MouseClicked): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the click event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  11. def onClick(state: Model, position: Pos): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the click event

    position

    the position of the mouse cursor relative to the view’s top left-hand corner

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  12. def onClose(): Unit

    Causes an effect when the view’s GUI window is closed for any reason.

    Causes an effect when the view’s GUI window is closed for any reason. By default, this method does nothing.

    Definition Classes
    ViewFrame
  13. def onKeyDown(state: Model, event: event.KeyPressed): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the keyboard event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  14. def onKeyDown(state: Model, key: Key): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the keyboard event

    key

    the key that was pressed down

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  15. def onKeyUp(state: Model, event: event.KeyReleased): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the keyboard event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  16. def onKeyUp(state: Model, key: Key): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the keyboard event

    key

    the key that was released

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  17. def onMouseDown(state: Model, event: event.MousePressed): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the mouse event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  18. def onMouseDown(state: Model, position: Pos): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the mouse event

    position

    the position of the mouse cursor relative to the view’s top left-hand corner

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  19. def onMouseDrag(state: Model, event: event.MouseDragged): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the drag event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  20. def onMouseDrag(state: Model, position: Pos): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the drag event

    position

    the position of the mouse cursor relative to the view’s top left-hand corner

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  21. def onMouseEnter(state: Model, event: event.MouseEntered): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the mouse event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  22. def onMouseExit(state: Model, event: event.MouseExited): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the mouse event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  23. def onMouseMove(state: Model, event: event.MouseMoved): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the move event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  24. def onMouseMove(state: Model, position: Pos): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the move event

    position

    the position of the mouse cursor relative to the view’s top left-hand corner

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  25. def onMouseUp(state: Model, event: event.MouseReleased): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the mouse event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  26. def onMouseUp(state: Model, position: Pos): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the mouse event

    position

    the position of the mouse cursor relative to the view’s top left-hand corner

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  27. final def onStop(): Unit

    Causes an additional effect when the view is stopped (with stop()).

    Causes an additional effect when the view is stopped (with stop()). This implementation delegates to the underlying View that is being traced. In addition, if the traced view had been started with startAndGet and reaches its tick limit before being done, this method causes the returned future to complete with a failure.

    Definition Classes
    GeneratesTrace → Controls
  28. def onTick(previousState: Model, time: Long): Model

    Handles a clock tick and adds it to the view’s trace.

    Handles a clock tick and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    previousState

    the state of the model before the clock tick

    time

    the running number of the clock tick (the first tick being number 1, the second 2, etc.)

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  29. def onTick(previousState: Model): Model

    Handles a clock tick and adds it to the view’s trace.

    Handles a clock tick and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    previousState

    the state of the model before the clock tick

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  30. def onType(state: Model, event: event.KeyTyped): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the keyboard event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  31. def onType(state: Model, character: Char): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the keyboard event

    character

    the key that was typed

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  32. def onWheel(state: Model, event: event.MouseWheelMoved): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the wheel event

    event

    the GUI event that caused this handler to be called

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  33. def onWheel(state: Model, rotation: Int): Model

    Handles a GUI event and adds it to the view’s trace.

    Handles a GUI event and adds it to the view’s trace. Delegates the actual event-handling to the corresponding method on the underlying View that is being traced.

    state

    the state of the model at the time of the wheel event

    rotation

    the number of steps the wheel rotated (negative means up, positive down)

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  34. final def refresh(): Unit

    Programmatically requests an update to the graphics of the view (even though no clock tick or triggering GUI event occurred).

    Programmatically requests an update to the graphics of the view (even though no clock tick or triggering GUI event occurred).

    Definition Classes
    ViewFrame
  35. val refreshPolicy: RefreshPolicy
    Definition Classes
    ViewFrame
  36. final def simulate(tickLimit: Int = Int.MaxValue): Unit

    Runs the view as if by calling start except that it runs “headless”, with no actual GUI window visible and independently of a real-time clock.

    Runs the view as if by calling start except that it runs “headless”, with no actual GUI window visible and independently of a real-time clock. A number of simulated clock ticks are immediately sent to the view; this continues until either the view determines it is done or a predetermined maximum number of ticks has been reached.

    tickLimit

    the maximum number of ticks to simulate; Int.MaxValue (which is the default) means there is no such limit

    Definition Classes
    ViewFrame → Controls
  37. final def simulateAndGet(tickLimit: Int = Int.MaxValue): Seq[(TraceData, TraceEvent)]

    Simulates this trace-generating view with simulate and returns the resulting trace.

    Simulates this trace-generating view with simulate and returns the resulting trace. This is equivalent to calling first simulate, then trace. See also startAndGet.

    tickLimit

    the maximum number of ticks to simulate; Int.MaxValue (which is the default) means there is no such limit

    Definition Classes
    GeneratesTrace
  38. def sound(state: Model): Option[sound.sampled.Sound]

    Determines whether the view should play a sound, given a state of its model.

    Determines whether the view should play a sound, given a state of its model. This implementation delegates to the underlying underlying View that is being traced.

    state

    a state of the model

    returns

    a Sound that the view should play; None if no sound is appropriate for the given state

    Definition Classes
    TraceGeneratingDefaults → ControlDefaults → Controls
  39. final def start(): Unit

    Starts the view: loads the model in the GUI window, makes the window visible oncreen, and starts the clock.

    Starts the view: loads the model in the GUI window, makes the window visible oncreen, and starts the clock. Cf. simulate.

    Definition Classes
    ViewFrame → Controls
  40. final def startAndGet(tickLimit: Long = Long.MaxValue): Future[Seq[(TraceData, TraceEvent)]]

    Starts this trace-generating view with start and returns a Future that evaluates to the resulting trace.

    Starts this trace-generating view with start and returns a Future that evaluates to the resulting trace. The Future succeeds when the view is done; if the view isn’t done after a given number of clock ticks, the Future fails with Aborted, producing a partial trace. See also simulateAndGet.

    tickLimit

    the maximum number of ticks to process before the future completes with a failure

    Definition Classes
    GeneratesTrace
  41. final def stop(): Unit

    Stops the view: stops the clock, stops listening to events, and disposes of the GUI window.

    Stops the view: stops the clock, stops listening to events, and disposes of the GUI window. A stopped view cannot be restarted.

    Definition Classes
    ViewFrame
  42. val terminateOnClose: Boolean
    Definition Classes
    ViewFrame
  43. final def toString: String

    Returns a brief textual description of the view.

    Returns a brief textual description of the view.

    Definition Classes
    GeneratesTrace → AnyRef → Any
  44. final def tooltip: String

    the tooltip text to be displayed while the mouse overs on the view

    the tooltip text to be displayed while the mouse overs on the view

    Definition Classes
    ViewFrame
  45. final def tooltip_=(newText: String): Unit

    Sets the tooltip text to be displayed while the mouse overs on the view.

    Sets the tooltip text to be displayed while the mouse overs on the view.

    Definition Classes
    ViewFrame
  46. final def trace: Seq[(TraceData, TraceEvent)]

    Returns a trace of the events processed by this view.

    Returns a trace of the events processed by this view. The trace comes in a collection of pairs, each of which is composed of a TraceData value that describes at the time of the event and a TraceEvent value that describes the event itself.

    Definition Classes
    GeneratesTrace
  47. final def traced: Traced[Model]

    Returns a View that stores a trace of the ticks and GUI events that its event handlers process.

    Returns a View that stores a trace of the ticks and GUI events that its event handlers process. This parameterless method stores, at each event, the (immutable) state of the View’s model. This is equivalent to calling tracedWith and passing in identity.

    Definition Classes
    ControlDefaults
  48. final def tracedPics: Traced[Pic]

    Returns a View that stores a pictorial trace of the ticks and GUI events that the View’s event handlers process.

    Returns a View that stores a pictorial trace of the ticks and GUI events that the View’s event handlers process. This is equivalent to calling tracedWith and passing in the View’s makePic method.

    Definition Classes
    ControlDefaults
  49. final def tracedWith[TraceData](extractTrace: (Model) => TraceData): Traced[TraceData]

    Returns a view that collects of the ticks and GUI events that the View’s event handlers process, using the given function to generate that trace.

    Returns a view that collects of the ticks and GUI events that the View’s event handlers process, using the given function to generate that trace. That trace-collecting view, which an instance of the Traced subclass, delegates the actual event handling to this original view but provides an additional interface for tracing.

    TraceData

    the type of the model-state descriptions in the trace

    extractTrace

    a function that determines how to describe a model state in the generated trace

    Definition Classes
    ViewFrame → ControlDefaults
    See also

    traced, tracedPics

  50. final def visible: Boolean

    whether this view’s GUI frame is visible onscreen

    whether this view’s GUI frame is visible onscreen

    Definition Classes
    ViewFrame
  51. final def visible_=(desiredVisibility: Boolean): Unit

    Sets whether this view’s GUI frame is visible onscreen.

    Sets whether this view’s GUI frame is visible onscreen.

    Definition Classes
    ViewFrame