Beispiel #1
0
            public void LoadSection(PELoader peLoader)
            {
                Stream fileStream = peLoader.getStream();

                fileStream.Seek(peLoader.VaToOffset(header.virtualAddress), SeekOrigin.Begin);
                BinaryReader reader = new BinaryReader(fileStream);

                this.rawData = reader.ReadBytes(header.sizeOfRawData);
            }
        private void LoadMetaData(ArrayList loadedStreams,
                                  bool fLoadCode,
                                  bool fLoadSectionsFromExecutable,
                                  bool fLoadDebugInfo)
        {
            // try to load the metadata for all streams in loadedStreams.

            this.entryList    = new ArrayList();
            this.metaDataList = new ArrayList();

            foreach (LoadedStream stream in loadedStreams)
            {
                PELoader loader = null;
                try {
                    if (fDebug)
                    {
                        Console.Out.WriteLine("loading " + stream.Name + "'");
                    }
                    loader = new PELoader(stream.Content, stream.Name);
                }
                catch (FileNotFoundException) {
                    // failed on raw filename; try prefixing with libDirNames elts
                    if (fDebug)
                    {
                        Console.Out.WriteLine("...failed");
                    }
                }
                StringBuilder sb = new StringBuilder();
                if (loader == null)
                {
                    sb.Append("Unable to load '");
                    sb.Append(stream.Name);
                    sb.Append("'");
                    Console.Out.WriteLine(sb.ToString());
                    Console.Out.WriteLine("Aborting!");
                    String stackTrace = System.Environment.StackTrace;
                    Console.Out.WriteLine(stackTrace);
                    throw new Exception(sb.ToString());
                }

                TimeSpan diffSpan  = System.DateTime.Now.Subtract(startTime);
                int      diffMsec  = (int)diffSpan.TotalMilliseconds;
                String   secString = (diffMsec / 1000).ToString();
                sb.Append("        ", 0, (8 - secString.Length));
                sb.Append(secString);
                sb.Append('.');
                sb.Append((diffMsec % 1000).ToString("000"));
                sb.Append(":  ");
                sb.Append("Loading metadata ");
                if (fLoadCode)
                {
                    sb.Append("with code ");
                }
                sb.Append("from '");
                sb.Append(stream.Name);
                sb.Append("'");
                Console.Out.WriteLine(sb.ToString());
                MetaData metaData =
                    MetaData.loadMetaData(stream.Path, loader, fLoadCode, fLoadDebugInfo);
                metaDataList.Add(metaData);
                ResolverEntry entry = new ResolverEntry(metaData, stream.Name);
                entryList.Add(entry);
                //              if (fLoadSectionsFromExecutable && loader.IsExecutableImage()) {
                //                  Console.Out.WriteLine("loading all sections from " + fileName);
                //                  loader.loadSections();
                //              }
                loader.getStream().Close();
            }
        }