source: app/src/lib/matchdescr.cc @ 25b4022

Last change on this file since 25b4022 was 25ae32e, checked in by obrebski <obrebski@…>, 16 years ago

git-svn-id: svn://atos.wmid.amu.edu.pl/utt@4 e293616e-ec6a-49c2-aa92-f4a8b91c5d16

  • Property mode set to 100644
File size: 1.9 KB
Line 
1#include <ctype.h>
2#include <stdio.h>
3
4inline
5bool inline_matchattr(const char* a, const char* b)
6{
7  const char *p, *q; // pomocnicze wskazniki
8  while(*a && *b)
9  {
10    p=a; q=b; 
11    while(isupper(*p) && isupper(*q)) // rowny prefiks
12      if(*p==*q) ++p, ++q;
13      else if(*p<*q) // a jest mniejszy
14      {
15        // przesywamy a do nastepnego atr
16        a=p;
17        while(isupper(*a)) ++a; while(islower(*a)) ++a; 
18        goto end;
19      } 
20      else
21      {
22        // przesuwamy b do nastepnego atr
23        b=q;
24        while(isupper(*b)) ++b; while(islower(*b)) ++b; 
25        goto end;
26      }
27
28    if(islower(*p) && islower(*q)) // rowne atrybuty
29    {
30      a=p; b=q; // przesuwamy wskaznik, sprawdzamy wartosci
31      while(*a != *b)
32      {
33        if(*a > *b && !islower(*++b)) return false;
34        if(*a < *b && !islower(*++a)) return false;
35      }
36      // znaleziono rowna wartosc, przesywamy a i b do nast atr
37      while(isupper(*a)) ++a; while(islower(*a)) ++a; 
38      while(isupper(*b)) ++b; while(islower(*b)) ++b;
39      goto end;
40    }
41 
42    if(islower(*p)) // a jest krotszy, czyli mniejszy
43    { // przesuwamy a do nastepnego atrybutu
44      a=p;
45      while(islower(*a)) ++a; 
46      goto end;
47    }
48
49    if(islower(*q)) // b jest krotszy, czyli mniejszy
50    { // przesuwamy b do nastepnego atrybutu
51      b=q;
52      while(islower(*b)) ++b; 
53      goto end;
54    }
55  end: ;
56  }
57  return true;
58}
59
60
61bool matchattr(const char* a, const char* b)
62{
63  return inline_matchattr(a,b);
64}
65
66bool matchdescr(const char* a, const char* b)
67{
68  while(isupper(*a) && isupper(*b) && *a==*b) ++a, ++b;
69  if(*a=='\0')
70    if(*b=='\0' || *b=='/') return true;
71    else return false;
72
73  if(*a=='/')
74    if(*b=='\0') return true;
75    else if(*b=='/') return inline_matchattr(++a, ++b);
76
77  return false;
78}
79
80
81int main()
82{
83  char a[100], b[100];
84  while(scanf("%s %s", a, b)==2)
85    printf("%s & %s = %d\n", a, b, matchdescr(a,b));
86}
Note: See TracBrowser for help on using the repository browser.