SlideShare una empresa de Scribd logo
1 de 30
 Lisp Input and Output
overview Read function. Parsing of numbers and symbols Macro characters Input functions Output functions Querying the user
Printed representation Lisp presents a representation of most objects in printed representation which is used for input/output purposes. Functions such as print takes a lisp object and send the characters of its printed representation to a stream. The collection of routines that does this is called (Lisp)printer.
What read function accepts Lisp reader accepts characters, interpret them as a printed representation of the lisp object, and construct and return such an object. The reader can also be used as a lexical analyzer for a more general user-written parser. The reader is organized as a recursive descent parser.
The reader operates by reading a character from the input stream and treating it in one of the three ways: ,[object Object]
Constituent and escape characters are accumulated to make a token, which is then interpreted as number or symbol.
Macro characters trigger the invocation of the functions that can perform arbitrary parsing actions, including recursive invocation of the reader.Every character that appears in the input stream must be one of the following types: Illegal, whitespace, constituents ( [,],{,},?,and !) single escape, multiple escape or macro.
Parsing of numbers and symbols When an extended token is read, it is interpreted as a number or symbol. Whitespace, macro or escape character will always be treated as alphabetic within an extended token.
Lisp syntax for numbers Number::=integer|ratio|floating-point number Integer::=[sign] {digit}+  [decimal-point] Ratio::= [sign] {digit}+ / {digit}+ Floating-point-number::= [sign] {digit}* decimal-point {digit}+ [exponent]| [sign] {digit}+ [decimal-number {digit}*] exponent Sign::= +|- Decimal-point::= . Digit::= 0|1|2|3|4|5|6|7|8|9 Exponent::= exponent-marker [sign] {digit}+ Exponent-marker::= e|s|f|d|l|E|S|F|D|L
Token must satisfy the following requirements: It consists entirely of digits, signs (+ or -), ratio markers (/), decimal points(.), extension characters(^ or _), and number markers. It consists at least one digit. It begins with a digit, sign, decimal point, or extension character. It does not end with a sign. Ex: 1b5000, 777777q, 1.7J, ^-43^, 3.1.2.6 etc.
symbols The following are always treated as symbols: *read-base* The value of read base controls the interpretation  of tokens by read as being integers or ratios. Its value is the radix in which the integers or ratios are to be read. The value must be any integer from 2 to 36,and it is normally 10.  for ex if the *read-base* is set as 16(hexadecimal radix),  variables with names such as a,b,f , bad and face will be treated by the reader as numbers. /         /5       +    1+     1-    foo+ ab.cd   -    ^        ^/-
*read-supress*if this value is set as nil, the Lisp reader operates normally, when it is not null the most interesting operation of the reader are suppressed. *read-eval* its default value is always t, if *read-eval* is false. Reader macro signals an error.
Macro characters When a macro character is encountered, then the function associated with that macro is invoked and may produce an object to be returned. Macro characters are normally defined as follows:    The left parenthesis initiates reading a pair of list. The function read is called recursively to read successive objects until a right parenthesis is found to be next in the input stream. A list of objects read are returned.
‘ single-quote provides an abbreviation to make it easier to put constants in the programs. ; is used to write comments. “ double-quote character represents the printed representation of a string. A back-quote is followed by a template, a picture of a data structure to be built. # is dispatching macro-character. It reads an optional digit string and then one more character, and uses that character to select a function to run as a macro-character function.
Standard dispatching macro character syntax  # reads in a character object that represents a character x. #ame1 reads in as the character object whose name is name1. The name1 should have the syntax of the symbol. # ’ is an abbreviation for (function foo) A series of representations of objects enclosed by #( and )is read as a simple vector of those objects. If unsigned decimal integer appears between the # and (, it specifies explicitly the length of the vector.
#:foo requires foo to have a syntax of an unqualified symbol name. It denotes an uninterened symbol whose name is foo. Every time an uninterended symbol is created when this symbol is encountered. #,foo is read as the object resulting from the evaluation of the lisp object represented by foo, which may be the printed representation of any lisp object. #B reads rational in binary(radix 2) ex:#B110113 #o reads rational in octal(radix 8) ex: #o777511 #X reads rational in hexadecimal(radix 16) ex: #xFoo3840
#nA constructs an n-dimensional array Ex: #2A ((0 1 5) (foo 2(hot dog))) represents a 2 cross 3 matrix: 0  1  5                              f00 2 (hot dog) #s (name slot1 value1 slot2 value2….) denotes a structure. #+ syntax provides a read time conditionality facility; the syntax is #+feature form #- form is equivalent to #+(not feature) form. If feature is true, then this syntax represents a lisp object whose printed representation is form. If the feature is false, then this syntax is effectively white space.
The following names are standards across all implementations: Newline, space Rubout  delete character Page the form-feed or page-separator character Tab the tabulate character  Return carriage return character Linefeed the line-feed character
Read table Read table is the data structure used to control the reader. It has information about the syntax of each character. *read-table* is the current read table To program the reader for a different syntax, begin with the copy of the standard common lisp read table and then customize the individual characters within the copy. Copy-readtable &optional from-readtable to read-table
readtable case readtable is a function used to control the readers interpretation of the case. It provides access to a slot in the read table. The possible values of the slots are: :upcase replaceable characters are converted to upper case :downcase replaceable characters are converted into lower case :preserve the cases of all characters remain unchanged :invert all replicable characters of same case are converted to opposite case
Input functions Characters in inputs take optional arguments called: ,[object Object]
eof-error-p argument controls if the input is from a file, and end of file is reached.
If eof-error-p is true , an error will be signaled at the end of the file. If it is false, then no error is signaled, instead it returns eof-value.
if end-of-file is encountered and eof-error-p argument is not nil, the kind of error that is signaled may depend on the value of recursive-p.,[object Object]
Unread-char character &optional input-stream  unread-char puts the character onto the front of the input-stream.  listen &optional input-stream  The predicate listen is true if there is a character immediately available from the input stream, and false if not.  clear-input &optional input-stream ,[object Object],Read-byte binary-input-stream &optional eof-error-p eof-value  read-byte tread one byte from the binary input stream and returns it in the form of an integer.
Output functions that operate on stream of functions These functions take an optional argument output-stream(defaults to variable *standard-output*) on where to send the output.  write object &key :stream :escape :radix :base :circle :pretty :level :length :case :gensym :array: readable: right-margin :miser-width :lines and :pprint-dispatch the printed representation of the object is written to the output stream specified by :stream, which defaults to the value *standard-output*  The other keyword arguments specify values used to control the generation of the printed representation.
Prin1 object &optional output-stream prin1 outputs the printed representation  of object to output-stream. Print object &optional output-stream printed representation of the object is preceded by newline and followed by a space. PPrin1 object &optional output-stream trailing space is omitted and the object is printed with the *print-pretty* flag non-nil to produce “pretty” output. Princ object &optional output-stream  Is similar to prin1 except that the output has no escape characters.
Write-char character &optional output-stream outputs the character to the output stream and returns the character Write-string string &optional output-stream &key :start  :end Write-line string &optional output-stream &key :start  :end writes the character of the specified substring to the output-stream. The :start and :end delimit a substring of string in usual manner.  write-lined does the same thing but then outputs a new-line afterwards.
finish-output &optional output-stream  Attempts to ensure that all the output sent to the output stream has reached the destination, only then returns nil. force-output &optional output-stream initiates the emptying of any internal buffers and returns nil without waiting for completion. clear-output &optional output-stream ,[object Object],Output to binary streams: Write-byte integer binary-output-stream  write-byte returns one byte, the value of the integer.
Formatted output The function format is used for producing nicely formatted text. ,[object Object],Format outputs the characters of control string A format directive consists of a tilde(~) , optional prefix parameters separated by commas, optional colon( : ) and ( @ ) sign modifiers, and a single character indicating what kind of directive this is.

