summaryrefslogtreecommitdiff
path: root/libs/fsScan/include/AbstractMedia.h
blob: 8c87dd5785fe7d7efcf0cf385b8b5eb5240b5823 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/**
 * ======================== legal notice ======================
 * 
 * File:      AbstractMedia.h
 * Created:   2. Juli 2012, 14
 * Author:    <a href="mailto:geronimo013@gmx.de">Geronimo</a>
 * Project:   libfsScan: mediatypes and filesystem scanning
 * 
 * CMP - compound media player
 * 
 * is a client/server mediaplayer intended to play any media from any workstation
 * without the need to export or mount shares. cmps is an easy to use backend
 * with a (ready to use) HTML-interface. Additionally the backend supports
 * authentication via HTTP-digest authorization.
 * cmpc is a client with vdr-like osd-menues.
 * 
 * Copyright (c) 2012 Reinhard Mantey, some rights reserved!
 * published under Creative Commons by-sa
 * For details see http://creativecommons.org/licenses/by-sa/3.0/
 * 
 * The cmp project's homepage is at http://projects.vdr-developer.org/projects/cmp
 * 
 * --------------------------------------------------------------
 */
#ifndef ABSTRACTMEDIA_H
#define	ABSTRACTMEDIA_H

#include <File.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <vector>

typedef struct {
  const char *extension;
  const char *mimeType;
} SupportedExtension;

class cAbstractMedia {
public:
  typedef enum {
    Invalid,
    Audio,
    Movie,
    DVDImage,
    LegacyVdrRecording,
    VdrRecording,
    Picture,
    Unknown
    } SupportedMediaType;

  virtual ~cAbstractMedia();

  SupportedMediaType MediaType(void) const { return mediaType; }
  const char *MimeType(void) const { return mimeType; }
  const char *AbsolutePath(void) const;
  ulong LastModified(void) const;
  const char *LogicalPath(void) const { return logicalPath; }
  virtual const char *Name(void) const;
  virtual bool NeedsFurtherScan(void) const;
  virtual size_t Size(void) const;
  virtual const char *URI(void) const { return uri; }
  virtual void Refresh(void);
      ///< will be called right before start streaming, so this call is used to
      ///< determine the real size, number of files, etc.
  virtual size_t ReadChunk(char *buf, size_t bufSize);
      ///< used to hide the differences between single- and multi-file media.
  virtual void Reset(void);
  static const char *MediaType2Text(int Type);

protected:
  cAbstractMedia(const cFile &File, const char *Mime, SupportedMediaType Type);
  void SetMimeType(const char *MimeType);
  const cFile &KeyPath(void) { return keyPath; }
  int fd;

private:
  SupportedMediaType mediaType;
  char *mimeType;
  char *uri;
  char *logicalPath;
  cFile keyPath;
  };

#endif	/* ABSTRACTMEDIA_H */