注: 以下は古めの環境(Lenny or Squeeze)と古めのpython (2.5 or 2.6)をターゲットにしたときの手順なので、最新の環境では別な方法があるかもしれません。
たぶんこれだけあれば大丈夫。(python-supportはdeprecatedらしいけどここでは無視)
apt-get source python-xxx
で適当なパッケージのソースをダウンロードして参考にするとよい
以下例
#!/usr/bin/python from setuptools import setup, Extension __version__ = "0.0.1" setup(name = "yourext", version = __version__, author = "Your Name", author_email = "[email protected], url = "http://example.com/python-yourext", download_url = "http://example.com/python-yourext-%s.tgz" % __version__, description = "yourext client library for python", long_description = open('README.md').read(), license = "LGPL", platforms = ["Platform Independent"], classifiers = [ "Development Status :: 5 - Production/Stable", "Intended Audience :: Developers", "License :: OSI Approved :: GNU Library or Lesser General Public License (LGPL)", "Operating System :: OS Independent", "Programming Language :: Python", "Topic :: Software Development :: Libraries :: Python Modules" ], ext_modules = [ Extension(name='yourext', sources=['path_to_swig/yourext.i'], include_dirs=['path_to_lib/include'], library_dirs=['path_to_lib/lib'], libraries=['yourlibrary'], define_macros=[(FOO_BAR, 123), (DEBUG, None)], extra_compile_args=['-std=gnu99', '-Wextra'], ) ], py_modules = ['pure_python_module_name', 'foo.bar'], include_dirs = [''], )
-I, -L, -l
の値-DFOO_BAR=123 -DDEBUG
の意味.py
ファイルをpy_modulesに含める汎用的な方法は見つからなかった。(必要な場合はスクリプトでinclude_dirsにコピーすることで対応できる)以下コマンドでpython extのビルドを確認する。成功すると、buildディレクトリ以下に共有ライブラリが生成される
python setup.py build
以下コマンドでdebianパッケージに必要なファイルを生成する。このときegg-info等も生成される
python setup.py --command-package=stdeb.command debianize --force-buildsystem=True
debuild -uc -us
-uc -us
は署名を省略するためのオプション。
成功すると、親ディレクトリにdebファイルができてるはず
dlocate -S filename
のようにすればそのファイルを含むパッケージを調べることができるとりあえずウェブサーバがたちあがりさえすればいいときは、pythonのSimpleHTTPServerを使うのが便利です。 起動したカレントディレクトリ以下のファイルをブラウズできるので、テスト用のスタティックなスタブデータを一時的に配置したいときとかにも使えます。最近の一般的なlinuxディストリビューションであればデフォルトではいってるpythonで使えると思います。
$ python -mSimpleHTTPServer 3333
デフォルトポートは8000ですが、引数で指定することもできます。
ちなみにrubyでもwebrickを使って同様のことができますが、こちら で紹介されているwebrickのワンライナーは長すぎて覚えられないのでいつもpythonを使ってます。
でもリクエストに応じたロジックを入れたい場合はrubyのsinatraの方が便利です。
$ ruby -rsinatra -e 'get("/"){sleep 3}'
ポートを変更する場合は以下のようにします
$ ruby -rsinatra -e 'set :port,3333; get("/"){sleep 3}'
debian lennyは2012-02-06にEnd of lifeを迎えました。 それに伴いlennyのリポジトリもoldstable扱いとなりパスが変わったため、デフォルトのsources.listでは404 Not Foundとなってパッケージがインストールできなくなってしまいました。 早めにアップデートしたほうが好ましいですが、そのまま引き続きlennyを使いたい場合もあると思います。 そのような場合は以下のようにsources.listを変更してやれば今までどおりパッケージをとれるようになります。
deb http://archive.debian.org/debian-security/ lenny/updates main deb-src http://archive.debian.org/debian-security/ lenny/updates main deb http://archive.debian.org/debian/ lenny main deb-src http://archive.debian.org/debian/ lenny main
backportsなどもarchiveのほうにあるのでお好みで追加してください。
pythonではvirtualenvというユーティリティを使って複数の環境を切り替えることができます。しかしvirtualenvはセットアップがちょっとわかりにくかったりバージョンによってはこけたりしていまいち使いこなせていませんでした。久し振りにブログを書くついでにpython環境を再構築しようと思って調べたところ、virtualenv-burrito というのが使いやすかったので紹介します。これを使えば非常に簡単にpython環境を整えることができます。
$ curl -s https://raw.github.com/brainsik/virtualenv-burrito/master/virtualenv-burrito.sh | $SHELL
として再ログインするだけです。勝手にパスやシェルの補完設定もしてくれます。
新しい環境の構築は、
$ mkvirtualenv newname
環境の切り替えは、
$ workon newname $ # or $ workon 2.7
不要な環境の削除は、
$ rmvirtualenv newname
以上が基本的な使い方です。さらに詳しい使い方はvirtualenvwrapperのコマンドリファレンス等をみてください。
virtualenv-burrito自体はvirtualenv+virtualenvwrapperの環境を構築するだけなので、本格的に使いたい場合はvirtualenvについての理解が必要です。ただ、ほとんどの場合は単にバージョンとパッケージが切り替えられればいいと思うので、mkvirtualenvとworkonさえ覚えておけば十分です。 いくつか注意点もあります。
$ rm -Rf ~/.venvburrito/lib/python/distribute-0.6.24-py2.7.egg $ mkvirtualenv -p $(which python3.2) --distribute py32
いまからpython環境を構築するならvirtualenv-burritoつかっとくと、virtualenvとvirtualenvwrapperをセットアップするまでの手間が省けていいと思います
こんな風にイメージ画像がある記事の場合は、一覧ページでもこの画像をサムネイルで表示させたい。
例えば、 http://mojavy.com のトップページ右カラムにある最近の記事一覧みたいに画像を表示できるようにする。
これをするには、postオブジェクトにそういう属性をもたせればよいので、controllers/blog/post.pyに以下のように一行追加する。
+++ b/_blogofile/_controllers/blog/post.py @@ -93,6 +93,7 @@ class Post(object): self.slug = None self.draft = False self.filters = None + self.image = None self.__parse() self.__post_process()
そうしておくと、各記事のヘッダにあるyamlから勝手に読み込んでくれるので、
categories: date: 2011/11/06 20:32:51 title: image: /images/rena.jpg
のようにすれば${post.image}のようにして参照できる。
]]>