Skip to main content

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [List Home]
[cdt-dev] Directory structure rebellion - Embedded development

Hi,

First up - I'm new to the list and fully admit to having not read through
every past post first, so please just link me to the relevant place if this
is an often repeated question, and correct any bad assumptions/conclusions I
have made.

My questions/comments relate to using Eclipse in either managed make or
standard make with a directory structure that does not conform to the
apparent Eclipse requirement for all build files to be under the project
file directory.  Most (if not all) embedded projects I have worked on
include files from outside of the project directory for items such as
drivers, architecture specific port code, middleware etc.  These files are
typically under configuration control and so should ideally only exist in
one place but are common to lots of different applications.

As an example, I distribute an open source mini real time kernel.  For this
I provide ports to many different architectures and demo projects for many
different compilers/IDEs.  I am trying to promote Eclipse use and even
provide a kernel aware plug in - but finding acceptance of this really
difficult.  The root directory is split into two:

+ FreeRTOS
    |
    + Source
    + Demo

The Source directory contains the core kernel code for ALL the ports, and
the Demo directory contains the example projects.  There are many example
projects and all reference code from the Source directory.  Each demo
project also references source code from a common directory under Demo.
This in my opinion is a logical and maintainable structure and has served
well for the last 6 years.  http://www.freertos.org/a00017.html provides a
more complete explanation.

So there are two problems.  First off only a small subset of the files under
Source need to be built.  Second the projects are stored in a subdirectory
under Demo but need to reference files that are higher up the directory
structure.  For example ../../common.

Using managed make is with this structure is, well, not easily workable, so
I use standard makefiles.  To get the project working I need to jump through
the following hoops:  Write a makefile [which users do not expect to do when
using an IDE], create a linked resource variable to somewhere lower down the
directory tree, setup paths from the linked resource variable to the files
required, created a working set, manually configured the working set to only
show the files that are in the makefile.  If I want to add or removed files
I need to edit the makefile and the working set.

This ends up with a working setup - !!!however!!! the linked resource
variable seems to be saved as part of the workspace, not the project.  This
means for each example I provide I have to include the entire workspace,
which is not designed for easy distribution.

So - am I missing something obvious here?  How would others use the build
system in Eclipse, just taking it as read that the project simply cannot be
at the root of all the code that might need to be included?  How would
others distribute such projects, expect their users to maintain the code,
and document how to setup such a project?  I'm hoping there is a simple
answer to this or a plan to add something to the CDT that makes it function
in a more 'traditional' way whereby a project can select the files to be
included through the IDE.

Thanks in advance for any advice you can provide.

Regards,
Richard.

+ http://www.FreeRTOS.org
Designed for Microcontrollers.  
More than 7000 downloads per month.


Back to the top