X-Git-Url: http://gitweb.michael.orlitzky.com/?p=mjotex.git;a=blobdiff_plain;f=mjo-listing.tex;h=cf3fc582a1d1e7fa8aefb8a62e7488477ade3dbf;hp=aa24b5cc5cadda0490b34277afc43ccb9f9cbe7a;hb=f9205a3b883c08499edfdd3f9d1a6170a6fc6755;hpb=049c836f042cd24d586e35b2d214b8ac00e2e215 diff --git a/mjo-listing.tex b/mjo-listing.tex index aa24b5c..cf3fc58 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,20 @@ 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". +\newcommand*{\sagelisting}[1]{\tcbinputlisting{listing only,% + colback=codebg,% + coltext=codefg,% + left=2em,% + listing options={language=sage,style=sage},% + listing file=sage_listings/#1.listing}} + + +\fi