using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Perforce.P4 { /// <summary> /// Identifies one or more specific versioned objects in a Perforce repository. /// </summary> public class FileSpec { public FileSpec() { } public FileSpec(FileSpec fs) { DepotPath = fs.DepotPath; ClientPath = fs.ClientPath; LocalPath = fs.LocalPath; Version = fs.Version; } public FileSpec(PathSpec path, VersionSpec version) { if (path.GetType() == typeof(DepotPath)) { DepotPath = (DepotPath)path; ClientPath = null; LocalPath = null; } else if (path.GetType() == typeof(ClientPath)) { DepotPath = null; ClientPath = (ClientPath)path; LocalPath = null; } else if (path.GetType() == typeof(LocalPath)) { DepotPath = null; ClientPath = null; LocalPath = (LocalPath)path; } Version = version; } public FileSpec(FileMetaData meta) { DepotPath = meta.DepotPath; ClientPath = meta.ClientPath; LocalPath = meta.LocalPath; Version = new Revision(meta.HeadRev); } public FileSpec(DepotPath dp, ClientPath cp, LocalPath lp, VersionSpec version) { DepotPath = dp; ClientPath = cp; LocalPath = lp; Version = version; } public static FileSpec ClientSpec(String path) { return new FileSpec(new ClientPath(path), null); } public static FileSpec ClientSpec(String path, int rev) { return new FileSpec(new ClientPath(path), new Revision(rev)); } public static FileSpec DepotSpec(String path) { return new FileSpec(new DepotPath(path), null); } public static FileSpec DepotSpec(String path, int rev) { return new FileSpec(new DepotPath(path), new Revision(rev)); } public static FileSpec LocalSpec(String path) { return new FileSpec(new LocalPath(path), null); } public static FileSpec LocalSpec(String path, int rev) { return new FileSpec(new LocalPath(path), new Revision(rev)); } /// <summary> /// Create a list of FileSpec objects from a list of client paths /// </summary> /// <param name="paths">List of paths</param> /// <returns>List of FileSpec objects</returns> public static IList<FileSpec> ClientSpecList(params String[] paths) { List<FileSpec> val = new List<FileSpec>(); for (int idx = 0; idx < paths.Length; idx++) { val.Add(new FileSpec(new ClientPath(paths[idx]), null)); } return val; } /// <summary> /// Create a list of FileSpec objects from a list of depot paths /// </summary> /// <param name="paths">List of paths</param> /// <returns>List of FileSpec objects</returns> public static IList<FileSpec> DepotSpecList(params String[] paths) { List<FileSpec> val = new List<FileSpec>(); for (int idx = 0; idx < paths.Length; idx++) { val.Add(new FileSpec(new DepotPath(paths[idx]), null)); } return val; } /// <summary> /// Create a list of FileSpec objects from a list of local paths /// </summary> /// <param name="paths">List of paths</param> /// <returns>List of FileSpec objects</returns> public static IList<FileSpec> LocalSpecList(params String[] paths) { List<FileSpec> val = new List<FileSpec>(); for (int idx = 0; idx < paths.Length; idx++) { val.Add(new FileSpec(new LocalPath(paths[idx]), null)); } return val; } /// <summary> /// Create a list of FileSpec objects from a list of local paths /// </summary> /// <param name="paths">List of paths</param> /// <returns>List of FileSpec objects</returns> public static IList<FileSpec> LocalSpecList(IList<String> paths) { List<FileSpec> val = new List<FileSpec>(); if (paths!=null) { for (int idx = 0; idx < paths.Count; idx++) { val.Add(new FileSpec(new LocalPath(paths[idx]), null)); } } return val; } /// <summary> /// Create a copy of a filespec without a version /// </summary> public FileSpec StripVersion() { FileSpec fs = new FileSpec(this); fs.Version = null; return fs; } /// <summary> /// Copies a list of FileSpec objects without vesions /// </summary> /// <param name="specs">List of FileSpecs</param> /// <returns>List of FileSpec objects</returns> public static IList<FileSpec> UnversionedSpecList(IList<FileSpec> specs) { List<FileSpec> val = new List<FileSpec>(); if (specs!=null) { for (int idx = 0; idx < specs.Count; idx++) { val.Add(specs[idx].StripVersion()); } } return val; } /// <summary> /// Create an array of FileSpec objects from a list of local paths /// </summary> /// <param name="paths">List of paths</param> /// <returns>List of FileSpec objects</returns> public static FileSpec[] LocalSpecArray(params String[] paths) { FileSpec[] val = new FileSpec[paths.Length]; for (int idx = 0; idx < paths.Length; idx++) { val[idx] = new FileSpec(new LocalPath(paths[idx]), null); } return val; } /// <summary> /// Create an array of FileSpec objects from a list of local paths /// </summary> /// <param name="paths">List of paths</param> /// <returns>List of FileSpec objects</returns> public static FileSpec[] LocalSpecArray(IList<String> paths) { FileSpec[] val = new FileSpec[paths.Count]; for (int idx = 0; idx < paths.Count; idx++) { val[idx] = new FileSpec(new LocalPath(paths[idx]), null); } return val; } public DepotPath DepotPath { get; set; } public ClientPath ClientPath { get; set; } public LocalPath LocalPath { get; set; } public VersionSpec Version { get; set; } public override string ToString() { string value = null; if (DepotPath != null) { value = DepotPath.Path; } else if (ClientPath != null) { value = ClientPath.Path; } else if (LocalPath != null) { value = LocalPath.Path; if ((value.Length > 1) && (value[1] == ':') && char.IsUpper(value, 0)) { value = value.Substring(0, 1).ToLower() + value.Substring(1); } } if (value != null) { if (Version != null) { value += Version.ToString(); } } return value; } public string ToEscapedString() { string value = null; if (DepotPath != null) { value = DepotPath.Path; } else if (ClientPath != null) { value = ClientPath.Path; } else if (LocalPath != null) { value = LocalPath.Path; if ((value.Length > 1) && (value[1] == ':') && char.IsUpper(value, 0)) { value = value.Substring(0, 1).ToLower() + value.Substring(1); } } value = PathSpec.EscapePath(value); if (value != null) { if (Version != null) { value += Version.ToString(); } } return value; } public string ToString(Type pathType) { string value = null; if (pathType == typeof(DepotPath)) { value = DepotPath.Path; } if (pathType == typeof(ClientPath)) { value = ClientPath.Path; } if (pathType == typeof(LocalPath)) { value = LocalPath.Path; if ((value.Length > 1) && (value[1] == ':') && char.IsUpper(value, 0)) { value = value.Substring(0, 1).ToLower() + value.Substring(1); } } value = PathSpec.EscapePath(value); if (Version !=null ) { value += Version.ToString(); } return value; } /// <summary> /// Copy the non-null entries into a new string array. /// </summary> public static string[] ToStrings(IList<FileSpec> list) { if (list == null) return null; if ((list.Count == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Count; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Count; idx++) { if (list[idx] != null) { value[idx2++] = list[idx].ToString(); } } return value; } /// <summary> /// Copy the non-null entries into a new string array /// with the paths escaped for special characters /// </summary> public static string[] ToEscapedStrings(IList<FileSpec> list) { if (list == null) return null; if ((list.Count == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Count; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Count; idx++) { if (list[idx] != null) { value[idx2++] = list[idx].ToEscapedString(); } } return value; } /// <summary> /// Copy the non-null entries into a new string array /// with the paths escaped for special characters /// </summary> public static string[] ToEscapedStrings(params FileSpec[] list) { if (list == null) return null; if ((list.Length == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { value[idx2++] = list[idx].ToEscapedString(); } } return value; } /// <summary> /// Copy the non-null entries into a new string array. /// </summary> public static string[] ToStrings(params FileSpec[] list) { if (list == null) return null; if ((list.Length == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { value[idx2++] = list[idx].ToString(); } } return value; } /// <summary> /// Copy the non-null entries into a new string array containing the paths. /// </summary> public static string[] ToPaths(params FileSpec[] list) { if (list == null) return null; if ((list.Length == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { if (list[idx].DepotPath != null) { value[idx2++] = list[idx].DepotPath.Path; } else if (list[idx].LocalPath != null) { value[idx2++] = list[idx].LocalPath.Path; } else if (list[idx].ClientPath != null) { value[idx2] = list[idx].ClientPath.Path; if ((value[idx2].Length > 1) && (value[idx2][1] == ':') && char.IsUpper(value[idx2], 0)) { value[idx2] = value[idx2].Substring(0, 1).ToLower() + value[idx2].Substring(1); } idx2++; } } } return value; } /// <summary> /// Copy the non-null entries into a new string array containing the paths /// escaped for special characters /// </summary> public static string[] ToEscapedPaths(params FileSpec[] list) { if (list == null) return null; if ((list.Length == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { if (list[idx].DepotPath != null) { value[idx2++] = PathSpec.EscapePath(list[idx].DepotPath.Path); } else if (list[idx].LocalPath != null) { value[idx2++] = PathSpec.EscapePath(list[idx].LocalPath.Path); } else if (list[idx].ClientPath != null) { value[idx2] = PathSpec.EscapePath(list[idx].ClientPath.Path); if ((value[idx2].Length > 1) && (value[idx2][1] == ':') && char.IsUpper(value[idx2], 0)) { value[idx2] = value[idx2].Substring(0, 1).ToLower() + value[idx2].Substring(1); } idx2++; } } } return value; } /// <summary> /// Copy the non-null entries into a new string array containing the local paths /// escaped for special characters /// </summary> public static string[] ToEscapedLocalPaths(params FileSpec[] list) { if (list == null) return null; if ((list.Length == 1) && (list[0] == null)) return null; int count = 0; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { count++; } } int idx2 = 0; string[] value = new string[count]; for (int idx = 0; idx < list.Length; idx++) { if (list[idx] != null) { if (list[idx].LocalPath != null) { value[idx2] = PathSpec.EscapePath(list[idx].LocalPath.Path); if ((value[idx2].Length > 1) && (value[idx2][1] == ':') && char.IsUpper(value[idx2], 0)) { value[idx2] = value[idx2].Substring(0, 1).ToLower() + value[idx2].Substring(1); } idx2++; } } } return value; } public override bool Equals(object obj) { if ((obj is FileSpec) == false) { return false; } FileSpec o = obj as FileSpec; if (o.ClientPath != null) { if (o.ClientPath.Equals(this.ClientPath) == false) { return false; } } else { if (this.ClientPath != null) { return false; } } if (o.DepotPath != null) { if (o.DepotPath.Equals(this.DepotPath) == false) { return false; } } else { if (this.DepotPath != null) { return false; } } if (o.LocalPath != null) { if (o.LocalPath.Equals(this.LocalPath) == false) { return false; } } else { if (this.LocalPath != null) { return false; } } if (o.Version != null) { if (o.Version.Equals(this.Version) == false) { return false; } } else { if (this.Version != null) { return false; } } return true; } } }
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#1 | 25222 | seandanger | "Forking branch Main of perforce-software-p4connect to seandanger-p4connect." | ||
//guest/perforce_software/p4connect/main/src/P4Bridge/p4api.net/FileSpec.cs | |||||
#1 | 16209 | Norman Morse | Move entire source tree into "main" branch so workshop code will act correctly. | ||
//guest/perforce_software/p4connect/src/P4Bridge/p4api.net/FileSpec.cs | |||||
#3 | 13692 | Norman Morse |
Fix FileSpec corruption issue Make sure that the logged in user is verified against files in the default change. Multiple users can share the same workspace and cause lots of confusion. Also changed the code in Perforce.P4.Changelist.ToString() to create new FileSpecs instead of doing implicite casts. This should fix the exception if the source FileMetaData is incomplete some how. |
||
#2 | 12135 | Norman Morse |
Integrate dev branch changes into main. This code is the basiis of the 2.7 BETA release which provides Unity 5 compatibility |
||
#1 | 10940 | Norman Morse |
Inital Workshop release of P4Connect. Released under BSD-2 license |