mirror of
				https://gitlab.com/freepascal.org/lazarus/lazarus.git
				synced 2025-10-26 02:42:46 +02:00 
			
		
		
		
	Implemented TClipBoard.BeginUpdate/EndUpdate
git-svn-id: trunk@7728 -
This commit is contained in:
		
							parent
							
								
									66cbe700a5
								
							
						
					
					
						commit
						aeb2c02069
					
				| @ -123,7 +123,8 @@ interface | |||||||
| {$endif} | {$endif} | ||||||
| 
 | 
 | ||||||
| uses | uses | ||||||
|   Classes, SysUtils, FPCAdds, LCLType, LResources, LCLIntf, GraphType, Graphics; |   Classes, SysUtils, LCLproc, FPCAdds, LCLType, LResources, LCLIntf, GraphType, | ||||||
|  |   Graphics; | ||||||
| 
 | 
 | ||||||
| { for delphi compatibility: | { for delphi compatibility: | ||||||
| 
 | 
 | ||||||
| @ -150,6 +151,8 @@ type | |||||||
|     Stream: TMemoryStream; |     Stream: TMemoryStream; | ||||||
|   end; |   end; | ||||||
| 
 | 
 | ||||||
|  |   { TClipboard } | ||||||
|  | 
 | ||||||
|   TClipboard = Class(TPersistent) |   TClipboard = Class(TPersistent) | ||||||
|   private |   private | ||||||
|     FAllocated: Boolean;    // = has ownership |     FAllocated: Boolean;    // = has ownership | ||||||
| @ -175,15 +178,21 @@ type | |||||||
|     procedure InternalOnRequest(const RequestedFormatID: TClipboardFormat; |     procedure InternalOnRequest(const RequestedFormatID: TClipboardFormat; | ||||||
|       AStream: TStream); |       AStream: TStream); | ||||||
|     procedure SetAsText(const Value: string); |     procedure SetAsText(const Value: string); | ||||||
|     procedure SetBuffer(FormatID: TClipboardFormat; var Buffer; Size: Integer); |     function SetBuffer(FormatID: TClipboardFormat; | ||||||
|  |                        var Buffer; Size: Integer): Boolean; | ||||||
|     procedure SetOnRequest(AnOnRequest: TClipboardRequestEvent); |     procedure SetOnRequest(AnOnRequest: TClipboardRequestEvent); | ||||||
|  |     procedure BeginUpdate; | ||||||
|  |     function EndUpdate: Boolean; | ||||||
|  |     function IsUpdating: Boolean; | ||||||
|  |     function CanReadFromInterface: Boolean; | ||||||
|  |     function CanReadFromCache: Boolean; | ||||||
|   public |   public | ||||||
|     function AddFormat(FormatID: TClipboardFormat; Stream: TStream): Boolean; |     function AddFormat(FormatID: TClipboardFormat; Stream: TStream): Boolean; | ||||||
|     function AddFormat(FormatID: TClipboardFormat; var Buffer; Size: Integer): Boolean; |     function AddFormat(FormatID: TClipboardFormat; var Buffer; Size: Integer): Boolean; | ||||||
|     procedure Assign(Source: TPersistent); override; |     procedure Assign(Source: TPersistent); override; | ||||||
|     procedure AssignTo(Dest: TPersistent); override; |     procedure AssignTo(Dest: TPersistent); override; | ||||||
|     procedure Clear; |     procedure Clear; | ||||||
|     procedure Close; // dummy for delphi compatibility only |     procedure Close; | ||||||
|     constructor Create; |     constructor Create; | ||||||
|     constructor Create(AClipboardType: TClipboardType); |     constructor Create(AClipboardType: TClipboardType); | ||||||
|     destructor Destroy; override; |     destructor Destroy; override; | ||||||
| @ -199,12 +208,12 @@ type | |||||||
|     function HasFormat(FormatID: TClipboardFormat): Boolean; |     function HasFormat(FormatID: TClipboardFormat): Boolean; | ||||||
|     function HasFormatName(const FormatName: string): Boolean; |     function HasFormatName(const FormatName: string): Boolean; | ||||||
|     function HasPictureFormat: boolean; |     function HasPictureFormat: boolean; | ||||||
|     procedure Open; // dummy for delphi compatibility only |     procedure Open; | ||||||
|     //procedure SetAsHandle(Format: integer; Value: THandle); |     //procedure SetAsHandle(Format: integer; Value: THandle); | ||||||
|     procedure SetComponent(Component: TComponent); |     function SetComponent(Component: TComponent): Boolean; | ||||||
|     procedure SetFormat(FormatID: TClipboardFormat; Stream: TStream); |     function SetFormat(FormatID: TClipboardFormat; Stream: TStream): Boolean; | ||||||
|     procedure SetSupportedFormats(AFormatCount: integer; |     function SetSupportedFormats(AFormatCount: integer; | ||||||
|                                   FormatList: PClipboardFormat); |                                   FormatList: PClipboardFormat): Boolean; | ||||||
|     procedure SetTextBuf(Buffer: PChar); |     procedure SetTextBuf(Buffer: PChar); | ||||||
|     property AsText: string read GetAsText write SetAsText; |     property AsText: string read GetAsText write SetAsText; | ||||||
|     property ClipboardType: TClipboardType read FClipboardType; |     property ClipboardType: TClipboardType read FClipboardType; | ||||||
|  | |||||||
| @ -1410,6 +1410,9 @@ type | |||||||
|     procedure SetUseDockManager(const AValue: Boolean); |     procedure SetUseDockManager(const AValue: Boolean); | ||||||
|     procedure UpdateTabOrder(NewTabOrder: TTabOrder); |     procedure UpdateTabOrder(NewTabOrder: TTabOrder); | ||||||
|     function  WantsKeyBeforeInterface(Key: word; Shift: TShiftState): boolean; |     function  WantsKeyBeforeInterface(Key: word; Shift: TShiftState): boolean; | ||||||
|  |     procedure Insert(AControl: TControl); | ||||||
|  |     procedure Insert(AControl: TControl; Index: integer); | ||||||
|  |     procedure Remove(AControl: TControl); | ||||||
|   protected |   protected | ||||||
|     FWinControlFlags: TWinControlFlags; |     FWinControlFlags: TWinControlFlags; | ||||||
|     procedure AssignTo(Dest: TPersistent); override; |     procedure AssignTo(Dest: TPersistent); override; | ||||||
| @ -1514,7 +1517,7 @@ type | |||||||
|     procedure KeyUpAfterInterface(var Key: Word; Shift: TShiftState); dynamic; |     procedure KeyUpAfterInterface(var Key: Word; Shift: TShiftState); dynamic; | ||||||
|     procedure UTF8KeyPress(var UTF8Key: TUTF8Char); dynamic; |     procedure UTF8KeyPress(var UTF8Key: TUTF8Char); dynamic; | ||||||
|   protected |   protected | ||||||
|     Function  FindNextControl(CurrentControl: TWinControl; GoForward, |     function  FindNextControl(CurrentControl: TWinControl; GoForward, | ||||||
|                               CheckTabStop, CheckParent: Boolean): TWinControl; |                               CheckTabStop, CheckParent: Boolean): TWinControl; | ||||||
|     function  RealGetText: TCaption; override; |     function  RealGetText: TCaption; override; | ||||||
|     function  GetBorderStyle: TBorderStyle; |     function  GetBorderStyle: TBorderStyle; | ||||||
| @ -1631,9 +1634,6 @@ type | |||||||
|     Procedure InsertControl(AControl: TControl); |     Procedure InsertControl(AControl: TControl); | ||||||
|     Procedure InsertControl(AControl: TControl; Index: integer); |     Procedure InsertControl(AControl: TControl; Index: integer); | ||||||
|     Procedure RemoveControl(AControl: TControl); |     Procedure RemoveControl(AControl: TControl); | ||||||
|     Procedure Insert(AControl: TControl); |  | ||||||
|     Procedure Insert(AControl: TControl; Index: integer); |  | ||||||
|     Procedure Remove(AControl: TControl); |  | ||||||
|     procedure Repaint; override; |     procedure Repaint; override; | ||||||
|     Procedure SetFocus; virtual; |     Procedure SetFocus; virtual; | ||||||
|     Function FindChildControl(const ControlName: String): TControl; |     Function FindChildControl(const ControlName: String): TControl; | ||||||
|  | |||||||
| @ -16,17 +16,15 @@ | |||||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.                     * |  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.                     * | ||||||
|  *                                                                           * |  *                                                                           * | ||||||
|  ***************************************************************************** |  ***************************************************************************** | ||||||
| } |  | ||||||
| { |  | ||||||
|   The clipboard is able to emulate the windows and gtk behaviour/features. |  | ||||||
|    |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
|  |   The clipboard is able to work with the windows and gtk behaviour/features. | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| { TClipboard } | { TClipboard } | ||||||
| 
 | 
 | ||||||
| constructor TClipboard.Create; | constructor TClipboard.Create; | ||||||
| begin | begin | ||||||
|  |   // default: create a normal Clipboard
 | ||||||
|   Create(ctClipboard); |   Create(ctClipboard); | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| @ -66,10 +64,11 @@ begin | |||||||
|         ClipboardTypeName[ClipboardType]); |         ClipboardTypeName[ClipboardType]); | ||||||
|   end; |   end; | ||||||
|   Result:=FCount-1; |   Result:=FCount-1; | ||||||
|   while (Result>=0) and (FData[Result].FormatID<>FormatID) do dec(Result); |   while (Result>=0) and (FData[Result].FormatID<>FormatID) do | ||||||
|  |     dec(Result); | ||||||
|   FormatAdded:=false; |   FormatAdded:=false; | ||||||
|   if (Result<0) and CreateIfNotExists then begin |   if (Result<0) and CreateIfNotExists then begin | ||||||
|     // add format
 |     // add new format
 | ||||||
