mirror of
https://github.com/python/cpython.git
synced 2025-11-03 03:22:27 +00:00
Initial revision
This commit is contained in:
parent
c636014c43
commit
85a5fbbdfe
78 changed files with 13589 additions and 0 deletions
398
Python/modsupport.c
Normal file
398
Python/modsupport.c
Normal file
|
|
@ -0,0 +1,398 @@
|
|||
/* Module support implementation */
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#include "PROTO.h"
|
||||
#include "object.h"
|
||||
#include "intobject.h"
|
||||
#include "stringobject.h"
|
||||
#include "tupleobject.h"
|
||||
#include "listobject.h"
|
||||
#include "methodobject.h"
|
||||
#include "moduleobject.h"
|
||||
#include "modsupport.h"
|
||||
#include "import.h"
|
||||
#include "errors.h"
|
||||
|
||||
|
||||
/* Find a method in a module's method table.
|
||||
Usually called from a module's getattr method. */
|
||||
|
||||
object *
|
||||
findmethod(ml, op, name)
|
||||
struct methodlist *ml;
|
||||
object *op;
|
||||
char *name;
|
||||
{
|
||||
for (; ml->ml_name != NULL; ml++) {
|
||||
if (strcmp(name, ml->ml_name) == 0)
|
||||
return newmethodobject(ml->ml_name, ml->ml_meth, op);
|
||||
}
|
||||
err_setstr(NameError, name);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
object *
|
||||
initmodule(name, methods)
|
||||
char *name;
|
||||
struct methodlist *methods;
|
||||
{
|
||||
object *m, *d, *v;
|
||||
struct methodlist *ml;
|
||||
if ((m = new_module(name)) == NULL) {
|
||||
fprintf(stderr, "initializing module: %s\n", name);
|
||||
fatal("can't create a module");
|
||||
}
|
||||
d = getmoduledict(m);
|
||||
for (ml = methods; ml->ml_name != NULL; ml++) {
|
||||
v = newmethodobject(ml->ml_name, ml->ml_meth, (object *)NULL);
|
||||
if (v == NULL || dictinsert(d, ml->ml_name, v) != 0) {
|
||||
fprintf(stderr, "initializing module: %s\n", name);
|
||||
fatal("can't initialize module");
|
||||
}
|
||||
DECREF(v);
|
||||
}
|
||||
DECREF(m);
|
||||
return m; /* Yes, it still exists, in sys.modules... */
|
||||
}
|
||||
|
||||
|
||||
/* Convenience functions to set a type error exception and return 0 */
|
||||
|
||||
int
|
||||
err_badarg()
|
||||
{
|
||||
err_setstr(TypeError, "illegal argument type for built-in function");
|
||||
return 0;
|
||||
}
|
||||
|
||||
object *
|
||||
err_nomem()
|
||||
{
|
||||
err_setstr(MemoryError, "in built-in function");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Argument list handling tools.
|
||||
All return 1 for success, or call err_set*() and return 0 for failure */
|
||||
|
||||
int
|
||||
getnoarg(v)
|
||||
object *v;
|
||||
{
|
||||
if (v != NULL) {
|
||||
return err_badarg();
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getintarg(v, a)
|
||||
object *v;
|
||||
int *a;
|
||||
{
|
||||
if (v == NULL || !is_intobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
*a = getintvalue(v);
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getintintarg(v, a, b)
|
||||
object *v;
|
||||
int *a;
|
||||
int *b;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getintarg(gettupleitem(v, 0), a) &&
|
||||
getintarg(gettupleitem(v, 1), b);
|
||||
}
|
||||
|
||||
int
|
||||
getlongarg(v, a)
|
||||
object *v;
|
||||
long *a;
|
||||
{
|
||||
if (v == NULL || !is_intobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
*a = getintvalue(v);
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getlonglongargs(v, a, b)
|
||||
object *v;
|
||||
long *a, *b;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getlongarg(gettupleitem(v, 0), a) &&
|
||||
getlongarg(gettupleitem(v, 1), b);
|
||||
}
|
||||
|
||||
int
|
||||
getlonglongobjectargs(v, a, b, c)
|
||||
object *v;
|
||||
long *a, *b;
|
||||
object **c;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 3) {
|
||||
return err_badarg();
|
||||
}
|
||||
if (getlongarg(gettupleitem(v, 0), a) &&
|
||||
getlongarg(gettupleitem(v, 1), b)) {
|
||||
*c = gettupleitem(v, 2);
|
||||
return 1;
|
||||
}
|
||||
else {
|
||||
return err_badarg();
|
||||
}
|
||||
}
|
||||
|
||||
int
|
||||
getstrarg(v, a)
|
||||
object *v;
|
||||
object **a;
|
||||
{
|
||||
if (v == NULL || !is_stringobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
*a = v;
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getstrstrarg(v, a, b)
|
||||
object *v;
|
||||
object **a;
|
||||
object **b;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getstrarg(gettupleitem(v, 0), a) &&
|
||||
getstrarg(gettupleitem(v, 1), b);
|
||||
}
|
||||
|
||||
int
|
||||
getstrstrintarg(v, a, b, c)
|
||||
object *v;
|
||||
object **a;
|
||||
object **b;
|
||||
int *c;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 3) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getstrarg(gettupleitem(v, 0), a) &&
|
||||
getstrarg(gettupleitem(v, 1), b) &&
|
||||
getintarg(gettupleitem(v, 2), c);
|
||||
}
|
||||
|
||||
int
|
||||
getstrintarg(v, a, b)
|
||||
object *v;
|
||||
object **a;
|
||||
int *b;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getstrarg(gettupleitem(v, 0), a) &&
|
||||
getintarg(gettupleitem(v, 1), b);
|
||||
}
|
||||
|
||||
int
|
||||
getintstrarg(v, a, b)
|
||||
object *v;
|
||||
int *a;
|
||||
object **b;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getintarg(gettupleitem(v, 0), a) &&
|
||||
getstrarg(gettupleitem(v, 1), b);
|
||||
}
|
||||
|
||||
int
|
||||
getpointarg(v, a)
|
||||
object *v;
|
||||
int *a; /* [2] */
|
||||
{
|
||||
return getintintarg(v, a, a+1);
|
||||
}
|
||||
|
||||
int
|
||||
get3pointarg(v, a)
|
||||
object *v;
|
||||
int *a; /* [6] */
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 3) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getpointarg(gettupleitem(v, 0), a) &&
|
||||
getpointarg(gettupleitem(v, 1), a+2) &&
|
||||
getpointarg(gettupleitem(v, 2), a+4);
|
||||
}
|
||||
|
||||
int
|
||||
getrectarg(v, a)
|
||||
object *v;
|
||||
int *a; /* [2+2] */
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getpointarg(gettupleitem(v, 0), a) &&
|
||||
getpointarg(gettupleitem(v, 1), a+2);
|
||||
}
|
||||
|
||||
int
|
||||
getrectintarg(v, a)
|
||||
object *v;
|
||||
int *a; /* [4+1] */
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getrectarg(gettupleitem(v, 0), a) &&
|
||||
getintarg(gettupleitem(v, 1), a+4);
|
||||
}
|
||||
|
||||
int
|
||||
getpointintarg(v, a)
|
||||
object *v;
|
||||
int *a; /* [2+1] */
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getpointarg(gettupleitem(v, 0), a) &&
|
||||
getintarg(gettupleitem(v, 1), a+2);
|
||||
}
|
||||
|
||||
int
|
||||
getpointstrarg(v, a, b)
|
||||
object *v;
|
||||
int *a; /* [2] */
|
||||
object **b;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getpointarg(gettupleitem(v, 0), a) &&
|
||||
getstrarg(gettupleitem(v, 1), b);
|
||||
}
|
||||
|
||||
int
|
||||
getstrintintarg(v, a, b, c)
|
||||
object *v;
|
||||
object *a;
|
||||
int *b, *c;
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 3) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getstrarg(gettupleitem(v, 0), a) &&
|
||||
getintarg(gettupleitem(v, 1), b) &&
|
||||
getintarg(gettupleitem(v, 2), c);
|
||||
}
|
||||
|
||||
int
|
||||
getrectpointarg(v, a)
|
||||
object *v;
|
||||
int *a; /* [4+2] */
|
||||
{
|
||||
if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) {
|
||||
return err_badarg();
|
||||
}
|
||||
return getrectarg(gettupleitem(v, 0), a) &&
|
||||
getpointarg(gettupleitem(v, 1), a+4);
|
||||
}
|
||||
|
||||
int
|
||||
getlongtuplearg(args, a, n)
|
||||
object *args;
|
||||
long *a; /* [n] */
|
||||
int n;
|
||||
{
|
||||
int i;
|
||||
if (!is_tupleobject(args) || gettuplesize(args) != n) {
|
||||
return err_badarg();
|
||||
}
|
||||
for (i = 0; i < n; i++) {
|
||||
object *v = gettupleitem(args, i);
|
||||
if (!is_intobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
a[i] = getintvalue(v);
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getshorttuplearg(args, a, n)
|
||||
object *args;
|
||||
short *a; /* [n] */
|
||||
int n;
|
||||
{
|
||||
int i;
|
||||
if (!is_tupleobject(args) || gettuplesize(args) != n) {
|
||||
return err_badarg();
|
||||
}
|
||||
for (i = 0; i < n; i++) {
|
||||
object *v = gettupleitem(args, i);
|
||||
if (!is_intobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
a[i] = getintvalue(v);
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getlonglistarg(args, a, n)
|
||||
object *args;
|
||||
long *a; /* [n] */
|
||||
int n;
|
||||
{
|
||||
int i;
|
||||
if (!is_listobject(args) || getlistsize(args) != n) {
|
||||
return err_badarg();
|
||||
}
|
||||
for (i = 0; i < n; i++) {
|
||||
object *v = getlistitem(args, i);
|
||||
if (!is_intobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
a[i] = getintvalue(v);
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
getshortlistarg(args, a, n)
|
||||
object *args;
|
||||
short *a; /* [n] */
|
||||
int n;
|
||||
{
|
||||
int i;
|
||||
if (!is_listobject(args) || getlistsize(args) != n) {
|
||||
return err_badarg();
|
||||
}
|
||||
for (i = 0; i < n; i++) {
|
||||
object *v = getlistitem(args, i);
|
||||
if (!is_intobject(v)) {
|
||||
return err_badarg();
|
||||
}
|
||||
a[i] = getintvalue(v);
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue