~ubuntu-branches/ubuntu/trusty/gnuradio/trusty

« back to all changes in this revision

Viewing changes to pmt/src/scheme/gnuradio/pmt-serialize.scm

  • Committer: Bazaar Package Importer
  • Author(s): Kamal Mostafa
  • Date: 2010-03-13 07:46:01 UTC
  • mfrom: (2.1.2 sid)
  • Revision ID: james.westby@ubuntu.com-20100313074601-zjsa893a87bozyh7
Tags: 3.2.2.dfsg-1ubuntu1
* Fix build for Ubuntu lucid (LP: #260406)
  - add binary package dep for libusrp0, libusrp2-0: adduser
  - debian/rules clean: remove pre-built Qt moc files

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
;;;
 
2
;;; Copyright 2007 Free Software Foundation, Inc.
 
3
;;; 
 
4
;;; This file is part of GNU Radio
 
5
;;; 
 
6
;;; GNU Radio is free software; you can redistribute it and/or modify
 
7
;;; it under the terms of the GNU General Public License as published by
 
8
;;; the Free Software Foundation; either version 3, or (at your option)
 
9
;;; any later version.
 
10
;;; 
 
11
;;; GNU Radio is distributed in the hope that it will be useful,
 
12
;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
 
13
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
14
;;; GNU General Public License for more details.
 
15
;;; 
 
16
;;; You should have received a copy of the GNU General Public License along
 
17
;;; with this program; if not, write to the Free Software Foundation, Inc.,
 
18
;;; 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 
19
;;;
 
20
 
 
21
;;; An implementation of pmt_serialize in scheme.
 
22
;;; Currently handles only symbols and pairs.  They're all we need for now.
 
23
 
 
24
(define-module (gnuradio pmt-serialize)
 
25
  :export (pmt-serialize))
 
26
 
 
27
(load-from-path "gnuradio/pmt-serial-tags")
 
28
 
 
29
(define (pmt-serialize obj put-byte)
 
30
  (define (put-u16 x)
 
31
    (put-byte (logand (ash x -8) #xff))
 
32
    (put-byte (logand x #xff)))
 
33
    
 
34
  (cond ((null? obj)
 
35
         (put-byte pst-null))
 
36
        ((symbol? obj)
 
37
         (let* ((sym-as-bytes (map char->integer (string->list (symbol->string obj))))
 
38
                (len (length sym-as-bytes)))
 
39
           (put-byte pst-symbol)
 
40
           (put-u16 len)
 
41
           (for-each put-byte sym-as-bytes)))
 
42
        
 
43
        ((pair? obj)
 
44
         (put-byte pst-pair)
 
45
         (pmt-serialize (car obj) put-byte)
 
46
         (pmt-serialize (cdr obj) put-byte))
 
47
        (else
 
48
         (throw 'not-implemented "pmt-serialize" obj))))