fastMM memory manager
This commit is contained in:
parent
477cad10c7
commit
51f8122d9b
7730
2.10/Source/FastMM4.pas
Normal file
7730
2.10/Source/FastMM4.pas
Normal file
File diff suppressed because it is too large
Load Diff
139
2.10/Source/FastMM4Messages.pas
Normal file
139
2.10/Source/FastMM4Messages.pas
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
{
|
||||||
|
|
||||||
|
Fast Memory Manager: Messages
|
||||||
|
|
||||||
|
English translation by Pierre le Riche.
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
unit FastMM4Messages;
|
||||||
|
|
||||||
|
interface
|
||||||
|
|
||||||
|
{$Include FastMM4Options.inc}
|
||||||
|
|
||||||
|
const
|
||||||
|
{The name of the debug info support DLL}
|
||||||
|
FullDebugModeLibraryName = 'FastMM_FullDebugMode.dll';
|
||||||
|
{Event log strings}
|
||||||
|
LogFileExtension = '_MemoryManager_EventLog.txt'#0;
|
||||||
|
CRLF = #13#10;
|
||||||
|
EventSeparator = '--------------------------------';
|
||||||
|
{Class name messages}
|
||||||
|
UnknownClassNameMsg = 'Unknown';
|
||||||
|
{Stack trace Message}
|
||||||
|
CurrentStackTraceMsg = #13#10#13#10'The current stack trace leading to this error (return addresses): ';
|
||||||
|
{Memory dump message}
|
||||||
|
MemoryDumpMsg = #13#10#13#10'Current memory dump of 256 bytes starting at pointer address ';
|
||||||
|
{Block Error Messages}
|
||||||
|
BlockScanLogHeader = 'Allocated block logged by LogAllocatedBlocksToFile. The size is: ';
|
||||||
|
ErrorMsgHeader = 'FastMM has detected an error during a ';
|
||||||
|
GetMemMsg = 'GetMem';
|
||||||
|
FreeMemMsg = 'FreeMem';
|
||||||
|
ReallocMemMsg = 'ReallocMem';
|
||||||
|
BlockCheckMsg = 'free block scan';
|
||||||
|
OperationMsg = ' operation. ';
|
||||||
|
BlockHeaderCorruptedMsg = 'The block header has been corrupted. ';
|
||||||
|
BlockFooterCorruptedMsg = 'The block footer has been corrupted. ';
|
||||||
|
FreeModifiedErrorMsg = 'FastMM detected that a block has been modified after being freed. ';
|
||||||
|
DoubleFreeErrorMsg = 'An attempt has been made to free/reallocate an unallocated block.';
|
||||||
|
PreviousBlockSizeMsg = #13#10#13#10'The previous block size was: ';
|
||||||
|
CurrentBlockSizeMsg = #13#10#13#10'The block size is: ';
|
||||||
|
StackTraceAtPrevAllocMsg = #13#10#13#10'Stack trace of when this block was previously allocated (return addresses):';
|
||||||
|
StackTraceAtAllocMsg = #13#10#13#10'Stack trace of when this block was allocated (return addresses):';
|
||||||
|
PreviousObjectClassMsg = #13#10#13#10'The block was previously used for an object of class: ';
|
||||||
|
CurrentObjectClassMsg = #13#10#13#10'The block is currently used for an object of class: ';
|
||||||
|
PreviousAllocationGroupMsg = #13#10#13#10'The allocation group was: ';
|
||||||
|
PreviousAllocationNumberMsg = #13#10#13#10'The allocation number was: ';
|
||||||
|
CurrentAllocationGroupMsg = #13#10#13#10'The allocation group is: ';
|
||||||
|
CurrentAllocationNumberMsg = #13#10#13#10'The allocation number is: ';
|
||||||
|
StackTraceAtFreeMsg = #13#10#13#10'Stack trace of when the block was previously freed (return addresses):';
|
||||||
|
BlockErrorMsgTitle = 'Memory Error Detected';
|
||||||
|
{Virtual Method Called On Freed Object Errors}
|
||||||
|
StandardVirtualMethodNames: array[1 + vmtParent div 4 .. -1] of PChar = (
|
||||||
|
'SafeCallException',
|
||||||
|
'AfterConstruction',
|
||||||
|
'BeforeDestruction',
|
||||||
|
'Dispatch',
|
||||||
|
'DefaultHandler',
|
||||||
|
'NewInstance',
|
||||||
|
'FreeInstance',
|
||||||
|
'Destroy');
|
||||||
|
VirtualMethodErrorHeader = 'FastMM has detected an attempt to call a virtual method on a freed object. An access violation will now be raised in order to abort the current operation.';
|
||||||
|
InterfaceErrorHeader = 'FastMM has detected an attempt to use an interface of a freed object. An access violation will now be raised in order to abort the current operation.';
|
||||||
|
BlockHeaderCorruptedNoHistoryMsg = ' Unfortunately the block header has been corrupted so no history is available.';
|
||||||
|
FreedObjectClassMsg = #13#10#13#10'Freed object class: ';
|
||||||
|
VirtualMethodName = #13#10#13#10'Virtual method: ';
|
||||||
|
VirtualMethodOffset = 'Offset +';
|
||||||
|
VirtualMethodAddress = #13#10#13#10'Virtual method address: ';
|
||||||
|
StackTraceAtObjectAllocMsg = #13#10#13#10'Stack trace of when the object was allocated (return addresses):';
|
||||||
|
StackTraceAtObjectFreeMsg = #13#10#13#10'Stack trace of when the object was subsequently freed (return addresses):';
|
||||||
|
{Installation Messages}
|
||||||
|
AlreadyInstalledMsg = 'FastMM4 is already installed.';
|
||||||
|
AlreadyInstalledTitle = 'Already installed.';
|
||||||
|
OtherMMInstalledMsg = 'FastMM4 cannot be installed since another third party memory '
|
||||||
|
+ 'manager has already installed itself.'#13#10'If you want to use FastMM4, '
|
||||||
|
+ 'please make sure that FastMM4.pas is the very first unit in the "uses"'
|
||||||
|
+ #13#10'section of your project''s .dpr file.';
|
||||||
|
OtherMMInstalledTitle = 'Cannot install FastMM4 - Another memory manager is already installed';
|
||||||
|
MemoryAllocatedMsg = 'FastMM4 cannot install since memory has already been '
|
||||||
|
+ 'allocated through the default memory manager.'#13#10'FastMM4.pas MUST '
|
||||||
|
+ 'be the first unit in your project''s .dpr file, otherwise memory may '
|
||||||
|
+ 'be allocated'#13#10'through the default memory manager before FastMM4 '
|
||||||
|
+ 'gains control. '#13#10#13#10'If you are using an exception trapper '
|
||||||
|
+ 'like MadExcept (or any tool that modifies the unit initialization '
|
||||||
|
+ 'order),'#13#10'go into its configuration page and ensure that the '
|
||||||
|
+ 'FastMM4.pas unit is initialized before any other unit.';
|
||||||
|
MemoryAllocatedTitle = 'Cannot install FastMM4 - Memory has already been allocated';
|
||||||
|
{Leak checking messages}
|
||||||
|
LeakLogHeader = 'A memory block has been leaked. The size is: ';
|
||||||
|
LeakMessageHeader = 'This application has leaked memory. ';
|
||||||
|
SmallLeakDetail = 'The small block leaks are'
|
||||||
|
{$ifdef HideExpectedLeaksRegisteredByPointer}
|
||||||
|
+ ' (excluding expected leaks registered by pointer)'
|
||||||
|
{$endif}
|
||||||
|
+ ':'#13#10;
|
||||||
|
LargeLeakDetail = 'The sizes of leaked medium and large blocks are'
|
||||||
|
{$ifdef HideExpectedLeaksRegisteredByPointer}
|
||||||
|
+ ' (excluding expected leaks registered by pointer)'
|
||||||
|
{$endif}
|
||||||
|
+ ': ';
|
||||||
|
BytesMessage = ' bytes: ';
|
||||||
|
StringBlockMessage = 'String';
|
||||||
|
LeakMessageFooter = #13#10
|
||||||
|
{$ifndef HideMemoryLeakHintMessage}
|
||||||
|
+ #13#10'Note: '
|
||||||
|
{$ifdef RequireIDEPresenceForLeakReporting}
|
||||||
|
+ 'This memory leak check is only performed if Delphi is currently running on the same computer. '
|
||||||
|
{$endif}
|
||||||
|
{$ifdef FullDebugMode}
|
||||||
|
{$ifdef LogMemoryLeakDetailToFile}
|
||||||
|
+ 'Memory leak detail is logged to a text file in the same folder as this application. '
|
||||||
|
{$else}
|
||||||
|
+ 'Enable the "LogMemoryLeakDetailToFile" to obtain a log file containing detail on memory leaks. '
|
||||||
|
{$endif}
|
||||||
|
{$else}
|
||||||
|
+ 'To obtain a log file containing detail on memory leaks, enable the "FullDebugMode" and "LogMemoryLeakDetailToFile" conditional defines. '
|
||||||
|
{$endif}
|
||||||
|
+ 'To disable this memory leak check, undefine "EnableMemoryLeakReporting".'#13#10
|
||||||
|
{$endif}
|
||||||
|
+ #0;
|
||||||
|
LeakMessageTitle = 'Memory Leak Detected';
|
||||||
|
{$ifdef UseOutputDebugString}
|
||||||
|
FastMMInstallMsg = 'FastMM has been installed.';
|
||||||
|
FastMMInstallSharedMsg = 'Sharing an existing instance of FastMM.';
|
||||||
|
FastMMUninstallMsg = 'FastMM has been uninstalled.';
|
||||||
|
FastMMUninstallSharedMsg = 'Stopped sharing an existing instance of FastMM.';
|
||||||
|
{$endif}
|
||||||
|
{$ifdef DetectMMOperationsAfterUninstall}
|
||||||
|
InvalidOperationTitle = 'MM Operation after uninstall.';
|
||||||
|
InvalidGetMemMsg = 'FastMM has detected a GetMem call after FastMM was uninstalled.';
|
||||||
|
InvalidFreeMemMsg = 'FastMM has detected a FreeMem call after FastMM was uninstalled.';
|
||||||
|
InvalidReallocMemMsg = 'FastMM has detected a ReallocMem call after FastMM was uninstalled.';
|
||||||
|
InvalidAllocMemMsg = 'FastMM has detected a ReallocMem call after FastMM was uninstalled.';
|
||||||
|
{$endif}
|
||||||
|
|
||||||
|
implementation
|
||||||
|
|
||||||
|
end.
|
||||||
|
|
285
2.10/Source/FastMM4Options.inc
Normal file
285
2.10/Source/FastMM4Options.inc
Normal file
@ -0,0 +1,285 @@
|
|||||||
|
{
|
||||||
|
|
||||||
|
Fast Memory Manager: Options Include File
|
||||||
|
|
||||||
|
Set the default options for FastMM here.
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
{---------------------------Miscellaneous Options-----------------------------}
|
||||||
|
|
||||||
|
{Enable this define to align all blocks on 16 byte boundaries so aligned SSE
|
||||||
|
instructions can be used safely. If this option is disabled then some of the
|
||||||
|
smallest block sizes will be 8-byte aligned instead which may result in a
|
||||||
|
reduction in memory usage. Medium and large blocks are always 16-byte aligned
|
||||||
|
irrespective of this setting.}
|
||||||
|
{.$define Align16Bytes}
|
||||||
|
|
||||||
|
{Enable to use faster fixed-size move routines when upsizing small blocks.
|
||||||
|
These routines are much faster than the Borland RTL move procedure since they
|
||||||
|
are optimized to move a fixed number of bytes. This option may be used
|
||||||
|
together with the FastMove library for even better performance.}
|
||||||
|
{$define UseCustomFixedSizeMoveRoutines}
|
||||||
|
|
||||||
|
{Enable this option to use an optimized procedure for moving a memory block of
|
||||||
|
an arbitrary size. Disable this option when using the Fastcode move
|
||||||
|
("FastMove") library. Using the Fastcode move library allows your whole
|
||||||
|
application to gain from faster move routines, not just the memory manager. It
|
||||||
|
is thus recommended that you use the Fastcode move library in conjunction with
|
||||||
|
this memory manager and disable this option.}
|
||||||
|
{$define UseCustomVariableSizeMoveRoutines}
|
||||||
|
|
||||||
|
{Enable to always assume that the application is multithreaded. Enabling this
|
||||||
|
option will cause a significant performance hit with single threaded
|
||||||
|
applications. Enable if you are using multi-threaded third party tools that do
|
||||||
|
not properly set the IsMultiThread variable. Also set this option if you are
|
||||||
|
going to share this memory manager between a single threaded application and a
|
||||||
|
multi-threaded DLL.}
|
||||||
|
{.$define AssumeMultiThreaded}
|
||||||
|
|
||||||
|
{Due to QC#14070 ("Delphi IDE attempts to free memory after the shutdown code
|
||||||
|
of borlndmm.dll has been called"), FastMM cannot be uninstalled safely when
|
||||||
|
used inside a replacement borlndmm.dll for the IDE. Setting this option will
|
||||||
|
circumvent this problem by never uninstalling the memory manager.}
|
||||||
|
{.$define NeverUninstall}
|
||||||
|
|
||||||
|
{Set this option when you use runtime packages in this application or library.
|
||||||
|
This will automatically set the "AssumeMultiThreaded" option. Note that you
|
||||||
|
have to ensure that FastMM is finalized after all live pointers have been
|
||||||
|
freed - failure to do so will result in a large leak report followed by a lot
|
||||||
|
of A/Vs. (See the FAQ for more detail.) You may have to combine this option
|
||||||
|
with the NeverUninstall option.}
|
||||||
|
{.$define UseRuntimePackages}
|
||||||
|
|
||||||
|
{-----------------------------Debugging Options-------------------------------}
|
||||||
|
|
||||||
|
{Enable this option to suppress the display of all message dialogs. This is
|
||||||
|
useful in service applications that should not be interrupted.}
|
||||||
|
{.$define NoMessageBoxes}
|
||||||
|
|
||||||
|
{Set this option to use the Windows API OutputDebugString procedure to output
|
||||||
|
debug strings on startup/shutdown and when errors occur.}
|
||||||
|
{.$define UseOutputDebugString}
|
||||||
|
|
||||||
|
{Set this option to use the assembly language version which is faster than the
|
||||||
|
pascal version. Disable only for debugging purposes. Setting the
|
||||||
|
CheckHeapForCorruption option automatically disables this option.}
|
||||||
|
{$define ASMVersion}
|
||||||
|
|
||||||
|
{FastMM always catches attempts to free the same memory block twice, however it
|
||||||
|
can also check for corruption of the memory heap (typically due to the user
|
||||||
|
program overwriting the bounds of allocated memory). These checks are
|
||||||
|
expensive, and this option should thus only be used for debugging purposes.
|
||||||
|
If this option is set then the ASMVersion option is automatically disabled.}
|
||||||
|
{.$define CheckHeapForCorruption}
|
||||||
|
|
||||||
|
{Enable this option to catch attempts to perform MM operations after FastMM has
|
||||||
|
been uninstalled. With this option set when FastMM is uninstalled it will not
|
||||||
|
install the previous MM, but instead a dummy MM handler that throws an error
|
||||||
|
if any MM operation is attempted. This will catch attempts to use the MM
|
||||||
|
after FastMM has been uninstalled.}
|
||||||
|
{$define DetectMMOperationsAfterUninstall}
|
||||||
|
|
||||||
|
{Set the following option to do extensive checking of all memory blocks. All
|
||||||
|
blocks are padded with both a header and trailer that are used to verify the
|
||||||
|
integrity of the heap. Freed blocks are also cleared to to ensure that they
|
||||||
|
cannot be reused after being freed. This option slows down memory operations
|
||||||
|
dramatically and should only be used to debug an application that is
|
||||||
|
overwriting memory or reusing freed pointers. Setting this option
|
||||||
|
automatically enables CheckHeapForCorruption and disables ASMVersion.
|
||||||
|
Very important: If you enable this option your application will require the
|
||||||
|
FastMM_FullDebugMode.dll library. If this library is not available you will
|
||||||
|
get an error on startup.}
|
||||||
|
{.$define FullDebugMode}
|
||||||
|
|
||||||
|
{Set this option to perform "raw" stack traces, i.e. check all entries on the
|
||||||
|
stack for valid return addresses. Note that this is significantly slower
|
||||||
|
than using the stack frame tracing method, but is usually more complete. Has
|
||||||
|
no effect unless FullDebugMode is enabled}
|
||||||
|
{$define RawStackTraces}
|
||||||
|
|
||||||
|
{Set this option to check for user code that uses an interface of a freed
|
||||||
|
object. Note that this will disable the checking of blocks modified after
|
||||||
|
being freed (the two are not compatible). This option has no effect if
|
||||||
|
FullDebugMode is not also enabled.}
|
||||||
|
{.$define CatchUseOfFreedInterfaces}
|
||||||
|
|
||||||
|
{Set this option to log all errors to a text file in the same folder as the
|
||||||
|
application. Memory errors (with the FullDebugMode option set) will be
|
||||||
|
appended to the log file. Has no effect if "FullDebugMode" is not set.}
|
||||||
|
{$define LogErrorsToFile}
|
||||||
|
|
||||||
|
{Set this option to log all memory leaks to a text file in the same folder as
|
||||||
|
the application. Memory leak reports (with the FullDebugMode option set)
|
||||||
|
will be appended to the log file. Has no effect if "LogErrorsToFile" and
|
||||||
|
"FullDebugMode" are not also set. Note that usually all leaks are always
|
||||||
|
logged, even if they are "expected" leaks registered through
|
||||||
|
AddExpectedMemoryLeaks. Expected leaks registered by pointer may be excluded
|
||||||
|
through the HideExpectedLeaksRegisteredByPointer option.}
|
||||||
|
{$define LogMemoryLeakDetailToFile}
|
||||||
|
|
||||||
|
{Deletes the error log file on startup. No effect if LogErrorsToFile is not
|
||||||
|
also set.}
|
||||||
|
{.$define ClearLogFileOnStartup}
|
||||||
|
|
||||||
|
{---------------------------Memory Leak Reporting-----------------------------}
|
||||||
|
|
||||||
|
{Set this option to enable reporting of memory leaks. Combine it with the two
|
||||||
|
options below for further fine-tuning.}
|
||||||
|
{$define EnableMemoryLeakReporting}
|
||||||
|
|
||||||
|
{Set this option to suppress the display and logging of expected memory leaks
|
||||||
|
that were registered by pointer. Leaks registered by size or class are often
|
||||||
|
ambiguous, so these expected leaks are always logged to file (in
|
||||||
|
FullDebugMode with the LogMemoryLeakDetailToFile option set) and are never
|
||||||
|
hidden from the leak display if there are more leaks than are expected.}
|
||||||
|
{$define HideExpectedLeaksRegisteredByPointer}
|
||||||
|
|
||||||
|
{Set this option to require the presence of the Delphi IDE to report memory
|
||||||
|
leaks. This option has no effect if the option "EnableMemoryLeakReporting"
|
||||||
|
is not also set.}
|
||||||
|
{.$define RequireIDEPresenceForLeakReporting}
|
||||||
|
|
||||||
|
{Set this option to require the program to be run inside the IDE debugger to
|
||||||
|
report memory leaks. This option has no effect if the option
|
||||||
|
"EnableMemoryLeakReporting" is not also set.}
|
||||||
|
{$define RequireDebuggerPresenceForLeakReporting}
|
||||||
|
|
||||||
|
{Set this option to require the presence of debug info ($D+ option) in the
|
||||||
|
compiled unit to perform memory leak checking. This option has no effect if
|
||||||
|
the option "EnableMemoryLeakReporting" is not also set.}
|
||||||
|
{.$define RequireDebugInfoForLeakReporting}
|
||||||
|
|
||||||
|
{Set this option to enable manual control of the memory leak report. When
|
||||||
|
this option is set the ReportMemoryLeaksOnShutdown variable (default = false)
|
||||||
|
may be changed to select whether leak reporting should be done or not. When
|
||||||
|
this option is selected then both the variable must be set to true and the
|
||||||
|
other leak checking options must be applicable for the leak checking to be
|
||||||
|
done.}
|
||||||
|
{.$define ManualLeakReportingControl}
|
||||||
|
|
||||||
|
{Set this option to disable the display of the hint below the memory leak
|
||||||
|
message.}
|
||||||
|
{.$define HideMemoryLeakHintMessage}
|
||||||
|
|
||||||
|
{--------------------------Instruction Set Options----------------------------}
|
||||||
|
|
||||||
|
{Set this option to enable the use of MMX instructions. Disabling this option
|
||||||
|
will result in a slight performance hit, but will enable compatibility with
|
||||||
|
AMD K5, Pentium I and earlier CPUs. MMX is currently only used in the variable
|
||||||
|
size move routines, so if UseCustomVariableSizeMoveRoutines is not set then
|
||||||
|
this option has no effect.}
|
||||||
|
{$define EnableMMX}
|
||||||
|
|
||||||
|
{Set this option to force the use of MMX instructions without checking
|
||||||
|
whether the CPU supports it. If this option is disabled then the CPU will be
|
||||||
|
checked for compatibility first, and if MMX is not supported it will fall
|
||||||
|
back to the FPU move code. Has no effect unless EnableMMX is also set.}
|
||||||
|
{$define ForceMMX}
|
||||||
|
|
||||||
|
{-----------------------Memory Manager Sharing Options------------------------}
|
||||||
|
|
||||||
|
{Allow sharing of the memory manager between a main application and DLLs that
|
||||||
|
were also compiled with FastMM. This allows you to pass dynamic arrays and
|
||||||
|
long strings to DLL functions provided both are compiled to use FastMM.
|
||||||
|
Sharing will only work if the library that is supposed to share the memory
|
||||||
|
manager was compiled with the "AttemptToUseSharedMM" option set. Note that if
|
||||||
|
the main application is single threaded and the DLL is multi-threaded that you
|
||||||
|
have to set the IsMultiThread variable in the main application to true or it
|
||||||
|
will crash when a thread contention occurs. Note that statically linked DLL
|
||||||
|
files are initialized before the main application, so the main application may
|
||||||
|
well end up sharing a statically loaded DLL's memory manager and not the other
|
||||||
|
way around. }
|
||||||
|
{.$define ShareMM}
|
||||||
|
|
||||||
|
{Allow sharing of the memory manager by a DLL with other DLLs (or the main
|
||||||
|
application if this is a statically loaded DLL) that were also compiled with
|
||||||
|
FastMM. Set this option with care in dynamically loaded DLLs, because if the
|
||||||
|
DLL that is sharing its MM is unloaded and any other DLL is still sharing
|
||||||
|
the MM then the application will crash. This setting is only relevant for
|
||||||
|
DLL libraries and requires ShareMM to also be set to have any effect.
|
||||||
|
Sharing will only work if the library that is supposed to share the memory
|
||||||
|
manager was compiled with the "AttemptToUseSharedMM" option set. Note that
|
||||||
|
if DLLs are statically linked then they will be initialized before the main
|
||||||
|
application and then the DLL will in fact share its MM with the main
|
||||||
|
application. This option has no effect unless ShareMM is also set.}
|
||||||
|
{.$define ShareMMIfLibrary}
|
||||||
|
|
||||||
|
{Define this to attempt to share the MM of the main application or other loaded
|
||||||
|
DLLs in the same process that were compiled with ShareMM set. When sharing a
|
||||||
|
memory manager, memory leaks caused by the sharer will not be freed
|
||||||
|
automatically. Take into account that statically linked DLLs are initialized
|
||||||
|
before the main application, so set the sharing options accordingly.}
|
||||||
|
{.$define AttemptToUseSharedMM}
|
||||||
|
|
||||||
|
{Define this option to allow sharing between the default memory manager and
|
||||||
|
FastMM. This option only works together with the memory manager of BDS2006.
|
||||||
|
With this option enabled FastMM can be shared with applications using the
|
||||||
|
Delphi 2006 MM and vice versa. (You may have to add SimpleShareMem.pas to the
|
||||||
|
project using the Delphi 2006 memory manager to enable sharing.)}
|
||||||
|
{$define EnableSharingWithDefaultMM}
|
||||||
|
|
||||||
|
{--------------------------------Option Grouping------------------------------}
|
||||||
|
|
||||||
|
{Group the options you use for release and debug versions below}
|
||||||
|
{$ifdef Release}
|
||||||
|
{Specify the options you use for release versions below}
|
||||||
|
{.$undef FullDebugMode}
|
||||||
|
{.$undef CheckHeapForCorruption}
|
||||||
|
{.$define ASMVersion}
|
||||||
|
{.$undef EnableMemoryLeakReporting}
|
||||||
|
{.$undef UseOutputDebugString}
|
||||||
|
{$else}
|
||||||
|
{Specify the options you use for debugging below}
|
||||||
|
{.$define FullDebugMode}
|
||||||
|
{.$define EnableMemoryLeakReporting}
|
||||||
|
{.$define UseOutputDebugString}
|
||||||
|
{$endif}
|
||||||
|
|
||||||
|
{--------------------Compilation Options For borlndmm.dll---------------------}
|
||||||
|
{If you're compiling the replacement borlndmm.dll, set the defines below
|
||||||
|
for the kind of dll you require.}
|
||||||
|
|
||||||
|
{Set this option when compiling the borlndmm.dll}
|
||||||
|
{.$define borlndmmdll}
|
||||||
|
|
||||||
|
{Set this option if the dll will be used by the Delphi IDE}
|
||||||
|
{.$define dllforide}
|
||||||
|
|
||||||
|
{Set this option if you're compiling a debug dll}
|
||||||
|
{.$define debugdll}
|
||||||
|
|
||||||
|
{Do not change anything below this line}
|
||||||
|
{$ifdef borlndmmdll}
|
||||||
|
{$define AssumeMultiThreaded}
|
||||||
|
{$undef HideExpectedLeaksRegisteredByPointer}
|
||||||
|
{$undef RequireDebuggerPresenceForLeakReporting}
|
||||||
|
{$undef RequireDebugInfoForLeakReporting}
|
||||||
|
{$define DetectMMOperationsAfterUninstall}
|
||||||
|
{$undef ManualLeakReportingControl}
|
||||||
|
{$undef ShareMM}
|
||||||
|
{$undef AttemptToUseSharedMM}
|
||||||
|
{$ifdef dllforide}
|
||||||
|
{$define NeverUninstall}
|
||||||
|
{$define HideMemoryLeakHintMessage}
|
||||||
|
{$undef RequireIDEPresenceForLeakReporting}
|
||||||
|
{$ifndef debugdll}
|
||||||
|
{$undef EnableMemoryLeakReporting}
|
||||||
|
{$endif}
|
||||||
|
{$else}
|
||||||
|
{$define EnableMemoryLeakReporting}
|
||||||
|
{$undef NeverUninstall}
|
||||||
|
{$undef HideMemoryLeakHintMessage}
|
||||||
|
{$define RequireIDEPresenceForLeakReporting}
|
||||||
|
{$endif}
|
||||||
|
{$ifdef debugdll}
|
||||||
|
{$define FullDebugMode}
|
||||||
|
{$define RawStackTraces}
|
||||||
|
{$undef CatchUseOfFreedInterfaces}
|
||||||
|
{$define LogErrorsToFile}
|
||||||
|
{$define LogMemoryLeakDetailToFile}
|
||||||
|
{$undef ClearLogFileOnStartup}
|
||||||
|
{$else}
|
||||||
|
{$undef FullDebugMode}
|
||||||
|
{$endif}
|
||||||
|
{$endif}
|
Loading…
Reference in New Issue
Block a user