;ELC���
;;; Compiled
;;; in Emacs version 28.0.50
;;; with all optimizations.



(byte-code "\300\301!\210\300\302!\210\303\304\305\306\307\310\311\312\313\314\315\316&\210\317\320\321\322\323\324\325\326\327&\207" [require ox-md ox-publish custom-declare-group org-export-gfm nil "Options specific to Markdown export back-end." :tag "Org Github Flavored Markdown" :group org-export :version "24.4" :package-version (Org . "8.0") org-export-define-derived-backend gfm md :filters-alist ((:filter-parse-tree . org-md-separate-elements)) :menu-entry (103 "Export to Github Flavored Markdown" ((71 "To temporary buffer" (lambda (a s v b) (org-gfm-export-as-markdown a s v))) (103 "To file" (lambda (a s v b) (org-gfm-export-to-markdown a s v))) (111 "To file and open" (lambda (a s v b) (if a (org-gfm-export-to-markdown t s v) (org-open-file (org-gfm-export-to-markdown nil s v))))))) :translate-alist ((inner-template . org-gfm-inner-template) (paragraph . org-gfm-paragraph) (strike-through . org-gfm-strike-through) (src-block . org-gfm-src-block) (table-cell . org-gfm-table-cell) (table-row . org-gfm-table-row) (table . org-gfm-table))] 12)
#@154 Transcode PARAGRAPH element into Github Flavoured Markdown format.
CONTENTS is the paragraph contents.  INFO is a plist used as a
communication channel.
(defalias 'org-gfm-paragraph #[(paragraph contents info) "\304\305\"\204�\306\307\310	!\311#\312P\n\211:\204�\313\262\202(�\211@9\203(�\211AA\262@\211;\203@�\314\315\"\203@�\316\315\317	\313\320%\202A�	)\207" [info contents paragraph first-object plist-get :preserve-breaks mapconcat identity split-string " " "\n" nil string-match "\\`#" replace-regexp-in-string "\\#" t] 7 (#$ . 1154)])
#@134 Transcode SRC-BLOCK element into Github Flavored Markdown
format. CONTENTS is nil.  INFO is a plist used as a communication
channel.
(defalias 'org-gfm-src-block #[(src-block contents info) "\306\211;\203�\307\310#\266\202\202�\311A@\"\266\202\312\n\"\313	\314Q\313\f
Q,\207" [src-block lang info code prefix suffix :language get-text-property 0 plist-get org-export-format-code-default "```" "\n"] 6 (#$ . 1711)])
#@152 Transcode STRIKE-THROUGH from Org to Markdown (GFM).
CONTENTS is the text with strike-through markup.  INFO is a plist
holding contextual information.
(defalias 'org-gfm-strike-through #[(strike-through contents info) "\301\302\"\207" [contents format "~~%s~~"] 3 (#$ . 2146)])
(defvar width-cookies nil)
(defvar width-cookies-table nil)
(defconst gfm-table-left-border "|")
(defconst gfm-table-right-border " |")
(defconst gfm-table-separator " |")
#@214 Return width of TABLE at given COLUMN. INFO is a plist used as
communication channel. Width of a column is determined either by
inquerying `width-cookies' in the column, or by the maximum cell with in
the column.
(defalias 'org-gfm-table-col-width #[(table column info) "\306!\205\n�\307	\"\f=\203�\n\310=\204�\n\202B�\f=\203'�\306!\204,�\311 \312\313!\314\315\316$\210\317	#*)\207" [width-cookies column cookie table width-cookies-table specialp hash-table-p gethash nil make-hash-table 0 org-export-table-has-special-column-p org-element-map table-row #[(row) "\305\203 �	\211:\204�\306\262\202�\211@9\203�\211AA\262@\2027�	\211:\204,�\306\262\2027�\211@9\2037�\211AA\262\n\234\211:\204D�\306\262\202O�\211@9\203O�\211AA\262\"G\f]\211\207" [specialp row column info max-width org-export-data nil] 3] puthash max-width info] 5 (#$ . 2604)])
#@119 Return a function to build horizontal line in TABLE with given
CHAR. INFO is a plist used as a communication channel.
(defalias 'org-gfm-make-hline-builder #[(table info char) "\301\302\303\304\305\306\307EFE\207" [char lambda (col) let ((max-width (max 3 (org-gfm-table-col-width table col info)))) (when (< max-width 1) (setq max-width 1)) make-string max-width] 8 (#$ . 3486)])
#@131 Transcode TABLE-CELL element from Org into GFM. CONTENTS is content
of the cell. INFO is a plist used as a communication channel.
(defalias 'org-gfm-table-cell #[(table-cell contents info) "\306!\307\n\"A\310	\n#\311\n\"\203�\312\202�\313\314\206&�\315\211\316\317\f\320!Z]\321\"P
Q.\207" [table-cell table info column width left-border org-export-get-parent-table org-export-table-cell-address org-gfm-table-col-width org-export-table-cell-starts-colgroup-p "| " " " " |" "" make-string 0 string-width 32 right-border contents data] 7 (#$ . 3875)])
#@137 Transcode TABLE-ROW element from Org into GFM. CONTENTS is cell
contents of TABLE-ROW. INFO is a plist used as a communication
channel.
(defalias 'org-gfm-table-row #[(table-row contents info) "\306!\307\211;\203�\310\311#\266\202\202�\312A@\"\266\202\313=\203W�\314\315	\300\316\n$\"\317=\203W�\306!\320\n\"\321	\n\322#\323	\n\"A\324\325\326\311
S\"#Q,)\207" [table-row table info header-p build-rule cols org-export-get-parent-table :type get-text-property 0 plist-get rule cl-position org-element-map identity 1 org-export-table-row-starts-header-p org-gfm-make-hline-builder 45 org-export-table-dimensions mapconcat #[(col) "	!\207" [build-rule col] 2] number-sequence gfm-table-left-border gfm-table-separator gfm-table-right-border contents] 7 (#$ . 4457)])
#@149 Transcode TABLE element into Github Flavored Markdown table.
CONTENTS is the contents of the table. INFO is a plist holding
contextual information.
(defalias 'org-gfm-table #[(table contents info) "\306\307\310	$\211G\311X\312	\"A\313\205�
 \314\315\316#P,\207" [table info rows no-header cols build-dummy-header org-element-map table-row identity 1 org-export-table-dimensions #[nil "\306	\307#\306	\310#\311\312\nS\"\313\314#\315\313\316#\315\260+\207" [table info cols columns build-rule build-empty-cell org-gfm-make-hline-builder 32 45 number-sequence 0 mapconcat #[(col) "	!\207" [build-empty-cell col] 2] "\n" #[(col) "	!\207" [build-rule col] 2] gfm-table-left-border gfm-table-separator gfm-table-right-border] 9] replace-regexp-in-string "\n\n" "\n" contents] 6 (#$ . 5255)])
#@110 Return an appropriate table of contents entry for HEADLINE. INFO is a
plist used as a communication channel.
(defalias 'org-gfm-format-toc #[(headline) "\306\307	\"	\"\310\211;\203�\311\312#\266\202\202!�\313A@\"\266\202S\314\315_\316\"\260\317\211;\203=�\311\312#\266\202\202E�\313A@\"\266\202\206L�\320	\"\f\321\n\322
\323\260,\207" [headline info title level indent anchor org-export-data org-export-get-alt-title :level get-text-property 0 plist-get make-string 2 32 :CUSTOM_ID org-export-get-reference "- [" "](#" ")"] 6 (#$ . 6080)])
#@79 Format the footnote section.
INFO is a plist used as a communication channel.
(defalias 'org-gfm-footnote-section #[(info) "\306!\211\307\211\307\211\307\n:\203U�\n@\211\211A\242\211A\242@\310
\"\307\311\203=�\312\202>�\313\314\311\315\314##\266\202BB\nA\211\202�\237.\211\205k�\316\317\320\316\321\322\323	\324#\"#*\207" [info fn-alist #1=#:--cl-var-- n type raw org-export-collect-footnote-definitions nil org-export-data replace-regexp-in-string "\\`\\([ 	]*\n\\)+" "\\`[ 	\n
]+" "" "[ 	\n
]+\\'" format "## %s\n%s" "Footnotes" "\n%s\n" mapconcat #[(fn) "@A\304\305\304\306\307\"\310\304\311\n\"\n\304\312\n\"$\"	#*\207" [fn def n info format "%s %s\n" plist-get :html-footnote-format org-html--anchor "fn.%d" " class=\"footnum\" href=\"#fnr.%d\""] 10] "\n" #2=#:--cl-var-- #3=#:--cl-var--] 11 (#$ . 6646)])
#@150 Return body of document after converting it to Markdown syntax.
CONTENTS is the transcoded contents string.  INFO is a plist
holding export options.
(defalias 'org-gfm-inner-template #[(contents info) "\306\307\"\211\205
�\310	\"\311\312\n\313#\206�\314\n\203 �\315\202!�\314\f
\313\316!\260\317\320\2035�\321\2026�\322\314\320\323\314##\266\202,\207" [info depth headlines toc-string toc-tail contents plist-get :with-toc org-export-collect-headlines mapconcat org-gfm-format-toc "\n" "" "\n\n" org-gfm-footnote-section nil replace-regexp-in-string "\\`\\([ 	]*\n\\)+" "\\`[ 	\n
]+" "[ 	\n
]+\\'"] 10 (#$ . 7508)])
#@713 Export current buffer to a Github Flavored Markdown buffer.

If narrowing is active in the current buffer, only export its
narrowed part.

If a region is active, export that region.

A non-nil optional argument ASYNC means the process should happen
asynchronously.  The resulting buffer should be accessible
through the `org-export-stack' interface.

When optional argument SUBTREEP is non-nil, export the sub-tree
at point, extracting information from the headline properties
first.

When optional argument VISIBLE-ONLY is non-nil, don't export
contents of hidden elements.

Export is done in a buffer named "*Org GFM Export*", which will
be displayed when `org-export-show-temporary-export-buffer' is
non-nil.
(defalias 'org-gfm-export-as-markdown #[(&optional async subtreep visible-only) "\303\304\305	\n\306\211\307&\207" [async subtreep visible-only org-export-to-buffer gfm "*Org GFM Export*" nil #[nil "\300 \207" [text-mode] 1]] 9 (#$ . 8144) nil])
#@245 Assume the current region has org-mode syntax, and convert it
to Github Flavored Markdown.  This can be used in any buffer.
For example, you can write an itemized list in org-mode syntax in
a Markdown buffer and use this command to convert it.
(defalias 'org-gfm-convert-region-to-md #[nil "\300\301!\207" [org-export-replace-region-by gfm] 2 (#$ . 9111) nil])
#@600 Export current buffer to a Github Flavored Markdown file.

If narrowing is active in the current buffer, only export its
narrowed part.

If a region is active, export that region.

A non-nil optional argument ASYNC means the process should happen
asynchronously.  The resulting file should be accessible through
the `org-export-stack' interface.

When optional argument SUBTREEP is non-nil, export the sub-tree
at point, extracting information from the headline properties
first.

When optional argument VISIBLE-ONLY is non-nil, don't export
contents of hidden elements.

Return output file's name.
(defalias 'org-gfm-export-to-markdown #[(&optional async subtreep visible-only) "\304\305\"\306\307	\n%)\207" [subtreep outfile async visible-only org-export-output-file-name ".md" org-export-to-file gfm] 6 (#$ . 9479) nil])
#@206 Publish an org file to Markdown.
FILENAME is the filename of the Org file to be published.  PLIST
is the property list for the given project.  PUB-DIR is the
publishing directory.
Return output file name.
(defalias 'org-gfm-publish-to-gfm #[(plist filename pub-dir) "\303\304\305	\n%\207" [filename plist pub-dir org-publish-org-to gfm ".md"] 6 (#$ . 10314)])
(provide 'ox-gfm)