Here's the (simple) solution: http://stackoverflow.com/questions/2621440/generic-list-view-raises-attribute-error-function-object-has-no-attribute-c
Change .filter(pub_date__lte=datetime.datetime.now()) to .filter(pub_date__lte=datetime.datetime.now) On Apr 12, 11:46 am, QC <querycl...@googlemail.com> wrote: > An odd error here, perhaps someone can help track down source as it's > attempting to extend the Django CMS & attempts to use uses some logic > written as part of that project. In short, using: > > urls.py > ====================== > from django.conf.urls.defaults import * > from cmsplugin_flat_news.models import News > > '''RETURNING _CLONE ERROR WHEN IMPLEMENTED > def get_news(): > return News.published.all() > > news_dict = { > 'queryset': get_news, > > } > > news_list_dic = { > 'queryset': get_news, > 'paginate_by': 50,} > > ''' > # NEXT SECTION FUNCTIONS BUT NEEDS SERVER RESTART TO SEE NEW POSTS. > SEE:http://docs.djangoproject.com/en/dev/topics/db/queries/#caching-and-q... > & EXAMPLE > HERE:http://docs.djangoproject.com/en/dev/topics/generic-views/#adding-ext... > > news_dict = { > 'queryset': News.published.all(), > > } > > news_list_dic = { > 'queryset': News.published.all(),#SAME ISSUE > 'paginate_by': 50, > > } > > urlpatterns = patterns('django.views.generic.list_detail', > (r'^$', 'object_list', news_list_dic), > (r'^(?P<page>[0-9]+)/$', 'object_list', dict(news_list_dic)), > url(r'^(?P<slug>[-\w]+)/$', 'object_detail', news_dict, > name='news_view'), > ) > > models.py > ====================== > class PublishedNewsManager(models.Manager): > #Filters out all unpublished news and news with a publication date in > the future > def get_query_set(self): > return super(PublishedNewsManager, self).get_query_set() \ > .filter(is_published=True) \ > > .filter(pub_date__lte=datetime.datetime.now()) > > class News(models.Model): > title = models.CharField(_('Title'), max_length=255) > slug = models.SlugField(_('Slug'), > unique_for_date='pub_date') > author = models.ForeignKey(User) > description = models.TextField(_('Description'), > blank=True) > image = generic.GenericRelation('NewsImage', > blank=True, null=True) > content = models.TextField(_('Content'), blank=True) > tags = TagField() > is_published = models.BooleanField(_('Published'), default=False) > pub_date = models.DateTimeField(_('Publication date'), > default=datetime.datetime.now()) > created = models.DateTimeField(auto_now_add=True, > editable=False) > updated = models.DateTimeField(auto_now=True, > editable=False) > published = PublishedNewsManager() > objects = models.Manager() > > =============== > See issue in comments: basically, error raised by implementing the > 'correct' solution to add extra context to the views. Error is > Attribute Error: "'function' object has no attribute '_clone'" > > Trying: News.published.all instead of News.published.all() raises the > error whether used as part of a wrapper function or directly in the > queryset part of the urlpattern. > > Must be missing something obvious? Think it is to do with the > PublishedNewsManager not returning objects as a dictionary, or > tweaking the code to correctly return the objects to the view. -- You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-us...@googlegroups.com. To unsubscribe from this group, send email to django-users+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/django-users?hl=en.