附加清单[数据库]

时间:2010-08-01 02:31:38

标签: scala lift

我是Scala的新手,我正在编写一个简单的rss阅读器。 我有班级经理来管理订阅源和内容。

package lib
import scala.xml._
import java.net.URL
import net.liftweb.couchdb.{CouchDB, Database}
import dispatch.{Http, StatusCode}

/**
 * @author smix
 * 
 * Feeds manager
 */
object Manager {
 var db = List[Database]()
 /*
  * Initialize CouchDb databases
  */
 def init = {
  this.appendDb(new Database("myserver.com", 5984, "content"))
 }

 /*
  * Append a new database to the databases list
  */
 private def appendDb(database: Database) : Unit = {
  database :: db 
  // Strange exception if database has been already created
  /* try {
   this.db.head.createIfNotCreated(new Http())
  } catch {
   case e:java.lang.NoClassDefFoundError => {}
  } */
 }

 /*
  * Fetch articles from feed by url
  */
    def fetchItems(feedUrl: String): List[scala.xml.Elem] = { 
   val rssFeed = XML.load( (new URL(feedUrl)).openConnection.getInputStream )
   val items = rssFeed \ "channel" \ "item"

   val articles: List[scala.xml.Elem] = List()
   for(item <- items) {
      item :: articles
   }

   articles
    }

}

我想在CouchDb中存储内容。我需要有沙发数据库列表(供稿,文章等)。我写了课,但是当我调用appendDb时,我得到一个错误:

Exception in thread "main" java.lang.NoClassDefFoundError: lib/Manager$
 at collector$.main(collector.scala:5)
 at collector.main(collector.scala)
Caused by: java.lang.ClassNotFoundException: lib.Manager$
 at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
 at java.security.AccessController.doPrivileged(Native Method)
 at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
 at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
 at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
 at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
 ... 2 more

当我重新编辑db定义:var db = List[Int]()并且第一行appendDb:1 :: this.db项目运行正常...奇怪。

另外,有趣的是,当我为现有数据库调用createIfNotCreated时,为什么会出现异常(在appendDb中注释了try-catch块)。

1 个答案:

答案 0 :(得分:2)

该异常表示您在运行程序时缺少某些类(可能是一个或多个JAR文件),尽管它们与编译它们无关,或者它们 可用。

你还应该注意appendDb中的第一行没有任何结果。它通过将List置于database引用的List的前面来构建新的db,但结果值将被丢弃。也许你的意思是:

  db = database :: db