Más contenido relacionado

La actualidad más candente

Garbage collection
Garbage collectionGarbage collection
Garbage collectionSomya Bagai
 
Artificial Intelligence Notes Unit 1
Artificial Intelligence Notes Unit 1 Artificial Intelligence Notes Unit 1
Artificial Intelligence Notes Unit 1 DigiGurukul
 
Conditional and control statement
Conditional and control statementConditional and control statement
Conditional and control statementnarmadhakin
 
Object Oriented Programming Lecture Notes
Object Oriented Programming Lecture NotesObject Oriented Programming Lecture Notes
Object Oriented Programming Lecture NotesFellowBuddy.com
 
Introduction to oops concepts
Introduction to oops conceptsIntroduction to oops concepts
Introduction to oops conceptsNilesh Dalvi
 
Object Oriented Programming Concepts for beginners
Object Oriented Programming Concepts for beginners Object Oriented Programming Concepts for beginners
Object Oriented Programming Concepts for beginners Vibhawa Nirmal
 
Important features of java
Important features of javaImportant features of java
Important features of javaAL- AMIN
 
Java Garbage Collection - How it works
Java Garbage Collection - How it worksJava Garbage Collection - How it works
Java Garbage Collection - How it worksMindfire Solutions
 
OOP - Understanding association, aggregation, composition and dependency
OOP - Understanding association, aggregation, composition and dependencyOOP - Understanding association, aggregation, composition and dependency
OOP - Understanding association, aggregation, composition and dependencyMudasir Qazi
 
