Example #1
0
 private static PdbSrcSrvSection CreatePdbSrcSrvSection(Project currentProject, PdbStoreManager pdbStoreManager,
     string pdbFile)
 {
     var srcSrvSection = new PdbSrcSrvSection();
     srcSrvSection.Ini.Add("VERSION", "2");
     srcSrvSection.Ini.Add("INDEXVERSION", "2");
     srcSrvSection.Ini.Add("DATETIME", DateTime.Now.ToString(CultureInfo.InvariantCulture));
     srcSrvSection.Variables.Add("SRCSRVTRG", "%var2%");
     var sourceList = GetSourceList(currentProject, pdbStoreManager, pdbFile);
     foreach (var source in sourceList){
         srcSrvSection.Sources.Add(new[]{source});
     }
     return srcSrvSection;
 }
Example #2
0
        public static void Main(string[] args)
        {
            _logger=GetLogger();
            var options = new Options();
            bool arguments = Parser.Default.ParseArguments(args, options);
            if (!arguments){
                string message = options.GetUsage();
                _logger.Error(message);
                throw new ArgumentException(message);
            }
            var projectFiles = new List<string>();
            projectFiles.AddRange(Directory.GetFiles(options.SourceDir, "*.csproj", SearchOption.AllDirectories));
            projectFiles.AddRange(Directory.GetFiles(options.SourceDir, "*.vbproj", SearchOption.AllDirectories));
            var failedProjects = new List<KeyValuePair<string,string>>();
            var projects = GetProjects(projectFiles);
            _logger.Info(string.Format("Found '{0}' project(s)", projectFiles.Count));
            var pdbFiles = Directory.GetFiles(options.PDBDir, "*.pdb").ToArray();
            _logger.Info(string.Format("Found '{0}' pdb files", pdbFiles.Length));
            foreach (var pdbFile in pdbFiles){
                var currentProject = projects.FirstOrDefault(project => Path.GetFileName(project.GetOutputPdbFile()) == Path.GetFileName(pdbFile));
                if (currentProject!=null){
                    var pdbStoreManager = new PdbStoreManager(options.DbgToolsPath);
                    var srcSrvSection = CreatePdbSrcSrvSection(currentProject, pdbStoreManager, pdbFile);
                    var writeSrcSrv = pdbStoreManager.WriteSrcSrv(pdbFile, srcSrvSection);
                    var fileName = Path.GetFileNameWithoutExtension(pdbFile);
                    if (!string.IsNullOrEmpty(writeSrcSrv)){
                        failedProjects.Add(new KeyValuePair<string,string>(pdbFile,writeSrcSrv));
                        _logger.Error(fileName+"-->"+writeSrcSrv);
                    }
                    else{
                        _logger.Info(fileName+" indexed successfully!");
                    }
                }
                else{
                    failedProjects.Add(new KeyValuePair<string, string>(pdbFile,"Project not found"));
                    _logger.Error(pdbFile +"-->Project not found");
                }
            }

            if (Debugger.IsAttached)
                Console.ReadKey();
        }
Example #3
0
 private static IEnumerable<string> GetSourceList(Project currentProject, PdbStoreManager pdbStoreManager, string pdbFile)
 {
     var compilableItems = currentProject.GetCompilableItems();
     var indexedFiles = pdbStoreManager.GetIndexedFiles(pdbFile);
     if (indexedFiles.Any()){
         var longestDir = Enumerable.Range(0, indexedFiles.Min(s => s.Length)).Reverse()
         .Select(len => new { len, possibleMatch = indexedFiles.First().Substring(0, len) })
         .Where(@t => indexedFiles.All(f => f.StartsWith(@t.possibleMatch)))
         .Select(@t => @t.possibleMatch).First();
         return compilableItems.Select(compilableItem => new { compilableItem, targetPath = Path.Combine(currentProject.DirectoryPath, compilableItem.EvaluatedInclude) })
                 .Select(@t => Path.Combine(longestDir, @t.compilableItem.EvaluatedInclude) + "*" + @t.targetPath);
     }
     return Enumerable.Empty<string>();
 }