1*67e74705SXin Li#!/usr/bin/env python 2*67e74705SXin Li 3*67e74705SXin Liimport os 4*67e74705SXin Liimport re 5*67e74705SXin Liimport time 6*67e74705SXin Lifrom pprint import pprint 7*67e74705SXin Li 8*67e74705SXin Li### 9*67e74705SXin Li 10*67e74705SXin Lic99URL = 'http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1124.pdf' 11*67e74705SXin Lic99TOC = [('Foreword', 'xi'), 12*67e74705SXin Li('Introduction', 'xiv'), 13*67e74705SXin Li('1. Scope', '1'), 14*67e74705SXin Li('2. Normative references', '2'), 15*67e74705SXin Li('3. Terms, definitions, and symbols', '3'), 16*67e74705SXin Li('4. Conformance', '7'), 17*67e74705SXin Li('5. Environment', '9'), 18*67e74705SXin Li('5.1 Conceptual models', '9'), 19*67e74705SXin Li('5.1.1 Translation environment', '9'), 20*67e74705SXin Li('5.1.2 Execution environments', '11'), 21*67e74705SXin Li('5.2 Environmental considerations', '17'), 22*67e74705SXin Li('5.2.1 Character sets', '17'), 23*67e74705SXin Li('5.2.2 Character display semantics', '19'), 24*67e74705SXin Li('5.2.3 Signals and interrupts', '20'), 25*67e74705SXin Li('5.2.4 Environmental limits', '20'), 26*67e74705SXin Li('6. Language', '29'), 27*67e74705SXin Li('6.1 Notation', '29'), 28*67e74705SXin Li('6.2 Concepts', '29'), 29*67e74705SXin Li('6.2.1 Scopes of identifiers', '29'), 30*67e74705SXin Li('6.2.2 Linkages of identifiers', '30'), 31*67e74705SXin Li('6.2.3 Name spaces of identifiers', '31'), 32*67e74705SXin Li('6.2.4 Storage durations of objects', '32'), 33*67e74705SXin Li('6.2.5 Types', '33'), 34*67e74705SXin Li('6.2.6 Representations of types', '37'), 35*67e74705SXin Li('6.2.7 Compatible type and composite type', '40'), 36*67e74705SXin Li('6.3 Conversions', '42'), 37*67e74705SXin Li('6.3.1 Arithmetic operands', '42'), 38*67e74705SXin Li('6.3.2 Other operands', '46'), 39*67e74705SXin Li('6.4 Lexical elements', '49'), 40*67e74705SXin Li('6.4.1 Keywords', '50'), 41*67e74705SXin Li('6.4.2 Identifiers', '51'), 42*67e74705SXin Li('6.4.3 Universal character names', '53'), 43*67e74705SXin Li('6.4.4 Constants', '54'), 44*67e74705SXin Li('6.4.5 String literals', '62'), 45*67e74705SXin Li('6.4.6 Punctuators', '63'), 46*67e74705SXin Li('6.4.7 Header names', '64'), 47*67e74705SXin Li('6.4.8 Preprocessing numbers', '65'), 48*67e74705SXin Li('6.4.9 Comments', '66'), 49*67e74705SXin Li('6.5 Expressions', '67'), 50*67e74705SXin Li('6.5.1 Primary expressions', '69'), 51*67e74705SXin Li('6.5.2 Postfix operators', '69'), 52*67e74705SXin Li('6.5.3 Unary operators', '78'), 53*67e74705SXin Li('6.5.4 Cast operators', '81'), 54*67e74705SXin Li('6.5.5 Multiplicative operators', '82'), 55*67e74705SXin Li('6.5.6 Additive operators', '82'), 56*67e74705SXin Li('6.5.7 Bitwise shift operators', '84'), 57*67e74705SXin Li('6.5.8 Relational operators', '85'), 58*67e74705SXin Li('6.5.9 Equality operators', '86'), 59*67e74705SXin Li('6.5.10 Bitwise AND operator', '87'), 60*67e74705SXin Li('6.5.11 Bitwise exclusive OR operator', '88'), 61*67e74705SXin Li('6.5.12 Bitwise inclusive OR operator', '88'), 62*67e74705SXin Li('6.5.13 Logical AND operator', '89'), 63*67e74705SXin Li('6.5.14 Logical OR operator', '89'), 64*67e74705SXin Li('6.5.15 Conditional operator', '90'), 65*67e74705SXin Li('6.5.16 Assignment operators', '91'), 66*67e74705SXin Li('6.5.17 Comma operator', '94'), 67*67e74705SXin Li('6.6 Constant expressions', '95'), 68*67e74705SXin Li('6.7 Declarations', '97'), 69*67e74705SXin Li('6.7.1 Storage-class specifiers', '98'), 70*67e74705SXin Li('6.7.2 Type specifiers', '99'), 71*67e74705SXin Li('6.7.3 Type qualifiers', '108'), 72*67e74705SXin Li('6.7.4 Function specifiers', '112'), 73*67e74705SXin Li('6.7.5 Declarators', '114'), 74*67e74705SXin Li('6.7.6 Type names', '122'), 75*67e74705SXin Li('6.7.7 Type definitions', '123'), 76*67e74705SXin Li('6.7.8 Initialization', '125'), 77*67e74705SXin Li('6.8 Statements and blocks', '131'), 78*67e74705SXin Li('6.8.1 Labeled statements', '131'), 79*67e74705SXin Li('6.8.2 Compound statement', '132'), 80*67e74705SXin Li('6.8.3 Expression and null statements', '132'), 81*67e74705SXin Li('6.8.4 Selection statements', '133'), 82*67e74705SXin Li('6.8.5 Iteration statements', '135'), 83*67e74705SXin Li('6.8.6 Jump statements', '136'), 84*67e74705SXin Li('6.9 External definitions', '140'), 85*67e74705SXin Li('6.9.1 Function definitions', '141'), 86*67e74705SXin Li('6.9.2 External object definitions', '143'), 87*67e74705SXin Li('6.10 Preprocessing directives', '145'), 88*67e74705SXin Li('6.10.1 Conditional inclusion', '147'), 89*67e74705SXin Li('6.10.2 Source file inclusion', '149'), 90*67e74705SXin Li('6.10.3 Macro replacement', '151'), 91*67e74705SXin Li('6.10.4 Line control', '158'), 92*67e74705SXin Li('6.10.5 Error directive', '159'), 93*67e74705SXin Li('6.10.6 Pragma directive', '159'), 94*67e74705SXin Li('6.10.7 Null directive', '160'), 95*67e74705SXin Li('6.10.8 Predefined macro names', '160'), 96*67e74705SXin Li('6.10.9 Pragma operator', '161'), 97*67e74705SXin Li('6.11 Future language directions', '163'), 98*67e74705SXin Li('6.11.1 Floating types', '163'), 99*67e74705SXin Li('6.11.2 Linkages of identifiers', '163'), 100*67e74705SXin Li('6.11.3 External names', '163'), 101*67e74705SXin Li('6.11.4 Character escape sequences', '163'), 102*67e74705SXin Li('6.11.5 Storage-class specifiers', '163'), 103*67e74705SXin Li('6.11.6 Function declarators', '163'), 104*67e74705SXin Li('6.11.7 Function definitions', '163'), 105*67e74705SXin Li('6.11.8 Pragma directives', '163'), 106*67e74705SXin Li('6.11.9 Predefined macro names', '163'), 107*67e74705SXin Li('7. Library', '164'), 108*67e74705SXin Li('7.1 Introduction', '164'), 109*67e74705SXin Li('7.1.1 Definitions of terms', '164'), 110*67e74705SXin Li('7.1.2 Standard headers', '165'), 111*67e74705SXin Li('7.1.3 Reserved identifiers', '166'), 112*67e74705SXin Li('7.1.4 Use of library functions', '166'), 113*67e74705SXin Li('7.2 Diagnostics <assert.h>', '169'), 114*67e74705SXin Li('7.2.1 Program diagnostics', '169'), 115*67e74705SXin Li('7.3 Complex arithmetic <complex.h>', '170'), 116*67e74705SXin Li('7.3.1 Introduction', '170'), 117*67e74705SXin Li('7.3.2 Conventions', '170'), 118*67e74705SXin Li('7.3.3 Branch cuts', '171'), 119*67e74705SXin Li('7.3.4 The CX_LIMITED_RANGE pragma', '171'), 120*67e74705SXin Li('7.3.5 Trigonometric functions', '172'), 121*67e74705SXin Li('7.3.6 Hyperbolic functions', '174'), 122*67e74705SXin Li('7.3.7 Exponential and logarithmic functions', '176'), 123*67e74705SXin Li('7.3.8 Power and absolute-value functions', '177'), 124*67e74705SXin Li('7.3.9 Manipulation functions', '178'), 125*67e74705SXin Li('7.4 Character handling <ctype.h>', '181'), 126*67e74705SXin Li('7.4.1 Character classification functions', '181'), 127*67e74705SXin Li('7.4.2 Character case mapping functions', '184'), 128*67e74705SXin Li('7.5 Errors <errno.h>', '186'), 129*67e74705SXin Li('7.6 Floating-point environment <fenv.h>', '187'), 130*67e74705SXin Li('7.6.1 The FENV_ACCESS pragma', '189'), 131*67e74705SXin Li('7.6.2 Floating-point exceptions', '190'), 132*67e74705SXin Li('7.6.3 Rounding', '193'), 133*67e74705SXin Li('7.6.4 Environment', '194'), 134*67e74705SXin Li('7.7 Characteristics of floating types <float.h>', '197'), 135*67e74705SXin Li('7.8 Format conversion of integer types <inttypes.h>', '198'), 136*67e74705SXin Li('7.8.1 Macros for format specifiers', '198'), 137*67e74705SXin Li('7.8.2 Functions for greatest-width integer types', '199'), 138*67e74705SXin Li('7.9 Alternative spellings <iso646.h>', '202'), 139*67e74705SXin Li('7.10 Sizes of integer types <limits.h>', '203'), 140*67e74705SXin Li('7.11 Localization <locale.h>', '204'), 141*67e74705SXin Li('7.11.1 Locale control', '205'), 142*67e74705SXin Li('7.11.2 Numeric formatting convention inquiry', '206'), 143*67e74705SXin Li('7.12 Mathematics <math.h>', '212'), 144*67e74705SXin Li('7.12.1 Treatment of error conditions', '214'), 145*67e74705SXin Li('7.12.2 The FP_CONTRACT pragma', '215'), 146*67e74705SXin Li('7.12.3 Classification macros', '216'), 147*67e74705SXin Li('7.12.4 Trigonometric functions', '218'), 148*67e74705SXin Li('7.12.5 Hyperbolic functions', '221'), 149*67e74705SXin Li('7.12.6 Exponential and logarithmic functions', '223'), 150*67e74705SXin Li('7.12.7 Power and absolute-value functions', '228'), 151*67e74705SXin Li('7.12.8 Error and gamma functions', '230'), 152*67e74705SXin Li('7.12.9 Nearest integer functions', '231'), 153*67e74705SXin Li('7.12.10 Remainder functions', '235'), 154*67e74705SXin Li('7.12.11 Manipulation functions', '236'), 155*67e74705SXin Li('7.12.12 Maximum, minimum, and positive difference functions', '238'), 156*67e74705SXin Li('7.12.13 Floating multiply-add', '239'), 157*67e74705SXin Li('7.12.14 Comparison macros', '240'), 158*67e74705SXin Li('7.13 Nonlocal jumps <setjmp.h>', '243'), 159*67e74705SXin Li('7.13.1 Save calling environment', '243'), 160*67e74705SXin Li('7.13.2 Restore calling environment', '244'), 161*67e74705SXin Li('7.14 Signal handling <signal.h>', '246'), 162*67e74705SXin Li('7.14.1 Specify signal handling', '247'), 163*67e74705SXin Li('7.14.2 Send signal', '248'), 164*67e74705SXin Li('7.15 Variable arguments <stdarg.h>', '249'), 165*67e74705SXin Li('7.15.1 Variable argument list access macros', '249'), 166*67e74705SXin Li('7.16 Boolean type and values <stdbool.h>', '253'), 167*67e74705SXin Li('7.17 Common definitions <stddef.h>', '254'), 168*67e74705SXin Li('7.18 Integer types <stdint.h>', '255'), 169*67e74705SXin Li('7.18.1 Integer types', '255'), 170*67e74705SXin Li('7.18.2 Limits of specified-width integer types', '257'), 171*67e74705SXin Li('7.18.3 Limits of other integer types', '259'), 172*67e74705SXin Li('7.18.4 Macros for integer constants', '260'), 173*67e74705SXin Li('7.19 Input/output <stdio.h>', '262'), 174*67e74705SXin Li('7.19.1 Introduction', '262'), 175*67e74705SXin Li('7.19.2 Streams', '264'), 176*67e74705SXin Li('7.19.3 Files', '266'), 177*67e74705SXin Li('7.19.4 Operations on files', '268'), 178*67e74705SXin Li('7.19.5 File access functions', '270'), 179*67e74705SXin Li('7.19.6 Formatted input/output functions', '274'), 180*67e74705SXin Li('7.19.7 Character input/output functions', '296'), 181*67e74705SXin Li('7.19.8 Direct input/output functions', '301'), 182*67e74705SXin Li('7.19.9 File positioning functions', '302'), 183*67e74705SXin Li('7.19.10 Error-handling functions', '304'), 184*67e74705SXin Li('7.20 General utilities <stdlib.h>', '306'), 185*67e74705SXin Li('7.20.1 Numeric conversion functions', '307'), 186*67e74705SXin Li('7.20.2 Pseudo-random sequence generation functions', '312'), 187*67e74705SXin Li('7.20.3 Memory management functions', '313'), 188*67e74705SXin Li('7.20.4 Communication with the environment', '315'), 189*67e74705SXin Li('7.20.5 Searching and sorting utilities', '318'), 190*67e74705SXin Li('7.20.6 Integer arithmetic functions', '320'), 191*67e74705SXin Li('7.20.7 Multibyte/wide character conversion functions', '321'), 192*67e74705SXin Li('7.20.8 Multibyte/wide string conversion functions', '323'), 193*67e74705SXin Li('7.21 String handling <string.h>', '325'), 194*67e74705SXin Li('7.21.1 String function conventions', '325'), 195*67e74705SXin Li('7.21.2 Copying functions', '325'), 196*67e74705SXin Li('7.21.3 Concatenation functions', '327'), 197*67e74705SXin Li('7.21.4 Comparison functions', '328'), 198*67e74705SXin Li('7.21.5 Search functions', '330'), 199*67e74705SXin Li('7.21.6 Miscellaneous functions', '333'), 200*67e74705SXin Li('7.22 Type-generic math <tgmath.h>', '335'), 201*67e74705SXin Li('7.23 Date and time <time.h>', '338'), 202*67e74705SXin Li('7.23.1 Components of time', '338'), 203*67e74705SXin Li('7.23.2 Time manipulation functions', '339'), 204*67e74705SXin Li('7.23.3 Time conversion functions', '341'), 205*67e74705SXin Li('7.24 Extended multibyte and wide character utilities <wchar.h>', '348'), 206*67e74705SXin Li('7.24.1 Introduction', '348'), 207*67e74705SXin Li('7.24.2 Formatted wide character input/output functions', '349'), 208*67e74705SXin Li('7.24.3 Wide character input/output functions', '367'), 209*67e74705SXin Li('7.24.4 General wide string utilities', '371'), 210*67e74705SXin Li('7.24.5 Wide character time conversion functions', '385'), 211*67e74705SXin Li('7.24.6 Extended multibyte/wide character conversion utilities', '386'), 212*67e74705SXin Li('7.25 Wide character classification and mapping utilities <wctype.h>', 213*67e74705SXin Li '393'), 214*67e74705SXin Li('7.25.1 Introduction', '393'), 215*67e74705SXin Li('7.25.2 Wide character classification utilities', '394'), 216*67e74705SXin Li('7.25.3 Wide character case mapping utilities', '399'), 217*67e74705SXin Li('7.26 Future library directions', '401'), 218*67e74705SXin Li('7.26.1 Complex arithmetic <complex.h>', '401'), 219*67e74705SXin Li('7.26.2 Character handling <ctype.h>', '401'), 220*67e74705SXin Li('7.26.3 Errors <errno.h>', '401'), 221*67e74705SXin Li('7.26.4 Format conversion of integer types <inttypes.h>', '401'), 222*67e74705SXin Li('7.26.5 Localization <locale.h>', '401'), 223*67e74705SXin Li('7.26.6 Signal handling <signal.h>', '401'), 224*67e74705SXin Li('7.26.7 Boolean type and values <stdbool.h>', '401'), 225*67e74705SXin Li('7.26.8 Integer types <stdint.h>', '401'), 226*67e74705SXin Li('7.26.9 Input/output <stdio.h>', '402'), 227*67e74705SXin Li('7.26.10 General utilities <stdlib.h>', '402'), 228*67e74705SXin Li('7.26.11 String handling <string.h>', '402'), 229*67e74705SXin Li('<wchar.h>', '402'), 230*67e74705SXin Li('<wctype.h>', '402'), 231*67e74705SXin Li('Annex A (informative) Language syntax summary', '403'), 232*67e74705SXin Li('A.1 Lexical grammar', '403'), 233*67e74705SXin Li('A.2 Phrase structure grammar', '409'), 234*67e74705SXin Li('A.3 Preprocessing directives', '416'), 235*67e74705SXin Li('Annex B (informative) Library summary', '418'), 236*67e74705SXin Li('B.1 Diagnostics <assert.h>', '418'), 237*67e74705SXin Li('B.2 Complex <complex.h>', '418'), 238*67e74705SXin Li('B.3 Character handling <ctype.h>', '420'), 239*67e74705SXin Li('B.4 Errors <errno.h>', '420'), 240*67e74705SXin Li('B.5 Floating-point environment <fenv.h>', '420'), 241*67e74705SXin Li('B.6 Characteristics of floating types <float.h>', '421'), 242*67e74705SXin Li('B.7 Format conversion of integer types <inttypes.h>', '421'), 243*67e74705SXin Li('B.8 Alternative spellings <iso646.h>', '422'), 244*67e74705SXin Li('B.9 Sizes of integer types <limits.h>', '422'), 245*67e74705SXin Li('B.10 Localization <locale.h>', '422'), 246*67e74705SXin Li('B.11 Mathematics <math.h>', '422'), 247*67e74705SXin Li('B.12 Nonlocal jumps <setjmp.h>', '427'), 248*67e74705SXin Li('B.13 Signal handling <signal.h>', '427'), 249*67e74705SXin Li('B.14 Variable arguments <stdarg.h>', '427'), 250*67e74705SXin Li('B.15 Boolean type and values <stdbool.h>', '427'), 251*67e74705SXin Li('B.16 Common definitions <stddef.h>', '428'), 252*67e74705SXin Li('B.17 Integer types <stdint.h>', '428'), 253*67e74705SXin Li('B.18 Input/output <stdio.h>', '428'), 254*67e74705SXin Li('B.19 General utilities <stdlib.h>', '430'), 255*67e74705SXin Li('B.20 String handling <string.h>', '432'), 256*67e74705SXin Li('B.21 Type-generic math <tgmath.h>', '433'), 257*67e74705SXin Li('B.22 Date and time <time.h>', '433'), 258*67e74705SXin Li('B.23 Extended multibyte/wide character utilities <wchar.h>', '434'), 259*67e74705SXin Li('B.24 Wide character classification and mapping utilities <wctype.h>', 260*67e74705SXin Li '436'), 261*67e74705SXin Li('Annex C (informative) Sequence points', '438'), 262*67e74705SXin Li('Annex D (normative) Universal character names for identifiers', '439'), 263*67e74705SXin Li('Annex E (informative) Implementation limits', '441'), 264*67e74705SXin Li('Annex F (normative) IEC 60559 floating-point arithmetic', '443'), 265*67e74705SXin Li('F.1 Introduction', '443'), 266*67e74705SXin Li('F.2 Types', '443'), 267*67e74705SXin Li('F.3 Operators and functions', '444'), 268*67e74705SXin Li('F.4 Floating to integer conversion', '446'), 269*67e74705SXin Li('F.5 Binary-decimal conversion', '446'), 270*67e74705SXin Li('F.6 Contracted expressions', '447'), 271*67e74705SXin Li('F.7 Floating-point environment', '447'), 272*67e74705SXin Li('F.8 Optimization', '450'), 273*67e74705SXin Li('F.9 Mathematics <math.h>', '453'), 274*67e74705SXin Li('Annex G (informative) IEC 60559-compatible complex arithmetic', '466'), 275*67e74705SXin Li('G.1 Introduction', '466'), 276*67e74705SXin Li('G.2 Types', '466'), 277*67e74705SXin Li('G.3 Conventions', '466'), 278*67e74705SXin Li('G.4 Conversions', '467'), 279*67e74705SXin Li('G.5 Binary operators', '467'), 280*67e74705SXin Li('G.6 Complex arithmetic <complex.h>', '471'), 281*67e74705SXin Li('G.7 Type-generic math <tgmath.h>', '479'), 282*67e74705SXin Li('Annex H (informative) Language independent arithmetic', '480'), 283*67e74705SXin Li('H.1 Introduction', '480'), 284*67e74705SXin Li('H.2 Types', '480'), 285*67e74705SXin Li('H.3 Notification', '484'), 286*67e74705SXin Li('Annex I (informative) Common warnings', '486'), 287*67e74705SXin Li('Annex J (informative) Portability issues', '488'), 288*67e74705SXin Li('J.1 Unspecified behavior', '488'), 289*67e74705SXin Li('J.2 Undefined behavior', '491'), 290*67e74705SXin Li('J.3 Implementation-defined behavior', '504'), 291*67e74705SXin Li('J.4 Locale-specific behavior', '511'), 292*67e74705SXin Li('J.5 Common extensions', '512'), 293*67e74705SXin Li('Bibliography', '515'), 294*67e74705SXin Li('Index', '517')] 295*67e74705SXin Li 296*67e74705SXin LicXXURL = 'http://open-std.org/jtc1/sc22/wg21/docs/papers/2008/n2723.pdf' 297*67e74705SXin LicXXTOC = [('Contents', 'ii'), 298*67e74705SXin Li('List of Tables', 'ix'), 299*67e74705SXin Li('1 General', '1'), 300*67e74705SXin Li('1.1 Scope', '1'), 301*67e74705SXin Li('1.2 Normative references', '1'), 302*67e74705SXin Li('1.3 Definitions', '2'), 303*67e74705SXin Li('1.4 Implementation compliance', '4'), 304*67e74705SXin Li('1.5 Structure of this International Standard', '5'), 305*67e74705SXin Li('1.6 Syntax notation', '5'), 306*67e74705SXin Li('1.7 The C++ memory model', '6'), 307*67e74705SXin Li('1.8 The C++ object model', '6'), 308*67e74705SXin Li('1.9 Program execution', '7'), 309*67e74705SXin Li('1.10 Multi-threaded executions and data races', '10'), 310*67e74705SXin Li('1.11 Acknowledgments', '13'), 311*67e74705SXin Li('2 Lexical conventions', '15'), 312*67e74705SXin Li('2.1 Phases of translation', '15'), 313*67e74705SXin Li('2.2 Character sets', '16'), 314*67e74705SXin Li('2.3 Trigraph sequences', '17'), 315*67e74705SXin Li('2.4 Preprocessing tokens', '17'), 316*67e74705SXin Li('2.5 Alternative tokens', '18'), 317*67e74705SXin Li('2.6 Tokens', '19'), 318*67e74705SXin Li('2.7 Comments', '19'), 319*67e74705SXin Li('2.8 Header names', '19'), 320*67e74705SXin Li('2.9 Preprocessing numbers', '20'), 321*67e74705SXin Li('2.10 Identifiers', '20'), 322*67e74705SXin Li('2.11 Keywords', '20'), 323*67e74705SXin Li('2.12 Operators and punctuators', '21'), 324*67e74705SXin Li('2.13 Literals', '21'), 325*67e74705SXin Li('3 Basic concepts', '29'), 326*67e74705SXin Li('3.1 Declarations and definitions', '29'), 327*67e74705SXin Li('3.2 One definition rule', '31'), 328*67e74705SXin Li('3.3 Declarative regions and scopes', '33'), 329*67e74705SXin Li('3.4 Name lookup', '38'), 330*67e74705SXin Li('3.5 Program and linkage', '51'), 331*67e74705SXin Li('3.6 Start and termination', '54'), 332*67e74705SXin Li('3.7 Storage duration', '58'), 333*67e74705SXin Li('3.8 Object Lifetime', '62'), 334*67e74705SXin Li('3.9 Types', '65'), 335*67e74705SXin Li('3.10 Lvalues and rvalues', '70'), 336*67e74705SXin Li('3.11 Alignment', '72'), 337*67e74705SXin Li('4 Standard conversions', '73'), 338*67e74705SXin Li('4.1 Lvalue-to-rvalue conversion', '74'), 339*67e74705SXin Li('4.2 Array-to-pointer conversion', '74'), 340*67e74705SXin Li('4.3 Function-to-pointer conversion', '74'), 341*67e74705SXin Li('4.4 Qualification conversions', '74'), 342*67e74705SXin Li('4.5 Integral promotions', '75'), 343*67e74705SXin Li('4.6 Floating point promotion', '76'), 344*67e74705SXin Li('4.7 Integral conversions', '76'), 345*67e74705SXin Li('4.8 Floating point conversions', '76'), 346*67e74705SXin Li('4.9 Floating-integral conversions', '77'), 347*67e74705SXin Li('4.10 Pointer conversions', '77'), 348*67e74705SXin Li('4.11 Pointer to member conversions', '77'), 349*67e74705SXin Li('4.12 Boolean conversions', '78'), 350*67e74705SXin Li('4.13 Integer conversion rank', '78'), 351*67e74705SXin Li('5 Expressions', '79'), 352*67e74705SXin Li('5.1 Primary expressions', '80'), 353*67e74705SXin Li('5.2 Postfix expressions', '85'), 354*67e74705SXin Li('5.3 Unary expressions', '96'), 355*67e74705SXin Li('5.4 Explicit type conversion (cast notation)', '104'), 356*67e74705SXin Li('5.5 Pointer-to-member operators', '105'), 357*67e74705SXin Li('5.6 Multiplicative operators', '106'), 358*67e74705SXin Li('5.7 Additive operators', '106'), 359*67e74705SXin Li('5.8 Shift operators', '107'), 360*67e74705SXin Li('5.9 Relational operators', '108'), 361*67e74705SXin Li('5.10 Equality operators', '109'), 362*67e74705SXin Li('5.11 Bitwise AND operator', '110'), 363*67e74705SXin Li('5.12 Bitwise exclusive OR operator', '110'), 364*67e74705SXin Li('5.13 Bitwise inclusive OR operator', '110'), 365*67e74705SXin Li('5.14 Logical AND operator', '110'), 366*67e74705SXin Li('5.15 Logical OR operator', '110'), 367*67e74705SXin Li('5.16 Conditional operator', '111'), 368*67e74705SXin Li('5.17 Assignment and compound assignment operators', '112'), 369*67e74705SXin Li('5.18 Comma operator', '113'), 370*67e74705SXin Li('5.19 Constant expressions', '113'), 371*67e74705SXin Li('6 Statements', '116'), 372*67e74705SXin Li('6.1 Labeled statement', '116'), 373*67e74705SXin Li('6.2 Expression statement', '116'), 374*67e74705SXin Li('6.3 Compound statement or block', '116'), 375*67e74705SXin Li('6.4 Selection statements', '117'), 376*67e74705SXin Li('6.5 Iteration statements', '118'), 377*67e74705SXin Li('6.6 Jump statements', '121'), 378*67e74705SXin Li('6.7 Declaration statement', '122'), 379*67e74705SXin Li('6.8 Ambiguity resolution', '123'), 380*67e74705SXin Li('7 Declarations', '125'), 381*67e74705SXin Li('7.1 Specifiers', '126'), 382*67e74705SXin Li('7.2 Enumeration declarations', '140'), 383*67e74705SXin Li('7.3 Namespaces', '143'), 384*67e74705SXin Li('7.4 The asm declaration', '156'), 385*67e74705SXin Li('7.5 Linkage specifications', '156'), 386*67e74705SXin Li('8 Declarators', '160'), 387*67e74705SXin Li('8.1 Type names', '161'), 388*67e74705SXin Li('8.2 Ambiguity resolution', '161'), 389*67e74705SXin Li('8.3 Meaning of declarators', '163'), 390*67e74705SXin Li('8.4 Function definitions', '175'), 391*67e74705SXin Li('8.5 Initializers', '177'), 392*67e74705SXin Li('9 Classes', '191'), 393*67e74705SXin Li('9.1 Class names', '193'), 394*67e74705SXin Li('9.2 Class members', '194'), 395*67e74705SXin Li('9.3 Member functions', '197'), 396*67e74705SXin Li('9.4 Static members', '200'), 397*67e74705SXin Li('9.5 Unions', '202'), 398*67e74705SXin Li('9.6 Bit-fields', '203'), 399*67e74705SXin Li('9.7 Nested class declarations', '204'), 400*67e74705SXin Li('9.8 Local class declarations', '205'), 401*67e74705SXin Li('9.9 Nested type names', '206'), 402*67e74705SXin Li('10 Derived classes', '207'), 403*67e74705SXin Li('10.1 Multiple base classes', '208'), 404*67e74705SXin Li('10.2 Member name lookup', '210'), 405*67e74705SXin Li('10.3 Virtual functions', '213'), 406*67e74705SXin Li('10.4 Abstract classes', '217'), 407*67e74705SXin Li('11 Member access control', '219'), 408*67e74705SXin Li('11.1 Access specifiers', '221'), 409*67e74705SXin Li('11.2 Accessibility of base classes and base class members', '222'), 410*67e74705SXin Li('11.3 Access declarations', '224'), 411*67e74705SXin Li('11.4 Friends', '225'), 412*67e74705SXin Li('11.5 Protected member access', '228'), 413*67e74705SXin Li('11.6 Access to virtual functions', '229'), 414*67e74705SXin Li('11.7 Multiple access', '230'), 415*67e74705SXin Li('11.8 Nested classes', '230'), 416*67e74705SXin Li('12 Special member functions', '231'), 417*67e74705SXin Li('12.1 Constructors', '231'), 418*67e74705SXin Li('12.2 Temporary objects', '233'), 419*67e74705SXin Li('12.3 Conversions', '235'), 420*67e74705SXin Li('12.4 Destructors', '238'), 421*67e74705SXin Li('12.5 Free store', '240'), 422*67e74705SXin Li('12.6 Initialization', '242'), 423*67e74705SXin Li('12.7 Construction and destruction', '247'), 424*67e74705SXin Li('12.8 Copying class objects', '250'), 425*67e74705SXin Li('12.9 Inheriting Constructors', '255'), 426*67e74705SXin Li('13 Overloading', '259'), 427*67e74705SXin Li('13.1 Overloadable declarations', '259'), 428*67e74705SXin Li('13.2 Declaration matching', '261'), 429*67e74705SXin Li('13.3 Overload resolution', '262'), 430*67e74705SXin Li('13.4 Address of overloaded function', '281'), 431*67e74705SXin Li('13.5 Overloaded operators', '282'), 432*67e74705SXin Li('13.6 Built-in operators', '286'), 433*67e74705SXin Li('14 Templates', '290'), 434*67e74705SXin Li('14.1 Template parameters', '291'), 435*67e74705SXin Li('14.2 Names of template specializations', '294'), 436*67e74705SXin Li('14.3 Template arguments', '296'), 437*67e74705SXin Li('14.4 Type equivalence', '302'), 438*67e74705SXin Li('14.5 Template declarations', '303'), 439*67e74705SXin Li('14.6 Name resolution', '318'), 440*67e74705SXin Li('14.7 Template instantiation and specialization', '331'), 441*67e74705SXin Li('14.8 Function template specializations', '343'), 442*67e74705SXin Li('15 Exception handling', '363'), 443*67e74705SXin Li('15.1 Throwing an exception', '364'), 444*67e74705SXin Li('15.2 Constructors and destructors', '366'), 445*67e74705SXin Li('15.3 Handling an exception', '366'), 446*67e74705SXin Li('15.4 Exception specifications', '368'), 447*67e74705SXin Li('15.5 Special functions', '371'), 448*67e74705SXin Li('15.6 Exceptions and access', '372'), 449*67e74705SXin Li('16 Preprocessing directives', '373'), 450*67e74705SXin Li('16.1 Conditional inclusion', '375'), 451*67e74705SXin Li('16.2 Source file inclusion', '376'), 452*67e74705SXin Li('16.3 Macro replacement', '377'), 453*67e74705SXin Li('16.4 Line control', '382'), 454*67e74705SXin Li('16.5 Error directive', '383'), 455*67e74705SXin Li('16.6 Pragma directive', '383'), 456*67e74705SXin Li('16.7 Null directive', '383'), 457*67e74705SXin Li('16.8 Predefined macro names', '383'), 458*67e74705SXin Li('16.9 Pragma operator', '384'), 459*67e74705SXin Li('17 Library introduction', '386'), 460*67e74705SXin Li('17.1 General', '386'), 461*67e74705SXin Li('17.2 Overview', '386'), 462*67e74705SXin Li('17.3 Definitions', '386'), 463*67e74705SXin Li('17.4 Additional definitions', '390'), 464*67e74705SXin Li('17.5 Method of description (Informative)', '390'), 465*67e74705SXin Li('17.6 Library-wide requirements', '396'), 466*67e74705SXin Li('18 Language support library', '407'), 467*67e74705SXin Li('18.1 Types', '407'), 468*67e74705SXin Li('18.2 Implementation properties', '408'), 469*67e74705SXin Li('18.3 Integer types', '417'), 470*67e74705SXin Li('18.4 Start and termination', '418'), 471*67e74705SXin Li('18.5 Dynamic memory management', '420'), 472*67e74705SXin Li('18.6 Type identification', '424'), 473*67e74705SXin Li('18.7 Exception handling', '427'), 474*67e74705SXin Li('18.8 Initializer lists', '432'), 475*67e74705SXin Li('18.9 Other runtime support', '434'), 476*67e74705SXin Li('19 Diagnostics library', '435'), 477*67e74705SXin Li('19.1 Exception classes', '435'), 478*67e74705SXin Li('19.2 Assertions', '439'), 479*67e74705SXin Li('19.3 Error numbers', '440'), 480*67e74705SXin Li('19.4 System error support', '440'), 481*67e74705SXin Li('20 General utilities library', '452'), 482*67e74705SXin Li('20.1 Requirements', '452'), 483*67e74705SXin Li('20.2 Utility components', '457'), 484*67e74705SXin Li('20.3 Compile-time rational arithmetic', '463'), 485*67e74705SXin Li('20.4 Tuples', '465'), 486*67e74705SXin Li('20.5 Metaprogramming and type traits', '473'), 487*67e74705SXin Li('20.6 Function objects', '486'), 488*67e74705SXin Li('20.7 Memory', '509'), 489*67e74705SXin Li('20.8 Time utilities', '548'), 490*67e74705SXin Li('20.9 Date and time functions', '562'), 491*67e74705SXin Li('21 Strings library', '563'), 492*67e74705SXin Li('21.1 Character traits', '563'), 493*67e74705SXin Li('21.2 String classes', '569'), 494*67e74705SXin Li('21.3 Class template basic_string', '572'), 495*67e74705SXin Li('21.4 Numeric Conversions', '599'), 496*67e74705SXin Li('21.5 Null-terminated sequence utilities', '600'), 497*67e74705SXin Li('22 Localization library', '604'), 498*67e74705SXin Li('22.1 Locales', '604'), 499*67e74705SXin Li('22.2 Standard locale categories', '617'), 500*67e74705SXin Li('22.3 Standard code conversion facets', '657'), 501*67e74705SXin Li('22.4 C Library Locales', '659'), 502*67e74705SXin Li('23 Containers library', '660'), 503*67e74705SXin Li('23.1 Container requirements', '660'), 504*67e74705SXin Li('23.2 Sequence containers', '681'), 505*67e74705SXin Li('23.3 Associative containers', '719'), 506*67e74705SXin Li('23.4 Unordered associative containers', '744'), 507*67e74705SXin Li('24 Iterators library', '759'), 508*67e74705SXin Li('24.1 Iterator requirements', '759'), 509*67e74705SXin Li('24.2 Header <iterator> synopsis', '764'), 510*67e74705SXin Li('24.3 Iterator primitives', '767'), 511*67e74705SXin Li('24.4 Predefined iterators', '770'), 512*67e74705SXin Li('24.5 Stream iterators', '784'), 513*67e74705SXin Li('25 Algorithms library', '792'), 514*67e74705SXin Li('25.1 Non-modifying sequence operations', '802'), 515*67e74705SXin Li('25.2 Mutating sequence operations', '806'), 516*67e74705SXin Li('25.3 Sorting and related operations', '815'), 517*67e74705SXin Li('25.4 C library algorithms', '829'), 518*67e74705SXin Li('26 Numerics library', '831'), 519*67e74705SXin Li('26.1 Numeric type requirements', '831'), 520*67e74705SXin Li('26.2 The floating-point environment', '832'), 521*67e74705SXin Li('26.3 Complex numbers', '833'), 522*67e74705SXin Li('26.4 Random number generation', '842'), 523*67e74705SXin Li('26.5 Numeric arrays', '884'), 524*67e74705SXin Li('26.6 Generalized numeric operations', '904'), 525*67e74705SXin Li('26.7 C Library', '907'), 526*67e74705SXin Li('27 Input/output library', '912'), 527*67e74705SXin Li('27.1 Iostreams requirements', '912'), 528*67e74705SXin Li('27.2 Forward declarations', '912'), 529*67e74705SXin Li('27.3 Standard iostream objects', '915'), 530*67e74705SXin Li('27.4 Iostreams base classes', '916'), 531*67e74705SXin Li('27.5 Stream buffers', '934'), 532*67e74705SXin Li('27.6 Formatting and manipulators', '944'), 533*67e74705SXin Li('27.7 String-based streams', '972'), 534*67e74705SXin Li('27.8 File-based streams', '984'), 535*67e74705SXin Li('28 Regular expressions library', '1000'), 536*67e74705SXin Li('28.1 Definitions', '1000'), 537*67e74705SXin Li('28.2 Requirements', '1000'), 538*67e74705SXin Li('28.3 Regular expressions summary', '1002'), 539*67e74705SXin Li('28.4 Header <regex> synopsis', '1003'), 540*67e74705SXin Li('28.5 Namespace std::regex_constants', '1009'), 541*67e74705SXin Li('28.6 Class regex_error', '1012'), 542*67e74705SXin Li('28.7 Class template regex_traits', '1012'), 543*67e74705SXin Li('28.8 Class template basic_regex', '1015'), 544*67e74705SXin Li('28.9 Class template sub_match', '1020'), 545*67e74705SXin Li('28.10Class template match_results', '1025'), 546*67e74705SXin Li('28.11Regular expression algorithms', '1029'), 547*67e74705SXin Li('28.12Regular expression Iterators', '1033'), 548*67e74705SXin Li('28.13Modified ECMAScript regular expression grammar', '1039'), 549*67e74705SXin Li('29 Atomic operations library', '1042'), 550*67e74705SXin Li('29.1 Order and Consistency', '1044'), 551*67e74705SXin Li('29.2 Lock-free Property', '1046'), 552*67e74705SXin Li('29.3 Atomic Types', '1046'), 553*67e74705SXin Li('29.4 Operations on Atomic Types', '1051'), 554*67e74705SXin Li('29.5 Flag Type and Operations', '1054'), 555*67e74705SXin Li('30 Thread support library', '1057'), 556*67e74705SXin Li('30.1 Requirements', '1057'), 557*67e74705SXin Li('30.2 Threads', '1058'), 558*67e74705SXin Li('30.3 Mutual exclusion', '1063'), 559*67e74705SXin Li('30.4 Condition variables', '1077'), 560*67e74705SXin Li('A Grammar summary', '1085'), 561*67e74705SXin Li('A.1 Keywords', '1085'), 562*67e74705SXin Li('A.2 Lexical conventions', '1085'), 563*67e74705SXin Li('A.3 Basic concepts', '1089'), 564*67e74705SXin Li('A.4 Expressions', '1090'), 565*67e74705SXin Li('A.5 Statements', '1093'), 566*67e74705SXin Li('A.6 Declarations', '1094'), 567*67e74705SXin Li('A.7 Declarators', '1097'), 568*67e74705SXin Li('A.8 Classes', '1098'), 569*67e74705SXin Li('A.9 Derived classes', '1099'), 570*67e74705SXin Li('A.10 Special member functions', '1099'), 571*67e74705SXin Li('A.11 Overloading', '1100'), 572*67e74705SXin Li('A.12 Templates', '1100'), 573*67e74705SXin Li('A.13 Exception handling', '1101'), 574*67e74705SXin Li('A.14 Preprocessing directives', '1101'), 575*67e74705SXin Li('B Implementation quantities', '1103'), 576*67e74705SXin Li('C Compatibility', '1105'), 577*67e74705SXin Li('C.1 C++ and ISO C', '1105'), 578*67e74705SXin Li('C.2 Standard C library', '1114'), 579*67e74705SXin Li('D Compatibility features', '1119'), 580*67e74705SXin Li('D.1 Increment operator with bool operand', '1119'), 581*67e74705SXin Li('D.2 static keyword', '1119'), 582*67e74705SXin Li('D.3 Access declarations', '1119'), 583*67e74705SXin Li('D.4 Implicit conversion from const strings', '1119'), 584*67e74705SXin Li('D.5 C standard library headers', '1119'), 585*67e74705SXin Li('D.6 Old iostreams members', '1120'), 586*67e74705SXin Li('D.7 char* streams', '1121'), 587*67e74705SXin Li('D.8 Binders', '1130'), 588*67e74705SXin Li('D.9 auto_ptr', '1132'), 589*67e74705SXin Li('E Universal-character-names', '1135'), 590*67e74705SXin Li('F Cross references', '1137'), 591*67e74705SXin Li('Index', '1153')] 592*67e74705SXin Li 593*67e74705SXin LikDocuments = { 594*67e74705SXin Li 'C99' : (c99URL, c99TOC, 12), 595*67e74705SXin Li 'C++' : (cXXURL, cXXTOC, 12), 596*67e74705SXin Li} 597*67e74705SXin Li 598*67e74705SXin Lidef findClosestTOCEntry(data, target): 599*67e74705SXin Li # FIXME: Fix for named spec references 600*67e74705SXin Li if isinstance(target[0],str): 601*67e74705SXin Li return ('.'.join(target),'<named>',1) 602*67e74705SXin Li 603*67e74705SXin Li offset = data[2] 604*67e74705SXin Li best = None 605*67e74705SXin Li for (name,page) in data[1]: 606*67e74705SXin Li if ' ' in name: 607*67e74705SXin Li section,name = name.split(' ',1) 608*67e74705SXin Li if section == 'Annex': 609*67e74705SXin Li section,name = name.split(' ',1) 610*67e74705SXin Li section = 'Annex '+section 611*67e74705SXin Li else: 612*67e74705SXin Li section = None 613*67e74705SXin Li try: 614*67e74705SXin Li page = int(page) + offset 615*67e74705SXin Li except: 616*67e74705SXin Li page = 1 617*67e74705SXin Li try: 618*67e74705SXin Li spec = SpecIndex.fromstring(section) 619*67e74705SXin Li except: 620*67e74705SXin Li spec = None 621*67e74705SXin Li 622*67e74705SXin Li # Meh, could be better... 623*67e74705SXin Li if spec is not None: 624*67e74705SXin Li dist = spec - target 625*67e74705SXin Li if best is None or dist < best[0]: 626*67e74705SXin Li best = (dist, (section, name, page)) 627*67e74705SXin Li return best[1] 628*67e74705SXin Li 629*67e74705SXin Li# What a hack. Slow to boot. 630*67e74705SXin LidoxyLineRefRE = re.compile(r"<a name=\"l([0-9]+)\"></a>") 631*67e74705SXin Lidef findClosestLineReference(clangRoot, doxyName, target): 632*67e74705SXin Li try: 633*67e74705SXin Li f = open(os.path.join(clangRoot, 'docs', 'doxygen', 'html', doxyName)) 634*67e74705SXin Li except: 635*67e74705SXin Li return None 636*67e74705SXin Li 637*67e74705SXin Li best = None 638*67e74705SXin Li for m in doxyLineRefRE.finditer(f.read()): 639*67e74705SXin Li line = int(m.group(1), 10) 640*67e74705SXin Li dist = abs(line - target) 641*67e74705SXin Li if best is None or dist < best[0]: 642*67e74705SXin Li best = (dist,'l'+m.group(1)) 643*67e74705SXin Li f.close() 644*67e74705SXin Li if best is not None: 645*67e74705SXin Li return best[1] 646*67e74705SXin Li return None 647*67e74705SXin Li 648*67e74705SXin Li### 649*67e74705SXin Li 650*67e74705SXin LinameAndSpecRefRE = re.compile(r"(C99|C90|C\+\+|H\&S) ((([0-9]+)(\.[0-9]+)*|\[[^]]+\])(p[0-9]+)?)") 651*67e74705SXin LiloneSpecRefRE = re.compile(r" (([0-9]+)(\.[0-9]+){2,100}(p[0-9]+)?)") 652*67e74705SXin Lidef scanFile(path, filename): 653*67e74705SXin Li try: 654*67e74705SXin Li f = open(path) 655*67e74705SXin Li except IOError: 656*67e74705SXin Li print >>sys.stderr,'WARNING: Unable to open:',path 657*67e74705SXin Li return 658*67e74705SXin Li 659*67e74705SXin Li for i,ln in enumerate(f): 660*67e74705SXin Li ignore = set() 661*67e74705SXin Li for m in nameAndSpecRefRE.finditer(ln): 662*67e74705SXin Li section = m.group(2) 663*67e74705SXin Li name = m.group(1) 664*67e74705SXin Li if section.endswith('.'): 665*67e74705SXin Li section = section[:-1] 666*67e74705SXin Li yield RefItem(name, section, filename, path, i+1) 667*67e74705SXin Li ignore.add(section) 668*67e74705SXin Li for m in loneSpecRefRE.finditer(ln): 669*67e74705SXin Li section = m.group(1) 670*67e74705SXin Li if section.endswith('.'): 671*67e74705SXin Li section = section[:-1] 672*67e74705SXin Li if section not in ignore: 673*67e74705SXin Li yield RefItem(None, section, filename, path, i+1) 674*67e74705SXin Li 675*67e74705SXin Li### 676*67e74705SXin Li 677*67e74705SXin Liclass SpecIndex: 678*67e74705SXin Li @staticmethod 679*67e74705SXin Li def fromstring(str): 680*67e74705SXin Li # Check for named sections 681*67e74705SXin Li if str[0] == '[': 682*67e74705SXin Li assert ']' in str 683*67e74705SXin Li secs = str[1:str.index(']')].split('.') 684*67e74705SXin Li tail = str[str.index(']')+1:] 685*67e74705SXin Li if tail: 686*67e74705SXin Li assert tail[0] == 'p' 687*67e74705SXin Li paragraph = int(tail[1:]) 688*67e74705SXin Li else: 689*67e74705SXin Li paragraph = None 690*67e74705SXin Li indices = secs 691*67e74705SXin Li else: 692*67e74705SXin Li secs = str.split('.') 693*67e74705SXin Li paragraph = None 694*67e74705SXin Li if 'p' in secs[-1]: 695*67e74705SXin Li secs[-1],p = secs[-1].split('p',1) 696*67e74705SXin Li paragraph = int(p) 697*67e74705SXin Li indices = map(int, secs) 698*67e74705SXin Li return SpecIndex(indices, paragraph) 699*67e74705SXin Li 700*67e74705SXin Li def __init__(self, indices, paragraph=None): 701*67e74705SXin Li assert len(indices)>0 702*67e74705SXin Li self.indices = tuple(indices) 703*67e74705SXin Li self.paragraph = paragraph 704*67e74705SXin Li 705*67e74705SXin Li def __str__(self): 706*67e74705SXin Li s = '.'.join(map(str,self.indices)) 707*67e74705SXin Li if self.paragraph is not None: 708*67e74705SXin Li s += '.p%d'%(self.paragraph,) 709*67e74705SXin Li return s 710*67e74705SXin Li 711*67e74705SXin Li def __repr__(self): 712*67e74705SXin Li return 'SpecIndex(%s, %s)'%(self.indices, self.paragraph) 713*67e74705SXin Li 714*67e74705SXin Li def __cmp__(self, b): 715*67e74705SXin Li return cmp((self.indices,self.paragraph), 716*67e74705SXin Li (b.indices,b.paragraph)) 717*67e74705SXin Li 718*67e74705SXin Li def __hash__(self): 719*67e74705SXin Li return hash((self.indices,self.paragraph)) 720*67e74705SXin Li 721*67e74705SXin Li def __sub__(self, indices): 722*67e74705SXin Li def sub(a,b): 723*67e74705SXin Li a = a or 0 724*67e74705SXin Li b = b or 0 725*67e74705SXin Li return abs(a-b) 726*67e74705SXin Li return map(sub,self.indices,indices) 727*67e74705SXin Li 728*67e74705SXin Liclass RefItem: 729*67e74705SXin Li def __init__(self, name, section, filename, path, line): 730*67e74705SXin Li self.name = name 731*67e74705SXin Li self.section = SpecIndex.fromstring(section) 732*67e74705SXin Li self.filename = filename 733*67e74705SXin Li self.path = path 734*67e74705SXin Li self.line = line 735*67e74705SXin Li 736*67e74705SXin Li def __str__(self): 737*67e74705SXin Li if self.name is not None: 738*67e74705SXin Li return '%s %s'%(self.name, self.section) 739*67e74705SXin Li else: 740*67e74705SXin Li return '--- %s'%(self.section,) 741*67e74705SXin Li 742*67e74705SXin Li def __repr__(self): 743*67e74705SXin Li return 'RefItem(%s, %r, "%s", "%s", %d)'%(self.name, 744*67e74705SXin Li self.section, 745*67e74705SXin Li self.filename, 746*67e74705SXin Li self.path, 747*67e74705SXin Li self.line) 748*67e74705SXin Li 749*67e74705SXin Li def __cmp__(self, b): 750*67e74705SXin Li return cmp((self.name,self.section,self.filename,self.path,self.line), 751*67e74705SXin Li (b.name,b.section,self.filename,self.path,self.line)) 752*67e74705SXin Li 753*67e74705SXin Li def __hash__(self): 754*67e74705SXin Li return hash((self.name,self.section,self.filename,self.path,self.line)) 755*67e74705SXin Li 756*67e74705SXin Li### 757*67e74705SXin Li 758*67e74705SXin Lidef sorted(l): 759*67e74705SXin Li l = list(l) 760*67e74705SXin Li l.sort() 761*67e74705SXin Li return l 762*67e74705SXin Li 763*67e74705SXin Lidef getRevision(path): 764*67e74705SXin Li import subprocess 765*67e74705SXin Li p = subprocess.Popen(['svn', 'info', path], 766*67e74705SXin Li stdin=open('/dev/null','r'), 767*67e74705SXin Li stdout=subprocess.PIPE) 768*67e74705SXin Li for ln in p.stdout.read(1024).split('\n'): 769*67e74705SXin Li if ln.startswith('Revision:'): 770*67e74705SXin Li return ln.split(':',1)[1].strip() 771*67e74705SXin Li return None 772*67e74705SXin Li 773*67e74705SXin Lidef buildRefTree(references): 774*67e74705SXin Li root = (None, {}, []) 775*67e74705SXin Li 776*67e74705SXin Li def getNode(keys): 777*67e74705SXin Li if not keys: 778*67e74705SXin Li return root 779*67e74705SXin Li key,parent = keys[-1],getNode(keys[:-1]) 780*67e74705SXin Li node = parent[1].get(key) 781*67e74705SXin Li if node is None: 782*67e74705SXin Li parent[1][key] = node = (key, {}, []) 783*67e74705SXin Li return node 784*67e74705SXin Li 785*67e74705SXin Li for ref in references: 786*67e74705SXin Li n = getNode((ref.name,) + ref.section.indices) 787*67e74705SXin Li n[2].append(ref) 788*67e74705SXin Li 789*67e74705SXin Li def flatten((key, children, data)): 790*67e74705SXin Li children = sorted(map(flatten,children.values())) 791*67e74705SXin Li return (key, children, sorted(data)) 792*67e74705SXin Li 793*67e74705SXin Li return flatten(root) 794*67e74705SXin Li 795*67e74705SXin Lidef preorder(node,parents=(),first=True): 796*67e74705SXin Li (key,children,data) = node 797*67e74705SXin Li if first: 798*67e74705SXin Li yield parents+(node,) 799*67e74705SXin Li for c in children: 800*67e74705SXin Li for item in preorder(c, parents+(node,)): 801*67e74705SXin Li yield item 802*67e74705SXin Li 803*67e74705SXin Lidef main(): 804*67e74705SXin Li global options 805*67e74705SXin Li from optparse import OptionParser 806*67e74705SXin Li parser = OptionParser("usage: %prog [options] CLANG_ROOT <output-dir>") 807*67e74705SXin Li parser.add_option("", "--debug", dest="debug", 808*67e74705SXin Li help="Print extra debugging output", 809*67e74705SXin Li action="store_true", 810*67e74705SXin Li default=False) 811*67e74705SXin Li (opts, args) = parser.parse_args() 812*67e74705SXin Li 813*67e74705SXin Li if len(args) != 2: 814*67e74705SXin Li parser.error("incorrect number of arguments") 815*67e74705SXin Li 816*67e74705SXin Li references = [] 817*67e74705SXin Li root,outputDir = args 818*67e74705SXin Li if os.path.isdir(root): 819*67e74705SXin Li for (dirpath, dirnames, filenames) in os.walk(root): 820*67e74705SXin Li for filename in filenames: 821*67e74705SXin Li name,ext = os.path.splitext(filename) 822*67e74705SXin Li if ext in ('.c', '.cpp', '.h', '.def'): 823*67e74705SXin Li fullpath = os.path.join(dirpath, filename) 824*67e74705SXin Li references.extend(list(scanFile(fullpath, filename))) 825*67e74705SXin Li else: 826*67e74705SXin Li references.extend(list(scanFile(root, root))) 827*67e74705SXin Li 828*67e74705SXin Li refTree = buildRefTree(references) 829*67e74705SXin Li 830*67e74705SXin Li specs = {} 831*67e74705SXin Li for ref in references: 832*67e74705SXin Li spec = specs[ref.name] = specs.get(ref.name,{}) 833*67e74705SXin Li items = spec[ref.section] = spec.get(ref.section,[]) 834*67e74705SXin Li items.append(ref) 835*67e74705SXin Li 836*67e74705SXin Li print 'Found %d references.'%(len(references),) 837*67e74705SXin Li 838*67e74705SXin Li if opts.debug: 839*67e74705SXin Li pprint(refTree) 840*67e74705SXin Li 841*67e74705SXin Li referencesPath = os.path.join(outputDir,'references.html') 842*67e74705SXin Li print 'Writing: %s'%(referencesPath,) 843*67e74705SXin Li f = open(referencesPath,'w') 844*67e74705SXin Li print >>f, '<html><head><title>clang: Specification References</title></head>' 845*67e74705SXin Li print >>f, '<body>' 846*67e74705SXin Li print >>f, '\t<h2>Specification References</h2>' 847*67e74705SXin Li for i,node in enumerate(refTree[1]): 848*67e74705SXin Li specName = node[0] or 'Unknown' 849*67e74705SXin Li print >>f, '<a href="#spec%d">%s</a><br>'%(i,specName) 850*67e74705SXin Li for i,node in enumerate(refTree[1]): 851*67e74705SXin Li specName = node[0] or 'Unknown' 852*67e74705SXin Li print >>f, '<hr>' 853*67e74705SXin Li print >>f, '<a name="spec%d">'%(i,) 854*67e74705SXin Li print >>f, '<h3>Document: %s</h3>'%(specName or 'Unknown',) 855*67e74705SXin Li print >>f, '<table border="1" cellspacing="2" width="80%">' 856*67e74705SXin Li print >>f, '<tr><th width="20%">Name</th><th>References</th></tr>' 857*67e74705SXin Li docData = kDocuments.get(specName) 858*67e74705SXin Li for path in preorder(node,first=False): 859*67e74705SXin Li if not path[-1][2]: 860*67e74705SXin Li continue 861*67e74705SXin Li components = '.'.join([str(p[0]) for p in path[1:]]) 862*67e74705SXin Li print >>f, '\t<tr>' 863*67e74705SXin Li tocEntry = None 864*67e74705SXin Li if docData is not None: 865*67e74705SXin Li tocEntry = findClosestTOCEntry(docData, [p[0] for p in path[1:]]) 866*67e74705SXin Li if tocEntry is not None: 867*67e74705SXin Li section,name,page = tocEntry 868*67e74705SXin Li # If section is exact print the TOC name 869*67e74705SXin Li if page is not None: 870*67e74705SXin Li linkStr = '<a href="%s#page=%d">%s</a> (pg.%d)'%(docData[0],page,components,page) 871*67e74705SXin Li else: 872*67e74705SXin Li linkStr = components 873*67e74705SXin Li if section == components: 874*67e74705SXin Li print >>f, '\t\t<td valign=top>%s<br>%s</td>'%(linkStr,name) 875*67e74705SXin Li else: 876*67e74705SXin Li print >>f, '\t\t<td valign=top>%s</td>'%(linkStr,) 877*67e74705SXin Li else: 878*67e74705SXin Li print >>f, '\t\t<td valign=top>%s</td>'%(components,) 879*67e74705SXin Li print >>f, '\t\t<td valign=top>' 880*67e74705SXin Li for item in path[-1][2]: 881*67e74705SXin Li # XXX total hack 882*67e74705SXin Li relativePath = item.path[len(root):] 883*67e74705SXin Li if relativePath.startswith('/'): 884*67e74705SXin Li relativePath = relativePath[1:] 885*67e74705SXin Li # XXX this is broken, how does doxygen mangle w/ multiple 886*67e74705SXin Li # refs? Can we just read its map? 887*67e74705SXin Li filename = os.path.basename(relativePath) 888*67e74705SXin Li doxyName = '%s-source.html'%(filename.replace('.','_8'),) 889*67e74705SXin Li # Grrr, why can't doxygen write line number references. 890*67e74705SXin Li lineReference = findClosestLineReference(root,doxyName,item.line) 891*67e74705SXin Li if lineReference is not None: 892*67e74705SXin Li linkStr = 'http://clang.llvm.org/doxygen/%s#%s'%(doxyName,lineReference) 893*67e74705SXin Li else: 894*67e74705SXin Li linkStr = 'http://clang.llvm.org/doxygen/%s'%(doxyName,) 895*67e74705SXin Li if item.section.paragraph is not None: 896*67e74705SXin Li paraText = ' (p%d)'%(item.section.paragraph,) 897*67e74705SXin Li else: 898*67e74705SXin Li paraText = '' 899*67e74705SXin Li print >>f,'<a href="%s">%s:%d</a>%s<br>'%(linkStr,relativePath,item.line,paraText) 900*67e74705SXin Li print >>f, '\t\t</td>' 901*67e74705SXin Li print >>f, '\t</tr>' 902*67e74705SXin Li print >>f, '</table>' 903*67e74705SXin Li print >>f, '<hr>' 904*67e74705SXin Li print >>f, 'Generated: %s<br>'%(time.strftime('%Y-%m-%d %H:%M'),) 905*67e74705SXin Li print >>f, 'SVN Revision: %s'%(getRevision(root),) 906*67e74705SXin Li print >>f, '</body>' 907*67e74705SXin Li f.close() 908*67e74705SXin Li 909*67e74705SXin Liif __name__=='__main__': 910*67e74705SXin Li main() 911