Developing R Graphical User Interfaces
Developing R Graphical User InterfacesDeveloping R Graphical User Interfaces
Developing R Graphical User InterfacesSetia Pramana
 
Compiler Design
Compiler DesignCompiler Design
Compiler DesignMir Majid
 
graphics programming in java
graphics programming in javagraphics programming in java
graphics programming in javaAbinaya B
 
Principles of programming languages. Detail notes
Principles of programming languages. Detail notesPrinciples of programming languages. Detail notes
Principles of programming languages. Detail notesVIKAS SINGH BHADOURIA
 

La actualidad más candente (20)

Graphics a buffer
Graphics a bufferGraphics a buffer
Graphics a buffer
 
Garbage collection
Garbage collectionGarbage collection
Garbage collection
 
Artificial Intelligence Notes Unit 1
Artificial Intelligence Notes Unit 1 Artificial Intelligence Notes Unit 1
Artificial Intelligence Notes Unit 1
 
LISP: Introduction to lisp
LISP: Introduction to lispLISP: Introduction to lisp
LISP: Introduction to lisp
 
Conditional and control statement
Conditional and control statementConditional and control statement
Conditional and control statement
 
Object Oriented Programming Lecture Notes
Object Oriented Programming Lecture NotesObject Oriented Programming Lecture Notes
Object Oriented Programming Lecture Notes
 
Introduction to oops concepts
Introduction to oops conceptsIntroduction to oops concepts
Introduction to oops concepts
 
Polygon filling
Polygon fillingPolygon filling
Polygon filling
 
OOPS Basics With Example
OOPS Basics With ExampleOOPS Basics With Example
OOPS Basics With Example
 
Object Oriented Programming Concepts for beginners
Object Oriented Programming Concepts for beginners Object Oriented Programming Concepts for beginners
Object Oriented Programming Concepts for beginners
 
Predicate logic
 Predicate logic Predicate logic
Predicate logic
 
Python
PythonPython
Python
 
Important features of java
Important features of javaImportant features of java
Important features of java
 
Java Garbage Collection - How it works
Java Garbage Collection - How it worksJava Garbage Collection - How it works
Java Garbage Collection - How it works
 
OOP - Understanding association, aggregation, composition and dependency
OOP - Understanding association, aggregation, composition and dependencyOOP - Understanding association, aggregation, composition and dependency
OOP - Understanding association, aggregation, composition and dependency
 
Developing R Graphical User Interfaces
Developing R Graphical User InterfacesDeveloping R Graphical User Interfaces
Developing R Graphical User Interfaces
 
Java I/o streams
Java I/o streamsJava I/o streams
Java I/o streams
 
Compiler Design
Compiler DesignCompiler Design
Compiler Design
 
graphics programming in java
graphics programming in javagraphics programming in java
graphics programming in java
 
Principles of programming languages. Detail notes
Principles of programming languages. Detail notesPrinciples of programming languages. Detail notes
Principles of programming languages. Detail notes
 

Destacado

Facebook: An Innovative Influenza Pandemic Early Warning System
Facebook: An Innovative Influenza Pandemic Early Warning SystemFacebook: An Innovative Influenza Pandemic Early Warning System
Facebook: An Innovative Influenza Pandemic Early Warning SystemChen Luo
 
