]> git.llucax.com Git - software/sercom-old.git/blobdiff - src/sercom/sqlo.py
sc_codegen acepta un directorio de bibliotecas.
[software/sercom-old.git] / src / sercom / sqlo.py
index f4824df116387bbbc87a0c3d2ce74c6d8d67d4ed..de62085749fefc662562f19095683ec17bed9a19 100644 (file)
@@ -1,5 +1,7 @@
 from sqlobject import *
 from sqlobject.sqlbuilder import *
+import errno
+import os
 from os import path
 
 __all__ = ('Curso', 'Inscripto', 'Docente', 'Ejercicio', 'Entrega',
@@ -96,17 +98,29 @@ class CasoDePrueba(BaseSQLObject):
     def _get_path(self):
         return path.join(self.ejercicio.path, 'casos_de_prueba', self.nombre)
 
+    def _get_pathEntradas(self):
+        return path.join(self.path, 'entradas')
+
+    def _get_pathSalidas(self):
+        return path.join(self.path, 'salidas')
+
     def _get_archivosEntrada(self):
         try:
-            return os.listdir(path.join(self.path, 'entradas'))
-        except:
-            return []
+            return frozenset(os.listdir(self.pathEntradas))
+        except OSError, (err, msg):
+            if err == errno.ENOENT:
+                return frozenset()
+            else:
+                raise
 
     def _get_archivosSalida(self):
         try:
-            return os.listdir(path.join(self.path, 'salidas'))
-        except:
-            return []
+            return frozenset(os.listdir(self.pathSalidas))
+        except OSError, (err, msg):
+            if err == errno.ENOENT:
+                return frozenset()
+            else:
+                raise
 
 class Intento(BaseSQLObject):
     # Clave
@@ -141,6 +155,9 @@ class Intento(BaseSQLObject):
             '%s.%s.%s' % (curso.curso, entrega.nroEjercicio, entrega.entrega),
             '%s.%s' % (self.inscripto.padron, self.numero))
 
+    def _get_chrootPath(self):
+        return path.join(self.path, 'chroot')
+
     def _get_pruebasPasadas(self):
         for p in self.pruebas:
             if not p.pasada:
@@ -179,4 +196,10 @@ class Prueba(BaseSQLObject):
     pasada          = BoolCol(default = None)
     observaciones   = StringCol(default = None)
 
+    def _get_archivosSalida(self):
+        ent = self.casoDePrueba.archivosEntrada
+        sal = self.casoDePrueba.archivosSalida
+        return frozenset([f for f in os.listdir(self.intento.chrootPath) \
+                    if f in sal or f not in ent and f <> 'tp'])
+
 # vim: set et sw=4 sts=4 :