[vala] Move package adding logic to CodeContext



commit b1b8e7d02c9205b4520c8f25bafbd82357015621
Author: Luca Bruno <lethalman88 gmail com>
Date:   Mon Aug 23 19:42:44 2010 +0200

    Move package adding logic to CodeContext

 compiler/valacompiler.vala |   81 +++++-------------------------------
 vala/valacodecontext.vala  |   89 ++++++++++++++++++++++++++++++++++++++--
 vapigen/valavapigen.vala   |   97 +++++++++-----------------------------------
 3 files changed, 116 insertions(+), 151 deletions(-)
---
diff --git a/compiler/valacompiler.vala b/compiler/valacompiler.vala
index 33cfc19..09c5aac 100644
--- a/compiler/valacompiler.vala
+++ b/compiler/valacompiler.vala
@@ -151,56 +151,6 @@ class Vala.Compiler {
 		}
 	}
 
-	private bool add_gir (CodeContext context, string gir) {
-		var gir_path = context.get_gir_path (gir, gir_directories);
-
-		if (gir_path == null) {
-			return false;
-		}
-
-		context.add_source_file (new SourceFile (context, SourceFileType.PACKAGE, gir_path));
-
-		return true;
-	}
-	
-	private bool add_package (CodeContext context, string pkg) {
-		if (context.has_package (pkg)) {
-			// ignore multiple occurences of the same package
-			return true;
-		}
-	
-		var package_path = context.get_package_path (pkg, vapi_directories);
-		
-		if (package_path == null) {
-			return false;
-		}
-		
-		context.add_package (pkg);
-		
-		context.add_source_file (new SourceFile (context, SourceFileType.PACKAGE, package_path));
-		
-		var deps_filename = Path.build_filename (Path.get_dirname (package_path), "%s.deps".printf (pkg));
-		if (FileUtils.test (deps_filename, FileTest.EXISTS)) {
-			try {
-				string deps_content;
-				size_t deps_len;
-				FileUtils.get_contents (deps_filename, out deps_content, out deps_len);
-				foreach (string dep in deps_content.split ("\n")) {
-					dep = dep.strip ();
-					if (dep != "") {
-						if (!add_package (context, dep)) {
-							Report.error (null, "%s, dependency of %s, not found in specified Vala API directories".printf (dep, pkg));
-						}
-					}
-				}
-			} catch (FileError e) {
-				Report.error (null, "Unable to read dependency file: %s".printf (e.message));
-			}
-		}
-		
-		return true;
-	}
-	
 	private int run () {
 		context = new CodeContext ();
 		CodeContext.push (context);
@@ -247,6 +197,8 @@ class Vala.Compiler {
 		} else {
 			context.directory = context.basedir;
 		}
+		context.vapi_directories = vapi_directories;
+		context.gir_directories = gir_directories;
 		context.debug = debug;
 		context.thread = thread;
 		context.mem_profiler = mem_profiler;
@@ -284,9 +236,7 @@ class Vala.Compiler {
 		if (context.profile == Profile.POSIX) {
 			if (!nostdpkg) {
 				/* default package */
-				if (!add_package (context, "posix")) {
-					Report.error (null, "posix not found in specified Vala API directories");
-				}
+				context.add_external_package ("posix");
 			}
 		} else if (context.profile == Profile.GOBJECT) {
 			int glib_major = 2;
@@ -307,27 +257,19 @@ class Vala.Compiler {
 
 			if (!nostdpkg) {
 				/* default packages */
-				if (!add_package (context, "glib-2.0")) {
-					Report.error (null, "glib-2.0 not found in specified Vala API directories");
-				}
-				if (!add_package (context, "gobject-2.0")) {
-					Report.error (null, "gobject-2.0 not found in specified Vala API directories");
-				}
+				context.add_external_package ("glib-2.0");
+				context.add_external_package ("gobject-2.0");
 			}
 		} else if (context.profile == Profile.DOVA) {
 			if (!nostdpkg) {
 				/* default package */
-				if (!add_package (context, "dova-core-0.1")) {
-					Report.error (null, "dova-core-0.1 not found in specified Vala API directories");
-				}
+				context.add_external_package ("dova-core-0.1");
 			}
 		}
 
 		if (packages != null) {
 			foreach (string package in packages) {
-				if (!add_package (context, package) && !add_gir (context, package)) {
-					Report.error (null, "%s not found in specified Vala API directories or GObject-Introspection GIR directories".printf (package));
-				}
+				context.add_external_package (package);
 				if (context.profile == Profile.GOBJECT && package == "dbus-glib-1") {
 					context.add_define ("DBUS_GLIB");
 				}
@@ -365,11 +307,10 @@ class Vala.Compiler {
 		bool has_c_files = false;
 
 		foreach (string source in sources) {
-			if (!context.add_source_filename (source, run_output)) {
-				break;
-			}
-			if (source.has_suffix (".c")) {
-				has_c_files = true;
+			if (context.add_source_filename (source, run_output)) {
+				if (source.has_suffix (".c")) {
+					has_c_files = true;
+				}
 			}
 		}
 		sources = null;
diff --git a/vala/valacodecontext.vala b/vala/valacodecontext.vala
index 0dbcf0b..8525fff 100644
--- a/vala/valacodecontext.vala
+++ b/vala/valacodecontext.vala
@@ -104,6 +104,16 @@ public class Vala.CodeContext {
 	public string directory { get; set; }
 
 	/**
+	 * List of directories where to find .vapi files.
+	 */
+	public string[] vapi_directories;
+
+	/**
+	 * List of directories where to find .gir files.
+	 */
+	public string[] gir_directories;
+
+	/**
 	 * Produce debug information.
 	 */
 	public bool debug { get; set; }
@@ -294,6 +304,72 @@ public class Vala.CodeContext {
 	}
 
 	/**
+	 * Pull the specified package into the context.
+	 * The method is tolerant if the package has been already loaded.
+	 *
+	 * @param pkg a package name
+	 * @return false if the package could not be loaded
+	 *
+	 */
+	public bool add_external_package (string pkg) {
+		if (has_package (pkg)) {
+			// ignore multiple occurences of the same package
+			return true;
+		}
+
+		// first try .vapi
+		var path = get_vapi_path (pkg);
+		if (path == null) {
+			// try with .gir
+			path = get_gir_path (pkg);
+		}
+		if (path == null) {
+			Report.error (null, "Package `%s' not found in specified Vala API directories or GObject-Introspection GIR directories".printf (pkg));
+			return false;
+		}
+
+		add_package (pkg);
+
+		add_source_file (new SourceFile (this, SourceFileType.PACKAGE, path));
+
+		var deps_filename = Path.build_filename (Path.get_dirname (path), "%s.deps".printf (pkg));
+		if (!add_packages_from_file (deps_filename)) {
+			return false;
+		}
+
+		return true;
+	}
+
+	/**
+	 * Read the given filename and pull in packages.
+	 * The method is tolerant if the file does not exist.
+	 *
+	 * @param filename a filanem
+	 * @return false if an error occurs while reading the file or if a package could not be added
+	 */
+	public bool add_packages_from_file (string filename) {
+		if (!FileUtils.test (filename, FileTest.EXISTS)) {
+			return true;
+		}
+
+		try {
+			string contents;
+			FileUtils.get_contents (filename, out contents);
+			foreach (string package in contents.split ("\n")) {
+				package = package.strip ();
+				if (package != "") {
+					add_external_package (package);
+				}
+			}
+		} catch (FileError e) {
+			Report.error (null, "Unable to read dependency file: %s".printf (e.message));
+			return false;
+		}
+
+		return true;
+	}
+
+	/**
 	 * Add the specified source file to the context. Only .vala, .vapi, .gs,
 	 * and .c extensions are supported.
 	 *
@@ -335,6 +411,11 @@ public class Vala.CodeContext {
 			source_file.relative_filename = filename;
 
 			add_source_file (source_file);
+			// look for a local .deps
+			var deps_filename = "%s.deps".printf (filename.ndup (filename.length - ".vapi".length));
+			if (!add_packages_from_file (deps_filename)) {
+				return false;
+			}
 		} else if (filename.has_suffix (".c")) {
 			add_c_source_file (rpath);
 		} else {
@@ -366,8 +447,8 @@ public class Vala.CodeContext {
 		return (define in defines);
 	}
 
-	public string? get_package_path (string pkg, string[] directories) {
-		var path = get_file_path (pkg + ".vapi", "vala" + Config.PACKAGE_SUFFIX + "/vapi", "vala/vapi", directories);
+	public string? get_vapi_path (string pkg) {
+		var path = get_file_path (pkg + ".vapi", "vala" + Config.PACKAGE_SUFFIX + "/vapi", "vala/vapi", vapi_directories);
 
 		if (path == null) {
 			/* last chance: try the package compiled-in vapi dir */
@@ -380,8 +461,8 @@ public class Vala.CodeContext {
 		return path;
 	}
 
-	public string? get_gir_path (string gir, string[] directories) {
-		return get_file_path (gir + ".gir", "gir-1.0", null, directories);
+	public string? get_gir_path (string gir) {
+		return get_file_path (gir + ".gir", "gir-1.0", null, gir_directories);
 	}
 
 	string? get_file_path (string basename, string versioned_data_dir, string? data_dir, string[] directories) {
diff --git a/vapigen/valavapigen.vala b/vapigen/valavapigen.vala
index 577d519..32bbb25 100644
--- a/vapigen/valavapigen.vala
+++ b/vapigen/valavapigen.vala
@@ -30,6 +30,8 @@ class Vala.VAPIGen : Object {
 	static string[] sources;
 	[CCode (array_length = false, array_null_terminated = true)]
 	static string[] vapi_directories;
+	[CCode (array_length = false, array_null_terminated = true)]
+	static string[] gir_directories;
 	static string library;
 	[CCode (array_length = false, array_null_terminated = true)]
 	static string[] packages;
@@ -38,6 +40,7 @@ class Vala.VAPIGen : Object {
 
 	const OptionEntry[] options = {
 		{ "vapidir", 0, 0, OptionArg.FILENAME_ARRAY, ref vapi_directories, "Look for package bindings in DIRECTORY", "DIRECTORY..." },
+		{ "girdir", 0, 0, OptionArg.FILENAME_ARRAY, ref gir_directories, "Look for GIR bindings in DIRECTORY", "DIRECTORY..." },
 		{ "pkg", 0, 0, OptionArg.STRING_ARRAY, ref packages, "Include binding for PACKAGE", "PACKAGE..." },
 		{ "library", 0, 0, OptionArg.STRING, ref library, "Library name", "NAME" },
 		{ "metadata", 0, 0, OptionArg.FILENAME, ref metadata_filename, "Metadata filename", "FILE" },
@@ -61,68 +64,20 @@ class Vala.VAPIGen : Object {
 			return 1;
 		}
 	}
-
-	/* TODO: this is duplicated between here and the compiler. its should go somewhere on its own */
-	private bool add_package (string pkg) {
-		if (context.has_package (pkg)) {
-			// ignore multiple occurences of the same package
-			return true;
-		}
-
-		var package_path = context.get_package_path (pkg, vapi_directories);
-		
-		if (package_path == null) {
-			return false;
-		}
-		
-		context.add_package (pkg);
-
-		context.add_source_file (new SourceFile (context, SourceFileType.PACKAGE, package_path));
-
-		var deps_filename = Path.build_filename (Path.get_dirname (package_path), "%s.deps".printf (pkg));
-		if (FileUtils.test (deps_filename, FileTest.EXISTS)) {
-			try {
-				string deps_content;
-				ulong deps_len;
-				FileUtils.get_contents (deps_filename, out deps_content, out deps_len);
-				foreach (string dep in deps_content.split ("\n")) {
-					dep = dep.strip ();
-					if (dep != "") {
-						if (!add_package (dep)) {
-							Report.error (null, "%s, dependency of %s, not found in specified Vala API directories".printf (dep, pkg));
-						}
-					}
-				}
-			} catch (FileError e) {
-				Report.error (null, "Unable to read dependency file: %s".printf (e.message));
-			}
-		}
-
-		return true;
-	}
 	
-	private static string[]? get_packages_from_depsfile (string depsfile) {
-		try {
-			string contents;
-			FileUtils.get_contents (depsfile, out contents);
-			return contents.strip ().split ("\n");
-		} catch (FileError e) {
-			// deps files are optional
-			return null;
-		}
-	}
-
 	private int run () {
 		context = new CodeContext ();
 		context.profile = Profile.GOBJECT;
+		context.vapi_directories = vapi_directories;
+		context.gir_directories = gir_directories;
 		CodeContext.push (context);
 		
 		/* default package */
-		if (!add_package ("glib-2.0")) {
-			Report.error (null, "glib-2.0 not found in specified Vala API directories");
-		}
-		if (!add_package ("gobject-2.0")) {
-			Report.error (null, "gobject-2.0 not found in specified Vala API directories");
+		context.add_external_package ("glib-2.0");
+		context.add_external_package ("gobject-2.0");
+
+		if (context.report.get_errors () > 0) {
+			return quit ();
 		}
 
 		/* load packages from .deps file */
@@ -132,40 +87,28 @@ class Vala.VAPIGen : Object {
 			}
 
 			var depsfile = source.substring (0, source.length - "gi".length) + "deps";
+			context.add_packages_from_file (depsfile);
+		}
 
-			if (!FileUtils.test (depsfile, FileTest.EXISTS)) continue;
-			
-			string[] deps = get_packages_from_depsfile (depsfile);
-			
-			foreach (string dep in deps) {
-				if (!add_package (dep)) {
-					Report.error (null, "%s not found in specified Vala API directories".printf (dep));
-				}
-			}
+		if (context.report.get_errors () > 0) {
+			return quit ();
 		}
 
 		// depsfile for gir case
 		if (library != null) {
 			var depsfile = library + ".deps";
-			if (FileUtils.test (depsfile, FileTest.EXISTS)) {
-
-				string[] deps = get_packages_from_depsfile (depsfile);
-
-				foreach (string dep in deps) {
-					if (!add_package (dep)) {
-						Report.error (null, "%s not found in specified Vala API directories".printf (dep));
-					}
-				}
-			}
+			context.add_packages_from_file (depsfile);
 		} else {
 			Report.error (null, "--library option must be specified");
 		}
 
+		if (context.report.get_errors () > 0) {
+			return quit ();
+		}
+
 		if (packages != null) {
 			foreach (string package in packages) {
-				if (!add_package (package)) {
-					Report.error (null, "%s not found in specified Vala API directories".printf (package));
-				}
+				context.add_external_package (package);
 			}
 			packages = null;
 		}



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]