WEKA: Output Knowledge Representation
WEKA: Output Knowledge RepresentationWEKA: Output Knowledge Representation
WEKA: Output Knowledge RepresentationDataminingTools Inc
 
PresentacióN De Quimica
PresentacióN De QuimicaPresentacióN De Quimica
PresentacióN De Quimicaguestf6a53c
 
Kidical Mass Presentation
Kidical Mass PresentationKidical Mass Presentation
Kidical Mass PresentationEugene SRTS
 
MS Sql Server: Manipulating Database
MS Sql Server: Manipulating DatabaseMS Sql Server: Manipulating Database
MS Sql Server: Manipulating DatabaseDataminingTools Inc
 
Procedures And Functions in Matlab
Procedures And Functions in MatlabProcedures And Functions in Matlab
Procedures And Functions in MatlabDataminingTools Inc
 
Bernoullis Random Variables And Binomial Distribution
Bernoullis Random Variables And Binomial DistributionBernoullis Random Variables And Binomial Distribution
Bernoullis Random Variables And Binomial DistributionDataminingTools Inc
 
MS Sql Server: Doing Calculations With Functions
MS Sql Server: Doing Calculations With FunctionsMS Sql Server: Doing Calculations With Functions
MS Sql Server: Doing Calculations With FunctionsDataminingTools Inc
 
HistoriografíA Latina LatíN Ii
HistoriografíA Latina LatíN IiHistoriografíA Latina LatíN Ii
HistoriografíA Latina LatíN Iilara
 
Pentaho: Reporting Solution Development
Pentaho: Reporting Solution DevelopmentPentaho: Reporting Solution Development
Pentaho: Reporting Solution DevelopmentDataminingTools Inc
 

Destacado (20)

LISP: Data types in lisp
LISP: Data types in lispLISP: Data types in lisp
LISP: Data types in lisp
 
PROLOG: Introduction To Prolog
PROLOG: Introduction To PrologPROLOG: Introduction To Prolog
PROLOG: Introduction To Prolog
 
Facebook: An Innovative Influenza Pandemic Early Warning System
Facebook: An Innovative Influenza Pandemic Early Warning SystemFacebook: An Innovative Influenza Pandemic Early Warning System
Facebook: An Innovative Influenza Pandemic Early Warning System
 
WEKA: Output Knowledge Representation
WEKA: Output Knowledge RepresentationWEKA: Output Knowledge Representation
WEKA: Output Knowledge Representation
 
Txomin Hartz Txikia
Txomin Hartz TxikiaTxomin Hartz Txikia
Txomin Hartz Txikia
 
PresentacióN De Quimica
PresentacióN De QuimicaPresentacióN De Quimica
PresentacióN De Quimica
 
Kidical Mass Presentation
Kidical Mass PresentationKidical Mass Presentation
Kidical Mass Presentation
 
MS Sql Server: Manipulating Database
MS Sql Server: Manipulating DatabaseMS Sql Server: Manipulating Database
MS Sql Server: Manipulating Database
 
XL-Miner: Timeseries
XL-Miner: TimeseriesXL-Miner: Timeseries
XL-Miner: Timeseries
 
Data Applied:Decision Trees
Data Applied:Decision TreesData Applied:Decision Trees
Data Applied:Decision Trees
 
Procedures And Functions in Matlab
Procedures And Functions in MatlabProcedures And Functions in Matlab
Procedures And Functions in Matlab
 
Control Statements in Matlab
Control Statements in  MatlabControl Statements in  Matlab
Control Statements in Matlab
 
Bernoullis Random Variables And Binomial Distribution
Bernoullis Random Variables And Binomial DistributionBernoullis Random Variables And Binomial Distribution
Bernoullis Random Variables And Binomial Distribution
 
R: Apply Functions
R: Apply FunctionsR: Apply Functions
R: Apply Functions
 
MS Sql Server: Doing Calculations With Functions
MS Sql Server: Doing Calculations With FunctionsMS Sql Server: Doing Calculations With Functions
MS Sql Server: Doing Calculations With Functions
 
Classification Continued
Classification ContinuedClassification Continued
Classification Continued
 
