-# Handle -a, -c and -s arguments; returns them as SQL constraints
-def parse_args():
- if Options["Suite"]:
- suite_ids_list = [];
- for suite in string.split(Options["Suite"]):
- suite_id = db_access.get_suite_id(suite);
- if suite_id == -1:
- utils.warn("suite '%s' not recognised." % (suite));
- else:
- suite_ids_list.append(suite_id);
- if suite_ids_list:
- con_suites = "AND su.id IN (%s)" % string.join(map(str, suite_ids_list), ", ");
- else:
- utils.fubar("No valid suite given.");
- else:
- con_suites = "";
-
- if Options["Architecture"]:
- arch_ids_list = [];
- check_source = 0;
- for architecture in string.split(Options["Architecture"]):
- if architecture == "source":
- check_source = 1;
- else:
- architecture_id = db_access.get_architecture_id(architecture);
- if architecture_id == -1:
- utils.warn("architecture '%s' not recognised." % (architecture));
- else:
- arch_ids_list.append(architecture_id);
- if arch_ids_list:
- con_architectures = "AND a.id IN (%s)" % string.join(map(str, arch_ids_list), ", ");
- else:
- if not check_source:
- utils.fubar("No valid architecture given.");
- else:
- con_architectures = "";
- check_source = 1;
-
- if Options["Component"]:
- component_ids_list = [];
- for component in string.split(Options["Component"]):
- component_id = db_access.get_component_id(component);
- if component_id == -1:
- utils.warn("component '%s' not recognised." % (component));
- else:
- component_ids_list.append(component_id);
- if component_ids_list:
- con_components = "AND su.id IN (%s)" % string.join(map(str, component_ids_list), ", ");
- else:
- utils.fubar("No valid component given.");
- else:
- con_components = "";
-
- return (con_suites, con_architectures, con_components, check_source);
-
-################################################################################
-