I've been trying to find examples of cases where it is complicated to 
> structure the project because circular imports are forbidden, but I can't 
> find something simple that I can show you. The thing is when I've been 
> confronted to such cases, it was with large projects, and I have no simple 
> way of reducing it to anything that can stand in a mail.
>

Fair enough, understandable - although is it not also quite possible that 
the complexity you saw was (at least in part) due to circular imports? :)


> Maybe it would help if you gave an example of some code that you think 
>> requires circular imports and we can see if it can be restructured without?
>>
>
> I know that most projects can be restructured without circular imports, 
> but my point is that sometimes, even if it *can* be restructured without 
> them, it *should not*. 
>

I guess my point is the exact opposite, even if it can be structured with 
them it shouldn't.  In my mind circularity increases package coupling 
whereas breaking the coupling with interfaces leads to more robust 
packages.  No evidence either from my side (other than anecdotal) so would 
be interesting to hear about any studies that have been done on this. Note 
that Go supports this perhaps better than Java or C# due to implicit 
interface satisfaction.

I don't really know how to convey clearly what's in my mind, maybe I'm 
> wrong in my  conclusions, but I've thought a lot about this and it makes me 
> uncomfortable. From my own perspective, if the logical resolution of a 
> problem leads to a structure with loops in its semantics and construction, 
> the language should not require rethinking such solution so that there are 
> no more loops in its architecture.
>
>
Fair enough, I'll concede there could be situations I've not come across 
where not using circular imports would be more convoluted than with.

Jamie 

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to