X-Git-Url: http://gitweb.michael.orlitzky.com/?a=blobdiff_plain;f=mjo-listing.tex;h=ccd0d9cf0fb23aaf14f40177959df3a41ed95473;hb=66a672c6c1657ad96422fcdb4828bc5d9a108ab0;hp=aa24b5cc5cadda0490b34277afc43ccb9f9cbe7a;hpb=049c836f042cd24d586e35b2d214b8ac00e2e215;p=mjotex.git diff --git a/mjo-listing.tex b/mjo-listing.tex index aa24b5c..ccd0d9c 100644 --- a/mjo-listing.tex +++ b/mjo-listing.tex @@ -10,8 +10,17 @@ % x % \end{tcblisting} % -\usepackage{listings} -\usepackage{tcolorbox} +\ifx\havemjolisting\undefined +\def\havemjolisting{1} + + +\ifx\lstset\undefined + \usepackage{listings} +\fi + +\ifx\tcbuselibrary\undefined + \usepackage{tcolorbox} +\fi % Tell tcolorbox to use ``listings'' within the boxes. \tcbuselibrary{listings} @@ -27,7 +36,8 @@ \lstset{% basicstyle=\ttfamily\small, columns=fullflexible, - keepspaces=true + keepspaces=true, + showstringspaces=false } % Define a style for interactive sage prompt listings. @@ -37,3 +47,23 @@ keywordstyle=\color{brilliantlavender}, stringstyle=\color{brilliantgreen} } + + +% Input a SageMath example code listing from a file. You generally +% want these to be in separate files so that the build system can test +% them automatically. +% +% The sole argument is the "name" of the listing, which ultimately +% just identifies a file named "sage_listings/.listing". +\newtcbinputlisting{\sagelisting}[2][]{% + colback=codebg,% + coltext=codefg,% + enlarge bottom finally by=\baselineskip,% + enlarge top initially by=\baselineskip,% + left=2em,% + listing only,% + listing options={language=sage,style=sage},% + listing file=sage_listings/#2.listing,% + #1} + +\fi