Foxit PDF SDK
foxit.pdf.FileSpec Class Reference
Inheritance diagram for foxit.pdf.FileSpec:
foxit.common.Base

Public Member Functions

 FileSpec (PDFDoc document)
 Constructor.
More...
 
 FileSpec (PDFDoc document, PDFObject pdf_object)
 Constructor, from an existing file specification PDF object in a PDF document.
More...
 
 FileSpec (FileSpec other)
 Constructor, with another file specification object.
More...
 
bool Embed (string file_path)
 Embed the whole content of a file which is specified by file path.
More...
 
bool Embed (PDFObject pdf_object)
 (Only support in PDF 2.0) Embed the whole content of a PDF stream object or a PDF reference object which refers to a PDF stream object, when current file specification object is used as an associated file.
More...
 
bool Embed (StreamCallback stream)
 Embed a file by using foxit.common.fxcrt.StreamCallback .
More...
 
bool ExportToFile (string path)
 Export the file data that represented in current file specification directly into a file.
More...
 
bool ExportToFileStream (StreamCallback stream)
 Export the file data that represented in current file specification through a stream callback object.
More...
 
AssociatedFiles.Relationship GetAssociteFileRelationship ()
 (Only supported in PDF 2.0) Get the associated file relationship when current file specification is used as an associated file.
More...
 
string GetChecksum ()
 Get the checksum for embedded file.
More...
 
long GetCompressedEmbeddedFileSize ()
 Get the compressed file size of embedded file.
More...
 
DateTime GetCreationDateTime ()
 Get creation date and time about when the embedded file was created.
More...
 
string GetDescription ()
 Get the descriptive text associated with current file specification.
More...
 
PDFDictionary GetDict ()
 Get the PDF dictionary of current file specification.
More...
 
FileReaderCallback GetFileData ()
 Get the file data of embedded file.
More...
 
string GetFileName ()
 Get the file name.
More...
 
long GetFileSize ()
 Get the size of embedded file (uncompressed file size).
More...
 
DateTime GetModifiedDateTime ()
 Get modified date and time about when the embedded file was last modified.
More...
 
string GetSubtype ()
 (Only support in PDF 2.0) Get the MIME type value for "Subtype" key for embedded file when current file specification is used as an associated file.
More...
 
bool IsEmbedded ()
 Check whether current file specification object represents an embedded file or not.
More...
 
bool IsEmpty ()
 Check whether current object is empty or not.
More...
 
void SetAssociteFileRelationship (AssociatedFiles.Relationship associfile_relationship)
 (Only supported in PDF 2.0) Set the associated file relationship when current file specification is used as an associated file.
More...
 
void SetChecksum (byte[] checksum)
 Set the checksum for embedded file. (Not affect local file)
More...
 
void SetCreationDateTime (DateTime date_time)
 Set the creation date and time for the embedded file. (Not affect local file)
More...
 
void SetDescription (string description)
 Set the descriptive text associated with current file specification.
More...
 
void SetFileName (string file_name)
 Set the file name.
More...
 
void SetModifiedDateTime (DateTime date_time)
 Set last modified date and time for the embedded file. (Not affect local file)
More...
 
void SetSubtype (string subtype)
 (Only support in PDF 2.0) Set the MIME type value for "Subtype" key for embedded file (Not affect local file) when current file specification is used as an associated file.
More...
 

Detailed Description

A PDF file can refer to the contents of another file by using a file specification. File specification can simply represents the file path of another file, or represents the whole content of another file, which is embedded to current PDF file.

Constructor & Destructor Documentation

◆ FileSpec() [1/3]

foxit.pdf.FileSpec.FileSpec ( PDFDoc  document)
inline

Constructor.

This constructor is to construct a new file specification object (without any data).

Parameters
[in]documentA valid PDF document object, to which the new file specification object will belongs.

◆ FileSpec() [2/3]

foxit.pdf.FileSpec.FileSpec ( PDFDoc  document,
PDFObject  pdf_object 
)
inline

Constructor, from an existing file specification PDF object in a PDF document.

Parameters
[in]documentA valid PDF document object, to which the file specification PDF object belongs.
[in]pdf_objectA valid PDF object which represents an existing file specification object in the PDF document. It should be either a dictionary object or a PDF reference object:
  • If it is a PDF dictionary object, it should be a file specification dictionary.
  • If it is a PDF reference object, it should refer to a file specification dictionary.