|     inc(FCount); |     inc(FCount); | ||||||
|     NewSize:=SizeOf(TClipboardData)*FCount; |     NewSize:=SizeOf(TClipboardData)*FCount; | ||||||
|     ReallocMem(FData,NewSize); |     ReallocMem(FData,NewSize); | ||||||
| @ -79,21 +78,23 @@ begin | |||||||
|     FSupportedFormatsChanged:=true; |     FSupportedFormatsChanged:=true; | ||||||
|     FormatAdded:=true; |     FormatAdded:=true; | ||||||
|   end; |   end; | ||||||
|   // CreateIfNotExists = true means changing the clipboard
 |   if not IsUpdating then begin | ||||||
|   // => we need OwnerShip for that
 |     // CreateIfNotExists = true means changing the clipboard
 | ||||||
|   if CreateIfNotExists and (not GetOwnerShip) then begin |     // => we need OwnerShip for that
 | ||||||
|     // getting ownership failed
 |     if CreateIfNotExists and (not GetOwnerShip) then begin | ||||||
|     if FormatAdded then begin |       // getting ownership failed
 | ||||||
|       // undo: remove added format
 |       if FormatAdded then begin | ||||||
|       // Note: This creates a little overhead in case of an error, but reduces
 |         // undo: remove added format
 | ||||||
