Skip to content

Instantly share code, notes, and snippets.

Avatar

Alexander Schepanovski Suor

View GitHub Profile
@Suor
Suor / mutating_querysets.py
Created Mar 16, 2011
Django: mutating querysets
View mutating_querysets.py
# THIS VERSION IS OUTDATED
# see .inplace(), .cloning(), ._clone() and .clone() methods of QuerySetMixin
# in https://github.com/Suor/django-cacheops/blob/master/cacheops/query.py
from django.conf import settings
from django.db.models import Model, Manager
MUTATING_QUERYSETS = getattr(settings, 'MUTATING_QUERYSETS', False)
class QuerySetMixin(object):
def __init__(self, *args, **kwargs):
@Suor
Suor / gist:876324
Created Mar 18, 2011
QuerySet which returns namedtuples
View gist:876324
from itertools import imap
from collections import namedtuple
from django.db.models.query import QuerySet, ValuesQuerySet
class NamedTuplesQuerySet(ValuesQuerySet):
def iterator(self):
# Purge any extra columns that haven't been explicitly asked for
extra_names = self.query.extra_select.keys()
@Suor
Suor / jinjalink_loader.py
Created May 14, 2011
Jinja2 template loader for django
View jinjalink_loader.py
@Suor
Suor / monkey.py
Created May 16, 2011
Efficient pickling of django models
View monkey.py
from django.db.models import Model
from itertools import izip
def attnames(cls, _cache={}):
try:
return _cache[cls]
except KeyError:
_cache[cls] = [f.attname for f in cls._meta.fields]
return _cache[cls]
@Suor
Suor / INSTALL.markdown
Created Nov 7, 2011
open_file_at_cursor sublime command
View INSTALL.markdown
cd ~/.config/sublime-text-2/Packages/User/
curl -O https://raw.github.com/gist/1344471/open_file_at_cursor.py

Open keyboard bindings file, and add a line to it

[
    ...
    { "keys": ["alt+o"], "command": "open_file_at_cursor" } // this one
@Suor
Suor / update-sublime.pl
Created Feb 4, 2012
Sublime Text 2 updater for Linux
View update-sublime.pl
#!/usr/bin/perl
use v5.10;
use strict;
use warnings FATAL => 'all';
use Mojo::UserAgent;
my $latest_url = Mojo::UserAgent->new->get('http://www.sublimetext.com/2')
@Suor
Suor / gist:2049656
Created Mar 16, 2012
Redis rate limiting
View gist:2049656
FUNCTION LIMIT_API_CALL(ip)
ts = CURRENT_UNIX_TIME()
_, current, _ = MULTI
SETNX(ip, ts * 10)
INCR(ip, 1)
EXPIRE(ip, 1)
EXEC
IF current - ts * 10 > 10 THEN
ERROR "too many requests per second"
ELSE
@Suor
Suor / README.md
Created Jun 7, 2012
Примеры использования AOP
View README.md

Задача: нужно при активации услуги продлять жизнь объявления. Как не писать одинаковый код в каждом обработчике активации? Примеры возможного аспектно-ориентированного кода на разных языках. Код на перле рабочий с библиотекой Aspect, на остальных языках просто возможные варианты.

Первый вариант использует простые обёртки - перед вызовом AdvertService.activate() навешивает обёртку на метод .save() отдельного объявления, которая уже его продляет. Второй вариант комбинирует два среза: вызов AbstractAdvert.save() и нахождение в потоке управления AdvertService.activate(), и накладывает обработчик на комбинированный срез.

Интересно как недостаточный синтаксис и семантика разных языков делают подобные операции неуклюжими.

P.S. Другой вариант - использование событий, но он более многословный.

@Suor
Suor / cmdline_opts.pl
Created Jul 11, 2012
Parse command line options with kind of pattern matching
View cmdline_opts.pl
given (\@ARGV) {
when ([]) {
make_all();
}
when ([qr/first|second|third/]) {
make_source(@ARGV);
}
when ([qr/first|second|third/, qr/\d\d\d\d-\d\d-\d\d/]) {
make_source_day(@ARGV);
}
@Suor
Suor / model_command.py
Created Sep 7, 2012
django ModelCommand
View model_command.py
import re
from django.core.management.base import LabelCommand, CommandError
from django.db.models.loading import get_model
class ModelCommand(LabelCommand):
args = 'model+'
def handle_label(self, label, **options):
if not re.search(r'^\w+\.\w+$', label):