This PDF object can be retrieved from foxit.pdf.objects.PDFNameTree in type foxit.pdf.objects.PDFNameTree.Type.e_EmbeddedFiles .

◆ FileSpec() [3/3]

foxit.pdf.FileSpec.FileSpec ( FileSpec  other)
inline

Constructor, with another file specification object.

Parameters
[in]otherAnother file specification object.

Member Function Documentation

◆ Embed() [1/3]

bool foxit.pdf.FileSpec.Embed ( string  file_path)
inline

Embed the whole content of a file which is specified by file path.

When this function succeeds, the whole content of specified file will be embedded to the PDF document that current file specification belongs to.

Parameters
[in]file_pathA full path of an existing local file.
Returns
true means success, while false means failure.

◆ Embed() [2/3]

bool foxit.pdf.FileSpec.Embed ( PDFObject  pdf_object)
inline

(Only support in PDF 2.0) Embed the whole content of a PDF stream object or a PDF reference object which refers to a PDF stream object, when current file specification object is used as an associated file.

When this function succeeds, the whole content of specified PDF stream object will be embedded to the PDF document that current file specification belongs to.

Parameters
[in]pdf_objectA valid PDF object. It should be either a PDF stream object or a PDF reference object which refers to a PDF stream object.
Returns
true means success, while false means failure.

◆ Embed() [3/3]

bool foxit.pdf.FileSpec.Embed ( StreamCallback  stream)
inline

Embed a file by using foxit.common.fxcrt.StreamCallback .

When this function succeeds, please keep input stream callback object valid until the PDF file (which current file specification belongs to) is saved or closed.

Parameters
[in]streamA foxit.common.fxcrt.StreamCallback object which is implemented by user to read the file content.
Returns
true means success, while false means failure.

◆ ExportToFile()

bool foxit.pdf.FileSpec.ExportToFile ( string  path)
inline

Export the file data that represented in current file specification directly into a file.

Parameters
[in]pathA full path of a file to which the data will be saved.
Returns
true means success, while false means failure.

◆ ExportToFileStream()

bool foxit.pdf.FileSpec.ExportToFileStream ( StreamCallback  stream)
inline

Export the file data that represented in current file specification through a stream callback object.

Parameters
[in]streamA foxit.common.fxcrt.StreamCallback object which is implemented by user to save the file data.
Returns
true means success, while false means failure.

◆ GetAssociteFileRelationship()

AssociatedFiles.Relationship foxit.pdf.FileSpec.GetAssociteFileRelationship ( )
inline

(Only supported in PDF 2.0) Get the associated file relationship when current file specification is used as an associated file.

Returns
The associated file relationship. Please refer to values starting from foxit.pdf.AssociatedFiles.Relationship.e_RelationshipSource and this should be one of these values.

◆ GetChecksum()

string foxit.pdf.FileSpec.GetChecksum ( )
inline

Get the checksum for embedded file.

This function is only useful when current file specification object represents an embedded file. A 16-byte string that is the checksum of the bytes of the uncompressed embedded file. The checksum is calculated by applying the standard MD5 message-digest algorithm to the bytes of the embedded file stream.
If current file specification object does not represent an embedded file, this function will return an empty string.

Returns
The checksum string.

◆ GetCompressedEmbeddedFileSize()

long foxit.pdf.FileSpec.GetCompressedEmbeddedFileSize ( )
inline

Get the compressed file size of embedded file.

This function is only useful when current file specification object represents an embedded file. If current file specification object does not represent an embedded file, this function will return 0 directly.

Returns
Compressied file size of embedded file.

◆ GetCreationDateTime()

DateTime foxit.pdf.FileSpec.GetCreationDateTime ( )
inline

Get creation date and time about when the embedded file was created.

This function is only useful when current file specification object represents an embedded file. If current file specification object does not represent an embedded file, this function will return a date and time object will all value 0.

Returns
The creation date time of embedded file.

◆ GetDescription()

string foxit.pdf.FileSpec.GetDescription ( )
inline

Get the descriptive text associated with current file specification.

Returns
The descriptive text.

◆ GetDict()

PDFDictionary foxit.pdf.FileSpec.GetDict ( )
inline

Get the PDF dictionary of current file specification.

Returns
A PDF dictionary object.

◆ GetFileData()

FileReaderCallback foxit.pdf.FileSpec.GetFileData ( )
inline