HistoriografíA Latina LatíN Ii
HistoriografíA Latina LatíN IiHistoriografíA Latina LatíN Ii
HistoriografíA Latina LatíN Ii
 
Anime
AnimeAnime
Anime
 
Continuous Random Variables
Continuous Random VariablesContinuous Random Variables
Continuous Random Variables
 
Pentaho: Reporting Solution Development
Pentaho: Reporting Solution DevelopmentPentaho: Reporting Solution Development
Pentaho: Reporting Solution Development
 

Similar a LISP: Input And Output

LISP: Data types in lisp
LISP: Data types in lispLISP: Data types in lisp
LISP: Data types in lispLISP Content
 
Python programming: Anonymous functions, String operations
Python programming: Anonymous functions, String operationsPython programming: Anonymous functions, String operations
Python programming: Anonymous functions, String operationsMegha V
 
AI UNIT-4 Final (2).pptx
AI UNIT-4 Final (2).pptxAI UNIT-4 Final (2).pptx
AI UNIT-4 Final (2).pptxprakashvs7
 
Introduction of bison
Introduction of bisonIntroduction of bison
Introduction of bisonvip_du
 
Current C++ code- parse-h -- This file contains the function prototype (1).pdf
Current C++ code- parse-h -- This file contains the function prototype (1).pdfCurrent C++ code- parse-h -- This file contains the function prototype (1).pdf
Current C++ code- parse-h -- This file contains the function prototype (1).pdfshyamsunder1211
 
Getting started with c++.pptx
Getting started with c++.pptxGetting started with c++.pptx
Getting started with c++.pptxAkash Baruah
 
Stream Based Input Output
Stream Based Input OutputStream Based Input Output
Stream Based Input OutputBharat17485
 
compiler Design course material chapter 2
compiler Design course material chapter 2compiler Design course material chapter 2
compiler Design course material chapter 2gadisaAdamu
 
02. chapter 3 lexical analysis
02. chapter 3   lexical analysis02. chapter 3   lexical analysis
02. chapter 3 lexical analysisraosir123
 
Programming fundamental
Programming fundamentalProgramming fundamental
Programming fundamentalMukesh Thakur
 
Getting started with c++
Getting started with c++Getting started with c++
Getting started with c++K Durga Prasad
 
IMP PPT- Python programming fundamentals.pptx
IMP PPT- Python programming fundamentals.pptxIMP PPT- Python programming fundamentals.pptx
IMP PPT- Python programming fundamentals.pptxlemonchoos
 
Chapter 13.1.3
Chapter 13.1.3Chapter 13.1.3
Chapter 13.1.3patcha535
 

Similar a LISP: Input And Output (20)

LISP: Data types in lisp
LISP: Data types in lispLISP: Data types in lisp
LISP: Data types in lisp
 
Python programming: Anonymous functions, String operations
Python programming: Anonymous functions, String operationsPython programming: Anonymous functions, String operations
Python programming: Anonymous functions, String operations
 
AI UNIT-4 Final (2).pptx
AI UNIT-4 Final (2).pptxAI UNIT-4 Final (2).pptx
AI UNIT-4 Final (2).pptx
 
Compilers Design
Compilers DesignCompilers Design
Compilers Design
 
Introduction of bison
Introduction of bisonIntroduction of bison
Introduction of bison
 
PHP Web Programming
PHP Web ProgrammingPHP Web Programming
PHP Web Programming
 
Current C++ code- parse-h -- This file contains the function prototype (1).pdf
Current C++ code- parse-h -- This file contains the function prototype (1).pdfCurrent C++ code- parse-h -- This file contains the function prototype (1).pdf
Current C++ code- parse-h -- This file contains the function prototype (1).pdf
 
Getting started with c++.pptx
Getting started with c++.pptxGetting started with c++.pptx
Getting started with c++.pptx
 
python_strings.pdf
python_strings.pdfpython_strings.pdf
python_strings.pdf
 
Introduction to R for beginners
Introduction to R for beginnersIntroduction to R for beginners
Introduction to R for beginners
 
Compiler Design
Compiler DesignCompiler Design
Compiler Design
 
Stream Based Input Output
Stream Based Input OutputStream Based Input Output
Stream Based Input Output
 
