/usr/share/gap/lib/info.gd is in gap-libs 4r7p5-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 | #############################################################################
##
#W info.gd GAP library Steve Linton
##
##
#Y Copyright (C) 1997, Lehrstuhl D für Mathematik, RWTH Aachen, Germany
#Y (C) 1998 School Math and Comp. Sci., University of St Andrews, Scotland
#Y Copyright (C) 2002 The GAP Group
##
## This package sets up the new Info messages system
##
## Informational messages are controlled by the user setting desired
## levels of verbosity for InfoClasses. A set of InfoClasses is an
## InfoSelector, and classes and selectors may be built up with \+
#N I wanted to use \or, but this isn't an operation
##
## A message is associated with a selector and a level and is
## printed when the desired level for any of the classes in the selector
## equals or exceeds the level of the message
##
## The main user calls are NewInfoClass( <name> ) to define a new class,
## \+ or \[\] to combine InfoClasses into an InfoSelector
## SetInfoLevel( <class>, <level> ) to set desired printing levels and
## Info( <selector>, <level>, <data>, <moredata>, ... ) to selectively print
## <data>, <moredata>, etc. There is SetInfoHandler( <class>, <fun> ) to
## customize the way the <data>, etc. are printed.
##
## Also available are InfoLevel( <class> ) to inspect the level, and
## SetAllInfoLevels( <level> )
##
#N There may be a case for doing this without using method selection at all
#N as it could then be installed earlier in library loading
#N
##
## This file is the declarations part of that package
##
#############################################################################
##
#C IsInfoClass(<obj>) the category of Info Classes
##
DeclareCategory("IsInfoClass", IsObject);
#############################################################################
##
#V InfoClassFamily the family of Info Classes
##
BIND_GLOBAL( "InfoClassFamily",
NewFamily("InfoClassFamily", IsInfoClass, IsInfoClass) );
#############################################################################
##
#C IsInfoSelector(<obj>) the category of sets of InfoClasses
##
## Such sets are what we actually use in message selection
##
DeclareCategoryCollections( "IsInfoClass" );
DeclareSynonym( "IsInfoSelector", IsInfoClassCollection and IsSSortedList );
#############################################################################
##
#O NewInfoClass( <name> ) obtain a new Info Class
##
## The name is used only for printing, and is not checked for uniqueness
##
DeclareOperation("NewInfoClass", [IsString] );
#############################################################################
##
#F DeclareInfoClass( <name> ) obtain a new Info Class
##
## Info classes of the {\GAP} library are created by `DeclareInfoClass'.
## The variables are automatically made read-only.
##
DeclareGlobalFunction( "DeclareInfoClass" );
#############################################################################
##
#O SetInfoLevel( <class>, <level>) set desired verbosity level for a class
##
#N Is it sensible to SetInfoLevel for a selector?
#N Would RaiseInfoLevel (which would not lower it if it were already higher
#N or LowerInfoLevel (the opposite) be any use?
##
## Info level 0 means no #I messages, higher levels produce more messages
##
DeclareOperation("SetInfoLevel", [IsInfoClass, IsInt]);
#############################################################################
##
#O InfoLevel( <class> ) get desired verbosity level for a class
##
#N Does this make sense for a selector (gets the max of the levels for the
#N classes that make up the selector, presumably)?
#N
#N In the final version, this will have to be done directly, not via an
#N Operation, as the kernel needs to do it quickly, and for a whole selector
##
DeclareOperation("InfoLevel", [IsInfoClass]);
#############################################################################
##
#O Info( <selector>, <level>, <data> [, <moredata>...] ) possibly print
## a message
##
## If the desired verbosity level for any of the classes making up selector
## is equal to or greater than level, then this function should Print "#I "
## then do CallFuncList(Print, <data> ...) (where <data> may be multiple
## arguments), then Print a newline. Can be customized with SetInfoHandler.
##
## Info is now a keyword, implemented in the kernel, so that data arguments
## are not evaluated when they are not needed
##
#############################################################################
##
#O SetInfoHandler( <selector>, <handler> )
##
## <handler> must be of the form function(selector, level, moreargsfrominfo)
##
DeclareGlobalFunction("SetInfoHandler");
DeclareGlobalFunction("DefaultInfoHandler");
#############################################################################
##
#O SetInfoOutput( <selector>, <out> )
##
## <out> must be output file name or stream
##
DeclareGlobalFunction("SetInfoOutput");
DeclareGlobalFunction("SetDefaultInfoOutput");
BIND_GLOBAL("DefaultInfoOutput", "*Print*");
#############################################################################
##
#O CompletionBar( <class>, <level>, <string>, <value> )
##
## if the info level of <class> is at least <level>, this displays a bar
## graph showing progress of <value> (a number between 0 and 1).
##
## If <value> is not a number, the bar graph display is terminated.
DeclareGlobalFunction("CompletionBar");
#############################################################################
##
#E info.gd ends here
##
|