|       // overhead in case of everything works
 |         // Note: This creates a little overhead in case of an error, but reduces
 | ||||||
|       FData[Result].Stream.Free; |         // overhead in case of everything works
 | ||||||
|       NewSize:=SizeOf(TClipboardData)*FCount; |         FData[Result].Stream.Free; | ||||||
|       ReallocMem(FData,NewSize); |         NewSize:=SizeOf(TClipboardData)*FCount; | ||||||
|  |         ReallocMem(FData,NewSize); | ||||||
|  |       end; | ||||||
|  |       Result:=-1; | ||||||
|  |       raise Exception.Create('Unable to get clipboard ownership for '+ | ||||||
|  |         ClipboardTypeName[ClipboardType]); | ||||||
|     end; |     end; | ||||||
|     Result:=-1; |  | ||||||
|     raise Exception.Create('Unable to get clipboard ownership for '+ |  | ||||||
|       ClipboardTypeName[ClipboardType]); |  | ||||||
|   end; |   end; | ||||||
|   //DebugLn('[TClipboard.IndexOfCachedFormatID] END ',ClipboardTypeName[ClipboardType]
 |   //DebugLn('[TClipboard.IndexOfCachedFormatID] END ',ClipboardTypeName[ClipboardType]
 | ||||||
|   //,' Format=',FormatID,' CreateIfNotExists=',CreateIfNotExists,' Result=',Result);
 |   //,' Format=',FormatID,' CreateIfNotExists=',CreateIfNotExists,' Result=',Result);
 | ||||||
| @ -108,17 +109,21 @@ var | |||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.AddFormat - Stream] A ',ClipboardTypeName[ClipboardType],' Format=',FormatID);
 |   //DebugLn('[TClipboard.AddFormat - Stream] A ',ClipboardTypeName[ClipboardType],' Format=',FormatID);
 | ||||||
