<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">I am looking for prescriptions.  Several of my problems are local functions, I guess I can make these static (I assume this works for functions).  I made some attempt to name space some of these (<span class="Apple-style-span" style="font-family: 'courier new', monospace; ">gamg_setup_events</span>) and others are tools that need to be global (<span class="Apple-style-span" style="font-family: 'courier new', monospace; ">createSimpleGraph</span>)  -- how should I fix these?  PetscCreateSimpleGraph?<div><br></div><div><div><br><div><div>On Mar 17, 2012, at 12:01 PM, Jed Brown wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div class="gmail_quote">On Sat, Mar 17, 2012 at 10:49, Shri <span dir="ltr"><<a href="mailto:abhyshr@mcs.anl.gov">abhyshr@mcs.anl.gov</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="font-family:Times New Roman;font-size:12pt;color:#000000">I don't know namespacing but looks like its a C++ declaration that can be simulated in C either using prefixes or by using a struct.<div><a href="http://ejrh.wordpress.com/2012/01/24/namespaces-in-c/" target="_blank">http://ejrh.wordpress.com/2012/01/24/namespaces-in-c/</a> . </div>
<div>What's the prefered PETSc way of namespacing in C? Use the prefix 'Petsc'?</div></div></blockquote></div><br><div>Yes, use prefixes for all symbols with extern linkage. (Whichever prefix is appropriate for the class you are working with.)</div>
<div><br></div><div>If you have symbols that go togother, and especially if it might make sense to have multiple instances, it makes sense to put them together in a struct. There may still be a global instance of the struct (which must itself be namespaced), but the members of the struct no longer need their own namespace because they are not symbols (in the linker sense).</div>
<div><br></div><div>Any time you create a symbol with extern linkage, you are declaring that nobody in the universe (defined by all code that might ever be linked into an application that somehow calls PETSc) will ever choose that name for themselves. PETSc already has (in my opinion) claimed more than its share in user-visible namespace (e.g. Vec and Mat), but changing that is obnoxious for users so it has been postponed indefinitely. There is no excuse, however, for not namespacing new symbols or symbols that are not public (intended for the user to interact with).</div>
</blockquote></div><br></div></div></body></html>