Assignment5
Assignment5Assignment5
Assignment5
 
compiler Design course material chapter 2
compiler Design course material chapter 2compiler Design course material chapter 2
compiler Design course material chapter 2
 
02. chapter 3 lexical analysis
02. chapter 3   lexical analysis02. chapter 3   lexical analysis
02. chapter 3 lexical analysis
 
Programming fundamental
Programming fundamentalProgramming fundamental
Programming fundamental
 
Getting started with c++
Getting started with c++Getting started with c++
Getting started with c++
 
Getting started with c++
Getting started with c++Getting started with c++
Getting started with c++
 
IMP PPT- Python programming fundamentals.pptx
IMP PPT- Python programming fundamentals.pptxIMP PPT- Python programming fundamentals.pptx
IMP PPT- Python programming fundamentals.pptx
 
Chapter 13.1.3
Chapter 13.1.3Chapter 13.1.3
Chapter 13.1.3
 

Más de DataminingTools Inc

AI: Introduction to artificial intelligence
AI: Introduction to artificial intelligenceAI: Introduction to artificial intelligence
AI: Introduction to artificial intelligenceDataminingTools Inc
 
Data Mining: Text and web mining
Data Mining: Text and web miningData Mining: Text and web mining
Data Mining: Text and web miningDataminingTools Inc
 
Data Mining: Mining stream time series and sequence data
Data Mining: Mining stream time series and sequence dataData Mining: Mining stream time series and sequence data
Data Mining: Mining stream time series and sequence dataDataminingTools Inc
 
Data Mining: Mining ,associations, and correlations
Data Mining: Mining ,associations, and correlationsData Mining: Mining ,associations, and correlations
Data Mining: Mining ,associations, and correlationsDataminingTools Inc
 
Data Mining: Graph mining and social network analysis
Data Mining: Graph mining and social network analysisData Mining: Graph mining and social network analysis
Data Mining: Graph mining and social network analysisDataminingTools Inc
 
Data warehouse and olap technology
Data warehouse and olap technologyData warehouse and olap technology
Data warehouse and olap technologyDataminingTools Inc
 

Más de DataminingTools Inc (20)

Terminology Machine Learning
Terminology Machine LearningTerminology Machine Learning
Terminology Machine Learning
 
Techniques Machine Learning
Techniques Machine LearningTechniques Machine Learning
Techniques Machine Learning
 
Machine learning Introduction
Machine learning IntroductionMachine learning Introduction
Machine learning Introduction
 
Areas of machine leanring
Areas of machine leanringAreas of machine leanring
Areas of machine leanring
 
AI: Planning and AI
AI: Planning and AIAI: Planning and AI
AI: Planning and AI
 
AI: Logic in AI 2
AI: Logic in AI 2AI: Logic in AI 2
AI: Logic in AI 2
 
AI: Logic in AI
AI: Logic in AIAI: Logic in AI
AI: Logic in AI
 
AI: Learning in AI 2
AI: Learning in AI 2AI: Learning in AI 2
AI: Learning in AI 2
 
AI: Learning in AI
AI: Learning in AI AI: Learning in AI
AI: Learning in AI
 
AI: Introduction to artificial intelligence
AI: Introduction to artificial intelligenceAI: Introduction to artificial intelligence
AI: Introduction to artificial intelligence
 
AI: Belief Networks
AI: Belief NetworksAI: Belief Networks
AI: Belief Networks
 
AI: AI & Searching
AI: AI & SearchingAI: AI & Searching
AI: AI & Searching
 
AI: AI & Problem Solving
AI: AI & Problem SolvingAI: AI & Problem Solving
AI: AI & Problem Solving
 
Data Mining: Text and web mining
Data Mining: Text and web miningData Mining: Text and web mining
Data Mining: Text and web mining
 
Data Mining: Outlier analysis
Data Mining: Outlier analysisData Mining: Outlier analysis
Data Mining: Outlier analysis
 
Data Mining: Mining stream time series and sequence data
Data Mining: Mining stream time series and sequence dataData Mining: Mining stream time series and sequence data
Data Mining: Mining stream time series and sequence data
 
