[longomatch/redesign: 3/75] Change the database to use the new API and bump the db version number



commit 3957f203c198489cce7b3f8b0e808a1068f4cfb4
Author: Andoni Morales Alastruey <ylatuya gmail com>
Date:   Sun Nov 21 15:43:11 2010 +0100

    Change the database to use the new API and bump the db version number

 LongoMatch/Common/Constants.cs |    2 +-
 LongoMatch/DB/DataBase.cs      |   89 +++++++++++++++++++++-------------------
 2 files changed, 48 insertions(+), 43 deletions(-)
---
diff --git a/LongoMatch/Common/Constants.cs b/LongoMatch/Common/Constants.cs
index 6535fcd..326ca79 100644
--- a/LongoMatch/Common/Constants.cs
+++ b/LongoMatch/Common/Constants.cs
@@ -26,7 +26,7 @@ namespace LongoMatch.Common
 		
 		public const string PROJECT_NAME = SOFTWARE_NAME + " project";
 		
-		public const string DB_FILE = "longomatch.db";
+		public const string DB_FILE = "longomatch.1.db";
 		
 		public const string COPYRIGHT =  "Copyright ©2007-2010 Andoni Morales Alastruey";
 		
diff --git a/LongoMatch/DB/DataBase.cs b/LongoMatch/DB/DataBase.cs
index a55f319..69f308b 100644
--- a/LongoMatch/DB/DataBase.cs
+++ b/LongoMatch/DB/DataBase.cs
@@ -49,9 +49,9 @@ namespace LongoMatch.DB
 
 		private Version dbVersion;
 
-		private const int MAYOR=0;
+		private const int MAYOR=1;
 
-		private const int MINOR=1;
+		private const int MINOR=0;
 
 		/// <summary>
 		/// Creates a proxy for the database
@@ -126,36 +126,36 @@ namespace LongoMatch.DB
 					while (result.HasNext()) {
 						try{
 							Project p = (Project)result.Next();
+							ProjectDescription desc = p.Description;
+							db.Activate(desc,3);
 							try{
-								db.Activate(p.File,3);
 								//FIXME: It happens that the project's File object is set to null?¿?¿
 								// In that case, reset the value to let the user change it with the
 								// projects manager.
-								if (p.File.FilePath == null){}							
+								if (desc.File.FilePath == null){}							
 							}catch{
 								MessagePopup.PopupMessage(null, MessageType.Warning, 
-								                          Catalog.GetString("Error retrieving the file info for project:")+" "+p.Title+"\n"+
-								                          Catalog.GetString("This value will be reset. Remember to change it later with the projects manager"));
-								p.File = new PreviewMediaFile(Catalog.GetString("Change Me"),0,0,false,false,"","",0,0,null);
-								db.Store(p);
+								                          Catalog.GetString("Error retrieving the file " +
+								                                            "info for project:")+
+								                          " "+ desc.Title+"\n"+
+								                          Catalog.GetString("This value will be reset. " +
+								                                            "Remember to change it later with the " +
+								                                            "projects manager"));
+								desc.File = new PreviewMediaFile{
+									FilePath = Catalog.GetString("Change Me"),
+									VideoHeight = 0,
+									VideoWidth = 0,
+									HasVideo = false,
+									HasAudio = false,
+									Length = 0,
+									Fps = 0, 
+									VideoCodec = "",
+									AudioCodec = "",
+									Preview = null,
+								};
+									db.Store(p);
 							}
-							ProjectDescription pd = new ProjectDescription {
-								File = p.File.FilePath,
-								LocalName= p.LocalName,
-								VisitorName = p.VisitorName,
-								Season = p.Season,
-								Competition = p.Competition,
-								LocalGoals = p.LocalGoals,
-								VisitorGoals = p.VisitorGoals,
-								MatchDate = p.MatchDate,
-								Preview = p.File.Preview,
-								VideoCodec = p.File.VideoCodec,
-								AudioCodec = p.File.AudioCodec,
-								Length = new Time((int)(p.File.Length/1000)),
-								Format = String.Format("{0}x{1} {2}fps", 
-								                       p.File.VideoWidth, p.File.VideoHeight, p.File.Fps),
-							};
-							list.Add(pd);
+							list.Add(desc);
 						}catch{	
 							Console.WriteLine("Error retreiving project. Skip");
 						}