|   Result:=false; |   Result:=false; | ||||||
|   i:=IndexOfCachedFormatID(FormatID,true); |   BeginUpdate; | ||||||
|   if i<0 then exit; |   try | ||||||
|   if FData[i].Stream<>Stream then begin |     i:=IndexOfCachedFormatID(FormatID,true); | ||||||
|     if Stream<>nil then begin |     if i<0 then exit; | ||||||
|       OldPosition:=Stream.Position; |     if FData[i].Stream<>Stream then begin | ||||||
|       FData[i].Stream.LoadFromStream(Stream); |       if Stream<>nil then begin | ||||||
|       Stream.Position:=OldPosition; |         OldPosition:=Stream.Position; | ||||||
|     end else |         FData[i].Stream.LoadFromStream(Stream); | ||||||
|       FData[i].Stream.Clear; |         Stream.Position:=OldPosition; | ||||||
|  |       end else | ||||||
|  |         FData[i].Stream.Clear; | ||||||
|  |     end; | ||||||
|  |   finally | ||||||
|  |     Result:=EndUpdate; | ||||||
|   end; |   end; | ||||||
|   Result:=true; |  | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| function TClipboard.AddFormat(FormatID: TClipboardFormat; | function TClipboard.AddFormat(FormatID: TClipboardFormat; | ||||||
| @ -127,28 +132,38 @@ var i: integer; | |||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.AddFormat - Buffer] A ',ClipboardTypeName[ClipboardType],' Format=',FormatID,' Size=',Size);
 |   //DebugLn('[TClipboard.AddFormat - Buffer] A ',ClipboardTypeName[ClipboardType],' Format=',FormatID,' Size=',Size);
 | ||||||
|   Result:=false; |   Result:=false; | ||||||
|   i:=IndexOfCachedFormatID(FormatID,true); |   BeginUpdate; | ||||||
|   if i<0 then exit; |   try | ||||||
|   FData[i].Stream.Clear; |     i:=IndexOfCachedFormatID(FormatID,true); | ||||||
|   if Size>0 then |     if i<0 then exit; | ||||||
|     FData[i].Stream.Write(Buffer,Size); |     FData[i].Stream.Clear; | ||||||
|   Result:=true; |     if Size>0 then | ||||||
|  |       FData[i].Stream.Write(Buffer,Size); | ||||||
|  |   finally | ||||||
|  |     Result:=EndUpdate; | ||||||
|  |   end; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.SetFormat(FormatID: TClipboardFormat; Stream: TStream); | function TClipboard.SetFormat(FormatID: TClipboardFormat; | ||||||
|  |   Stream: TStream): Boolean; | ||||||
| // copy Stream to a MemoryStream, set the cache and tell the interface object
 | // copy Stream to a MemoryStream, set the cache and tell the interface object
 | ||||||
| begin | begin | ||||||
|   Clear; |   BeginUpdate; | ||||||
|   AddFormat(FormatID,Stream); |   try | ||||||
|  |     Clear; | ||||||
|  |     AddFormat(FormatID,Stream); | ||||||
|  |   finally | ||||||
|  |     Result:=EndUpdate; | ||||||
|  |   end; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.Clear; | procedure TClipboard.Clear; | ||||||
| var i: integer; | var i: integer; | ||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.Clear] A ',ClipboardTypeName[ClipboardType]);
 |   //DebugLn('[TClipboard.Clear] A ',ClipboardTypeName[ClipboardType]);
 | ||||||