Data Mining: Mining ,associations, and correlations
Data Mining: Mining ,associations, and correlationsData Mining: Mining ,associations, and correlations
Data Mining: Mining ,associations, and correlations
 
Data Mining: Graph mining and social network analysis
Data Mining: Graph mining and social network analysisData Mining: Graph mining and social network analysis
Data Mining: Graph mining and social network analysis
 
Data warehouse and olap technology
Data warehouse and olap technologyData warehouse and olap technology
Data warehouse and olap technology
 
Data Mining: Data processing
Data Mining: Data processingData Mining: Data processing
Data Mining: Data processing
 

LISP: Input And Output

  • 1. Lisp Input and Output
  • 2. overview Read function. Parsing of numbers and symbols Macro characters Input functions Output functions Querying the user
  • 3. Printed representation Lisp presents a representation of most objects in printed representation which is used for input/output purposes. Functions such as print takes a lisp object and send the characters of its printed representation to a stream. The collection of routines that does this is called (Lisp)printer.
  • 4. What read function accepts Lisp reader accepts characters, interpret them as a printed representation of the lisp object, and construct and return such an object. The reader can also be used as a lexical analyzer for a more general user-written parser. The reader is organized as a recursive descent parser.
  • 5.
  • 6. Constituent and escape characters are accumulated to make a token, which is then interpreted as number or symbol.
  • 7. Macro characters trigger the invocation of the functions that can perform arbitrary parsing actions, including recursive invocation of the reader.Every character that appears in the input stream must be one of the following types: Illegal, whitespace, constituents ( [,],{,},?,and !) single escape, multiple escape or macro.
  • 8. Parsing of numbers and symbols When an extended token is read, it is interpreted as a number or symbol. Whitespace, macro or escape character will always be treated as alphabetic within an extended token.
  • 9. Lisp syntax for numbers Number::=integer|ratio|floating-point number Integer::=[sign] {digit}+ [decimal-point] Ratio::= [sign] {digit}+ / {digit}+ Floating-point-number::= [sign] {digit}* decimal-point {digit}+ [exponent]| [sign] {digit}+ [decimal-number {digit}*] exponent Sign::= +|- Decimal-point::= . Digit::= 0|1|2|3|4|5|6|7|8|9 Exponent::= exponent-marker [sign] {digit}+ Exponent-marker::= e|s|f|d|l|E|S|F|D|L
  • 10. Token must satisfy the following requirements: It consists entirely of digits, signs (+ or -), ratio markers (/), decimal points(.), extension characters(^ or _), and number markers. It consists at least one digit. It begins with a digit, sign, decimal point, or extension character. It does not end with a sign. Ex: 1b5000, 777777q, 1.7J, ^-43^, 3.1.2.6 etc.
  • 11. symbols The following are always treated as symbols: *read-base* The value of read base controls the interpretation of tokens by read as being integers or ratios. Its value is the radix in which the integers or ratios are to be read. The value must be any integer from 2 to 36,and it is normally 10. for ex if the *read-base* is set as 16(hexadecimal radix), variables with names such as a,b,f , bad and face will be treated by the reader as numbers. / /5 + 1+ 1- foo+ ab.cd - ^ ^/-
  • 12. *read-supress*if this value is set as nil, the Lisp reader operates normally, when it is not null the most interesting operation of the reader are suppressed. *read-eval* its default value is always t, if *read-eval* is false. Reader macro signals an error.
  • 13. Macro characters When a macro character is encountered, then the function associated with that macro is invoked and may produce an object to be returned. Macro characters are normally defined as follows: The left parenthesis initiates reading a pair of list. The function read is called recursively to read successive objects until a right parenthesis is found to be next in the input stream. A list of objects read are returned.
  • 14. ‘ single-quote provides an abbreviation to make it easier to put constants in the programs. ; is used to write comments. “ double-quote character represents the printed representation of a string. A back-quote is followed by a template, a picture of a data structure to be built. # is dispatching macro-character. It reads an optional digit string and then one more character, and uses that character to select a function to run as a macro-character function.
  • 15. Standard dispatching macro character syntax # reads in a character object that represents a character x. #ame1 reads in as the character object whose name is name1. The name1 should have the syntax of the symbol. # ’ is an abbreviation for (function foo) A series of representations of objects enclosed by #( and )is read as a simple vector of those objects. If unsigned decimal integer appears between the # and (, it specifies explicitly the length of the vector.
  • 16. #:foo requires foo to have a syntax of an unqualified symbol name. It denotes an uninterened symbol whose name is foo. Every time an uninterended symbol is created when this symbol is encountered. #,foo is read as the object resulting from the evaluation of the lisp object represented by foo, which may be the printed representation of any lisp object. #B reads rational in binary(radix 2) ex:#B110113 #o reads rational in octal(radix 8) ex: #o777511 #X reads rational in hexadecimal(radix 16) ex: #xFoo3840
  • 17. #nA constructs an n-dimensional array Ex: #2A ((0 1 5) (foo 2(hot dog))) represents a 2 cross 3 matrix: 0 1 5 f00 2 (hot dog) #s (name slot1 value1 slot2 value2….) denotes a structure. #+ syntax provides a read time conditionality facility; the syntax is #+feature form #- form is equivalent to #+(not feature) form. If feature is true, then this syntax represents a lisp object whose printed representation is form. If the feature is false, then this syntax is effectively white space.
  • 18. The following names are standards across all implementations: Newline, space Rubout  delete character Page the form-feed or page-separator character Tab the tabulate character Return carriage return character Linefeed the line-feed character
  • 19. Read table Read table is the data structure used to control the reader. It has information about the syntax of each character. *read-table* is the current read table To program the reader for a different syntax, begin with the copy of the standard common lisp read table and then customize the individual characters within the copy. Copy-readtable &optional from-readtable to read-table
  • 20. readtable case readtable is a function used to control the readers interpretation of the case. It provides access to a slot in the read table. The possible values of the slots are: :upcase replaceable characters are converted to upper case :downcase replaceable characters are converted into lower case :preserve the cases of all characters remain unchanged :invert all replicable characters of same case are converted to opposite case
  • 21.
  • 22. eof-error-p argument controls if the input is from a file, and end of file is reached.
  • 23. If eof-error-p is true , an error will be signaled at the end of the file. If it is false, then no error is signaled, instead it returns eof-value.
  • 24.
  • 25.
  • 26. Output functions that operate on stream of functions These functions take an optional argument output-stream(defaults to variable *standard-output*) on where to send the output. write object &key :stream :escape :radix :base :circle :pretty :level :length :case :gensym :array: readable: right-margin :miser-width :lines and :pprint-dispatch the printed representation of the object is written to the output stream specified by :stream, which defaults to the value *standard-output*  The other keyword arguments specify values used to control the generation of the printed representation.
  • 27. Prin1 object &optional output-stream prin1 outputs the printed representation of object to output-stream. Print object &optional output-stream printed representation of the object is preceded by newline and followed by a space. PPrin1 object &optional output-stream trailing space is omitted and the object is printed with the *print-pretty* flag non-nil to produce “pretty” output. Princ object &optional output-stream  Is similar to prin1 except that the output has no escape characters.
  • 28. Write-char character &optional output-stream outputs the character to the output stream and returns the character Write-string string &optional output-stream &key :start :end Write-line string &optional output-stream &key :start :end writes the character of the specified substring to the output-stream. The :start and :end delimit a substring of string in usual manner.  write-lined does the same thing but then outputs a new-line afterwards.
  • 29.
  • 30.
  • 31. ~D, An arg, should be an integer is printed in decimal radix. Few examples for format function: (format nil “foo”) “foo” (setq x 5) (format nil “The answer is ~D.”, x)”The answer is 5.” (format nil “The answer is ~3D.”, x) “The answer is 5.”
  • 32. Querying the user The following functions provide a convenient interface for asking the questions of the user. y-or-n-p &optional format-string &rest arguments This predicate is used for asking the user a question whose answer is either yes or no. It types a message if supplied. All input and output is performed using the stream in the global variable *query-io*
  • 33. Ex: (y-or-n-p “Produce Listing file?”) opens a pop-up asking “Produce Listing file?” with two options “Yes” and ‘no”. Returns T on yes else returns NIL. (y-or-n-p “Cannot connect to network host ~S. Retry?” host) Y-or-n-p must be used when the user waiting to be questioned before preceding further.