File: SyncSyntax.cc

package info (click to toggle)
aspectc%2B%2B 1%3A1.1%2Bsvn20120529-2
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 222,560 kB
  • sloc: cpp: 3,935,531; ansic: 18,166; pascal: 14,783; sh: 2,188; makefile: 1,110; python: 340
file content (108 lines) | stat: -rw-r--r-- 4,087 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// This file is part of PUMA.
// Copyright (C) 1999-2003  The PUMA developer team.
//                                                                
// This program is free software;  you can redistribute it and/or 
// modify it under the terms of the GNU General Public License as 
// published by the Free Software Foundation; either version 2 of 
// the License, or (at your option) any later version.            
//                                                                
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of 
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  
// GNU General Public License for more details.                   
//                                                                
// You should have received a copy of the GNU General Public      
// License along with this program; if not, write to the Free     
// Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, 
// MA  02111-1307  USA                                            

#include "SyncSyntax.h"
#include "SyncSemantic.h"
#include "SyncBuilder.h"
#include "SyncTokens.h"
#include "SyncTree.h"

SyncSyntax::SyncSyntax(SyncBuilder &b, SyncSemantic &s) : 
  CCSyntax(b, s) {
}


SyncBuilder &SyncSyntax::builder() const { 
  return (SyncBuilder&)Puma::Syntax::builder(); 
}


SyncSemantic &SyncSyntax::semantic () const { 
  return (SyncSemantic&)Puma::Syntax::semantic(); 
}


/*****************************************************************************/
/*                                                                           */
/*                      A . 5   S t a t e m e n t s                          */
/*                                                                           */
/*****************************************************************************/


Puma::CTree *SyncSyntax::stmt() { 
  // This rule overloads the C++ statement grammar rule
  // first trying to parse a "synchronized" statement.

  // Try to parse a "synchronized" statement.
  if (parse(&SyncSyntax::sync_stmt)) {
    // Propagate the already built syntax tree 
    // node for the "synchronized" statement to 
    // the calling grammar rule.
    return builder().stmt(); 
  }
  // Not such a statement, so try to
  // parse a normal C++ statement.
  return Puma::CCSyntax::stmt();
}

           
Puma::CTree *SyncSyntax::sync_stmt() {
  // This is the new grammar rule for the "synchronized"
  // statement, i.e. the keyword "synchronized" followed 
  // by an optional statement sequence enclosed by curly 
  // brackets.
  //
  // 3: SYNCHRONIZED  {  }
  // 4: SYNCHRONIZED  {  stmt_seq  }

  // A result of 0 always means that the rule is failed.
  Puma::CTree *result = 0;
  
  // Try to parse the "synchronized" keyword followed 
  // by the opening curly bracket.
  if (parse(TOK_SYNC) && parse(Puma::TOK_OPEN_CURLY)) {
    // If the names declared in a "synchronized" block shall
    // be local to that block, a local scope has to be entered
    // by calling the semantic object method enter_local_scope(). 
    // This scope is left automatically when this rule is left.
    //semantic().enter_local_scope(); 
    
    // "synchronized" statements shall not be nested. This
    // is checked by the semantic analysis using a simple 
    // state variable set by enter_sync_stmt() and reset
    // by leave_sync_stmt().
    semantic().enter_sync_stmt(); 
    
    // Try to parse every statement (if any) up to the next 
    // closing curly bracket on the same nesting level.
    if (parse(&SyncSyntax::stmt_seq), parse(Puma::TOK_CLOSE_CURLY)) {
      // Check if the "synchronized" statement is nested.
      // Build the corresponding syntax tree if it is not 
      // nested, otherwise generate an error message and
      // return 0.
      result = semantic().sync_stmt();
    }
    
    // Reset the "nested" state after parsing the statement
    // sequence is finished.
    semantic().leave_sync_stmt(); 
  }
  
  // Return the result.
  return result;
}