|   for i:=0 to FCount-1 do |  | ||||||
|     FData[i].Stream.Free; |  | ||||||
|   if FData<>nil then begin |   if FData<>nil then begin | ||||||
|  |     for i:=0 to FCount-1 do | ||||||
|  |       FData[i].Stream.Free; | ||||||
|     FreeMem(FData,SizeOf(TClipboardData)*FCount); |     FreeMem(FData,SizeOf(TClipboardData)*FCount); | ||||||
|     FData:=nil; |     FData:=nil; | ||||||
|   end; |   end; | ||||||
| @ -156,33 +171,22 @@ begin | |||||||
|   //DebugLn('[TClipboard.Clear] END ',ClipboardTypeName[ClipboardType]);
 |   //DebugLn('[TClipboard.Clear] END ',ClipboardTypeName[ClipboardType]);
 | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| {procedure TClipboard.Adding; | procedure TClipboard.Open; | ||||||
|  | // Open and Closed must be balanced.
 | ||||||
|  | // When the Clipboard is Open, it will not read/write from/to the interface.
 | ||||||
|  | // Instead it will collect all changes until Close is called.
 | ||||||
|  | // It will then try to commit all changes as one block.
 | ||||||
| begin | begin | ||||||
|   if (FOpenRefCount <> 0) and not FEmptied then begin |   BeginUpdate; | ||||||
|     Clear; | end; | ||||||
|     FEmptied := True; |  | ||||||
|   end; |  | ||||||
| end;} |  | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.Close; | procedure TClipboard.Close; | ||||||
| begin | begin | ||||||
|   if FOpenRefCount = 0 then Exit; |   EndUpdate; | ||||||
|   Dec(FOpenRefCount); |  | ||||||
|   if FOpenRefCount = 0 then begin |  | ||||||
|   end; |  | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.Open; | procedure TClipboard.InternalOnRequest( | ||||||
| begin |   const RequestedFormatID: TClipboardFormat; AStream: TStream); | ||||||
|   if FOpenRefCount = 0 then begin |  | ||||||
|     if not GetOwnerShip then |  | ||||||
|       raise Exception.Create('unable to open clipboard'); |  | ||||||
|   end; |  | ||||||
|   Inc(FOpenRefCount); |  | ||||||
| end; |  | ||||||
| 
 |  | ||||||
| procedure TClipboard.InternalOnRequest(const RequestedFormatID: TClipboardFormat; |  | ||||||
|   AStream: TStream); |  | ||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.InternalOnRequest] A ',ClipboardTypeName[ClipboardType]
 |   //DebugLn('[TClipboard.InternalOnRequest] A ',ClipboardTypeName[ClipboardType]
 | ||||||
|   //,' RequestedFormatID=',RequestedFormatID,' AStream=',AStream<>nil,' Allocated=',FAllocated);
 |   //,' RequestedFormatID=',RequestedFormatID,' AStream=',AStream<>nil,' Allocated=',FAllocated);
 | ||||||
| @ -224,6 +228,41 @@ begin | |||||||
|   FOnRequest:=AnOnRequest; |   FOnRequest:=AnOnRequest; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
|  | procedure TClipboard.BeginUpdate; | ||||||
|  | begin | ||||||
|  |   Inc(FOpenRefCount); | ||||||
|  | end; | ||||||
|  | 
 | ||||||
|  | function TClipboard.EndUpdate: Boolean; | ||||||
|  | begin | ||||||
|  |   if FOpenRefCount = 0 then | ||||||
|  |     RaiseGDBException('TClipboard.EndUpdate'); | ||||||
|  |   Result:=true; | ||||||
|  |   Dec(FOpenRefCount); | ||||||
|  |   if FOpenRefCount = 0 then begin | ||||||
|  |     if FSupportedFormatsChanged then begin | ||||||
|  |       Result:=GetOwnerShip; | ||||||
|  |       if not Result then | ||||||
|  |         Clear; | ||||||
|  |     end; | ||||||
|  |   end; | ||||||
|  | end; | ||||||
|  | 
 | ||||||
|  | function TClipboard.IsUpdating: Boolean; | ||||||
|  | begin | ||||||
|  |   Result:=FOpenRefCount>0; | ||||||
|  | end; | ||||||
|  | 
 | ||||||
|  | function TClipboard.CanReadFromInterface: Boolean; | ||||||
|  | begin | ||||||
|  |   Result:=FAllocated and (not IsUpdating); | ||||||
|  | end; | ||||||
|  | 
 | ||||||
|  | function TClipboard.CanReadFromCache: Boolean; | ||||||
|  | begin | ||||||
|  |   Result:=FAllocated or IsUpdating; | ||||||
|  | end; | ||||||
|  | 
 | ||||||
| function TClipboard.GetFormat(FormatID: TClipboardFormat; | function TClipboard.GetFormat(FormatID: TClipboardFormat; | ||||||
|   Stream: TStream): Boolean; |   Stream: TStream): Boolean; | ||||||
| // request data from interface object or copy cached data to Stream
 | // request data from interface object or copy cached data to Stream
 | ||||||
| @ -233,8 +272,7 @@ begin | |||||||
|   Result:=false; |   Result:=false; | ||||||
|   if Stream=nil then exit; |   if Stream=nil then exit; | ||||||
|   if FormatID=0 then exit; |   if FormatID=0 then exit; | ||||||
|   if FAllocated then begin |   if CanReadFromCache then begin | ||||||
|     // having ownership
 |  | ||||||
