]> gitweb.factorcode.org Git - factor.git/commitdiff
Revert "html.streams: use style-stream."
authorJohn Benediktsson <mrjbq7@gmail.com>
Tue, 25 Feb 2020 20:10:42 +0000 (12:10 -0800)
committerJohn Benediktsson <mrjbq7@gmail.com>
Tue, 25 Feb 2020 20:10:42 +0000 (12:10 -0800)
This reverts commit 6f9a7dcc9ecab062314dec58a4b00abdafd1583f.

basis/html/streams/streams.factor

index 026a39db0077ed0b038092e088fe2775911b4d20..cf413dde1112f30204820f6756ef0c978532b182 100644 (file)
@@ -1,8 +1,9 @@
 ! Copyright (C) 2004, 2009 Slava Pestov.
 ! See http://factorcode.org/license.txt for BSD license.
 USING: accessors assocs combinators destructors fry html io
-io.styles kernel macros make math math.parser sequences
-splitting strings xml.syntax ;
+io.backend io.pathnames io.styles kernel macros make math
+math.order math.parser namespaces sequences strings words
+splitting xml xml.syntax ;
 IN: html.streams
 
 GENERIC: url-of ( object -- url )
@@ -12,21 +13,20 @@ M: object url-of drop f ;
 TUPLE: html-writer data ;
 INSTANCE: html-writer output-stream
 
-: <html-writer> ( -- html-writer )
-    html-writer new V{ } clone >>data ;
-
-: with-html-writer ( quot -- xml )
-    <html-writer> [ swap with-output-stream* ] keep data>> ; inline
-
 <PRIVATE
 
-TUPLE: html-sub-stream < style-stream parent ;
+: new-html-writer ( class -- html-writer )
+    new V{ } clone >>data ; inline
+
+TUPLE: html-sub-stream < html-writer style parent ;
 
 : new-html-sub-stream ( style stream class -- stream )
-    [ <html-writer> ] 3dip boa ; inline
+    new-html-writer
+        swap >>parent
+        swap >>style ; inline
 
 : end-sub-stream ( substream -- string style stream )
-    [ stream>> data>> ] [ style>> ] [ parent>> ] tri ;
+    [ data>> ] [ style>> ] [ parent>> ] tri ;
 
 : object-link-tag ( xml style -- xml )
     presented of [ url-of [ simple-link ] when* ] when* ;
@@ -173,10 +173,16 @@ M: html-writer make-cell-stream
 M: html-writer stream-write-table
     [
         table-style swap [
-            [ stream>> data>> [XML <td valign="top" style=<->><-></td> XML] ] with map
+            [ data>> [XML <td valign="top" style=<->><-></td> XML] ] with map
             [XML <tr><-></tr> XML]
         ] with map
         [XML <table style="display: inline-table; border-collapse: collapse;"><-></table> XML]
     ] emit-html ;
 
 M: html-writer dispose drop ;
+
+: <html-writer> ( -- html-writer )
+    html-writer new-html-writer ;
+
+: with-html-writer ( quot -- xml )
+    <html-writer> [ swap with-output-stream* ] keep data>> ; inline