In the function org-export--generate-copy-script, the buffer contents are copied over with buffer-substring-no-properties, so it appears that all text properties are lost in the temporary copy.

I wondered why that is done? 

I came across this because I was using text properties to find pieces of text to modify before exporting in a org-export-before hook, but it doesn't work since the text properties are gone. 

The text properties are put on by font-lock. Curiously, if I add these three lines

  (switch-to-buffer (current-buffer))
  (sem-mode 1)  # refontifies buffer
  (message-box "")

then the text-properties are put back on and I can find them again. If leave the first or last line off though, this does not work. The last line is especially mystifying.

Here is a minimal example that shows the issue. When you run the src block, the word red will be italicized, and when you export it red will be turned into the word yellow. without the unintuitive switch-to-buffer and message box lines though, you will get an error.

Any ideas on what is happening here?

# begin
This is red.


#+BEGIN_SRC emacs-lisp :results silent :exports none
(font-lock-add-keywords
 nil
 '(("red" 0 '(face italic changeme t))))


(defun preprocess (backend)
  (switch-to-buffer (current-buffer))
  (font-lock-add-keywords
   nil
   '(("red" 0 '(face italic changeme t))))
  (message-box "")
  (let* ((start (next-single-property-change (point) 'changeme))
(end (next-single-property-change start 'changeme)))
    (setf (buffer-substring start end) "yellow")))

(add-hook 'org-export-before-processing-hook 'preprocess nil t)
#+END_SRC

John

-----------------------------------
Professor John Kitchin 
Doherty Hall A207F
Department of Chemical Engineering
Carnegie Mellon University
Pittsburgh, PA 15213
412-268-7803