|     if Assigned(FOnRequest) then begin |     if Assigned(FOnRequest) then begin | ||||||
|       FOnRequest(FormatID,Stream); |       FOnRequest(FormatID,Stream); | ||||||
|       Result:=true; |       Result:=true; | ||||||
| @ -257,26 +295,31 @@ begin | |||||||
|   //DebugLn('[TClipboard.GetFormat] END ',ClipboardTypeName[ClipboardType],' FormatID=',FormatID,' Result=',Result);
 |   //DebugLn('[TClipboard.GetFormat] END ',ClipboardTypeName[ClipboardType],' FormatID=',FormatID,' Result=',Result);
 | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.SetComponent(Component: TComponent); | function TClipboard.SetComponent(Component: TComponent): Boolean; | ||||||
| var | var | ||||||
|   i: integer; |   i: integer; | ||||||
|   s: TMemoryStream; |   s: TMemoryStream; | ||||||
|   DestroyDriver: Boolean; |   DestroyDriver: Boolean; | ||||||
|   Writer: TWriter; |   Writer: TWriter; | ||||||
| begin | begin | ||||||
|   i:=IndexOfCachedFormatID(PredefinedClipboardFormat(pcfCustomData),true); |   BeginUpdate; | ||||||
|   s:=FData[i].Stream; |   try | ||||||
|   s.Clear; |     i:=IndexOfCachedFormatID(PredefinedClipboardFormat(pcfCustomData),true); | ||||||
|   s.WriteComponent(Component); |     s:=FData[i].Stream; | ||||||
|   DestroyDriver:=false; |     s.Clear; | ||||||
|   Writer := CreateLRSWriter(s,DestroyDriver); |     s.WriteComponent(Component); | ||||||
|   Try |     DestroyDriver:=false; | ||||||
|     Writer.WriteDescendent(Component, nil); |     Writer := CreateLRSWriter(s,DestroyDriver); | ||||||
|   Finally |     Try | ||||||
|     if DestroyDriver then Writer.Driver.Free; |       Writer.WriteDescendent(Component, nil); | ||||||
|     Writer.Destroy; |     Finally | ||||||
|  |       if DestroyDriver then Writer.Driver.Free; | ||||||
|  |       Writer.Destroy; | ||||||
|  |     end; | ||||||
|  |     s.Position:=0; | ||||||
|  |   finally | ||||||
|  |     Result:=EndUpdate; | ||||||
|   end; |   end; | ||||||
|   s.Position:=0; |  | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| function TClipboard.GetComponent(Owner, Parent: TComponent): TComponent; | function TClipboard.GetComponent(Owner, Parent: TComponent): TComponent; | ||||||
| @ -313,15 +356,20 @@ begin | |||||||
|   end; |   end; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.SetBuffer(FormatID: TClipboardFormat; | function TClipboard.SetBuffer(FormatID: TClipboardFormat; | ||||||
|   var Buffer; Size: Integer); |   var Buffer; Size: Integer): Boolean; | ||||||
| var i: integer; | var i: integer; | ||||||
| begin | begin | ||||||
|   i:=IndexOfCachedFormatID(FormatID,true); |   BeginUpdate; | ||||||
|   FData[i].Stream.Clear; |   try | ||||||
|   if Size>0 then begin |     i:=IndexOfCachedFormatID(FormatID,true); | ||||||
|     FData[i].Stream.Write(Buffer,Size); |     FData[i].Stream.Clear; | ||||||
|     FData[i].Stream.Position:=0; |     if Size>0 then begin | ||||||
|  |       FData[i].Stream.Write(Buffer,Size); | ||||||
|  |       FData[i].Stream.Position:=0; | ||||||
|  |     end; | ||||||
|  |   finally | ||||||
|  |     Result:=EndUpdate; | ||||||
|   end; |   end; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| @ -390,7 +438,7 @@ var cnt, i: integer; | |||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.SupportedFormats]');
 |   //DebugLn('[TClipboard.SupportedFormats]');
 | ||||||
