PageRenderTime 6ms CodeModel.GetById 1ms RepoModel.GetById 1ms app.codeStats 0ms

/scalate-core/src/main/scala/org/fusesource/scalate/support/AttributesHashMap.scala

http://github.com/scalate/scalate
Scala | 61 lines | 28 code | 12 blank | 21 comment | 3 complexity | d30daa59af2b28260b69cf3fbe32720a MD5 | raw file
  1. /**
  2. * Copyright (C) 2009-2011 the original author or authors.
  3. * See the notice.md file distributed with this work for additional
  4. * information regarding copyright ownership.
  5. *
  6. * Licensed under the Apache License, Version 2.0 (the "License");
  7. * you may not use this file except in compliance with the License.
  8. * You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. package org.fusesource.scalate.support
  19. import java.{ util => ju }
  20. import org.fusesource.scalate.AttributeMap
  21. import scala.collection.JavaConverters._
  22. /**
  23. * The default implementation for <code>AttributeMap</code> backed
  24. * by a map like collection.
  25. */
  26. class AttributesHashMap extends AttributeMap {
  27. private[this] val map = new ju.HashMap[String, Any]
  28. def get(key: String): Option[Any] = {
  29. val value = map.get(key)
  30. Option(value)
  31. }
  32. def apply(key: String): Any = {
  33. val answer = map.get(key)
  34. if (answer == null) {
  35. throw new NoSuchElementException("key " + key + " not available")
  36. } else {
  37. answer
  38. }
  39. }
  40. def update(key: String, value: Any): Unit = {
  41. map.put(key, value)
  42. }
  43. def remove(key: String): Option[Any] = {
  44. val value = map.remove(key)
  45. Option(value)
  46. }
  47. def keySet = map.keySet.asScala
  48. override def toString = map.toString
  49. }