sort=False was probably introduce to avoid un-necessary sorting... until it 
become necessary again and I did not set it back to True.

On Tuesday, 11 December 2012 08:52:13 UTC-6, Anthony wrote:
>
> Looks like sort=False was initially introduced 
> here<http://code.google.com/p/web2py/source/detail?path=/gluon/compileapp.py&name=R-1.96.1&r=777cfc90f5833646cbd0b585a6ccc596561e57bc>--
>  not clear exactly why. Note, fileutils.listdir automatically sorts the 
> files within folders, so this appears to affect only the sorting of the 
> folders. It wasn't really an issue until the recent introduction of 
> response.models_to_run because prior to that, with conditional models, only 
> one folder was run.
>
> Anthony
>
> On Tuesday, December 11, 2012 9:25:21 AM UTC-5, Massimo Di Pierro wrote:
>>
>> How did that get in there? Fixed in trunk. Thanks Joel for reporting this.
>>
>> On Tuesday, 11 December 2012 02:51:15 UTC-6, Joel Samuelsson wrote:
>>>
>>> I'm not sure if we're using the same web2py version. I am using the 
>>> current stable release (2.2.1). The call to listdir looks like this (just 
>>> downloaded a fresh copy and double-checked):
>>> models = listdir(path, '^\w+\.py$', 0, sort=False)
>>> I.e. sort=False. Otherwise, what you describe is true. With sort=False 
>>> though, sort order is not alphabetical and what you describe does not work 
>>> since you can't know in what order models are run.
>>>
>>> /Joel
>>>
>>>
>>> Den måndagen den 10:e december 2012 kl. 17:10:43 UTC+1 skrev Anthony:
>>>>
>>>> I've been testing the way you described above and it works, to a point. 
>>>>> The models are not imported in alphabetical order. This seems to be 
>>>>> controlled by this line (521):
>>>>
>>>> models = listdir(path, '^\w+\.py$', 0, sort=False) in compileapp.py
>>>>> listdir is essentially os.walk with a regexp for filtering and os.walk 
>>>>> doesn't give any guarantees for ordering at all from what I understand.
>>>>>
>>>>
>>>> Note, it is not os.listdir -- it is the listdir function from 
>>>> gluon/fileutils.py, which does sort the files alphabetically: 
>>>> http://code.google.com/p/web2py/source/browse/gluon/fileutils.py#88.
>>>>  
>>>>
>>>>> Later in compileapp, the models found with listdir are looped through, 
>>>>> once (not dependant on the regexp) which gives changing the regexp 
>>>>> between 
>>>>> models limited use.
>>>>>
>>>>
>>>> It loops through the files alphabetically -- within any given file, 
>>>> response.models_to_run can be changed, which can affect whether models 
>>>> that 
>>>> come *later* in alphabetical order get run (obviously it cannot cause 
>>>> models that come earlier in alphabetical order to be run). Using 
>>>> response.models_to_run does not change the order in which models are run, 
>>>> nor the ability of later models to affect earlier ones. It merely controls 
>>>> which models get run, with some ability for earlier models to make dynamic 
>>>> changes that affect later ones.
>>>>  
>>>>
>>>>> To explain my issue, I'll try to use an example. Please bear with me!
>>>>> Let's say I have the following models:
>>>>>
>>>>> dbInterface/someDbFile.py
>>>>>
>>>>> anotherInterface/someAnotherInterface.py
>>>>>
>>>>> __init__.py
>>>>> logic.py
>>>>>
>>>>>
>>>>> Now let's assume that listdir lists the models root dir first, then 
>>>>> anotherInterface dir and then dbInterface dir.
>>>>>
>>>>
>>>> That should be exactly how listdir lists the models.
>>>>  
>>>>
>>>>> I want the dbInterface to load before anotherInterface since 
>>>>> anotherInterface is dependant on dbInterface.
>>>>>
>>>>
>>>> Very simple -- just change the names so dbInterface comes before 
>>>> anotherInterface.
>>>>  
>>>>
>>>>> Is there any way I can control the order things are imported from 
>>>>> subfolders without changing web2py? I am aware that just setting sort to 
>>>>> true in the listdir-call will fix my issue but I would like to be able to 
>>>>> update web2py without having to make that change each time, if possible.
>>>>>
>>>>
>>>> As noted, sort is already True, so you should be OK. There is no way to 
>>>> change the order in which web2py executes the models, though (other than 
>>>> to 
>>>> generate your folder and file names to produce the order you desire).
>>>>  
>>>> Anthony
>>>>
>>>

-- 



Reply via email to