JiscMail Logo
Email discussion lists for the UK Education and Research communities

Help for COMP-FORTRAN-90 Archives


COMP-FORTRAN-90 Archives

COMP-FORTRAN-90 Archives


COMP-FORTRAN-90@JISCMAIL.AC.UK


View:

Message:

[

First

|

Previous

|

Next

|

Last

]

By Topic:

[

First

|

Previous

|

Next

|

Last

]

By Author:

[

First

|

Previous

|

Next

|

Last

]

Font:

Proportional Font

LISTSERV Archives

LISTSERV Archives

COMP-FORTRAN-90 Home

COMP-FORTRAN-90 Home

COMP-FORTRAN-90  1998

COMP-FORTRAN-90 1998

Options

Subscribe or Unsubscribe

Subscribe or Unsubscribe

Log In

Log In

Get Password

Get Password

Subject:

MODULE and naming strategies

From:

[log in to unmask] (Phillip Helbig)

Reply-To:

[log in to unmask]

Date:

Sun, 1 Feb 1998 11:05:49 GMT

Content-Type:

text/plain

Parts/Attachments:

Parts/Attachments

text/plain (119 lines)

Fortran 90 with its MODULEs and USE has made one to think more hardly
about the question when should the names of things be unique? 
Obviously, this is not a problem for standalone code, but is when other 
MODULEs are USEd, one links against object libraries etc.  This is also 
related to the issue of the best `MODULE strategy'.

Unique variables and routine names?  Surely not.  These are either
visible to other routines or not.  If not, no worry (nice feature, this
data hiding).  If they are, then one can rename them in the USE
statement; I think this difficulty is more than offset by the ease of
having understandable code without long,
guaranteed-to-be-unique-in-the-entire-world names. 

The names of object files (one per file, not per routine or MODULE)?
Probably a good idea.  Presumably, they would be unique anyway within an
object library, but often one links against more than one object
library. 

The names of MODULEs?  Definitely.  Is it not the name which is the only 
means of deciding which module to use?  If they are not unique, then one 
has to think about the order in which include directories are searched, 
which is undesirable.  Since procedures should ALWAYS be in MODULEs, one 
could simply give the name of (one of) the MODULE(s) to the file; since 
the latter is unique, the former would be as well, solving the problem 
in the previous paragraph.

It thus seems a good idea to me, in all code which is not standalone
(particularly that which is publicly distributed) to preced all MODULE 
names with something likely to make it unique: I precede mine with 
HELBIG_, NAG could (does?---I won't be installing the NAG F90 stuff for  
a few weeks yet) precede theirs with NAG_ etc.  As mentioned above, the 
source files would thus also have unique names.

The NUMERICAL RECIPES don't precede their MODULE names with NUMREC_ or 
whatever, so one has to be careful here.

On a related note, IIRC it was Clive Page who mentioned 5 MODULE 
strategies a while back, and asked for discussion.  I was surprised 
there was not more.  This was more concerned with INTERFACEs than with 
object files.  Let me recap briefly his 5, add two of my own, and ask if 
there is any reason to do anything other than that which I prefer.

   1.  Do nothing.  Access procedures as in FORTRAN77, as EXTERNAL.
       This is obviously not a good choice, as it makes no use of
       good F90 features.

   2.  Hand code INTERFACEs into the calling routines.
       Better, but means duplicated code, is error prone and there is
       no guaranteed consistency between INTERFACE and procedure.  One
       is also not forced to write an INTERFACE, and could still call
       routines as EXTERNAL.

   3.  Put all routines in one MODULE.
       Easy, no duplication and guaranteed consistency.  Might be OK for
       people who only do a minimum of Fortran coding (in which case
       it becomes equivalent to 7. below).  However, any changes mean 
       recompiling the whole thing, things from other sources might not 
       be available as source code, and the linker would presumably load 
       the whole large chunk of object code even if only one routine were 
       needed.  Nothing can be called EXTERNALly.

   4.  Keep the routines more or less one to a file, but put all 
       INTERFACEs in one module.  No recompilation problem, no need to
       load more code, easy to use.  However, there is no guaranteed 
       consistency, and it is still possible to call the routines as
       EXTERNAL procedures.  (This is the policy adopted by the 
       NUMERICAL RECIPES, by the way.)

   5.  Have one routine per MODULE and one MODULE per file.  Automatic
       consistency, cannot be called EXTERNALly, no recompilation or
       large code problems.  However, any complicated code would have
       very many USE statements.  This is the first serious choice, and
       does have something going for it---all the advantages, and 
       nothing must be decided as a matter of taste.  However, there are
       too many USE statements to remember.

   6.  Like 5., but have several MODULEs which consist only of USE 
       statements, such that things which are used together need only 
       have one USE statement in the calling routine.  Avoids the 
       disadvantage of 5 and thus looks pretty good.

   7.  As far as the user is concerned, the same as 6., but the several
       MODULEs would not have USE statements for other MODULEs 
       (consisting essentially of one routine) but rather the code for
       these routines.  At the slight cost of making the linker 
       occasionally load a bit too much code, this would keep related
       routines in one file and would thus be easier to maintain.  
       Also, if one needs global data known only to these routines,
       this MODULE file would be the logical place for that, the 
       routines accessing it by host association and not, as would have
       to be the case in 5. or 6., through a USE statement.  Again,
       easier to maintain.

Obviously, I prefer option 7, though 6. might be an alternative if the
individual routines are quite large.  Presumably, the linker could be
smart enough only to load code for those actually required, so perhaps
6. is only necessary, if at all, until linkers become smarter.  (I don't 
know how easy this would be to implement.)  As noted above, if one does 
only a small amount of coding, 7. is equivalent to 3.

Comments on both the issue of where names should be unique and which 
MODULE strategy is best are more than welcome; if there is not general 
interest in this, there should be, at least among those who write code 
which is used (or USEd) by others.


--
Phillip Helbig                          Email .......... [log in to unmask]
Nuffield Radio Astronomy Laboratories   Tel. ..... +44 1477 571 321 (ext. 297)
Jodrell Bank                            Fax ................. +44 1477 571 618
Macclesfield                            Telex ................. 36149 JODREL G
UK-Cheshire SK11 9DL                    Web .... http://www.jb.man.ac.uk/~pjh/

My opinions are not necessarily those of NRAL or the University of Manchester.



%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

Top of Message | Previous Page | Permalink

JiscMail Tools


RSS Feeds and Sharing


Advanced Options


Archives

December 2023
February 2023
November 2022
September 2022
February 2022
January 2022
June 2021
November 2020
September 2020
June 2020
May 2020
April 2020
December 2019
October 2019
September 2019
March 2019
February 2019
January 2019
November 2018
October 2018
September 2018
August 2018
July 2018
May 2018
April 2018
March 2018
February 2018
January 2018
December 2017
November 2017
October 2017
September 2017
August 2017
July 2017
June 2017
May 2017
April 2017
March 2017
January 2017
December 2016
November 2016
October 2016
September 2016
August 2016
July 2016
June 2016
May 2016
April 2016
March 2016
February 2016
December 2015
November 2015
October 2015
September 2015
August 2015
June 2015
April 2015
March 2015
January 2015
December 2014
November 2014
October 2014
August 2014
July 2014
May 2014
April 2014
March 2014
February 2014
January 2014
December 2013
November 2013
July 2013
June 2013
May 2013
April 2013
February 2013
January 2013
December 2012
November 2012
October 2012
September 2012
August 2012
July 2012
June 2012
April 2012
March 2012
February 2012
January 2012
December 2011
November 2011
October 2011
September 2011
August 2011
July 2011
June 2011
May 2011
April 2011
March 2011
February 2011
January 2011
December 2010
November 2010
October 2010
August 2010
July 2010
June 2010
March 2010
February 2010
January 2010
December 2009
October 2009
August 2009
July 2009
June 2009
March 2009
February 2009
January 2009
December 2008
November 2008
October 2008
September 2008
August 2008
July 2008
June 2008
May 2008
April 2008
March 2008
February 2008
December 2007
November 2007
October 2007
September 2007
August 2007
July 2007
June 2007
May 2007
April 2007
March 2007
January 2007
2006
2005
2004
2003
2002
2001
2000
1999
1998
1997


JiscMail is a Jisc service.

View our service policies at https://www.jiscmail.ac.uk/policyandsecurity/ and Jisc's privacy policy at https://www.jisc.ac.uk/website/privacy-notice

For help and support help@jisc.ac.uk

Secured by F-Secure Anti-Virus CataList Email List Search Powered by the LISTSERV Email List Manager