Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5352)

Unified Diff: chromecast/media/cma/backend/alsa/post_processing_pipeline_parser.h

Issue 2847673002: [Chromecast] Complete PostProcessingPipeline changes (Closed)
Patch Set: Add more test Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chromecast/media/cma/backend/alsa/post_processing_pipeline_parser.h
diff --git a/chromecast/media/cma/backend/alsa/post_processing_pipeline_parser.h b/chromecast/media/cma/backend/alsa/post_processing_pipeline_parser.h
index a2da06003c8f3a3bc6c228065963c363f7691879..f50403264c96b8cb4a54eec202b7b72148de21cf 100644
--- a/chromecast/media/cma/backend/alsa/post_processing_pipeline_parser.h
+++ b/chromecast/media/cma/backend/alsa/post_processing_pipeline_parser.h
@@ -7,6 +7,8 @@
#include <memory>
#include <string>
+#include <unordered_set>
+#include <vector>
#include "base/macros.h"
@@ -18,30 +20,48 @@ class ListValue;
namespace chromecast {
namespace media {
+// Helper class to hold information about a stream pipeline.
+struct StreamPipelineDescriptor {
+ // The format for pipeline is:
+ // [ {"processor": "PATH_TO_SHARED_OBJECT",
+ // "config": "CONFIGURATION_STRING"},
+ // {"processor": "PATH_TO_SHARED_OBJECT",
+ // "config": "CONFIGURATION_STRING"},
+ // ... ]
+ base::ListValue* pipeline;
+ std::unordered_set<std::string> stream_types;
+
+ StreamPipelineDescriptor(
+ base::ListValue* pipeline_in,
+ const std::unordered_set<std::string>& stream_types_in);
+ ~StreamPipelineDescriptor();
+ StreamPipelineDescriptor(const StreamPipelineDescriptor& other);
+ StreamPipelineDescriptor operator=(const StreamPipelineDescriptor& other) =
+ delete;
+};
+
// Helper class to parse post-processing pipeline descriptor file.
class PostProcessingPipelineParser {
public:
PostProcessingPipelineParser();
+
+ // Use json string instead of reading from file. For test only.
+ explicit PostProcessingPipelineParser(const std::string& json);
~PostProcessingPipelineParser();
- // Reads the pipeline descriptor file and does preliminary parsing.
- // Crashes with fatal log if parsing fails.
- void Initialize();
+ std::vector<StreamPipelineDescriptor> GetStreamPipelines();
- // Gets the list of processors for a given stream type.
- // The format will be:
- // [
- // {"processor": "PATH_TO_SHARED_OBJECT",
- // "config": "CONFIGURATION_STRING"},
- // {"processor": "PATH_TO_SHARED_OBJECT",
- // "config": "CONFIGURATION_STRING"},
- // ...
- // ]
- base::ListValue* GetPipelineByDeviceId(const std::string& device_id);
+ // Gets the list of processors for the mix/linearize stages.
+ // Same format as StreamPipelineDescriptor.pipeline
+ base::ListValue* GetMixPipeline();
+ base::ListValue* GetLinearizePipeline();
+
+ static std::string file_path();
kmackay 2017/04/28 00:31:42 GetFilePath()
bshaya 2017/04/28 01:37:37 Done.
private:
+ base::ListValue* GetPipelineByKey(const std::string& key);
+
std::unique_ptr<base::DictionaryValue> config_dict_;
- base::DictionaryValue* pipeline_dict_ = nullptr;
DISALLOW_COPY_AND_ASSIGN(PostProcessingPipelineParser);
};

Powered by Google App Engine
This is Rietveld 408576698