@@ -184,9 +184,7 @@ namespace LongoMatch.DB
 			lock (this.locker) {
 				IObjectContainer db = Db4oFactory.OpenFile(file);
 				try	{
-					IQuery query = db.Query();
-					query.Constrain(typeof(Project));
-					query.Descend("file").Descend("filePath").Constrain(filename);
+					IQuery query = GetQueryWithContrains(db, file);
 					IObjectSet result = query.Execute();
 					ret = (Project) db.Ext().PeekPersisted(result.Next(),10,true);
 					return ret;
@@ -209,7 +207,7 @@ namespace LongoMatch.DB
 				IObjectContainer db = Db4oFactory.OpenFile(file);
 				try
 				{
-					if (!this.Exists(project.File.FilePath,db)) {
+					if (!Exists(project.Description.File.FilePath,db)) {
 						db.Store(project);
 						db.Commit();
 					}
@@ -232,9 +230,7 @@ namespace LongoMatch.DB
 				SetDeleteCascadeOptions();
 				IObjectContainer db = Db4oFactory.OpenFile(file);
 				try	{
-					IQuery query = db.Query();
-					query.Constrain(typeof(Project));
-					query.Descend("file").Descend("filePath").Constrain(filePath);
+					IQuery query = GetQueryWithContrains(db, file);
 					IObjectSet result = query.Execute();
 					Project project = (Project)result.Next();
 					db.Delete(project);
@@ -267,10 +263,8 @@ namespace LongoMatch.DB
 				IObjectContainer db = Db4oFactory.OpenFile(file);
 				try	{
 					// We look for a project with the same filename
-					if (!Exists(project.File.FilePath,db)) {
-						IQuery query = db.Query();
-						query.Constrain(typeof(Project));
-						query.Descend("file").Descend("filePath").Constrain(previousFileName);
+					if (!Exists(project.Description.File.FilePath,db)) {
+						IQuery query = GetQueryWithContrains(db, file);
 						IObjectSet result = query.Execute();
 						//Get the stored project and replace it with the new one
 						if (result.Count == 1){
@@ -305,9 +299,7 @@ namespace LongoMatch.DB
 				SetDeleteCascadeOptions();
 				IObjectContainer db = Db4oFactory.OpenFile(file);
 				try	{
-					IQuery query = db.Query();
-					query.Constrain(typeof(Project));
-					query.Descend("file").Descend("filePath").Constrain(project.File.FilePath);
+					IQuery query = GetQueryWithContrains(db, file);
 					IObjectSet result = query.Execute();
 					//Get the stored project and replace it with the new one
 					Project fd = (Project)result.Next();
@@ -334,13 +326,20 @@ namespace LongoMatch.DB
 		public bool Exists(Project project){
 			IObjectContainer db = Db4oFactory.OpenFile(file);
 			try{
-				return Exists(project.File.FilePath, db);
+				return Exists(project.Description.File.FilePath, db);
 			}catch{
 				return false;
 			}finally{
 				CloseDB(db);
 			}				
 		}
+		
+		private IQuery GetQueryWithContrains(IObjectContainer db, string filename){
+			IQuery query = db.Query();
+			query.Constrain(typeof(Project));
+			query.Descend("description").Descend("file").Descend("filePath").Constrain(filename);
+			return query;
+		}
 
 		private void CloseDB(IObjectContainer db) {
 			db.Ext().Purge();
@@ -349,25 +348,31 @@ namespace LongoMatch.DB
 
 		private void SetDeleteCascadeOptions() {
 			Db4oFactory.Configure().ObjectClass(typeof(Project)).CascadeOnDelete(true);
-			Db4oFactory.Configure().ObjectClass(typeof(Sections)).CascadeOnDelete(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Categories)).CascadeOnDelete(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Category)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(TimeNode)).CascadeOnDelete(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Play)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Time)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Team)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(HotKey)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Player)).CascadeOnDelete(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Tag)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(TeamTemplate)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Drawing)).CascadeOnDelete(true);
 		}
 
 		private void SetUpdateCascadeOptions() {
 			Db4oFactory.Configure().ObjectClass(typeof(Project)).CascadeOnUpdate(true);
-			Db4oFactory.Configure().ObjectClass(typeof(Sections)).CascadeOnUpdate(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Categories)).CascadeOnUpdate(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Category)).CascadeOnUpdate(true);
 			Db4oFactory.Configure().ObjectClass(typeof(TimeNode)).CascadeOnUpdate(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Play)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Time)).CascadeOnUpdate(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Team)).CascadeOnUpdate(true);
 			Db4oFactory.Configure().ObjectClass(typeof(HotKey)).CascadeOnUpdate(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Player)).CascadeOnUpdate(true);
 			Db4oFactory.Configure().ObjectClass(typeof(TeamTemplate)).CascadeOnUpdate(true);
+			Db4oFactory.Configure().ObjectClass(typeof(Tag)).CascadeOnDelete(true);
 			Db4oFactory.Configure().ObjectClass(typeof(Drawing)).CascadeOnUpdate(true);
 		}
 



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