view anagram/guisupport/items.cpp @ 0:13d2b8934445

Import AnaGram (near-)release tree into Mercurial.
author David A. Holland
date Sat, 22 Dec 2007 17:52:45 -0500
parents
children
line wrap: on
line source

/*
 * AnaGram, A System for Syntax Directed Programming
 * Copyright 1993-1999 Parsifal Software. All Rights Reserved.
 * See the file COPYING for license and usage terms.
 *
 * items.cpp
 */

#include "dc.h"
#include "dict.h"
#include "items.h"
#include "myalloc.h"
#include "q1glbl.h"
#include "rule.h"
#include "stexpdc.h"
#include "stacks.h"
#include "token.h"
#include "ut.h"
#include "wm1.h"
#include "ws.h"

//#define INCLUDE_LOGGING
#include "log.h"


state_table_dc::item::item(unsigned ln) {
//  LOGSECTION("state_table_dc::item::item");
  int k = 0;
  unsigned lc = 0;
  unsigned *ndx = isht_dict->ndx;
  int *text = isht_dict->text;
  int *p;
//  LOGV(ln);
//  LOGV((int) text);
//  LOGV((int) ndx);
  while (lc <= ln) {
    lc += (text[ndx[k++]]-1)/2;
  }
//  LOGV(lc);
//  LOGV((int) p);
  p = &text[ndx[--k]];
  lc -= (*p++ -1)/2;
  p += 2*(first_flag = ln-lc);
  state = k;
//  LOGV((int) p);
  rule = *p++;
  index= *p;
//  LOGV(rule);
//  LOGV(index);
}

unsigned state_table_dc::item::token(void) {
  unsigned length;
  Rule r(rule);

  length = r->length();
  if (index >= length) {
    return 0;
  }
  //return lstptr(map_form_number[rule],tokens)[index];
  return r.token(index);
}

int build_item_list_ok(int tn) {
  LOGSECTION("build_item_list_ok");
  LOGV(tn);
  LOGV(ntkns);
  return tn && map_token_number[tn].non_terminal_flag;
}

dc_ref build_item_list(int tn) {
  //dc_ref window;
  if (tn == 0 || !map_token_number[tn].non_terminal_flag) {
    return dc_ref();
  }

  AgString head("Expansion Rules");
  AgString foot = AgString::format("T%03d: ", tn).concat(token_string(tn));
  return dc_ref(new expansion_rules_dc(tn, foot));
}

expansion_rules_dc::expansion_rules_dc(unsigned tn, const AgString foot)
  : dc("Expansion Rules", foot), token_number(tn)
{
  des->d_size.y = Token(tn)->expansionRuleList.size();
}

unsigned expansion_rules_dc::rule(unsigned ln) const {
  return Token(token_number).expansionRule(ln);
}

unsigned expansion_rules_dc::token(unsigned ln) const {
  int rn = rule(ln);
  if (map_form_number[rn].length() == 0) {
    return 0;
  }
  return Rule(rn).token(0);
}

void expansion_rules_dc::synchCursor(unsigned ln) const {
  unsigned rn = rule(ln);
  if (rn) {
    set_rule_line(rn);
  }
}

void expansion_rules_dc::getLine(unsigned ln) const{
  ics();
  append_item(rule(ln), 0);
}

int expansion_rules_dc::expansion_rules_ok(unsigned ln) {
  return build_item_list_ok(token(ln));
}

dc_ref expansion_rules_dc::expansion_rules(unsigned ln) {
  unsigned tn = token(ln);
  if (tn) {
    return build_item_list(token(ln));
  }
  return NULL;
}

int expansion_rules_dc::productions_ok(unsigned ln) {
  return productions_window_ok(token(ln));
}

dc_ref expansion_rules_dc::productions(unsigned ln) {
  unsigned tn = token(ln);
  if (tn) {
    return productions_window(token(ln));
  }
  return NULL;
}


dc_ref expansion_rules_dc::rule_context(unsigned ln) {
  unsigned rn = rule(ln);
  if (rn) {
    return rule_context_window(rn);
  }
  return NULL;
}

