Beispiel #1
0
    }

    if (strcmp("TOT",line) == 0) {
        rtsp_client->state = RTSP_PLAYER_CLOSE;
    }
}

static struct
{
	const char *val;
	int val_length;
	void (*parse_routine)(const char *line, rtsp_resp_t *decode, rtsp_client_t* client);
} header_types[] =
{
#define HEAD_TYPE(a, b) { a, sizeof(a) - 1, b }
	HEAD_TYPE("AlLow", rtsp_header_allow_public),
	HEAD_TYPE("Public", rtsp_header_allow_public),
	HEAD_TYPE("Connection", rtsp_header_connection),
	HEAD_TYPE("Content-Base", rtsp_header_content_base),
	HEAD_TYPE("Content-Length", rtsp_header_content_length),
	HEAD_TYPE("Content-Location", rtsp_header_content_loc),
	HEAD_TYPE("Content-Type", rtsp_header_content_type),
	HEAD_TYPE("CSeq", rtsp_header_cseq),
	HEAD_TYPE("Location", rtsp_header_location),
	HEAD_TYPE("Range", rtsp_header_range),
	HEAD_TYPE("Retry-After", rtsp_header_retry_after),
	HEAD_TYPE("RTP-client", rtsp_header_rtp),
	HEAD_TYPE("Session", rtsp_header_session),
	HEAD_TYPE("Set-Cookie", rtsp_header_cookie),
	HEAD_TYPE("Speed", rtsp_header_speed),
	HEAD_TYPE("Transport", rtsp_header_transport),
Beispiel #2
0
static status_t
uforth_execute_step(uforth_context_t *uf_ctx,
                    simulation_context_t *sc,
                    simulation_t *simulation,
                    uforth_heap_t *heap,
                    yana_complex_t *resultp,
                    int i)
{
    uforth_token_t *l_stack[16];
    int l_stack_pos = 0;
    status_t status = SUCCESS;
    uforth_token_t *token;
    yana_real_t r1, r2, r3;
    yana_complex_t c1, c2;
    yana_real_t f = sc?simulation_context_get_f(sc, i):0.L;
    int s = sc?simulation_context_get_n_samples(sc):0;
    uforth_token_type_t head_type;
    bool printed = false;
    bool end = false;
    bool free_heap = false;
    if ( NULL == heap )
    {
        free_heap = true;
        heap = uforth_heap_new();
    }
    for ( token = uf_ctx->first ;
            token && !end;
            token = token->next )
    {
        switch (token->type)
        {
        case UF_FREEAIR:
            POP_REAL("( x X -- x ) FREEAIR", r2);
            POP_REAL("( X x -- x ) FREEAIR", r1);
            PUSH_COMPLEX("FREEAIR", free_air_impedance(f, r1, r2));
            break;
        case UF_DIRIMP:
            POP_REAL("( x x X -- x ) FREEAIR", r3); // theta
            POP_REAL("( x X x -- x ) FREEAIR", r2); // r
            POP_REAL("( X x x -- x ) FREEAIR", r1); // Sd
            PUSH_COMPLEX("FREEAIR", free_air_dir_impedance(f, r2, r1, r3));
            break;
        case UF_MUL:
            POP_COMPLEX("( x X -- x ) MUL", c2);
            POP_COMPLEX("( X x -- x ) MUL", c1);
            PUSH_COMPLEX("MUL", c1*c2);
            break;
        case UF_DIV:
            POP_COMPLEX("( x X -- x ) DIV", c2);
            POP_COMPLEX("( X x -- x ) DIV", c1);
            PUSH_COMPLEX("DIV", c1/c2);
            break;
        case UF_ADD:
            POP_COMPLEX("( x X -- x ) ADD", c2);
            POP_COMPLEX("( X x -- x ) ADD", c1);
            PUSH_COMPLEX("ADD", c1+c2);
            break;
        case UF_SUB:
            POP_COMPLEX("( x X -- x ) SUB", c2);
            POP_COMPLEX("( X x -- x ) SUB", c1);
            PUSH_COMPLEX("SUB", c1-c2);
            break;
        case UF_NEG:
            POP_COMPLEX("( X -- x ) NEG", c1);
            PUSH_COMPLEX("NEG", -c1);
            break;
        case UF_EXP:
            POP_COMPLEX("( X -- x ) EXP", c1);
            PUSH_COMPLEX("EXP", cexp(c1));
            break;
        case UF_POW:
            POP_COMPLEX("( x X -- x ) POW", c2);
            POP_COMPLEX("( X x -- x ) POW", c1);
            PUSH_COMPLEX("POW", cpow(c1, c2));
            break;
        case UF_SQRT:
            POP_COMPLEX("( X -- x ) SQRT", c1);
            PUSH_COMPLEX("SQRT", csqrt(c1));
            break;
        case UF_LN:
            POP_COMPLEX("( X -- x ) LN", c1);
            PUSH_COMPLEX("LN", clog(c1));
            break;

        case UF_COS:
            POP_COMPLEX("( X -- x ) COS", c1);
            PUSH_COMPLEX("COS", ccos(c1));
            break;
        case UF_SIN:
            POP_COMPLEX("( X -- x ) SIN", c1);
            PUSH_COMPLEX("SIN", csin(c1));
            break;
        case UF_TAN:
            POP_COMPLEX("( X -- x ) TAN", c1);
            PUSH_COMPLEX("TAN", ctan(c1));
            break;
        case UF_ACOS:
            POP_COMPLEX("( X -- x ) ACOS", c1);
            PUSH_COMPLEX("ACOS", cacos(c1));
            break;
        case UF_ASIN:
            POP_COMPLEX("( X -- x ) ASIN", c1);
            PUSH_COMPLEX("ASIN", casin(c1));
            break;
        case UF_ATAN:
            POP_COMPLEX("( X -- x ) ATAN", c1);
            PUSH_COMPLEX("ATAN", catan(c1));
            break;
        case UF_LOG:
            POP_COMPLEX("( X -- x ) LOG", c1);
            PUSH_COMPLEX("LOG", clog10(c1));
            break;
        case UF_PAR:
            POP_COMPLEX("( x X -- x ) PAR", c2);
            POP_COMPLEX("( X x -- x ) PAR", c1);
            PUSH_COMPLEX("PAR", (c1*c2)/(c1+c2) );
            break;
        case UF_ABS:
            POP_COMPLEX("( X -- x ) ABS", c1);
            PUSH_REAL("ABS", cabs(c1));
            break;
        case UF_ARG:
            POP_COMPLEX("( X -- x ) ARG", c1);
            PUSH_REAL("ARG", carg(c1));
            break;
        case UF_DEG:
            POP_REAL("( X -- x ) DEG", r1);
            PUSH_REAL("DEG", 180. * r1 / M_PI );
            break;
        case UF_ANGLE:
            POP_REAL("( x X -- x ) ANGLE", r2);
            POP_REAL("( X x -- x ) ANGLE", r1);
            if ( fabs(r1-r2-2.*M_PI) > fabs(r1-r2) )
            {
                if ( fabs(r1-r2+2.*M_PI) > fabs(r1-r2) )
                    PUSH_REAL("ANGLE", r1-r2);
                else
                    PUSH_REAL("ANGLE", r1-r2+2.*M_PI);
            }
            else
            {
                if ( fabs(r1-r2+2.*M_PI) > fabs(r1-r2-2.*M_PI) )
                    PUSH_REAL("ANGLE", r1-r2-2.*M_PI);
                else
                    PUSH_REAL("ANGLE", r1-r2+2.*M_PI);
            }
            break;
        case UF_PDELAY:
            POP_REAL("( X -- x ) PDELAY", r1);
            PUSH_REAL("PDELAY",  - r1 /( 2. * M_PI * f ) );
            break;
        case UF_PREV_STEP:
            if ( 0 == i )
            {
                end = true;
                break;
            }
            --i;
            f = simulation_context_get_f(sc, i);
            break;
        case UF_NEXT_STEP:
            if ( s-1 == i )
            {
                end = true;
                break;
            }
            ++i;
            f = simulation_context_get_f(sc, i);
            break;
        case UF_IMAG:
            POP_COMPLEX("( X -- x ) IMAG", c1);
            PUSH_REAL("IMAG", cimag(c1));
            break;
        case UF_REAL:
            POP_COMPLEX("( X -- x ) REAL", c1);
            PUSH_REAL("REAL", creal(c1));
            break;
        case UF_PI:
            PUSH_REAL("PI", M_PI);
            break;
        case UF_RHO:
            PUSH_REAL("PI", YANA_RHO);
            break;
        case UF_C:
            PUSH_REAL("PI", YANA_C);
            break;
        case UF_MU:
            PUSH_REAL("PI", YANA_MU);
            break;
        case UF_F:
            PUSH_REAL("F", f);
            break;
        case UF_S:
            PUSH_REAL("F", i);
            break;
        case UF_I:
            PUSH_COMPLEX("I", 0. + I * 1.);
            break;
        case UF_DB:
            POP_COMPLEX("( X -- x ) DB", c1);
            PUSH_REAL("DB", 20. * log10(cabs(c1)));
            break;
        case UF_DBSPL:
            POP_COMPLEX("( X -- x ) DB", c1);
            PUSH_REAL("DB", 20. * log10(cabs(c1)/20e-6));
            break;
        case UF_DOT:
            HEAD_TYPE(head_type);
            if ( UF_VALUE_REAL == head_type )
            {
                POP_REAL("( X -- ) DOT", r1);
                fprintf(stdout, "%1.12g\t", (double)r1);
            }
            else if ( UF_VALUE_COMPLEX == head_type )
            {
                POP_COMPLEX("( X -- ) DOT", c1);
                fprintf(stdout, "%1.12g\t", (double)cabs(c1));
            }
            printed=true;
            break;
        case UF_DUP:
            POP_COMPLEX("( X -- x x ) DUP", c1);
            PUSH_COMPLEX("DUP", c1);
            PUSH_COMPLEX("DUP", c1);
            break;
        case UF_TO:
            token=token->next;
            if ( NULL == token )
            {
                ERROR("TO: end of instructions stream");
                status = FAILURE;
                goto loop_exit;
            }
            if ( token->type != UF_VALUE_SIMULATION )
            {
                ERROR("TO: %s is not a valid word to be set", token->symbol);
                status = FAILURE;
                goto loop_exit;
            }
            POP_COMPLEX("(X -- ) TO", c1);
            uforth_heap_set(heap, token->symbol, c1);
            break;
        case UF_SWAP:
            if ( uf_ctx->stack_pos < 2 )
            {
                ERROR("SWAP: Stack underflow");
                status = FAILURE;
                goto loop_exit;
            }
            token_swap(&uf_ctx->stack[uf_ctx->stack_pos-1],
                       &uf_ctx->stack[uf_ctx->stack_pos-2]);
            break;
        case UF_DROP:
            POP_COMPLEX("(X -- ) DROP", c1);
            break;
        case UF_IF:
            POP_COMPLEX("(X -- ) IF", c1);
            if ( 0. == c1 )
            {
                int depth=-1;
                uforth_token_t *orig_position = token;
                while ( ( token->type != UF_ELSE && token->type != UF_THEN ) || depth != 0 )
                {
                    if ( token->type == UF_IF ) ++depth;
                    if ( token->type == UF_THEN ) --depth;
                    token = token->next;
                    if ( NULL == token )
                    {
                        ERROR("IF: no matching ELSE or THEN found");
                        token = orig_position;
                        status = FAILURE;
                        goto loop_exit;
                    }
                }
            }
            break;
        case UF_ELSE:
        {
            int depth=0;
            uforth_token_t *orig_position = token;
            while ( token->type != UF_THEN || depth != 0 )
            {
                if ( token->type == UF_IF ) ++depth;
                if ( token->type == UF_THEN ) --depth;
                token = token->next;
                if ( NULL == token )
                {
                    ERROR("ELSE: no matching THEN found");
                    token = orig_position;
                    status = FAILURE;
                    goto loop_exit;
                }
            }
        }
        break;
        case UF_THEN:
            //noop
            break;
        case UF_BEGIN:
            L_PUSH(token);
            break;
        case UF_WHILE:
            POP_COMPLEX("(X -- ) WHILE", c1);
            if ( 0. == c1 )
            {
                L_DROP();
                int depth=0;
                uforth_token_t *orig_position = token;
                while ( token->type != UF_REPEAT || 0 != depth)
                {
                    if ( token->type == UF_BEGIN ) ++depth;
                    if ( token->type == UF_UNTIL ) --depth;
                    if ( token->type == UF_REPEAT ) --depth;
                    if ( token->type == UF_AGAIN ) --depth;
                    token=token->next;
                    if ( NULL == token )
                    {
                        ERROR("WHILE: no matching REPEAT found");
                        token = orig_position;
                        status = FAILURE;
                        goto loop_exit;
                    }
                }
            }
            break;
        case UF_REPEAT:
            L_HEAD(token);
            break;
        case UF_UNTIL:
            POP_COMPLEX("(X -- ) UNTIL", c1);
            if ( 0. == c1 )
                L_HEAD(token);
            else
                L_DROP();
            break;
        case UF_AGAIN:
            L_HEAD(token);
            break;
        case UF_LEAVE:
        {
            int depth = 0;
            L_DROP();
            uforth_token_t *orig_position = token;
            while ( ! ( ( token->type == UF_UNTIL ||
                          token->type == UF_REPEAT ||
                          token->type == UF_AGAIN ) && depth == 0 ) )
            {
                if ( token->type == UF_BEGIN ) ++depth;
                if ( token->type == UF_UNTIL ) --depth;
                if ( token->type == UF_REPEAT ) --depth;
                if ( token->type == UF_AGAIN ) --depth;
                token = token->next;
                if ( NULL == token )
                {
                    ERROR("LEAVE: no matching UNTIL|REPEAT|AGAIN found");
                    token = orig_position;
                    status = FAILURE;
                    goto loop_exit;
                }
            }
        }
        break;
        case UF_DEPTH:
            PUSH_REAL("DEPTH", uf_ctx->stack_pos);
            break;
        case UF_LT:
        case UF_LE:
        case UF_EQ:
        case UF_NE:
        case UF_GE:
        case UF_GT:
            POP_COMPLEX("(x X -- ) IF", c2);
            POP_COMPLEX("(X x -- ) IF", c1);
            if ( cimag(c1) != 0.L || cimag(c2) != 0.L )
            {
                ERROR("comparison between complex numbers");
                status = FAILURE;
                goto loop_exit;
            }
            r1=creal(c1);
            r2=creal(c2);
            PUSH_REAL("comparison",
                      UF_LT == token->type ? ( r1<r2)
                      : UF_LE == token->type ? (r1<=r2)
                      : UF_EQ == token->type ? (r1==r2)
                      : UF_NE == token->type ? (r1!=r2)
                      : UF_GE == token->type ? (r1>=r2)
                      : UF_GT == token->type ? (r1>r2)
                      : 0);
            break;
        case UF_VALUE_REAL:
            PUSH_REAL("real literal", token->r);
            break;
        case UF_VALUE_COMPLEX:
            assert(!"not possible");
            PUSH_REAL("complex literal", token->c);
            break;
        case UF_VALUE_SIMULATION:
        {
            yana_complex_t *sim_array;
            const uforth_token_t *heap_token = heap_token = uforth_heap_get(heap, token->symbol);
            if ( NULL != heap_token )
            {
                PUSH_COMPLEX("heap word", heap_token->c);
            }
            else
            {
                if ( token->symbol[0] != 'v'  &&  token->symbol[0] != 'I' )
                {
                    ERROR("Unknown symbol '%s'\n", token->symbol);
                    if ( sc )
                        HINT("dipoles start with 'I' and nodes start with 'v'");
                    status = FAILURE;
                    goto loop_exit;
                }
                sim_array = simulation_result(simulation, token->symbol+1);
                if ( NULL == sim_array )
                {
                    ERROR("Unknown symbol '%s'", token->symbol);
                    status = FAILURE;
                    goto loop_exit;
                }
                PUSH_COMPLEX("sim", sim_array[i]);
            }
        }
        break;
        }
    }
loop_exit:

    if (printed)
        fprintf(stdout, "\n");

    if ( SUCCESS != status && NULL != token )
    {
        fputs("ERROR: is here: ", stderr);
        uforth_token_t *t;
        for ( t = uf_ctx->first ;
                t != NULL ;
                t = t->next )
        {
            if ( t == token )
            {
                fprintf(stderr, ">>>%s<<<", t->symbol);
                break;
            }
            else
            {
                fprintf(stderr, "%s ", t->symbol);
            }
        }
        fputs("\n", stderr);
    }
    else if ( l_stack_pos != 0 )
    {
        ERROR("loop stack not empty at the end of the processing");
        status = FAILURE;
    }
    else if ( uf_ctx->stack_pos != 0 && NULL == resultp )
    {
        if ( !end )
            WARNING("stack not empty at the end of the processing");
        uf_ctx->stack_pos = 0;
    }

    if ( SUCCESS == status && NULL != resultp)
    {
        if ( uf_ctx->stack_pos != 1 )
        {
            ERROR("one result was expected and stack size is %d",
                  uf_ctx->stack_pos);
            status = FAILURE;
        }
        else
            POP_COMPLEX("RESULT", *resultp);
    }
    if ( free_heap )
        uforth_heap_free(heap);

    return status;
}