|   List.Clear; |   List.Clear; | ||||||
|   if FAllocated then begin |   if CanReadFromCache then begin | ||||||
|     for i:=0 to FCount-1 do |     for i:=0 to FCount-1 do | ||||||
|       List.Add(ClipboardFormatToMimeType(FData[i].FormatID)); |       List.Add(ClipboardFormatToMimeType(FData[i].FormatID)); | ||||||
|   end else begin |   end else begin | ||||||
| @ -409,29 +457,34 @@ var i: integer; | |||||||
| begin | begin | ||||||
|   AFormatCount:=0; |   AFormatCount:=0; | ||||||
|   FormatList:=nil; |   FormatList:=nil; | ||||||
|   if FAllocated and (FCount>0) then begin |   if CanReadFromCache then begin | ||||||
|     GetMem(FormatList,SizeOf(TClipBoardFormat)*FCount); |     if (FCount>0) then begin | ||||||
|     for i:=0 to FCount-1 do |       GetMem(FormatList,SizeOf(TClipBoardFormat)*FCount); | ||||||
|       FormatList[i]:=FData[i].FormatID; |       for i:=0 to FCount-1 do | ||||||
|     AFormatCount:=FCount; |         FormatList[i]:=FData[i].FormatID; | ||||||
|  |       AFormatCount:=FCount; | ||||||
|  |     end; | ||||||
|  |   end else begin | ||||||
|  |     ClipboardGetFormats(ClipboardType,AFormatCount,FormatList); | ||||||
|   end; |   end; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| procedure TClipboard.SetSupportedFormats(AFormatCount: integer; | function TClipboard.SetSupportedFormats(AFormatCount: integer; | ||||||
|   FormatList: PClipboardFormat); |   FormatList: PClipboardFormat): Boolean; | ||||||
| var i: integer; | var i: integer; | ||||||
| begin | begin | ||||||
|   Clear; |   BeginUpdate; | ||||||
|   FCount:=AFormatCount; |   try | ||||||
|   GetMem(FData,SizeOf(TClipboardData)*FCount); |     Clear; | ||||||
|   for i:=0 to FCount-1 do begin |     FCount:=AFormatCount; | ||||||
|     FData[i].FormatID:=FormatList[i]; |     GetMem(FData,SizeOf(TClipboardData)*FCount); | ||||||
|     FData[i].Stream:=TMemoryStream.Create; |     for i:=0 to FCount-1 do begin | ||||||
|   end; |       FData[i].FormatID:=FormatList[i]; | ||||||
|   FSupportedFormatsChanged:=true; |       FData[i].Stream:=TMemoryStream.Create; | ||||||
|   if not GetOwnerShip then begin |     end; | ||||||
|     raise Exception.Create('Unable to get clipboard ownership for '+ |     FSupportedFormatsChanged:=true; | ||||||
|       ClipboardTypeName[ClipboardType]); |   finally | ||||||
|  |     Result:=EndUpdate; | ||||||
|   end; |   end; | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| @ -444,12 +497,10 @@ begin | |||||||
|   List:=nil; |   List:=nil; | ||||||
|   Result:=0; |   Result:=0; | ||||||
|   cnt:=0; |   cnt:=0; | ||||||
|   if not FAllocated then begin |  | ||||||
|     if not ClipboardGetFormats(ClipboardType,cnt,List) then |  | ||||||
|       exit; |  | ||||||
|   end; |  | ||||||
|   try |   try | ||||||
|     if not FAllocated then begin |     if not CanReadFromCache then begin | ||||||
|  |       if not ClipboardGetFormats(ClipboardType,cnt,List) then | ||||||
|  |         exit; | ||||||
|       for i:=0 to cnt-1 do begin |       for i:=0 to cnt-1 do begin | ||||||
|         Result:=List[i]; |         Result:=List[i]; | ||||||
|         if TPicture.SupportsClipboardFormat(Result) then |         if TPicture.SupportsClipboardFormat(Result) then | ||||||
| @ -477,21 +528,19 @@ begin | |||||||
|   List:=nil; |   List:=nil; | ||||||
|   Result:=0; |   Result:=0; | ||||||
|   cnt:=0; |   cnt:=0; | ||||||
|   if not FAllocated then begin |  | ||||||
|     if not ClipboardGetFormats(ClipboardType,cnt,List) then |  | ||||||
|       exit; |  | ||||||
|   end; |  | ||||||
|   try |   try | ||||||
|     if not FAllocated then begin |     if not CanReadFromCache then begin | ||||||
|  |       if not ClipboardGetFormats(ClipboardType,cnt,List) then | ||||||
|  |         exit; | ||||||
|       for i:=0 to cnt-1 do begin |       for i:=0 to cnt-1 do begin | ||||||
|         Result:=List[i]; |         Result:=List[i]; | ||||||
|         if AnsiCompareText(ClipboardFormatToMimeType(Result),FormatName)=0 then |         if CompareText(ClipboardFormatToMimeType(Result),FormatName)=0 then | ||||||
|           exit; |           exit; | ||||||
|       end; |       end; | ||||||
|     end else begin |     end else begin | ||||||
|       for i:=FCount-1 downto 0 do begin |       for i:=FCount-1 downto 0 do begin | ||||||
|         Result:=FData[i].FormatID; |         Result:=FData[i].FormatID; | ||||||
|         if AnsiCompareText(ClipboardFormatToMimeType(Result),FormatName)=0 then |         if CompareText(ClipboardFormatToMimeType(Result),FormatName)=0 then | ||||||
|           exit; |           exit; | ||||||
|       end; |       end; | ||||||
|     end; |     end; | ||||||
| @ -513,7 +562,7 @@ var List: PClipboardFormat; | |||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.HasFormat] A ',ClipboardTypeName[ClipboardType],' Allocated=',FAllocated);
 |   //DebugLn('[TClipboard.HasFormat] A ',ClipboardTypeName[ClipboardType],' Allocated=',FAllocated);
 | ||||||
