From a5c199982b37f7407f2bdfee0540f3e1092c04e8 Mon Sep 17 00:00:00 2001
From: Pawel Szostek <pawel.szostek@gmail.com>
Date: Fri, 12 Jul 2013 00:03:19 +0200
Subject: [PATCH] make debugging information more infromative

---
 src/dep_solver.py |  4 ++--
 src/module.py     | 37 ++++++++++++++++++++++---------------
 2 files changed, 24 insertions(+), 17 deletions(-)

diff --git a/src/dep_solver.py b/src/dep_solver.py
index 3b1b9b9a..2c911b10 100644
--- a/src/dep_solver.py
+++ b/src/dep_solver.py
@@ -213,7 +213,7 @@ class DependencySolver:
                     if not pf:
                         logging.error("Missing dependency in file "+str(f)+": " + req[0]+'.'+req[1])
                     else:
-                        logging.debug("--> " + pf.path)
+                        logging.debug("%s depends on %s" % (f.path, pf.path))
                         if pf.path != f.path:
                             f.dep_depends_on.append(pf)
             #get rid of duplicates by making a set from the list and vice versa
@@ -230,7 +230,7 @@ class DependencySolver:
                     if not pf:
                         logging.warning("Cannot find depending for file "+str(f)+": "+req)
                     else:
-                        logging.debug("--> " + pf.path)
+                        logging.debug("%s depends on %s " % (f.path, pf.path))
                         f.dep_depends_on.append(pf)
             #get rid of duplicates by making a set from the list and vice versa
             f.dep_depends_on = list(set(f.dep_depends_on))
diff --git a/src/module.py b/src/module.py
index 2e0415dd..fd786f74 100644
--- a/src/module.py
+++ b/src/module.py
@@ -40,6 +40,10 @@ class Module(object):
     #PLEASE don't use this constructor. Create all modules with ModulePool.new_module()
     def __init__(self, parent, url, source, fetchto, pool):
         import path
+
+        assert url is not None
+        assert source is not None
+
         self._manifest = None
         self.fetchto = fetchto
         self.pool = pool
@@ -163,7 +167,7 @@ class Module(object):
     def parse_manifest(self):
         if self._manifest:
             return
-        logging.debug("parse_manifest: %s" % self.path)
+        logging.debug(self.path)
         if self.isparsed is True or self.isfetched is False:
             return
         if self.manifest is None:
@@ -173,10 +177,11 @@ class Module(object):
         manifest_parser = ManifestParser()
 
         # For non-top modules
-        if(self.parent is not None):
+        if self.parent is not None:
             manifest_parser.add_arbitrary_code("target=\""+str(global_mod.top_module.target)+"\"")
             manifest_parser.add_arbitrary_code("action=\""+str(global_mod.top_module.action)+"\"")
             manifest_parser.add_arbitrary_code("syn_device=\""+str(global_mod.top_module.syn_device)+"\"")
+            manifest_parser.add_arbitrary_code("sim_tool=\""+str(global_mod.top_module.sim_tool)+"\"")
 
         manifest_parser.add_arbitrary_code("__manifest=\""+self.path+"\"")
         manifest_parser.add_arbitrary_code(global_mod.options.arbitrary_code)
@@ -185,7 +190,6 @@ class Module(object):
             logging.debug("No manifest found in module "+str(self))
         else:
             manifest_parser.add_manifest(self.manifest)
-            logging.debug("Parsing manifest file: " + str(self.manifest))
 
         opt_map = None
         try:
@@ -196,19 +200,22 @@ class Module(object):
         self._manifest = opt_map
 
     def process_manifest(self):
-        logging.debug("process_manifest %s" % self.path)
+        if self._manifest is None:
+            logging.debug("there is no manifest to be processed")
+            return
+        logging.debug(self.path)
         if self._manifest["syn_ise_version"] is not None:
             version = self._manifest["syn_ise_version"]
             if isinstance(version, float):
                 version = str(version).split('.')
                 major = version[0]
-                mino = version[1]
+                minor = version[1]
                 self.syn_ise_version = (major, minor)
             if isinstance(version, basestring):
                 parts = version.split('.')
                 #assert len(parts) = 2
                 self.syn_ise_version = (int(parts[0]), int(parts[1]))
-        if(self._manifest["fetchto"] is not None):
+        if self._manifest["fetchto"] is not None:
             fetchto = path_mod.rel2abs(self._manifest["fetchto"], self.path)
             self.fetchto = fetchto
         else:
@@ -277,8 +284,10 @@ class Module(object):
 
         if self._manifest["files"] == []:
             self.files = SourceFileSet()
+            logging.debug(None)
         else:
             self._manifest["files"] = self._flatten_list(self._manifest["files"])
+            logging.debug(self.path + str(self._manifest["files"]))
             paths = self._make_list_of_paths(self._manifest["files"])
             self.files = self._create_file_list_from_paths(paths=paths)
             for f in self.files:
@@ -295,13 +304,9 @@ class Module(object):
             self.sim_only_files = self._create_file_list_from_paths(paths=paths)
 
         self.syn_pre_cmd = self._manifest["syn_pre_cmd"]
-        #self._check_filepath(self.syn_pre_cmd)
         self.syn_post_cmd = self._manifest["syn_post_cmd"]
-        #self._check_filepath(self.syn_post_cmd)
         self.sim_pre_cmd = self._manifest["sim_pre_cmd"]
-        #self._check_filepath(self.sim_pre_cmd)
         self.sim_post_cmd = self._manifest["sim_post_cmd"]
-        #self._check_filepath(self.sim_post_cmd)
 
         self.bit_file_targets = SourceFileSet()
         if len(self._manifest["bit_file_targets"]) != 0:
@@ -347,21 +352,23 @@ class Module(object):
 
     def _make_list_of_paths(self, list_of_paths):
         paths = []
+        logging.debug(str(list_of_paths))
         for filepath in list_of_paths:
-            filepath = path_mod.rel2abs(filepath, self.path)
             if self._check_filepath(filepath):
-                paths.append(filepath)
+                paths.append(path_mod.rel2abs(filepath, self.path))
         return paths
 
     def _check_filepath(self, filepath):
         if filepath:
-            if not os.path.exists(filepath):
-                logging.error("Specified path doesn't exist: %s" % filepath)
-                quit()
             if path_mod.is_abs_path(filepath):
                 logging.warning("Specified path seems to be an absolute path: %s\nOmitting." % filepath)
                 #return False
                 return True
+            filepath = path_mod.rel2abs(filepath, self.path)
+            if not os.path.exists(filepath):
+                logging.error("Specified path doesn't exist: %s" % filepath)
+                quit()
+
             if not os.path.isfile(filepath):
                 logging.warning("Specified path is not a normal file: %s\nOmitting." % filepath)
                 #return False
-- 
GitLab