Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

How to find the files linked (OLE) within a Word Document?

Posted on 2006-07-02
7
977 Views
Last Modified: 2008-01-09
Hi,

I have a requirement to read a range of OLE Compound File formats (including Word Documents, Excel, Powerpoint, etc) and perform the following tasks;
1) Extract a list of all files either linked or embedded to the parent document
2) Save these linked files to a specific location (or in the case of linked files, can just copy the link target to a new location)

My problem here is really in Step 1 -> I have so far been unable to find a way to access linked/embedded files within a parent document.

My current methodology is something like;

1) Call StgOpenStorageEx on the parent file and receive an IStorage pointer
2) Call StgIsStorageFile to make sure I am working with a compound storage file
3) Call IStorage->EnumElements to find the nested objects
4) Check the type of each object looking for contained STGTY_STORAGE objects
5) Try to get an IOleLink pointer from that storage?

Here is about where it falls down. No idea if my steps thus far are correct,  but I can't get an IOleLink pointer on any of the enumerated objects...

?
0
Comment
Question by:rjlohan
  • 4
  • 3
7 Comments
 
LVL 11

Expert Comment

by:KurtVon
ID: 17030019
I think the problem you are having is simply that Word stores the OLE links in a record within the storage object, not as a storage object.  I can't help much with parsing those, but this might: http://64.233.161.104/search?q=cache:Lyjp4eU4rLYJ:www.codeproject.com/macro/ssfview.asp+STGTY_STORAGE+Word&hl=en&gl=us&ct=clnk&cd=2&client=firefox-a

Hope this helps.
0
 
LVL 11

Accepted Solution

by:
KurtVon earned 500 total points
ID: 17030026
I think you will find the information you need in the "ObjectPool" storage item.
0
 

Author Comment

by:rjlohan
ID: 17034533
That looks to be right - if I call OpenStorage on the 'ObjectPool' storage item, the sub-storages of that appear to be the actual linked items, and have storage class IDs such as {CLSID_StdOleLink} or {CLSID_Microsoft Word Document}.

Just wish I could find some documentation to be sure! :-P

Cheers,
Ryan
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
LVL 11

Expert Comment

by:KurtVon
ID: 17036895
I know that Word uses the object pool to create the OLE objects it links to, but I suspect documentation is going to be hard to come by just because Microsoft guards that like a state secret.
0
 

Author Comment

by:rjlohan
ID: 17039422
It certainly looks that way. I have found how to access some link types, where the sub-storage within the ObjectPool has a classID of 'CLSID_StdOleLink', but accessing other embedded content, say a Word Document embedded as 'CLSID_Microsoft Word Document' is proving quite difficult. Can't find any information about the original link file (such as paths) within the storage anywhere.
0
 
LVL 11

Expert Comment

by:KurtVon
ID: 17047791
If I remember correctly, Word doesn't use a path, but a UUID for the location of the document.  The OS (2000 and later) tracks the UUID for the location, so renaming or moving the file keeps the UUID the same, and links are much harder to break.  Try passing UUIDs inside the object to directory services to see if any produce links.
0
 

Author Comment

by:rjlohan
ID: 17048003
Can't see anywhere to find that UUID. There must be a way, Word obviously knows how to do certain things, like opening these files...
0

Featured Post

Networking for the Cloud Era

Join Microsoft and Riverbed for a discussion and demonstration of enhancements to SteelConnect:
-One-click orchestration and cloud connectivity in Azure environments
-Tight integration of SD-WAN and WAN optimization capabilities
-Scalability and resiliency equal to a data center

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In days of old, returning something by value from a function in C++ was necessarily avoided because it would, invariably, involve one or even two copies of the object being created and potentially costly calls to a copy-constructor and destructor. A…
What is C++ STL?: STL stands for Standard Template Library and is a part of standard C++ libraries. It contains many useful data structures (containers) and algorithms, which can spare you a lot of the time. Today we will look at the STL Vector. …
The goal of the video will be to teach the user the concept of local variables and scope. An example of a locally defined variable will be given as well as an explanation of what scope is in C++. The local variable and concept of scope will be relat…
The viewer will learn additional member functions of the vector class. Specifically, the capacity and swap member functions will be introduced.

829 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question