]> git.tdb.fi Git - builder.git/blobdiff - source/dependencycache.cpp
Further changes for library compatibility
[builder.git] / source / dependencycache.cpp
index b2ba4e8ce953e9b92bd41d4c66443bf24c749237..f691d540190f65da3444ec97823562b3fb05afcd 100644 (file)
@@ -1,12 +1,12 @@
 /* $Id$
 
 This file is part of builder
-Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions
+Copyright © 2007-2009  Mikko Rasa, Mikkosoft Productions
 Distributed under the LGPL
 */
 
+#include <msp/core/maputils.h>
 #include <msp/fs/stat.h>
-#include <msp/io/except.h>
 #include <msp/io/file.h>
 #include <msp/io/print.h>
 #include <msp/strings/utils.h>
@@ -22,25 +22,17 @@ DependencyCache::DependencyCache(SourcePackage &p):
        changed(false)
 { }
 
-const StringList &DependencyCache::get_deps(const string &tgt) const
+void DependencyCache::set_deps(const string &tgt, const StringList &d)
 {
-       DepsMap::const_iterator i=deps.find(tgt);
-       if(i==deps.end())
-               throw KeyError("Unknown dependencies", tgt);
-
-       return i->second;
+       deps[tgt] = d;
+       changed = true;
 }
 
-void DependencyCache::set_deps(const string &tgt, const StringList &d)
+const StringList &DependencyCache::get_deps(const string &tgt) const
 {
-       deps[tgt]=d;
-       changed=true;
+       return get_item(deps, tgt);
 }
 
-/**
-Saves the depencency cache.  If there are no cached dependencies or they
-haven't been changed, does nothing.
-*/
 void DependencyCache::save() const
 {
        if(deps.empty() || !changed || package.get_builder().get_dry_run())
@@ -59,7 +51,7 @@ void DependencyCache::save() const
 
 void DependencyCache::load()
 {
-       string fn=(package.get_source()/".deps").str();
+       string fn = (package.get_source()/".deps").str();
 
        try
        {
@@ -68,12 +60,12 @@ void DependencyCache::load()
                string line;
                while(in.getline(line))
                {
-                       vector<string> parts=split(line, '|');
-                       deps[parts[0]]=StringList(parts.begin()+1, parts.end());
+                       vector<string> parts = split(line, '|');
+                       deps[parts[0]] = StringList(parts.begin()+1, parts.end());
                }
 
-               mtime=Time::TimeStamp::from_unixtime(FS::stat(fn).st_mtime);
+               mtime = FS::stat(fn).get_modify_time();
        }
-       catch(const IO::FileNotFound &)
+       catch(const IO::file_not_found &)
        { }
 }