int expansion_rules_dc::set_elements_ok(unsigned ln) {
  unsigned tn = token(ln);
  if (tn) {
    return token_set_window_ok(token(ln));
  }
  return 0;
}

dc_ref expansion_rules_dc::set_elements(unsigned ln) {
  unsigned tn = token(ln);
  if (tn) {
    return token_set_window(token(ln));
  }
  return NULL;
}

int expansion_rules_dc::usage_ok(unsigned ln) {
  unsigned tn = token(ln);
  return token_usage_window_ok(tn);
}

dc_ref expansion_rules_dc::usage(unsigned ln) {
  unsigned tn = token(ln);
  return token_usage_window(tn);
}

dc_ref expand_specific_item(dc_ref , int fn, int fx){
  int tn;
  Rule rule(fn);

  if (fx < 0 || fx >= rule->length()) {
    return dc_ref();
  }
  tn = rule.token(fx);
  return build_item_list(tn);
}

static int state_table_tabs[] = {7,0};

void state_table_dc::getLine(unsigned ln) const {
  item x(ln);
  ics();
  if (x.first_flag == 0) {
    apprintf("S%03d:", x.state);
  }
  acs('\t');
  append_item(x.rule, x.index);
}

void state_table_dc::synchCursor(unsigned ln) const {
  set_rule_line(item(ln).rule);
}

state_table_dc::state_table_dc(void)
  : dc("State Definition Table")
{
  int dp  = 0,k = isht_dict->nsx;
  const int *ndx = (int*)isht_dict->ndx, *text = (int*)isht_dict->text;


  tab_stops = state_table_tabs;
  columnHeadTitle = "State\tCharacteristic Rules";
  while (k--) dp += (text[*ndx++]-1);
  dp /=2;
  ok_ptr(des);
  des->d_size.y = dp;
}

dc_ref state_table_dc::aux_trace(unsigned ln) {
  return aux_trace_window(item(ln).state);
}

int state_table_dc::expansion_rules_ok(unsigned ln){
  item x(ln);
  unsigned tn = x.token();
  return build_item_list_ok(tn);
}

dc_ref state_table_dc::expansion_rules(unsigned ln){
  item x(ln);
  unsigned tn = x.token();
  if (tn == 0) {
    return NULL;
  }
  return build_item_list(tn);
}

int state_table_dc::keywords_ok(unsigned ln) {
  return keywords_window_ok(item(ln).state);
}

dc_ref state_table_dc::keywords(unsigned ln) {
  return keywords_window(item(ln).state);
}

int state_table_dc::previous_states_ok(unsigned ln) {
  return previous_states_window_ok(item(ln).state);
}

dc_ref state_table_dc::previous_states(unsigned ln) {
  return previous_states_window(item(ln).state);
}

int state_table_dc::productions_ok(unsigned ln) {
  return productions_window_ok(item(ln).token());
}

dc_ref state_table_dc::productions(unsigned ln) {
  return productions_window(item(ln).token());
}

int state_table_dc::reduction_states_ok(unsigned ln) {
  item x(ln);
  return reduction_states_window_ok(x.rule,x.index);
}

dc_ref state_table_dc::reduction_states(unsigned ln) {
  item x(ln);
  return reduction_states_window(x.state,x.rule,x.index);
}

dc_ref state_table_dc::rule_context(unsigned ln){
  item x(ln);
  return rule_context_window(x.rule);
}

int state_table_dc::set_elements_ok(unsigned ln) {
  return token_set_window_ok(item(ln).token());
}

dc_ref state_table_dc::set_elements(unsigned ln) {
  return token_set_window(item(ln).token());
}

dc_ref state_table_dc::state_expansion(unsigned ln) {
  return state_expansion_window(item(ln).state);
}

int state_table_dc::usage_ok(unsigned ln) {
  return token_usage_window_ok(item(ln).token());
}

dc_ref state_table_dc::usage(unsigned ln) {
  return token_usage_window(item(ln).token());
}