コードオブジェクト
******************

コードオブジェクト(Code objects)は CPython 実装の低レベルな詳細部分で
す。各オブジェクトは関数に束縛されていない実行可能コードの塊を表現して
います。

PyCodeObject

   コードオブジェクトを表現するために利用されるC構造体。この型のフィー
   ルドは何時でも変更され得ます。

PyTypeObject PyCode_Type

   これは Python の "code" 型を表現する "PyTypeObject" のインスタンス
   です。

int PyCode_Check(PyObject *co)

   *co* が "code" オブジェクトの場合に真を返します。この関数は常に成功
   します。

int PyCode_GetNumFree(PyCodeObject *co)

   *co* 内の自由変数(free variables)の数を返します。

PyCodeObject* PyCode_New(int argcount, int kwonlyargcount, int nlocals, int stacksize, int flags, PyObject *code, PyObject *consts, PyObject *names, PyObject *varnames, PyObject *freevars, PyObject *cellvars, PyObject *filename, PyObject *name, int firstlineno, PyObject *lnotab)
    *Return value: New reference.*

   新しいコードオブジェクトを返します。フレームを作成するためにダミー
   のコードオブジェクトが必要な場合は、代わりに "PyCode_NewEmpty()" を
   利用してください。バイトコードは頻繁に変更されるため、
   "PyCode_New()" を直接呼び出すと、 Python の詳細バージョンに依存して
   しまうことがあります。

PyCodeObject* PyCode_NewWithPosOnlyArgs(int argcount, int posonlyargcount, int kwonlyargcount, int nlocals, int stacksize, int flags, PyObject *code, PyObject *consts, PyObject *names, PyObject *varnames, PyObject *freevars, PyObject *cellvars, PyObject *filename, PyObject *name, int firstlineno, PyObject *lnotab)
    *Return value: New reference.*

   "PyCode_New()" に似ていますが、位置専用引数のための
   "posonlyargcount" が追加されています。

   バージョン 3.8 で追加.

PyCodeObject* PyCode_NewEmpty(const char *filename, const char *funcname, int firstlineno)
    *Return value: New reference.*

   新しい空のコードオブジェクトを、指定されたファイル名、関数名、開始
   行番号で作成します。返されたコードオブジェクトに対しての "exec()"
   や "eval()" は許されていません。