Get the file data of embedded file.

Returns
A foxit.common.fxcrt.FileReaderCallback object. User can call functions in class foxit.common.fxcrt.FileReaderCallback to read the file data.

◆ GetFileName()

string foxit.pdf.FileSpec.GetFileName ( )
inline

Get the file name.

Returns
The file name. If no file name can be found, this function will return an empty string.

◆ GetFileSize()

long foxit.pdf.FileSpec.GetFileSize ( )
inline

Get the size of embedded file (uncompressed file size).

This function is only useful when current file specification object represents an embedded file. If current file specification object does not represent an embedded file, this function will return 0 directly.

Returns
File size of embedded file (uncompressed file size).

◆ GetModifiedDateTime()

DateTime foxit.pdf.FileSpec.GetModifiedDateTime ( )
inline

Get modified date and time about when the embedded file was last modified.

This function is only useful when current file specification object represents an embedded file. If current file specification object does not represent an embedded file, this function will return a date and time object will all value 0.

Returns
The modified date time of embedded file.

◆ GetSubtype()

string foxit.pdf.FileSpec.GetSubtype ( )
inline

(Only support in PDF 2.0) Get the MIME type value for "Subtype" key for embedded file when current file specification is used as an associated file.

This function is only useful when current file specification object represents an embedded file and used as associated file.

Returns
The subtype string.

◆ IsEmbedded()

bool foxit.pdf.FileSpec.IsEmbedded ( )
inline

Check whether current file specification object represents an embedded file or not.

Returns
true means current file specification object represent an embedded file. false means current file specification object does not represent an embedded file.

◆ IsEmpty()

bool foxit.pdf.FileSpec.IsEmpty ( )
inline

Check whether current object is empty or not.

When the current object is empty, that means current object is useless.

Returns
true means current object is empty, while false means not.

◆ SetAssociteFileRelationship()

void foxit.pdf.FileSpec.SetAssociteFileRelationship ( AssociatedFiles.Relationship  associfile_relationship)
inline

(Only supported in PDF 2.0) Set the associated file relationship when current file specification is used as an associated file.

This function is required for a newly created associated file specification object.

Parameters
[in]associfile_relationshipThe associated file relationship to be set. Please refer to values starting from foxit.pdf.AssociatedFiles.Relationship.e_RelationshipSource and this would be one of these values.
Returns
None.

◆ SetChecksum()

void foxit.pdf.FileSpec.SetChecksum ( byte []  checksum)
inline

Set the checksum for embedded file. (Not affect local file)

This function is only useful if current file specification object represents an embedded file.
A 16-byte string that is the checksum of the bytes of the uncompressed embedded file. The checksum is calculated by applying the standard MD5 message-digest algorithm to the bytes of the embedded file stream.

Parameters
[in]checksumA checksum to be set.
Returns
None.

◆ SetCreationDateTime()

void foxit.pdf.FileSpec.SetCreationDateTime ( DateTime  date_time)
inline

Set the creation date and time for the embedded file. (Not affect local file)

This function is only useful when current file specification object represents an embedded file.

Parameters
[in]date_timeThe creation date and time to be set.
Returns
None.

◆ SetDescription()

void foxit.pdf.FileSpec.SetDescription ( string  description)
inline

Set the descriptive text associated with current file specification.

Parameters
[in]descriptionA descriptive text to be set. It should not be an empty string.
Returns
None.

◆ SetFileName()

void foxit.pdf.FileSpec.SetFileName ( string  file_name)
inline

Set the file name.

This function is required for a new file specification object (not constructed from an existing file specification PDF object).

Parameters
[in]file_nameThe file name to be set. It should not be an empty string.
Returns
None.

◆ SetModifiedDateTime()

void foxit.pdf.FileSpec.SetModifiedDateTime ( DateTime  date_time)
inline

Set last modified date and time for the embedded file. (Not affect local file)

This function is only useful when current file specification object represents an embedded file.

Parameters
[in]date_timeThe last modified date and time to be set.
Returns
None.

◆ SetSubtype()

void foxit.pdf.FileSpec.SetSubtype ( string  subtype)
inline

(Only support in PDF 2.0) Set the MIME type value for "Subtype" key for embedded file (Not affect local file) when current file specification is used as an associated file.

This function is only useful when current file specification object represents an embedded file and used as associated file.

Parameters
[in]subtypeA valid MIME type value.
Returns
None.