| Home » Eclipse Projects » Eclipse Platform » Relative path for linked resources, why not?
 Goto Forum:| 
| Relative path for linked resources, why not? [message #330304] | Thu, 24 July 2008 15:41  |  | 
| Eclipse User  |  |  |  |  | Originally posted by: jim.walseth.teejet.com 
 Our company has a "pre-ordained layout for source files" that in part
 lead to the effort to create a Flexible Project Structure:
 (ref.
 http://www.eclipse.org/eclipse/development/flexible-projects -proposal.html)
 
 Ours is a three-tiered hierachical folder structure from which we
 build many different applications using subsets of these source files
 (C++).  I can add files to the project as a linked resource due to the
 solutions described in the above reference, but the paths are absolute.
 
 Thus a significant problem remains if one wants to commit the Eclipse
 project as part of the codebase, then export later to an arbitrary folder
 and use the project.  Generally, the paths will not be correct anymore.
 At first here appears to be promise with the "path variable", but these
 are also required to be absolute.  And I was not successful trying to use
 system variables like HOME in the resource path or path variable.
 
 Has anyone figured this out, without going in and hacking the project
 file? Can anyone explain why relative paths are not used?
 
 FYI we are using Version: 3.4.0 (Ganymede).
 
 [PS This was posted on CDT group and suggestion was I move it here.]
 |  |  |  |  | 
| Re: Relative path for linked resources, why not? [message #330308 is a reply to message #330304] | Thu, 24 July 2008 18:12   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: wegener.cboenospam.com 
 "Jim Walseth" <jim.walseth@teejet.com> wrote in message
 news:0651dd72ac9d85a49c0b3328fe15598c$1@www.eclipse.org...
 >     Our company has a "pre-ordained layout for source files" that in part
 > lead to the effort to create a Flexible Project Structure:
 >     (ref.
 >
 http://www.eclipse.org/eclipse/development/flexible-projects -proposal.html)
 >
 >     Ours is a three-tiered hierachical folder structure from which we
 > build many different applications using subsets of these source files
 > (C++).  I can add files to the project as a linked resource due to the
 > solutions described in the above reference, but the paths are absolute.
 >
 >     Thus a significant problem remains if one wants to commit the Eclipse
 > project as part of the codebase, then export later to an arbitrary folder
 > and use the project.  Generally, the paths will not be correct anymore.
 > At first here appears to be promise with the "path variable", but these
 > are also required to be absolute.  And I was not successful trying to use
 > system variables like HOME in the resource path or path variable.
 >
 >     Has anyone figured this out, without going in and hacking the project
 > file? Can anyone explain why relative paths are not used?
 >
 >     FYI we are using Version: 3.4.0 (Ganymede).
 >
 > [PS This was posted on CDT group and suggestion was I move it here.]
 >
 >
 >
 
 When you use a Path Variable to define a resource link, the link that is
 stored in the .project file is relative to the Path Variable name.  The
 location that the Path Variable points to is defined in each workspace.
 This allows different developers to use the project on different systems.
 
 Lets say that you want to link to a source directory in the hierarchy
 C:\MyDevelopment\Project1\src and your codebase is checked into your SCM
 tool at the Project1 level.  You would create a Path Variable (DEV_ROOT)
 which points to C:\MyDevelopment.  When you create the linked folder, you
 select the DEV_ROOT path variable and extend it to include Project1.  This
 adds a DEV_ROOT\Project1 resource link to your .project file.  If you later
 check the source out into C:\AlternateDevelopment\Foo\Bar\Project1\src,  you
 import the project into a workspace and set the DEV_ROOT Path Variable to
 point to C:\AlternateDevelopment\Foo\Bar and your link is established for
 you.  The .project file doesn't change.
 
 At some point, you have to have an absolute location in order to be able to
 move relative to it.
 |  |  |  |  |  |  | 
| Re: Relative path for linked resources, why not? [message #330340 is a reply to message #330338] | Fri, 25 July 2008 14:29   |  | 
| Eclipse User  |  |  |  |  | Originally posted by: eclipse-news.rizzoweb.com 
 Jim Walseth wrote:
 > Thanks Dave.  I see the flexibility provided by the Path Variable.
 > However, to take advantage of it one must alter the Path Variable
 > through the IDE, after importing the project, also a manual step.
 
 Actually, if the CDT Path Variable is like the JDT Classpath Variable,
 it can be set before it is used (before a project is imported or created
 that uses it).
 
 
 >
 > What this does not address is this: the project and it's settings must
 > be regarded as part of a build or release.  In other words the correct
 > practice is to commit the project along with source code to a repository
 > and tag everything.  Later, check out (to an arbitrary location)
 > everything and do a build.  Ideally it should be possible to automate
 > this process.
 
 How are you going to automate Eclipse to start up, import the projects,
 and do its build?
 In my experience, the technique you're talking about is done without
 using an IDE, using Ant or make or Maven or CruiseControl, etc. So I
 guess I'm missing your high-level goal here.
 
 Anyway, because the value of the Path Variable is stored in the
 workspace, you could have that be the "constant" and not have to set the
 variable's value for every build, only when creating a workspace.
 
 Hope this helps,
 Eric
 |  |  |  |  |  |  | 
| Re: Relative path for linked resources, why not? [message #330364 is a reply to message #330348] | Sat, 26 July 2008 13:49  |  | 
| Eclipse User  |  |  |  |  | Originally posted by: wegener.cboenospam.com 
 Jim Walseth wrote:
 > Yes I think it is the workspace that I would like to reproduce in a way
 > that the build can be executed without any 'intervention' like changing
 > Path Variables.   These are some aspects that are unfamiliar coming from
 > other IDEs:
 >
 > 1) a folder becomes a workspace when you switch to that folder from
 > Eclipse, not like Visual Studio where Fo.dsw and Fi.dsw and Fum.dsw can
 > be in the same folder.  In other words the workspace is not a file.  How
 > would one commit this to the repository?  Commit all the files under
 > metadata?
 >
 An Eclipse workspace is not the same as a Visual Studio workspace.  In
 Eclipse the workspace is container to keep track of what your working on
 and how you want the environment to behave.  I Visual Studio, the
 workspace file defines relationships between projects and how projects
 are built.
 
 The Eclipse .project file and I belive an additional .cdt??? specific
 file more closely correspond to the Visual Studio workspace file.  These
 files define what resources make up the project, what the project
 depends on, and how to build the project.
 
 The Eclipse workspace keeps track of what perspectives (windows) and
 view are opened, how you want the environment to look, where source code
 repositories are located, etc.
 
 In general, you don't want to commit your workspace to a repository.
 You do want to commit the .project and .cdt???? files to a repository as
 you do with the .dsw files.
 
 > 2) You don't 'open' a project you 'import' it.  Meaning, one generally
 > works with a copy of the project?  What does this mean for version control?
 >
 
 The Eclipse workspace allows you to maintain a project in the workspace,
 but it doesn't require that the project resides in the workspace.
 Import is really a way of associating a workspace with a project.  The
 Import dialog should have a check box for copying the project into the
 workspace.  If you don't check this box, the project is left where ever
 it resides on the file system and your workspace just points to it.
 
 Importing is also dependent on the SCM provider that you are using.
 There are a number of providers with Eclipse plugins that allow for an
 integrated SCM experience.  Check with your SCM provider to see if they
 supply a plugin.
 
 > Right now this all feels like putting a square peg (legacy C++ projects)
 > in a round hole.  Plus newcomer confusion.  Thanks for the responses.
 >
 >
 
 There are some articles discussing Eclipse C++ development including one
 that discusses migrating from Visual Studio.  Maybe these can help you out.
 http://www-128.ibm.com/developerworks/library/os-ecl-vscdt/i ndex.html
 http://wiki.eclipse.org/CDT/User/FAQ
 
 >
 
 I know you are working on C++, but the Java tool documentation has a
 tutorial about project setup.  Some of the concepts including linked
 resources should pertain to C++ as well.
 
 http://help.eclipse.org/ganymede/topic/org.eclipse.jdt.doc.u ser/gettingStarted/qs-ProjectConfiguration.htm
 |  |  |  | 
 
 
 Current Time: Sat Oct 25 03:18:33 EDT 2025 
 Powered by FUDForum . Page generated in 0.58377 seconds |