|   if FormatID<>0 then begin |   if FormatID<>0 then begin | ||||||
|     if FAllocated then |     if CanReadFromCache then | ||||||
|       Result := (IndexOfCachedFormatID(FormatID,false)>=0) |       Result := (IndexOfCachedFormatID(FormatID,false)>=0) | ||||||
|     else begin |     else begin | ||||||
|       if not ClipboardGetFormats(ClipboardType,cnt,List) then begin |       if not ClipboardGetFormats(ClipboardType,cnt,List) then begin | ||||||
| @ -644,33 +693,12 @@ begin | |||||||
|     inherited AssignTo(Dest); |     inherited AssignTo(Dest); | ||||||
| end; | end; | ||||||
| 
 | 
 | ||||||
| {function TClipboard.GetAsHandle(Format: Word): THandle; |  | ||||||
| begin |  | ||||||
|   Open; |  | ||||||
|   try |  | ||||||
|     Result := GetClipboardData(Format); |  | ||||||
|   finally |  | ||||||
|     Close; |  | ||||||
|   end; |  | ||||||
| end;} |  | ||||||
| 
 |  | ||||||
| {procedure TClipboard.SetAsHandle(Format: Word; Value: THandle); |  | ||||||
| begin |  | ||||||
|   Open; |  | ||||||
|   try |  | ||||||
|     Adding; |  | ||||||
|     SetClipboardData(Format, Value); |  | ||||||
|   finally |  | ||||||
|     Close; |  | ||||||
|   end; |  | ||||||
| end;} |  | ||||||
| 
 |  | ||||||
| function TClipboard.GetFormatCount: Integer; | function TClipboard.GetFormatCount: Integer; | ||||||
| // ask interfaceobject
 | // ask interfaceobject
 | ||||||
| var List: PClipboardFormat; | var List: PClipboardFormat; | ||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.GetFormatCount]');
 |   //DebugLn('[TClipboard.GetFormatCount]');
 | ||||||
|   if FAllocated then |   if CanReadFromCache then | ||||||
|     Result:=FCount |     Result:=FCount | ||||||
|   else begin |   else begin | ||||||
|     if ClipboardGetFormats(ClipboardType,Result,List) then begin |     if ClipboardGetFormats(ClipboardType,Result,List) then begin | ||||||
| @ -686,7 +714,7 @@ var | |||||||
|   cnt: integer; |   cnt: integer; | ||||||
| begin | begin | ||||||
|   //DebugLn('[TClipboard.GetFormats] Index=',Index);
 |   //DebugLn('[TClipboard.GetFormats] Index=',Index);
 | ||||||
|   if FAllocated then begin |   if CanReadFromCache then begin | ||||||
|     if (Index<0) or (Index>=FCount) then |     if (Index<0) or (Index>=FCount) then | ||||||
|       raise Exception.Create('TClipboard.GetFormats: Index out of bounds: Index=' |       raise Exception.Create('TClipboard.GetFormats: Index out of bounds: Index=' | ||||||
|         +IntToStr(Index)+' Count='+IntToStr(FCount)); |         +IntToStr(Index)+' Count='+IntToStr(FCount)); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 mattias
						mattias