From 93fc8ffe1c34d3abb4d0ee72b6858e181c228378 Mon Sep 17 00:00:00 2001 From: Offray Luna Date: Thu, 25 Apr 2024 08:49:23 -0500 Subject: [PATCH] Resyncing after detachemed. --- .../BaselineOfMiniDocs.class.st | 15 ++-- src/MiniDocs/DataFrame.extension.st | 27 +++++++ src/MiniDocs/LeDatabase.extension.st | 30 +++++--- src/MiniDocs/LeMiniDocsImport.class.st | 13 ++-- src/MiniDocs/LePage.extension.st | 70 +++++++++++++++---- src/MiniDocs/LePictureSnippet.extension.st | 2 +- src/MiniDocs/LeTextSnippet.extension.st | 9 ++- src/MiniDocs/LeTextualSnippet.extension.st | 10 +++ src/MiniDocs/Markdeep.class.st | 14 ++-- src/MiniDocs/Markdown.class.st | 6 +- src/MiniDocs/NanoID.class.st | 4 ++ src/MiniDocs/Nimble.class.st | 17 +++-- src/MiniDocs/Pandoc.class.st | 21 ++++++ src/MiniDocs/Pandoc.extension.st | 11 +++ src/MiniDocs/String.extension.st | 32 +++++++-- src/MiniDocs/XMLElement.extension.st | 50 +++++++++---- src/MiniDocs/YQ.class.st | 16 +++-- src/PetitMarkdown/PPCMLink.class.st | 5 +- 18 files changed, 273 insertions(+), 79 deletions(-) create mode 100644 src/MiniDocs/Pandoc.extension.st diff --git a/src/BaselineOfMiniDocs/BaselineOfMiniDocs.class.st b/src/BaselineOfMiniDocs/BaselineOfMiniDocs.class.st index 6b278ec..5ec783b 100644 --- a/src/BaselineOfMiniDocs/BaselineOfMiniDocs.class.st +++ b/src/BaselineOfMiniDocs/BaselineOfMiniDocs.class.st @@ -13,14 +13,16 @@ BaselineOfMiniDocs >> baseline: spec [ "Dependencies" self setUpTeapot: spec. self setUpPetitParser: spec. - self setUpLepiterBuildingBlocs: spec. + "LepiterBuildingBlocs commented while resolving the conflict with the internal gtoolkit renaming." + "self setUpLepiterBuildingBlocs: spec" spec baseline: 'Mustache' with: [ spec repository: 'github://noha/mustache' ]; baseline: 'Temple' with: [ spec repository: 'github://astares/Pharo-Temple/src' ]; - baseline: 'Tealight' with: [ spec repository: 'github://astares/Tealight:main/src' ]. + baseline: 'Tealight' with: [ spec repository: 'github://astares/Tealight:main/src' ]; + baseline: 'DataFrame' with: [ spec repository: 'github://PolyMathOrg/DataFrame/src' ]. "self fossil: spec." - "self xmlParserHTML: spec" + self xmlParserHTML: spec. "Packages" spec @@ -28,10 +30,11 @@ BaselineOfMiniDocs >> baseline: spec [ package: 'MiniDocs' with: [ spec requires: #( 'Mustache' 'Temple' "Templating" - 'Teapot' 'Tealight' "Web server" + 'Teapot' 'Tealight' "Web server" 'PetitMarkdown' 'PetitParser' "Parsers" 'DataFrame' "Tabular data")]. - +. + "Groups" ]. @@ -90,7 +93,7 @@ BaselineOfMiniDocs >> xmlParserHTML: spec [ spec baseline: 'XMLParserHTML' with: [ spec - repository: 'github://pharo-contributions/XML-XMLParserHTML/src'; + repository: 'github://ruidajo/XML-XMLParserHTML/src'; loads: #('ALL')]; import: 'XMLParserHTML' ] diff --git a/src/MiniDocs/DataFrame.extension.st b/src/MiniDocs/DataFrame.extension.st index 75cfb01..47bcc09 100644 --- a/src/MiniDocs/DataFrame.extension.st +++ b/src/MiniDocs/DataFrame.extension.st @@ -1,5 +1,26 @@ Extension { #name : #DataFrame } +{ #category : #'*MiniDocs' } +DataFrame >> asMarkdown [ + | response | + response := '' writeStream. + self columnNames do: [ :name | response nextPutAll: '| ' , name , ' ' ]. + response + nextPutAll: '|'; + cr. + self columns size timesRepeat: [ response nextPutAll: '|---' ]. + response + nextPutAll: '|'; + cr. + self asArrayOfRows + do: [ :row | + row do: [ :cell | response nextPutAll: '| ' , cell asString , ' ' ]. + response + nextPutAll: '|'; + cr ]. + ^ response contents accentedCharactersCorrection withInternetLineEndings. +] + { #category : #'*MiniDocs' } DataFrame >> viewDataFor: aView [ @@ -17,3 +38,9 @@ DataFrame >> viewDataFor: aView [ ]. ^ columnedList ] + +{ #category : #'*MiniDocs' } +DataFrame >> webView [ + + ^ Pandoc convertString: self asMarkdown from: 'markdown' to: 'html' +] diff --git a/src/MiniDocs/LeDatabase.extension.st b/src/MiniDocs/LeDatabase.extension.st index 60c7c3f..939688e 100644 --- a/src/MiniDocs/LeDatabase.extension.st +++ b/src/MiniDocs/LeDatabase.extension.st @@ -44,14 +44,18 @@ LeDatabase >> addPageFromMarkdeep: markdeepDocTree withRemote: externalDocLocati remoteMetadata at: 'origin' put: externalDocLocation. dataSnippets := self sanitizeMarkdeepSnippets: divSnippets withMetadata: remoteMetadata. snippets := dataSnippets collect: [ :each | each asLepiterSnippet ]. - page := LePage new - title: (remoteMetadata at: 'title'); - basicUid: (UUID fromString36: (remoteMetadata at: 'id')); - createTime: (LeTime new time: (remoteMetadata at: 'created') asDateAndTime); - editTime: (LeTime new time: (remoteMetadata at: 'modified') asDateAndTime); - latestEditTime: (LeTime new time: (remoteMetadata at: 'modified') asDateAndTime); - createEmail: (remoteMetadata at: 'creator'); - editEmail: (remoteMetadata at: 'modifier'). + page := LePage new. + page + title: (remoteMetadata at: 'title' ifAbsent: [ page detectMarkdeepTitleFrom: markdeepDocTree ]); + basicUid: (UUID fromString36: (remoteMetadata at: 'id' ifAbsent: [UUID new asString36])); + createTime: (LeTime new + time: (remoteMetadata at: 'created' ifAbsent: [ DateAndTime now]) asDateAndTime); + editTime: (LeTime new + time: (remoteMetadata at: 'modified' ifAbsent: [ DateAndTime now]) asDateAndTime); + latestEditTime: (LeTime new + time: (remoteMetadata at: 'modified' ifAbsent: [ DateAndTime now]) asDateAndTime); + createEmail: (remoteMetadata at: 'creator' ifAbsent: [ 'unknown' ]); + editEmail: (remoteMetadata at: 'modifier' ifAbsent: [ 'unknown' ]). snippets do: [ :snippet | "| currentParent |" page addSnippet: snippet. "currentParent := page detectParentSnippetWithUid: (snippet metadata at: 'parent'). @@ -184,6 +188,16 @@ LeDatabase >> gtViewErrorDetailsOn: aView withKey: erroKey [ ]. ] +{ #category : #'*MiniDocs' } +LeDatabase >> importDocumentFrom: aURL [ + | doc | + "Using file extension in URL as a cheap (non-robuts) way of detecting the kind of document. + Better file type detection should be implemented in the future." + (aURL endsWith: '.md.html') ifTrue: [ ^ self addPageFromMarkdeepUrl: aURL ]. + doc := HedgeDoc fromLink: aURL asString. + ^ self addPage: doc asLePage +] + { #category : #'*MiniDocs' } LeDatabase >> importErrorForLocal: page withRemote: externalDocLocation [ diff --git a/src/MiniDocs/LeMiniDocsImport.class.st b/src/MiniDocs/LeMiniDocsImport.class.st index b3dbc98..b06e551 100644 --- a/src/MiniDocs/LeMiniDocsImport.class.st +++ b/src/MiniDocs/LeMiniDocsImport.class.st @@ -42,22 +42,25 @@ LeMiniDocsImport >> createURLeditable [ text: 'Document link'; switchToEditor. editable when: BrEditorAcceptWish do: [ :aWish | - self importHedgedoc: aWish text asString. + self importDocumentFrom: aWish text asString. ]. base addChild: editable. ^ base ] +{ #category : #accessing } +LeMiniDocsImport >> database [ + ^ database +] + { #category : #accessing } LeMiniDocsImport >> database: aLeDatabase [ database := aLeDatabase ] { #category : #accessing } -LeMiniDocsImport >> importHedgedoc: aURL [ - | doc | - doc := HedgeDoc fromLink: aURL asString. - ^ database addPage: doc asLePage +LeMiniDocsImport >> importDocumentFrom: aURL [ + ^ self database importDocumentFrom: aURL. ] { #category : #accessing } diff --git a/src/MiniDocs/LePage.extension.st b/src/MiniDocs/LePage.extension.st index 7426bae..fa264ac 100644 --- a/src/MiniDocs/LePage.extension.st +++ b/src/MiniDocs/LePage.extension.st @@ -26,15 +26,16 @@ LePage >> asMarkdeep [ markdeep := Markdeep new title: self title; body: bodyStream contents; + metadata: self metadata; file: self storage / self markdeepFileName; navTop: self navTop. - "self exportMetadataToHead: markdeep." self metadata at: 'authors' ifPresent: [ :author | markdeep metadata at: 'authors' put: author ]. self metadata at: 'version' ifPresent: [ :version | markdeep metadata at: 'version' put: version ]. + markdeep head: nil. ^ markdeep ] @@ -49,17 +50,12 @@ LePage >> asMarkdown [ | bodyStream markdown | bodyStream := '' writeStream. bodyStream - nextPutAll: '---'; - nextPutAll: String lf. - self metadata keysAndValuesDo: [ :k :v | - bodyStream - nextPutAll: k , ': "' , v, '"'; - nextPutAll: String lf ]. - bodyStream nextPutAll: '---' , String lf , String lf, String lf. - bodyStream nextPutAll: '# ', self title, String lf , String lf. + nextPutAll: '# ', self title; cr; cr. self preorderTraversal do: [ :snippet | bodyStream nextPutAll: snippet asMarkdown ]. - markdown := Markdown new contents: bodyStream contents. + markdown := Markdown new + contents: bodyStream contents demoteMarkdownHeaders; + metadata: (self metadata at: 'original' ifAbsentPut: Dictionary new). ^ markdown ] @@ -67,7 +63,21 @@ LePage >> asMarkdown [ LePage >> asMarkdownFile [ | folder | folder := self storage. - ^ MarkupFile exportAsFileOn: folder / self markdownFileName containing: self asMarkdown contents + ^ MarkupFile exportAsFileOn: folder / self markdownFileName containing: self asMarkdownWithMetadataWrappers contents +] + +{ #category : #'*MiniDocs' } +LePage >> asMarkdownWithMetadataWrappers [ + | bodyStream markdown | + bodyStream := '' writeStream. + bodyStream + nextPutAll: '# ', self title; cr; cr. + self preorderTraversal + do: [ :snippet | bodyStream nextPutAll: snippet asMarkdownWithMetadataWrappers ]. + markdown := Markdown new + contents: bodyStream contents demoteMarkdownHeaders; + metadata: (self metadata at: 'original' ifAbsentPut: Dictionary new). + ^ markdown ] { #category : #'*MiniDocs' } @@ -85,6 +95,14 @@ LePage >> defaultPandocTemplate [ ^ FileLocator home / '.pandoc' / 'templates' / 'clean-menu-mod.html' ] +{ #category : #'*MiniDocs' } +LePage >> detectMarkdeepTitleFrom: xmlSubtree [ + | titleLine | + titleLine := (xmlSubtree nodesCollect: [:node | node contentString ]) first lines + detect: [:line | line includesSubstring: ' **'] ifNone: ['Untitled']. + ^ titleLine trimmed trimBoth: [:char | char = $* ] +] + { #category : #'*MiniDocs' } LePage >> detectParentSnippetWithUid: uidString [ uidString = self uid asString36 ifTrue: [ ^ self ]. @@ -163,7 +181,7 @@ LePage >> markdownFileName [ { #category : #'*MiniDocs' } LePage >> metadata [ - ^ self options at: 'metadata' ifAbsentPut: [ self metadataUpdate] + ^ self metadataUpdate ] { #category : #'*MiniDocs' } @@ -173,7 +191,7 @@ LePage >> metadataUpdate [ at: 'id' put: self uidString; at: 'title' put: self contentAsString; at: 'created' put: self createTime greaseString; - at: 'modified' put: self latestEditTime greaseString; + at: 'modified' put: self getLatestEditTime greaseString; at: 'creator' put: self createEmail greaseString; at: 'modifier' put: self editEmail greaseString; yourself @@ -188,6 +206,19 @@ LePage >> navTop [ ifTrue: [ ^ topNavFile contents ] ] +{ #category : #'*MiniDocs' } +LePage >> olderChild [ + "I provide the last edited child node. + I'm useful to recalculate the age of a notebook." + | response| + response := self preorderTraversal first. + self preorderTraversal do: [:current | + current editTime >= response editTime + ifTrue: [ response := current ] + ]. + ^ response +] + { #category : #'*MiniDocs' } LePage >> options [ ^ options @@ -287,3 +318,16 @@ LePage >> uiRefreshWebPreviewButtonFor: anAction [ "TODO: If Chrome/Chromium are not installed, I should execute:" "WebBrowser openOn: self page localHostAddress" ] ] + +{ #category : #'*MiniDocs' } +LePage >> youngerChild [ + "I provide the first create child node. + I'm useful to recalculate the age of a notebook." + | response| + response := self preorderTraversal first. + self preorderTraversal do: [:current | + current createTime <= response createTime + ifTrue: [ response := current ] + ]. + ^ response +] diff --git a/src/MiniDocs/LePictureSnippet.extension.st b/src/MiniDocs/LePictureSnippet.extension.st index 77df79c..12dedb0 100644 --- a/src/MiniDocs/LePictureSnippet.extension.st +++ b/src/MiniDocs/LePictureSnippet.extension.st @@ -26,7 +26,7 @@ LePictureSnippet >> asMarkdeep [ ] { #category : #'*MiniDocs' } -LePictureSnippet >> asMarkdown [ +LePictureSnippet >> asMarkdownWithMetadataWrappers [ ^ self asMarkdeep ] diff --git a/src/MiniDocs/LeTextSnippet.extension.st b/src/MiniDocs/LeTextSnippet.extension.st index 02e62ab..5a222a6 100644 --- a/src/MiniDocs/LeTextSnippet.extension.st +++ b/src/MiniDocs/LeTextSnippet.extension.st @@ -2,9 +2,14 @@ Extension { #name : #LeTextSnippet } { #category : #'*MiniDocs' } LeTextSnippet >> asLePage [ - | page | + | page title currentSnippet | + title := self contentAsString markdownHeaders associations first value. + title := (title trimBoth: [:char | char = $# ]) trimmed. page := LePage new - initializeTitle: self contentAsString. + initializeTitle: title. + currentSnippet := LeTextSnippet new + string: self contentAsString. + page addSnippet: currentSnippet. self database addPage: page. self childrenDo: [:child | child moveToPageTitled: page title diff --git a/src/MiniDocs/LeTextualSnippet.extension.st b/src/MiniDocs/LeTextualSnippet.extension.st index ee61c3a..dc850f4 100644 --- a/src/MiniDocs/LeTextualSnippet.extension.st +++ b/src/MiniDocs/LeTextualSnippet.extension.st @@ -24,6 +24,16 @@ LeTextualSnippet >> asMarkdeep [ { #category : #'*MiniDocs' } LeTextualSnippet >> asMarkdown [ + + | output | + output := '' writeStream. + output + nextPutAll: self contentAsStringCustomized; lf. + ^ output contents +] + +{ #category : #'*MiniDocs' } +LeTextualSnippet >> asMarkdownWithMetadataWrappers [ "Inspired by Alpine.js and Assembler CSS 'x-' properties, we are going to use 'st-' properties as a way to extend divs metadata regarding its contents." | output | diff --git a/src/MiniDocs/Markdeep.class.st b/src/MiniDocs/Markdeep.class.st index 8ccb46e..5232639 100644 --- a/src/MiniDocs/Markdeep.class.st +++ b/src/MiniDocs/Markdeep.class.st @@ -30,7 +30,7 @@ Markdeep class >> fromPubPubTOC: orderedDictionary folder: folder index: ordina ] { #category : #accessing } -Markdeep >> asMarkdown [ +Markdeep >> asMarkdownWithMetadataWrappers [ ^ Markdown new metadata: self metadata; body: self body; @@ -294,6 +294,11 @@ Markdeep >> headContents [ nextPutAll: line; nextPut: Character lf ]. + self metadata keysAndValuesDo: [:k :v | + k = 'lang' + ifTrue: [ stream nextPutAll: ' '; cr. ] + ifFalse: [ stream nextPutAll: ' '; cr. ] + ]. stream nextPutAll: ''; nextPut: Character lf. @@ -378,13 +383,6 @@ Markdeep >> options [ ] ] -{ #category : #printing } -Markdeep >> printOn: aStream [ - super printOn: aStream. - aStream - nextPutAll: '( ', self title, ' )' -] - { #category : #'instance creation' } Markdeep >> processMarkdownFor: aFileReference [ "comment stating purpose of message" diff --git a/src/MiniDocs/Markdown.class.st b/src/MiniDocs/Markdown.class.st index 5bbfd1e..e50190e 100644 --- a/src/MiniDocs/Markdown.class.st +++ b/src/MiniDocs/Markdown.class.st @@ -149,7 +149,7 @@ Markdown >> fromFile: aFileReference [ { #category : #'instance creation' } Markdown >> fromString: markdownString [ - self metadata: markdownString yamlMetadata. + (self metadata) at: 'original' put: markdownString yamlMetadata. self body: markdownString contentsWithoutYAMLMetadata ] @@ -208,9 +208,11 @@ Markdown >> options [ { #category : #accessing } Markdown >> printOn: aStream [ + | response | super printOn: aStream. + response := self title ifNil: [ 'Untitled' ]. aStream - nextPutAll: '( ', self title , ' )' + nextPutAll: '( ', response , ' )' ] { #category : #accessing } diff --git a/src/MiniDocs/NanoID.class.st b/src/MiniDocs/NanoID.class.st index f29983b..1ccf498 100644 --- a/src/MiniDocs/NanoID.class.st +++ b/src/MiniDocs/NanoID.class.st @@ -28,6 +28,8 @@ NanoID class >> binaryFile [ { #category : #accessing } NanoID class >> generate [ self binaryFile exists ifFalse: [ NanoID install]. + Smalltalk os isWindows + ifTrue: [ ^ (LibC resultOfCommand:self binaryFile fullName) copyWithoutAll: (Character lf asString) ]. OSSUnixSubprocess new command: self binaryFile fullName; redirectStdout; @@ -41,6 +43,8 @@ NanoID class >> install [ IMPORTANT: Nimble, Nim's package manager should be installed, as this process doesn't verify its proper installation." self binaryFile exists ifTrue: [ ^ MiniDocs appFolder ]. Nimble install: 'nanoid'. + Smalltalk os isWindows + ifTrue: [ ^ LibC resultOfCommand: 'nanoid c ',self scriptSourceCode fullName ]. OSSUnixSubprocess new command: 'nim'; arguments: {'c'. self scriptSourceCode fullName}; diff --git a/src/MiniDocs/Nimble.class.st b/src/MiniDocs/Nimble.class.st index fdd9e19..78952aa 100644 --- a/src/MiniDocs/Nimble.class.st +++ b/src/MiniDocs/Nimble.class.st @@ -20,6 +20,8 @@ Nimble class >> detect: packageName [ Nimble class >> install: packageName [ (self detect: packageName) ifTrue: [ ^ self ]. self installPackagesList. + Smalltalk os isWindows + ifTrue: [ ^ LibC runCommand: 'nimble install ', packageName ]. OSSUnixSubprocess new command: 'nimble'; arguments: {'install'. @@ -41,11 +43,16 @@ Nimble class >> installPackagesList [ (FileLocator home / '.nimble' / 'packages_official.json') exists ifTrue: [ ^ self ]. - OSSUnixSubprocess new - command: 'nimble'; - arguments: #('refresh'); - redirectStdout; - runAndWaitOnExitDo: [ :process :outString | ^ outString ] + (Smalltalk os isUnix or: [ Smalltalk os isMacOS ]) + ifTrue: [ + OSSUnixSubprocess new + command: 'nimble'; + arguments: #('refresh'); + redirectStdout; + runAndWaitOnExitDo: [ :process :outString | ^ outString ]. + ]. + Smalltalk os isWindows + ifTrue: [ ^ LibC resultOfCommand: 'nimble refresh' ] ] { #category : #accessing } diff --git a/src/MiniDocs/Pandoc.class.st b/src/MiniDocs/Pandoc.class.st index f0d6bdd..34cda62 100644 --- a/src/MiniDocs/Pandoc.class.st +++ b/src/MiniDocs/Pandoc.class.st @@ -10,6 +10,16 @@ Class { #category : #'MiniDocs-Core' } +{ #category : #'*MiniDocs' } +Pandoc class >> convertString: aString from: inputFormat to: outputFormat [ + OSSUnixSubprocess new + shellCommand: 'echo "', aString , '" | pandoc -f ', inputFormat,' -t ', outputFormat; + redirectStdout; + runAndWaitOnExitDo: [ :command :outString | + ^ outString + ]. +] + { #category : #'as yet unclassified' } Pandoc class >> downloadLuaFilters [ self luaFilters do: [ :filter | | filterUrl | @@ -61,6 +71,17 @@ Pandoc class >> extractImagesInUnixFor: aFileReference withFilter: aLuaFilter [ ] ] +{ #category : #accessing } +Pandoc class >> htmlStringToMarkdown: aString [ + +OSSUnixSubprocess new + shellCommand: 'echo "', aString , '" | pandoc -f markdown -t html'; + redirectStdout; + runAndWaitOnExitDo: [ :command :outString | + ^ outString + ]. +] + { #category : #converters } Pandoc class >> htmlToMarkdown: inputFile [ diff --git a/src/MiniDocs/Pandoc.extension.st b/src/MiniDocs/Pandoc.extension.st new file mode 100644 index 0000000..0fbe3cf --- /dev/null +++ b/src/MiniDocs/Pandoc.extension.st @@ -0,0 +1,11 @@ +Extension { #name : #Pandoc } + +{ #category : #'*MiniDocs' } +Pandoc class >> convertString: aString from: inputFormat to: outputFormat [ + OSSUnixSubprocess new + shellCommand: 'echo "', aString , '" | pandoc -f ', inputFormat,' -t ', outputFormat; + redirectStdout; + runAndWaitOnExitDo: [ :command :outString | + ^ outString + ]. +] diff --git a/src/MiniDocs/String.extension.st b/src/MiniDocs/String.extension.st index 1b775c0..3c7f8ac 100644 --- a/src/MiniDocs/String.extension.st +++ b/src/MiniDocs/String.extension.st @@ -51,6 +51,15 @@ String >> deleteYAMLMetadata [ ^ newContents contents. ] +{ #category : #'*MiniDocs' } +String >> demoteMarkdownHeaders [ + | response | + response := self contents lines. + self markdownHeaders associations allButFirstDo: [ :assoc | + response at: assoc key put: '#', assoc value ]. + ^ response asStringWithCr withInternetLineEndings +] + { #category : #'*MiniDocs' } String >> detectYAMLMetadata [ | lines | @@ -62,15 +71,26 @@ String >> detectYAMLMetadata [ ] { #category : #'*MiniDocs' } -String >> promoteMarkdownHeaders [ - | headers response | - response := self contents. - headers := (LeTextSnippet string: response) ast // #LeHeaderNode collect: [ :each | each headerFullName asString ]. - headers do: [ :each | - response := response copyReplaceAll: each with: each allButFirst ]. +String >> markdownHeaders [ + | response headers | + headers := (LeTextSnippet string: self contents) ast // #LeHeaderNode collect: [ :each | each headerFullName asString ]. + response := OrderedDictionary new. + self lines doWithIndex: [:line :index | + (line beginsWithAnyOf: headers) + ifTrue: [ response at: index put: line ] + ]. ^ response ] +{ #category : #'*MiniDocs' } +String >> promoteMarkdownHeaders [ + | response | + response := self contents lines. + self markdownHeaders associationsDo: [ :assoc | + response at: assoc key put: assoc value allButFirst ]. + ^ response asStringWithCr withInternetLineEndings +] + { #category : #'*MiniDocs' } String >> romanizeAccents [ | modified corrections | diff --git a/src/MiniDocs/XMLElement.extension.st b/src/MiniDocs/XMLElement.extension.st index 04179db..895d5f6 100644 --- a/src/MiniDocs/XMLElement.extension.st +++ b/src/MiniDocs/XMLElement.extension.st @@ -9,23 +9,45 @@ XMLElement >> asSnippetDictionary [ ^ response ] +{ #category : #'*MiniDocs' } +XMLElement >> extractMarkdownImageLinkData [ + | linkParserNodes sanitizedText linkParser | + linkParser := (PPCommonMarkBlockParser parse: (self contentString trimBoth: [:each | each = Character lf]) allButFirst) + accept: CMBlockVisitor new. + linkParserNodes := linkParser children first children. + linkParserNodes size = 1 + ifTrue: [ sanitizedText := linkParserNodes first label text ] + ifFalse: [ sanitizedText := '' writeStream. + linkParserNodes allButLast + do: [ :each | + each className = 'PPCMText' + ifTrue: [ sanitizedText nextPutAll: each text allButFirst ]. + each className = 'PPCMLink' + ifTrue: [ sanitizedText nextPutAll: each printString ] ]. + sanitizedText := sanitizedText contents ]. + ^ {sanitizedText . self contentString } +] + { #category : #'*MiniDocs' } XMLElement >> sanitizedContent [ | className sanitizedText | className := self attributes at: 'st-class'. - ((className = 'LeTextSnippet') or: [className = 'LePictureSnippet']) - ifTrue: [ - sanitizedText := self contentString. - sanitizedText := sanitizedText allButFirst. - sanitizedText := sanitizedText allButLast. - ]. - (className = 'LePharoSnippet') ifTrue: [ | joinedText | - sanitizedText := self contentString lines. - sanitizedText := sanitizedText copyFrom: 4 to: sanitizedText size -2. - joinedText := '' writeStream. - sanitizedText do: [ :line | joinedText nextPutAll: line; nextPut: Character lf ]. - sanitizedText := joinedText contents allButLast. - ]. + className = 'LeTextSnippet' + ifTrue: [ sanitizedText := self contentString. + sanitizedText := sanitizedText allButFirst. + sanitizedText := sanitizedText allButLast ]. + className = 'LePharoSnippet' + ifTrue: [ | joinedText | + sanitizedText := self contentString lines. + sanitizedText := sanitizedText copyFrom: 4 to: sanitizedText size - 2. + joinedText := '' writeStream. + sanitizedText + do: [ :line | + joinedText + nextPutAll: line; + nextPut: Character lf ]. + sanitizedText := joinedText contents allButLast ]. + className = 'LePictureSnippet' + ifTrue: [ sanitizedText := self extractMarkdownImageLinkData ]. ^ sanitizedText - ] diff --git a/src/MiniDocs/YQ.class.st b/src/MiniDocs/YQ.class.st index 8b0eacf..7d64782 100644 --- a/src/MiniDocs/YQ.class.st +++ b/src/MiniDocs/YQ.class.st @@ -33,12 +33,16 @@ YQ class >> jsonToYaml: aDictionary [ | jsonFile | self binaryFile exists ifFalse: [ YQ install]. jsonFile := MarkupFile exportAsFileOn: FileLocator temp / 'data.json' containing: aDictionary. - OSSUnixSubprocess new - shellCommand: 'cat ', jsonFile fullName,' | yq -y'; - redirectStdout; - runAndWaitOnExitDo: [ :command :outString | - ^ outString - ]. + (Smalltalk os isUnix or: [ Smalltalk os isMacOS ]) + ifTrue: [ + OSSUnixSubprocess new + shellCommand: 'cat ', jsonFile fullName,' | yq -y'; + redirectStdout; + runAndWaitOnExitDo: [ :command :outString | + ^ outString + ]]. + Smalltalk os isWindows + ifTrue: [ ^ LibC resultOfCommand: 'yq -p=json ', jsonFile fullName ]. ] { #category : #accessing } diff --git a/src/PetitMarkdown/PPCMLink.class.st b/src/PetitMarkdown/PPCMLink.class.st index 3ae375b..856b2ee 100644 --- a/src/PetitMarkdown/PPCMLink.class.st +++ b/src/PetitMarkdown/PPCMLink.class.st @@ -39,9 +39,8 @@ PPCMLink >> printOn: aStream [ super initialize. ^ aStream nextPutAll: - self label text, - ' -> ', - self destination + '[',self label text,']', + '(',self destination,')' ] { #category : #accessing } -- 2.30.2